5 releases

0.0.5 Oct 25, 2023
0.0.4 Aug 12, 2023
0.0.3 Jul 25, 2023
0.0.2 Mar 11, 2023
0.0.1 Oct 23, 2022

#118 in Embedded development

Download history 98/week @ 2024-01-14 123/week @ 2024-01-21 314/week @ 2024-01-28 300/week @ 2024-02-04 311/week @ 2024-02-11 361/week @ 2024-02-18 430/week @ 2024-02-25 299/week @ 2024-03-03 199/week @ 2024-03-10 414/week @ 2024-03-17 401/week @ 2024-03-24 221/week @ 2024-03-31

1,246 downloads per month
Used in 3 crates (2 directly)

MIT/Apache

21KB
276 lines

About rhai-url

License crates.io crates.io API Docs

This crate provides url::Url access for the Rhai scripting language.

Usage

Cargo.toml

[dependencies]
rhai-url = "0.0.4"

Rhai script

// create a new Url
let url = Url("http://example.com/?q=query");

// get the absolute url as a string
print(url.href); // print 'http://example.com/?q=query'
print(url.to_string()); // print 'http://example.com/?q=query'

// get the url query string, without the leading ?
print(url.query); // print 'q=query'

// get the url fragment
print(url.fragment); // print ''

// hash is an alias of fragment
print(url.hash); // print ''

// clear the query
url.query_clear();
print(url.query); // print ''

// remove a query key
url.query_remove("q");

// query_remove with no arguments will clear the query string
url.query_remove();

// adds a query key value pair into the query string
url.query_append("q", "name");

You can see an example on how to use those function in the tests.

Rust source

use rhai::{Engine, EvalAltResult};
use rhai::packages::Package;
use rhai_url::UrlPackage;
use url::Url;

fn main() -> Result<(), Box<EvalAltResult>> {
    // Create Rhai scripting engine
    let mut engine = Engine::new();

    // Create url package and add the package into the engine
    let package = UrlPackage::new();
    package.register_into_engine(&mut engine);

    // Print the url
    let url = engine.eval::<Url>(r#"Url("http://test.dev/")"#)?;

    println!("{}", url);

    // Print the url string, equivalent of to_string()
    let href = engine.eval::<String>(r#"Url("http://test.dev/").href"#)?;

    println!("{}", href);

    Ok(())
}

Features

Feature Default Description
array enabled Enables support for Rhai Array
metadata disabled Enables support for generating package documentation

Dependencies

~6.5MB
~153K SLoC