Skip to content

Define context-free grammars using template strings.

Notifications You must be signed in to change notification settings

no-context/grammar

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 

Repository files navigation

grammar (WIP)

Define context-free grammars for use with parsing tools like nearley.

$ npm install grammar

Use template strings to define your grammar.

const bnf = require('grammar')

const id = ([x]) => x
const select = n => d => d[n]
const newObject = () => ({})
const newArray = () => []

const jsonGrammar = bnf`
  json -> object  ${id}
        | array   ${id}

  object  -> "{" members "}" ${select(1)}
  members -> null         ${newObject}
           | members pair ${([obj, pair]) => Object.assign(obj, pair)}
  pair -> string ":" value  ${([key, _, value]) => ({[key]: value})}

  array -> "[" items "]"  ${select(1)}
  items -> null         ${newArray}
         | items value  ${([xs, x]) => {xs.push(x); return xs}}

  value -> object   ${id}
         | array    ${id}
         | number   ${id}
         | string   ${id}
         | "true"   ${() => true}
         | "false"  ${() => false}
         | "null"   ${() => null}

  number -> %NUMBER  ${([tok]) => parseFloat(tok.value) }}
  string -> %STRING  ${([tok]) => JSON.parse(tok.value) }}
`

Now you can use it!

const nearley = require('nearley')
const p = nearley.Parser(jsonGrammar)
/// ...

About

Define context-free grammars using template strings.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published