Functions to manipulate unified-latex
Abstract Syntax Tree (AST).
If you want break apart or join an array of nodes based on a condition. For example,
this is used to split on &
characters in the align
environment.
npm install @unified-latex/unified-latex-util-split
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.
Joins an array of arrays with the item sep
function arrayJoin<T>(array: T[][], sep: T | T[]): T[];
Parameters
Param | Type |
---|---|
array | T[][] |
sep | T | T[] |
Split a list of nodes based on whether splitFunc
returns true
.
If onlySplitOnFirstOccurrence
is set to true in the options
object, then
there will be at most two segments returned.
function splitOnCondition(
nodes: Ast.Node[],
splitFunc: (node: Ast.Node) => boolean,
options: { onlySplitOnFirstOccurrence?: boolean }
): { segments: Ast.Node[][]; separators: Ast.Node[] };
Parameters
Param | Type |
---|---|
nodes | Ast.Node[] |
splitFunc | (node: Ast.Node) => boolean |
options | Omitted |
Split an array of AST nodes based on a macro. An object {segments: [], macros: []}
is returned. The original array is reconstructed as
segments[0] + macros[0] + segments[1] + ...
.
function splitOnMacro(
ast: Ast.Node[],
macroName: string | string[]
): { segments: Ast.Node[][]; macros: Ast.Macro[] };
Parameters
Param | Type |
---|---|
ast | Ast.Node[] |
macroName | string | string[] |
Does the reverse of splitOnMacro
function unsplitOnMacro({
segments,
macros,
}: {
segments: Ast.Node[][];
macros: Ast.Node[] | Ast.Node[][];
}): Ast.Node[];
Parameters
Param | Type |
---|---|
{ segments, macros, } | Omitted |