Skip to content
/ url_c3 Public

A module which can parse all kinds of URLs into a struct.

License

Notifications You must be signed in to change notification settings

louis77/url_c3

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

url_c3

This package contains the url module which can parse all kinds of URLs into a struct.

Installing

Clone the repository and run c3c test to run tests.

Usage

Parse URLs:

import url;

Url my_url = url::parse("jdbc:mysql://test_user:ouupppssss@localhost:3306/sakila?profileSQL=true#fragment")!;

assert(my_url.scheme == "jdbc:mysql");
assert(my_url.host == "localhost");
assert(my_url.port == 3306);
assert(my_url.username == "test_user");
assert(my_url.password == "ouupppssss");
assert(my_url.path == "/sakila");
assert(my_url.query == "profileSQL=true");
assert(my_url.fragment == "fragment");

Url implements the Printable interface, so you can use a formatter to convert it to a string:

Url url = { .scheme="jdbc:mysql", 
            .host="localhost", 
            .port=3306, 
            .username="test_user", 
            .password="ouupppssss", 
            .path="/sakila", 
            .query="profileSQL=true" };
String str = string::new_format("%s", url);

assert(str == "jdbc:mysql://test_user:ouupppssss@localhost:3306/sakila?profileSQL=true");

If you need structured access to the query part, you can fetch a HashMap of List(<String>) like so:

Url url = parse("foo://example.com:8042/over/there?name=ferret&age=99&age=11#nose")!;

Values vals = url.query_values(allocator::temp());
defer vals.free();

ListStr l_name = vals["name"]!;
assert(l_name[0] == "ferret");

ListStr l_age = vals["age"]!;
assert(l_age[0] == "99");
assert(l_age[1] == "11");

API

struct Url {
    String scheme;
    String host;
    uint   port;
    String username;
    String password;
    String path;
    String query;
    String fragment;
}

def ListStr = List(<String>);
def Values = map::HashMap(<String, ListStr>);

fn Url!   parse(String url_string)
fn String Url.to_string(Url* self, Allocator allocator = allocator::heap());
fn Values Url.query_values(Url* self, Allocator allocator = allocator::heap())

LICENSE

MIT. See LICENSE.

About

A module which can parse all kinds of URLs into a struct.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published