4.0.6 • Published 5 years ago
first-follow v4.0.6
first-follow
A small tool for calculating first, follow and predict sets for the grammar. Its size is only 390 bytes (minified and gzipped). No dependencies. Size Limit controls the size.
Installation
$ npm install first-followDemo
You can try this tool here.
Example
const firstFollow = require('first-follow');
const rules = [
  // S -> a b A
  {
    left: 'S',
    right: ['a', 'b', 'A']
  },
  // A -> b c
  {
    left: 'A',
    right: ['b', 'c']
  },
  // A -> ε
  {
    left: 'A',
    right: [null]
  }
];
const { firstSets, followSets, predictSets } = firstFollow(rules);
console.log(firstSets);
/*
 *  // S: a
 *  // A: b, ε
 *
 *  {
 *    S: ['a'],
 *    A: ['b', null]
 *  }
 */
console.log(followSets);
/*
 *  // S: ┤
 *  // A: ┤
 *
 *  {
 *    S: ['\u0000'],
 *    A: ['\u0000']
 *  }
 */
console.log(predictSets);
/*
 *  // 1: a
 *  // 2: b
 *  // 3: ┤
 * 
 *  {
 *    '1': ['a'],
 *    '2': ['b'],
 *    '3': ['\u0000']
 *  }
*/Rules
Input
The grammar is represented by array of objects. Each object describes the only one rule. The rule's object contains two required fields:
- left— specifies the left part of the rule. A single nonterminal:- A,- B,- Program,- Expression, etc.
- right— specifies the right part of the rule. It contains terminals and nonterminals or empty chain (epsilon):- A + B,- d * A,- ε, etc.
Output
- The firstSetsobject's keys are nonterminals and values are first sets for these nonterminals.
- The followSetsobject's keys are nonterminals and values are follow sets for these nonterminals.
- The predictSetsobject's keys are rules numbers (starting from1) and values are predict sets for these rules.
Definitions
- An empty chain (ε) is represented bynull.
- An end mark (┤) is represented by\u0000.
4.0.6
5 years ago
4.0.5
5 years ago
4.0.4
5 years ago
4.0.3
5 years ago
4.0.2
5 years ago
4.0.1
5 years ago
4.0.0
5 years ago
3.2.2
5 years ago
3.3.0
5 years ago
3.2.1
6 years ago
3.2.0
6 years ago
3.1.0
6 years ago
3.0.1
6 years ago
3.0.0
6 years ago
2.0.0
8 years ago
1.2.0
9 years ago
1.1.0
9 years ago
0.0.1
9 years ago
1.0.0
9 years ago