@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', {})
})

Dependencies (0)

    Dev Dependencies (5)

    Package Sidebar

    Install

    npm i @kupibilet/boolean-json-eval

    Weekly Downloads

    0

    Version

    3.2.2

    License

    MIT

    Last publish

    Collaborators

    • privetkometa
    • kupibilet-common
    • kupibilet-dev