@unified-latex/unified-latex-util-pegjs
TypeScript icon, indicating that this package has built-in type declarations

1.8.1 • Public • Published

unified-latex-util-pegjs

What is this?

Pegjs grammars to help parse strings into a unified-latex Abstract Syntax Tree (AST). Note, because of the dynamic nature of LaTeX, to get a full AST with arguments attached to macros, etc., the tree is parsed multiple times.

Also included are functions to decorate a Ast.Node[] array so that Pegjs can process it as if it were a string. This allows for complex second-pass parsing.

When should I use this?

If you are building libraries to parse specific LaTeX syntax (e.g., to parse tabular environments or systeme environments, etc.).

Install

npm install @unified-latex/unified-latex-util-pegjs

This package contains both esm and commonjs exports. To explicitly access the esm export, import the .js file. To explicitly access the commonjs export, import the .cjs file.

Functions

decorateArrayForPegjs(array)

Pegjs operates on strings. However, strings and arrays are very similar! This function adds charAt, charCodeAt, and substring methods to array so that array can then be fed to a Pegjs generated parser.

function decorateArrayForPegjs(array: any[]): StringlikeArray;

Parameters

Param Type
array any[]

splitStringsIntoSingleChars(nodes)

Splits all multi-character strings into strings that are all single characters.

function splitStringsIntoSingleChars(nodes: Ast.Node[]): Ast.Node[];

Parameters

Param Type
nodes Ast.Node[]

Package Sidebar

Install

npm i @unified-latex/unified-latex-util-pegjs

Weekly Downloads

3,531

Version

1.8.1

License

MIT

Unpacked Size

2.7 MB

Total Files

7

Last publish

Collaborators

  • siefkenj