rust_multistackvm 0.38.0

Stack-based virtual machine on top of rust_multistack crate
Documentation
use crate::multistackvm::VM;
use rust_dynamic::types::*;
use easy_error::{Error, bail};

pub fn stdlib_class_register(vm: &mut VM) -> Result<&mut VM, Error> {
    if vm.stack.current_stack_len() < 2 {
        bail!("Stack is too shallow for inline make");
    }
    match vm.stack.pull() {
        Some(class_value) => {
            if ! class_value.typoe_of() == CLASS {
                bail!("make expecting a lambda");
            }
            match vm.stack.pull() {
                Some(name_value) => {
                    match name_value.cast_string() {
                        Ok(name) => {
                            return vm.register_class(name, class_value);
                        }
                        Err(err) => {
                            bail!("MAKE expecting class name to be string: {}", err);
                        }
                    }
                }
                None => {
                    bail!("REGISTER returns: NO DATA #2");
                }
            }
        }
        None => {
            bail!("REGISTER returns: NO DATA #1");
        }
    }
}

pub fn stdlib_lambda_unregister(vm: &mut VM) -> Result<&mut VM, Error> {
    if vm.stack.current_stack_len() < 1 {
        bail!("Stack is too shallow for inline unregister");
    }

    match vm.stack.pull() {
        Some(name_value) => {
            match name_value.cast_string() {
                Ok(name) => {
                    return vm.unregister_lambda(name);
                }
                Err(err) => {
                    bail!("UNREGISTER expecting lanbda name to be string: {}", err);
                }
            }
        }
        None => {
            bail!("UNREGISTER returns: NO DATA #1");
        }
    }
}



pub fn init_stdlib(vm: &mut VM) {
    let _ = vm.register_inline("register".to_string(), stdlib_lambda_register);
    let _ = vm.register_inline("unregister".to_string(), stdlib_lambda_unregister);
}