eles 1.0.0

ELES; Extensible Logical Expression Solver
Documentation
[![github]](https://github.com/usagi/eles)&ensp;[![crates-io]](https://crates.io/crates/eles)&ensp;[![docs-rs]](https://docs.rs/eles)<br>
[![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::<bool>().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 <https://github.com/usagi/>