Skip to content

Commit

Permalink
Stop using std::collections
Browse files Browse the repository at this point in the history
  • Loading branch information
udoprog committed Oct 1, 2023
1 parent 6a4b4ce commit 4f3e346
Show file tree
Hide file tree
Showing 166 changed files with 3,922 additions and 2,788 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ jobs:
- uses: actions/checkout@v3
- uses: dtolnay/rust-toolchain@nightly
- uses: Swatinem/rust-cache@v2
- run: cargo doc -p rune
- run: cargo doc -p rune --all-features
env:
RUSTFLAGS: --cfg docsrs
RUSTDOCFLAGS: --cfg docsrs
Expand Down
6 changes: 6 additions & 0 deletions .github/workflows/site.yml
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,12 @@ jobs:
- run: cargo run --bin rune -- doc --output target/site/docs
env:
RUST_LOG: rune=info
- uses: dtolnay/rust-toolchain@nightly
- run: cargo +nightly doc -p rune --all-features --target-dir target/site/api
env:
RUST_LOG: rune=info
RUSTFLAGS: --cfg docsrs
RUSTDOCFLAGS: --cfg docsrs
- run: mdbook build -d ../target/site/book book
- uses: peaceiris/actions-gh-pages@v3
with:
Expand Down
59 changes: 24 additions & 35 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -79,42 +79,31 @@ use rune::{Context, Diagnostics, Source, Sources, Vm};
use rune::termcolor::{ColorChoice, StandardStream};
use std::sync::Arc;

#[tokio::main]
async fn main() -> rune::support::Result<()> {
let context = Context::with_default_modules()?;
let runtime = Arc::new(context.runtime()?);

let mut sources = Sources::new();
sources.insert(Source::new(
"script",
r#"
pub fn add(a, b) {
a + b
}
"#,
));

let mut diagnostics = Diagnostics::new();

let result = rune::prepare(&mut sources)
.with_context(&context)
.with_diagnostics(&mut diagnostics)
.build();

if !diagnostics.is_empty() {
let mut writer = StandardStream::stderr(ColorChoice::Always);
diagnostics.emit(&mut writer, &sources)?;
}

let unit = result?;
let mut vm = Vm::new(runtime, Arc::new(unit));

let output = vm.call(["add"], (10i64, 20i64))?;
let output: i64 = rune::from_value(output)?;

println!("{}", output);
Ok(())
let context = Context::with_default_modules()?;
let runtime = Arc::new(context.runtime()?);

let mut sources = Sources::new();
sources.insert(Source::memory("pub fn add(a, b) { a + b }")?);

let mut diagnostics = Diagnostics::new();

let result = rune::prepare(&mut sources)
.with_context(&context)
.with_diagnostics(&mut diagnostics)
.build();

if !diagnostics.is_empty() {
let mut writer = StandardStream::stderr(ColorChoice::Always);
diagnostics.emit(&mut writer, &sources)?;
}

let unit = result?;
let mut vm = Vm::new(runtime, Arc::new(unit));

let output = vm.call(["add"], (10i64, 20i64))?;
let output: i64 = rune::from_value(output)?;

println!("{}", output);
```

[in the `examples` folder]: https://github.com/rune-rs/rune/tree/main/examples/examples
Expand Down
2 changes: 1 addition & 1 deletion benches/benches/bench_main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ pub(crate) fn vm(
pub(crate) fn sources(source: &str) -> Sources {
let mut sources = Sources::new();
sources
.insert(Source::new("main", source))
.insert(Source::new("main", source).expect("Failed to construct source"))
.expect("Failed to insert source");
sources
}
Expand Down
1 change: 1 addition & 0 deletions book/src/SUMMARY.md
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@
- [Macros](./macros.md)
- [Advanced](./advanced.md)
- [Safety](./safety.md)
- [Sandboxing](./sandboxing.md)
- [The stack](./the_stack.md)
- [Call frames](./call_frames.md)
- [Compiler guide](./compiler_guide.md)
Expand Down
62 changes: 62 additions & 0 deletions book/src/sandboxing.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
# Sandboxing

Rune is capable of enforcing the following types of limitations:
* Memory limiting, where you specify the maxium amount of memory that Rune may
use either during compilation or execution.
* Instruction budgeting, where you can specify how many instructions the virtual
machine is permitted to execute.

## Instruction budgeting

Instruction budgeting is performed using the [`with` function] in the
`rune::budget` module.

The `with` function is capable of wrapping functions and futures. When wrapping
a future it ensures that the budget is suspended appropriately with the
execution of the future.

Budgeting is only performed on a per-instruction basis in the virtual machine.
What exactly constitutes an instruction might be a bit vague. But important to
note is that without explicit co-operation from native functions the budget
cannot be enforced. So care must be taken with the native functions that you
provide to Rune to ensure that the limits you impose cannot be circumvented.

[`with` function]: https://docs.rs/rune/latest/rune/runtime/budget/fn.with.html

## Memory limiting

Memory limiting is performed using the [`with` function] in the
`rune::alloc::limit` module.

```rust
use rune::alloc::limit;
use rune::alloc::Vec;

let f = limit::with(1024, || {
let mut vec = Vec::<u32>::try_with_capacity(256)?;

for n in 0..256u32 {
vec.try_push(n)?;
}

Ok::<_, rune_alloc::Error>(vec.into_iter().sum::<u32>())
});

let sum = f.call()?;
assert_eq!(sum, 32640);
```

In order for memory limiting to work as intended, you're may only use the
collections provided in the [`rune::alloc`] module. These contain forks of
popular collections such as [`std::collections`] and [`hashbrown`].

The `with` function is capable of wrapping [functions] and [futures]. When
wrapping a future it ensures that the limit is suspended appropriately with the
execution of the future.

[`with` function]: https://docs.rs/rune/latest/rune/alloc/limit/fn.with.html
[`rune::alloc`]: https://docs.rs/rune/latest/rune/alloc/index.html
[`std::collections`]: https://doc.rust-lang.org/std/collections/index.html
[`hashbrown`]: docs.rs/hashbrown
[functions]:
[futures]:
23 changes: 23 additions & 0 deletions crates/rune-alloc-macros/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
<img alt="rune logo" src="https://raw.githubusercontent.com/rune-rs/rune/main/assets/icon.png" />
<br>
<a href="https://rune-rs.github.io"><b>Visit the site 🌐</b></a>
&mdash;
<a href="https://rune-rs.github.io/book/"><b>Read the book 📖</b></a>

# rune-alloc-macros

<a href="https://github.com/rune-rs/rune"><img alt="github" src="https://img.shields.io/badge/github-rune--rs/rune-8da0cb?style=for-the-badge&logo=github" height="20"></a>
<a href="https://crates.io/crates/rune-alloc-macros"><img alt="crates.io" src="https://img.shields.io/crates/v/rune-alloc-macros.svg?style=for-the-badge&color=fc8d62&logo=rust" height="20"></a>
<a href="https://docs.rs/rune-alloc-macros"><img alt="docs.rs" src="https://img.shields.io/badge/docs.rs-rune--alloc--macros-66c2a5?style=for-the-badge&logoColor=white&logo=" height="20"></a>
<a href="https://github.com/rune-rs/rune/actions?query=branch%3Amain"><img alt="build status" src="https://img.shields.io/github/actions/workflow/status/rune-rs/rune/ci.yml?branch=main&style=for-the-badge" height="20"></a>
<a href="https://discord.gg/v5AeNkT"><img alt="chat on discord" src="https://img.shields.io/discord/558644981137670144.svg?logo=discord&style=flat-square" height="20"></a>
<br>
<br>

Macros for the Rune Language, an embeddable dynamic programming language for Rust.

<br>

## Usage

This is part of the [Rune Language](https://rune-rs.github.io).
4 changes: 2 additions & 2 deletions crates/rune-alloc-macros/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
//! <img alt="rune logo" src="https://raw.githubusercontent.com/rune-rs/rune/main/assets/icon.png" />
//! <br>
//! <a href="https://github.com/rune-rs/rune"><img alt="github" src="https://img.shields.io/badge/github-rune--rs/rune-8da0cb?style=for-the-badge&logo=github" height="20"></a>
//! <a href="https://crates.io/crates/rune-macros"><img alt="crates.io" src="https://img.shields.io/crates/v/rune-macros.svg?style=for-the-badge&color=fc8d62&logo=rust" height="20"></a>
//! <a href="https://docs.rs/rune-macros"><img alt="docs.rs" src="https://img.shields.io/badge/docs.rs-rune--macros-66c2a5?style=for-the-badge&logoColor=white&logo=" height="20"></a>
//! <a href="https://crates.io/crates/rune-alloc-macros"><img alt="crates.io" src="https://img.shields.io/crates/v/rune-alloc-macros.svg?style=for-the-badge&color=fc8d62&logo=rust" height="20"></a>
//! <a href="https://docs.rs/rune-alloc-macros"><img alt="docs.rs" src="https://img.shields.io/badge/docs.rs-rune--alloc--macros-66c2a5?style=for-the-badge&logoColor=white&logo=" height="20"></a>
//! <a href="https://discord.gg/v5AeNkT"><img alt="chat on discord" src="https://img.shields.io/discord/558644981137670144.svg?logo=discord&style=flat-square" height="20"></a>
//! <br>
//! Minimum support: Rust <b>1.70+</b>.
Expand Down
3 changes: 3 additions & 0 deletions crates/rune-alloc/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -26,4 +26,7 @@ ahash = { version = "0.8.3", default-features = false }
pin-project = "1.1.0"

[dev-dependencies]
rune = { package = "rune-shim", path = "../rune-shim", features = ["alloc"] }

rand = { version = "0.8.5", features = ["small_rng"] }
tokio = { version = "1.28.1", default-features = false, features = ["rt", "macros"] }
17 changes: 17 additions & 0 deletions crates/rune-alloc/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
<img alt="rune logo" src="https://raw.githubusercontent.com/rune-rs/rune/main/assets/icon.png" />
<br>
<a href="https://rune-rs.github.io"><b>Visit the site 🌐</b></a>
&mdash;
<a href="https://rune-rs.github.io/book/"><b>Read the book 📖</b></a>

# rune-alloc

<a href="https://github.com/rune-rs/rune"><img alt="github" src="https://img.shields.io/badge/github-rune--rs/rune-8da0cb?style=for-the-badge&logo=github" height="20"></a>
<a href="https://crates.io/crates/rune-alloc"><img alt="crates.io" src="https://img.shields.io/crates/v/rune-alloc.svg?style=for-the-badge&color=fc8d62&logo=rust" height="20"></a>
<a href="https://docs.rs/rune-alloc"><img alt="docs.rs" src="https://img.shields.io/badge/docs.rs-rune--alloc-66c2a5?style=for-the-badge&logoColor=white&logo=" height="20"></a>
<a href="https://github.com/rune-rs/rune/actions?query=branch%3Amain"><img alt="build status" src="https://img.shields.io/github/actions/workflow/status/rune-rs/rune/ci.yml?branch=main&style=for-the-badge" height="20"></a>
<a href="https://discord.gg/v5AeNkT"><img alt="chat on discord" src="https://img.shields.io/discord/558644981137670144.svg?logo=discord&style=flat-square" height="20"></a>
<br>
<br>

The Rune Language, an embeddable dynamic programming language for Rust.
Loading

0 comments on commit 4f3e346

Please sign in to comment.