Skip to main content
This release is 4 versions behind 0.5.4 — the latest version of @marcisbee/nanolex. Jump to latest

Built and signed on GitHub Actions

Parser grammar builder

This package works with Cloudflare Workers, Node.js, Deno, Bun, Browsers
This package works with Cloudflare Workers
This package works with Node.js
This package works with Deno
This package works with Bun
This package works with Browsers
JSR Score
76%
Published
3 months ago (0.5.0)

nanolex

@TODO readme

Very experimental parser building library

Usage

npm i nanolex
import { createToken, EOF, getComposedTokens, nanolex } from "nanolex";

// Define tokens
const Whitespace = createToken(/[ \t\n\r]+/, "WhiteSpace");
const LParen = createToken("(");
const RParen = createToken(")");
const Comma = createToken(",");
const Integer = createToken(/-?\d+/, "Integer");
const Identifier = createToken(/\w+/, "Identifier");

// List of tokenizable tokens
const tokens = getComposedTokens([
  Whitespace,
  LParen,
  RParen,
  Comma,
  Integer,
]);

// Define the usage of your parser
export function parser(value: string) {
  // Initiate grammar
  const {
    consume,
    zeroOrOne,
    zeroOrMany,
    zeroOrManySep,
    and,
    or,
    patternToSkip,
    throwIfError,
  } = nanolex(value, tokens);

  // Write patterns to skip, in this case ignore whitespace
  // Pattern is just grammar
  patternToSkip(consume(Whitespace));

  // Write parser grammar patterns here

  function FUNCTION() {
    return and([
      consume(Identifier),
      consume(LParen),
      PARAMS,
      consume(RParen),
    ], transform)();

    function transform([name, _, params]) {
      return {
        type: "function",
        name,
        params,
      };
    }
  }

  function PARAMS() {
    return zeroOrManySep(
      VALUE,
      consume(Comma),
    )();
  }

  function VALUE() {
    return or([
      consume(Integer, Number),
      FUNCTION,
    ])();
  }

  // Run the grammar
  const [output] = throwIfError(and([FUNCTION, consume(EOF)]));

  return output;
}
import { parser } from "./parser.ts";

parser("SUM(1, SUM(2, 3))");
/*
{
  "type": "function",
  "name": "SUM",
  "params": [
    1,
    {
      "type": "function",
      "name": "SUM",
      "params": [2, 3]
    }
  ]
}
*/
Built and signed on
GitHub Actions
View transparency log

Add Package

deno add jsr:@marcisbee/nanolex

Import symbol

import * as nanolex from "@marcisbee/nanolex";

---- OR ----

Import directly with a jsr specifier

import * as nanolex from "jsr:@marcisbee/nanolex";

Add Package

npx jsr add @marcisbee/nanolex

Import symbol

import * as nanolex from "@marcisbee/nanolex";

Add Package

yarn dlx jsr add @marcisbee/nanolex

Import symbol

import * as nanolex from "@marcisbee/nanolex";

Add Package

pnpm dlx jsr add @marcisbee/nanolex

Import symbol

import * as nanolex from "@marcisbee/nanolex";

Add Package

bunx jsr add @marcisbee/nanolex

Import symbol

import * as nanolex from "@marcisbee/nanolex";