A library that can parses boolean expressions, builds an binary expression tree and evalue given a set of values
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
glenux b50b5b1d75 Update 'README.md' 4 weeks ago
.github/workflows Update badges again 3 years ago
bin Rename project mm2ep_depend to namarara 4 years ago
doc Add doc directory 3 years ago
exe Rename namarara executable to namarara-cli 4 years ago
lib Add description + fix dependencies + bump version 3 years ago
spec Add nice examples 3 years ago
.gitignore Update gitignore 3 years ago
.rubocop.yml Update rubocop linting rules 4 years ago
.ruby-version Force ruby version 6 years ago
.tool-versions Clean unit tests 4 years ago
.travis.yml Update project architecture 6 years ago
Dockerfile Add Dockerfile 3 years ago
Gemfile Rename project mm2ep_depend to namarara 4 years ago
LICENSE.txt Update project architecture 6 years ago
README.md Update 'README.md' 4 weeks ago
Rakefile Enable rubocop 6 years ago
TODO.md Add TODO 6 years ago
demo.rb Rename project mm2ep_depend to namarara 4 years ago
namarara.gemspec Add description + fix dependencies + bump version 3 years ago

README.md

Namarara

Build Gem Version GitHub license Donate on patreon Please don't upload to GitHub

Namarara is a library that can parses boolean expressions, builds an binary expression tree and evalutes a result given a set of values associated to the variables used within the boolean expression.

Installation

Add this line to your application's Gemfile:

gem 'namarara'

And then execute:

$ bundle

Or install it yourself as:

$ gem install namarara

Usage

Evaluate a single expression

require 'namarara'

# Initialize Namarara
namarara = Namarara::Parser.new(Namarara::Lexer.new)

# Prepare variables 
namarara.names = {
  this: 'true',
  that: 'false',
  other: 'false',
  something_else: 'true'
}

# Build a binary expression tree (aka BET) from string
# and inject values
exp_tree = namarara.parse('this AND (that OR other) AND something_else')

# Compute tree with variables
result = exp_tree.compute
puts result # = false

Evaluating a set of rules

require 'namarara'

# Initialize Namarara
namarara = Namarara::Parser.new(Namarara::Lexer.new)

# A set of rules i want to check 
# (in this example we are looking for sensitive personnal data)
rules = {
    vulnerable_person: 'is_adult AND is_subordinate',
    has_constraints: 'is_adult AND has_children',
    is_child: 'NOT is_adult'
    # ...
}

# A set of values i want to inject (values must be expressed as strings)
namarara.names = {
    "is_adult" => 'false', 
    "is_subordinate" => 'true',
    "has_children" => 'true'
}

results = rules.map { |rule, expr| [rule, namarara.parse(expr).compute] }

if results.select{ |rule, value| value }.empty?
    puts "Perfect! Nothing to say ;-)"
else
    puts "Warning: you are collecting sensitive personnal data !"
    results.each do |rule, value|
      puts "#{value ? '>>':'  '} #{rule}: #{value}" 
    end
end

Development

After checking out the repo, run bin/setup to install dependencies.

Then, run rake test to run the tests.

You can also run bin/console for an interactive prompt that will allow you to experiment.

To install this gem onto your local machine, run bundle exec rake install.

To release a new version, update the version number in version.rb, and then run bundle exec rake release, which will create a git tag for the version, push git commits and tags, and push the .gem file to rubygems.org.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/glenux/namarara

Namarara is an open source project under the terms of the MIT License.

Original author : Brendon Torre

Current developer & maintainer : Glenn Y. Rolland (@glenux)

Sponsors and funding

Namarara is an independent project whose development and maintenance is made possible thanks to the support of its patrons.

If you wish to join them and support the work of its author, just participate with this link :

>>> Become a patron or sponsor on Patreon <<<