Automata.js is a regular expression converter written in JS for both Node.js and browser.
It aims to convert regular expression to finite state machine(FSM, like NFA). Besides, dot script transition is provided so that you can make diagrams with Graphiz.
// Install dependency modules.
npm install
// Run test.
make test
// Generate browser js.
make distribution
Currently, Automata.js supports minimal regular expressions:
+
: One or more*
: Zero or more?
: Zero or one()
: Capture everything enclosed|
: Or\n
: Newline\r
: Carriage return\t
: Tab\w
: [a-zA-Z0-9_]\d
: [0-9]
FSM
is a object represent a finite state machine(NFA, DFA).
The json definition is below:
{
initialState: 'id',
acceptStates: ['id', ... ] ,
numOfStates: Integer,
type: 'DFA' or 'NFA',
transitions: {
'id': { 'to_id': label, },
...,
}
}
Convert the fsm to Graphiz dot script.
text
: String
Determine whether text
matches to the FSM. This methods only supports DFA.
RegParser is a regular expression parser.
Set regular expression string
in parser.
Parses the given regular expression.
Returns a FSM
object, the FSM
represents a Nondeterministic Finite Automata(NFA).
Parses the given regular expression.
Returns a FSM
object, the FSM
represents a Deterministic Finite Automata(DFA).
Install via npm install automata.js
.
var regParser = require('automata.js');
var parser = new regParser.RegParser('a*b');
var nfa = parser.parseToNFA();
console.log(nfa.toDotScript());
Automata.js uses node-browserify to generate a browser distribution.
You can use Viz.js to render graphiz dot script in your web page.
var regParser = require('automata.js');
var parser = new regParser.RegParser('a*b');
var nfa = regParser.parseToNFA();
// render dot script to svg.
var result = Viz(nfa.toDotScript(), 'svg', 'dot');