An open API service indexing awesome lists of open source software.

https://github.com/usagi/eles


https://github.com/usagi/eles

Last synced: 2 months ago
JSON representation

Awesome Lists containing this project

README

        

[![github]](https://github.com/usagi/eles) [![crates-io]](https://crates.io/crates/eles) [![docs-rs]](https://docs.rs/eles)

[![Build Status](https://travis-ci.org/usagi/eles.svg?branch=master)](https://travis-ci.org/usagi/eles)

[github]: https://img.shields.io/badge/github-8da0cb?style=for-the-badge&labelColor=555555&logo=github
[crates-io]: https://img.shields.io/badge/crates.io-fc8d62?style=for-the-badge&labelColor=555555&logo=rust
[docs-rs]: https://img.shields.io/badge/docs.rs-66c2a5?style=for-the-badge&labelColor=555555&logoColor=white&logo=

# ELES; Extensible Logical Expression Solver

If you have an existing parser that outputs a single boolean value and you want to add support for AND, OR, XOR, and parentheses, ELES can be of great help. For example, if you already have a system that interprets string syntax to determine/search data for a single item, and you want to support AND/OR searches for multiple items or complex conditions assembled using parentheses, ELES is the usefull library for you.

## Example

```rust
// The simplest example
fn main()
{
let input = "true && (( false ^^ true && !! false )) || false";
let literal_parser = |literal: &str| Ok(literal.parse::().unwrap_or_default());
let r = eles::solve(&input, literal_parser);
println!("{:?}", r);
}
```

More examples are here:

- [examples/](examples/)
- [practical_use_case.rs](examples/practical_use_case.rs)
- [change_logical_operation_tokens.rs](examples/change_logical_operation_tokens.rs)
- [basic.rs](examples/basic.rs)
- [simplest.rs](examples/simplest.rs)

And these tests might be usefull that study usage:

- [tests/](tests/)
- [basics.rs](tests/basics.rs)

## LICENSE

- [MIT](LICENSE.md)

## Author

- USAGI.NETWORK / Usagi Ito