@kupibilet/boolean-json-eval
TypeScript icon, indicating that this package has built-in type declarations

3.2.2 • Public • Published
var evaluate = require('boolean-json-eval')

The package exports a function of two arguments:

  1. a boolean-json expression

  2. an object map from string variable name to true, false or a predicate (a function returning a boolean value) to be computed lazily.

It returns true or false.

var assert = require('assert')

assert(evaluate('x', {x: true}))

assert(
  evaluate(
    {or: ['a', {not: 'b'}, 'c']},
    {a: false, b: true, c: () => 2 * 2 === 4}
  )
)

assert(
  evaluate(
    {
      and:
      [
        {not: 'a'},
        {not: {not: {not: 'a'}}},
        {or: ['a', {not: 'a'}]}
      ]
    },
    {a: false}
  )
)

The function throws an exception if its expression argument references an undefined variable.

assert.throws(function() {
  evaluate('x', {})
})

Package Sidebar

Install

npm i @kupibilet/boolean-json-eval

Weekly Downloads

6

Version

3.2.2

License

MIT

Last publish

Collaborators

  • privetkometa
  • kupibilet-common
  • kupibilet-dev