Crate crabzilla[][src]

Crabzilla provides a simple interface for running JavaScript modules alongside Rust code.

Example

use crabzilla::*;
use std::io::stdin;
 
#[import_fn]
fn read_from_stdin() -> Value {
    let mut buffer = String::new();
    println!("Type your name: ");
    stdin().read_line(&mut buffer)?;
    buffer.pop();
    Value::String(buffer)
}
 
#[import_fn]
fn say_hello(args: Vec<Value>) {
    if let Some(string) = args.get(0) {
        if let Value::String(string) = string {
            println!("Hello, {}", string);
        }
    }
}
 
#[tokio::main]
async fn main() {
    let mut runtime = runtime! {
        read_from_stdin,
        say_hello,
    };
    if let Err(error) = runtime.load_module("./module.js").await {
        eprintln!("{}", error);
    }
}

In module.js:

const user = read_from_stdin();
say_hello(user);

Macros

runtime

Creates a runtime object and imports a list of functions.

Structs

Runtime

Represents a JavaScript runtime instance.

Enums

ImportedFn

Represents an imported Rust function.

Value

Represents any valid JSON value.

Functions

create_sync_fn

Receives a Rust function and returns a structure that can be imported in to a runtime.

Type Definitions

AnyError

A generic wrapper that can encapsulate any concrete error type.

Attribute Macros

import_fn

An attribute macro to convert Rust functions so they can be imported into a runtime.