Add quickstart documentation with chain and assign features
This commit is contained in:
parent
9faf781623
commit
aeb584edca
18
README.md
18
README.md
@ -4,7 +4,7 @@
|
||||
[data:image/s3,"s3://crabby-images/f8e90/f8e90831e20f644f9d3bf701c17011d27a10e0e2" alt=""](https://crates.io/crates/evalexpr)
|
||||
[data:image/s3,"s3://crabby-images/98352/98352ae9161a712d259ba1a126d3c1618a9d7cfa" alt=""](https://docs.rs/evalexpr)
|
||||
|
||||
Evalexpr is an expression evaluator in Rust.
|
||||
Evalexpr is an expression evaluator and tiny scripting language in Rust.
|
||||
It has a small and easy to use interface and can be easily integrated into any application.
|
||||
It is very lightweight and comes with no further dependencies.
|
||||
Evalexpr is [available on crates.io](https://crates.io/crates/evalexpr), and its [API Documentation is available on docs.rs](https://docs.rs/evalexpr).
|
||||
@ -42,6 +42,22 @@ assert_eq!(eval("1.0 + 2 * 3"), Ok(Value::from(7.0)));
|
||||
assert_eq!(eval("true && 4 > 2"), Ok(Value::from(true)));
|
||||
```
|
||||
|
||||
You can **chain** expressions and **assign** to variables like this:
|
||||
|
||||
```rust
|
||||
use evalexpr::*;
|
||||
|
||||
let mut context = HashMapContext::new();
|
||||
// Assign 5 to a like this
|
||||
assert_eq!(eval_empty_with_context_mut("a = 5", &mut context), Ok(EMPTY_VALUE));
|
||||
// The HashMapContext is type safe, so this will fail now
|
||||
assert_eq!(eval_empty_with_context_mut("a = 5.0", &mut context), Err(EvalexprError::expected_int(Value::from(5.0))));
|
||||
// We can check which value the context stores for a like this
|
||||
assert_eq!(context.get_value("a"), Some(&Value::from(5)));
|
||||
// And use the value in another expression like this
|
||||
assert_eq!(eval_int_with_context_mut("a = a + 2; a", &mut context), Ok(7));
|
||||
```
|
||||
|
||||
And you can use **variables** and **functions** in expressions like this:
|
||||
|
||||
```rust
|
||||
|
16
src/lib.rs
16
src/lib.rs
@ -29,6 +29,22 @@
|
||||
//! assert_eq!(eval("true && 4 > 2"), Ok(Value::from(true)));
|
||||
//! ```
|
||||
//!
|
||||
//! You can **chain** expressions and **assign** to variables like this:
|
||||
//!
|
||||
//! ```rust
|
||||
//! use evalexpr::*;
|
||||
//!
|
||||
//! let mut context = HashMapContext::new();
|
||||
//! // Assign 5 to a like this
|
||||
//! assert_eq!(eval_empty_with_context_mut("a = 5", &mut context), Ok(EMPTY_VALUE));
|
||||
//! // The HashMapContext is type safe, so this will fail now
|
||||
//! assert_eq!(eval_empty_with_context_mut("a = 5.0", &mut context), Err(EvalexprError::expected_int(Value::from(5.0))));
|
||||
//! // We can check which value the context stores for a like this
|
||||
//! assert_eq!(context.get_value("a"), Some(&Value::from(5)));
|
||||
//! // And use the value in another expression like this
|
||||
//! assert_eq!(eval_int_with_context_mut("a = a + 2; a", &mut context), Ok(7));
|
||||
//! ```
|
||||
//!
|
||||
//! And you can use **variables** and **functions** in expressions like this:
|
||||
//!
|
||||
//! ```rust
|
||||
|
Reference in New Issue
Block a user