NetsBlox is a browser-based visual programming environment (based on Snap!) that extends the typical block-based programming features with internet and distributed computing tools such as RPCs (remote procedure calls) that access network resources (e.g., databases or web APIs), and message passing between projects over the internet.
netsblox-vm
is a native Rust implementation of the NetsBlox code execution engine and runtime. This makes it possible to execute NetsBlox program code at blistering speeds on any device targeted by the Rust compiler. But more importantly, netsblox-vm
has several extension APIs which make it possible to extend its features with new hardware peripheral access capabilities (e.g., controlling sensors and actuators through GPIO), all with safe, native Rust.
netsblox-vm
contains the following feature flags.
| name | default | description |
| ---- | ------- | ----------- |
| all
| on | Enables all features |
| std
| on | Enables the std
crate dependency and access to the default StdSystem
implementation of System
|
| cli
| on | Enables the std
feature flag and additionally gives access to the cli
submodule, which gives API access to the standard CLI (needed for syscall extensions) rather than having to write a CLI from scratch |
| serde
| on | Enables serialization of some types |
no-std
netsblox-vm
supports building in no-std
environments by disabling the default std
feature flag.
However, the alloc
crate is still required in this case.
toml
[dependencies]
netsblox_vm = { version = "...", default-features = false }
Note that this precludes access to StdSystem
, meaning a new implementation of System
would be required for your target platform.
This crate includes a binary called nb
which serves as a shallow wrapper for the cli
API with a default suite of syscall extensions.
Note: if you need to create your own syscall extensions, you must do so in a separate binary using this crate as a dependency.
bash
cargo install netsblox-vm