Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/umutozel/jokenizer

:dragon: JavaScript expression tokenizer and evaluator
https://github.com/umutozel/jokenizer

evaluator expression javascript parser tokenizer typescript

Last synced: 3 months ago
JSON representation

:dragon: JavaScript expression tokenizer and evaluator

Awesome Lists containing this project

README

        

# Jokenizer - JavaScript Expression Parser and Evaluator

[![Build Status](https://api.travis-ci.com/umutozel/jokenizer.svg?branch=main)](https://travis-ci.com/github/umutozel/jokenizer)
[![Coverage Status](https://coveralls.io/repos/github/umutozel/jokenizer/badge.svg?branch=main)](https://coveralls.io/github/umutozel/jokenizer?branch=main)
[![npm version](https://badge.fury.io/js/jokenizer.svg)](https://badge.fury.io/js/jokenizer)
Known Vulnerabilities
[![GitHub issues](https://img.shields.io/github/issues/umutozel/Jokenizer.Net.svg)](https://github.com/umutozel/Jokenizer.Net/issues)
[![GitHub license](https://img.shields.io/badge/license-MIT-blue.svg)](https://raw.githubusercontent.com/umutozel/Jokenizer.Net/main/LICENSE)

[![GitHub stars](https://img.shields.io/github/stars/umutozel/jokenizer.net.svg?style=social&label=Star)](https://github.com/umutozel/jokenizer.net)
[![GitHub forks](https://img.shields.io/github/forks/umutozel/jokenizer.net.svg?style=social&label=Fork)](https://github.com/umutozel/jokenizer.net)

jokenizer is just a simple library to parse JavaScript expressions and evaluate them with custom scopes.

Written completely in TypeScript.

## Installation

```shell
npm i jokenizer
```

## Let's try it out

```JavaScript
import { tokenize, evaluate } from 'jokenizer';

const expression = tokenize('{ a: v1, b }');
const scope = { v1: 3, b: 5 };
const value = evaluate(expression, scope);

/*
expression =
{
"type": "O", // ObjectExpression
"members": [{
"type": "A", // AssignExpression
"name": "a",
"right": {
"type": "V", // VariableExpression
"name": "v1"
}
}, {
"type": "V",
"name": "b"
}]
}

value = { "a": 3, "b": 5 } // evaluated value
*/
```

## Supported Expression Types

### LiteralExpression

```JavaScript
evaluate(tokenize('42')); // 42
evaluate(tokenize('42.4242')); // 42.4242
evaluate(tokenize('"4\'2"')); // "4'2"
evaluate(tokenize('true')); // true
evaluate(tokenize('false')); // false
evaluate(tokenize('null')); // null
```

### VariableExpression

```JavaScript
evaluate(tokenize('Name'), { Name: 'Alan' }); // 'Alan'
```

### UnaryExpression

```JavaScript
evaluate(tokenize('-Str'), { Str: '5' }); // -5
evaluate(tokenize('+Str'), { Str: '5' }); // 5
evaluate(tokenize('!IsActive'), { IsActive: false }); // true
evaluate(tokenize('~index'), { index: -1 }); // 0
```

### GroupExpression

```JavaScript
evaluate(tokenize('(a, b)'), { a: 4, b: 2 }); // [1, 2]
evaluate(tokenize('a, b'), { a: 4, b: 2 }); // [4, 2]
evaluate(tokenize('(a)'), { a: 4 }); // 4 - if expression count is 1, returns its value
```

### ObjectExpression

```JavaScript
evaluate(tokenize('{ a: v1, b }'), { v1: 3, b: 5 }); // { a: 3, b: 5 }
```

### ArrayExpression

```JavaScript
evaluate(tokenize('[ a, 1 ]'), { a: 0 }); // [0, 1]
```

### BinaryExpression

```JavaScript
evaluate(tokenize('v1 <= v2'), { v1: 5, v2: 3 }); // false
evaluate(tokenize('v1 % v2'), { v1: 5, v2: 3 }); // 2
evaluate(tokenize('v1 * v2'), { v1: 5, v2: 3 }); // 15
evaluate(tokenize('v1 && v2'), { v1: true, v2: false }); // false
evaluate(tokenize('1 + 2 * 3')); // 7 - supports operator precedence
```

### MemberExpression

```JavaScript
evaluate(tokenize('Company.Name'), { Company: { Name: 'Netflix' } }); // 'Netflix'
```

### IndexerExpression

```JavaScript
evaluate(tokenize('Company["Name"]'), { Company: { Name: 'Netflix' } }); // 'Netflix'
evaluate(tokenize('Company[key]'), { Company: { Name: 'Netflix' }, key: 'Name' }); // 'Netflix'
```

### FuncExpression

```JavaScript

const f = evaluate(tokenize('(a, b) => a < b'));
f(2, 1); // false

const f = evaluate(tokenize('function(a, b) { return a < b; }'));
f(2, 1) // false
```

### CallExpression

```JavaScript
evaluate(tokenize('test(42, a)'), { test: (a, b) => a * b }, { a: 2 }); // 84
```

### TernaryExpression

```JavaScript
evaluate(tokenize('check ? 42 : 21'), { check: true }); // 42
```

## License

Jokenizer is under the [MIT License](LICENSE).