Skip to main content

A PEG Parser generator in Go

Project description

⻰OGoPEGo

A PEG parser generator in Go.

⻰OGoPEGo is the Go sibling of 竜TatSu (Python) and 铁修TieXiu (Rust). It is functionally complete and passes the same test suite as its siblings.

Refer to the 竜TatSu documentation for grammar syntax, semantics, and usage. The local SYNTAX.md describes the grammar format.

The CLI tool is a great way to explored the features offered by the library:

$ ogo --help
Usage: ogo <command> [flags]

ogopego: A PEG parser generator in Go

Flags:
  -h, --help             Show context-sensitive help.
  -o, --output=STRING    Output to a file instead of stdout
  -C, --color="auto"     Control colorized output for API results
  -t, --trace            Display a detailed trace of the parsing process
  -v, --version          Print version information

Commands:
  run <grammar> <inputs> ... [flags]
    Execute a grammar against one or more input files

  boot [flags]
    The internal boot grammar

  grammar <grammar> [flags]
    Grammar transformations

Run "ogo <command> --help" for more information on a command.

Installation

go install github.com/neogeny/ogopego/cmd/ogo@latest

Library API

import "github.com/neogeny/ogopego/api"

// Compile a grammar string into a Grammar object.
g, err := api.Compile(grammar, cfg)

// Parse input with a compiled Grammar.
tree, err := api.ParseInput(g, input, cfg)

// Compile and parse in one step.
tree, err := api.ParseGrammar(grammar, cfg)

// Compile to JSON-compatible output.
json, err := api.CompileToJSON(grammar, cfg)

// Parse input to JSON-compatible output.
json, err := api.ParseInputToJSON(g, input, cfg)

// JSON roundtrip via peg package.
jsonStr := peg.SerializeGrammar(g)
g2, err := peg.ParseGrammar([]byte(jsonStr))

Grammar object

import "github.com/neogeny/ogopego/peg"

// A compiled grammar. Create one with api.Compile.
type Grammar struct {
    Name       string            // grammar name
    Directives *asjson.OrderedMap // @@directives
    Keywords   []string           // @@keyword declarations
    Rules      []*Rule            // grammar rules
    Analyzed   bool               // true after Initialize()
}

// Parse input text with this grammar (use api.ParseInput).
result, err := api.ParseInput(g, text, cfg)

// Prepare grammar for parsing (link rules, detect left recursion).
err := g.Initialize()

// Serialize.
jsonStr := g.AsJSONStr()             // indented JSON
jsonStr := peg.SerializeGrammar(g)   // clean JSON (recommended)
data, err := peg.ParseGrammar([]byte(jsonStr))  // deserialize

// Display.
fmt.Println(g.PrettyPrint())    // EBNF pretty-print
fmt.Println(g.Railroads())      // railroad diagram

Features

  • Generation of source code with an object model for deifinitions in the grammar is complete. The model generator defines the types specified in the input grammar and creates the transformation from the Tree result of a call to Parse() to the object model.
  • Code generation of a parser recently moved in 竜TatSu to the loading of a model of the Grammar and using it as parser. ⻰OGoPEGo is cabable of generating a model of the Grammar constructor for a grammar that can be compiled by Go for blazing boot times.
  • ⻰OGoPEGo also knows how to load fast a Grammar model from 竜TatSu-format JSON.
  • Semantic actions (transformations) during parse are implemented through a SemanticsFunc(Tree) Tree configuration entry. Transformations are limited to Tree->Tree, so a walker must be used as post-processor if a different AST type is desidred. The AST model generation available through the CLI tool generates such a walker.
  • Interpolation and evaluation of `constant` expressions hasn't had any known use cases with 竜TatSu. They will not be implemented in ⻰OGoPEGo until a use case appears.

License

Licensed under the Apache License, Version 2.0 (LICENSE or http://www.apache.org/licenses/LICENSE-2.0).

Contribution

Unless explicitly stated otherwise, any contribution intentionally submitted for inclusion in the work, as defined in the Apache-2.0 license, shall be licensed as above, without any additional terms or conditions.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ogopego-0.1.8.tar.gz (119.8 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

ogopego-0.1.8-py3-none-win_amd64.whl (14.1 kB view details)

Uploaded Python 3Windows x86-64

ogopego-0.1.8-py3-none-manylinux_2_28_x86_64.whl (3.1 MB view details)

Uploaded Python 3manylinux: glibc 2.28+ x86-64

ogopego-0.1.8-py3-none-macosx_11_0_arm64.whl (3.0 MB view details)

Uploaded Python 3macOS 11.0+ ARM64

File details

Details for the file ogopego-0.1.8.tar.gz.

File metadata

  • Download URL: ogopego-0.1.8.tar.gz
  • Upload date:
  • Size: 119.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for ogopego-0.1.8.tar.gz
Algorithm Hash digest
SHA256 363d0fbf57e044c089cbab297693f89d8ff39e5a4f28e0da1a7b2ff6d0ef9609
MD5 950d3252f8440bfe2652df70de234224
BLAKE2b-256 d369d3a2a543a68255455c33a748257d695f50c49d2431185e093b01efaf577a

See more details on using hashes here.

Provenance

The following attestation bundles were made for ogopego-0.1.8.tar.gz:

Publisher: publish.yml on neogeny/ogopego

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ogopego-0.1.8-py3-none-win_amd64.whl.

File metadata

  • Download URL: ogopego-0.1.8-py3-none-win_amd64.whl
  • Upload date:
  • Size: 14.1 kB
  • Tags: Python 3, Windows x86-64
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for ogopego-0.1.8-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 99ff5a8ae1047c6f6fe9070f06f82605dff72be977e094c41cb0211015f402fe
MD5 8cc4e71ca2ff4648fb75238652c39655
BLAKE2b-256 07b054044912224110bd50d33d8ac01c95d98f2d08260157622d0a544668bb57

See more details on using hashes here.

Provenance

The following attestation bundles were made for ogopego-0.1.8-py3-none-win_amd64.whl:

Publisher: publish.yml on neogeny/ogopego

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ogopego-0.1.8-py3-none-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for ogopego-0.1.8-py3-none-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 c6f82273fe289c2b2d8bd737642974b02b77ae50b8f088a3c0ef1381f3b93a09
MD5 f67664ce5e65b42ce5747dad2e9b199c
BLAKE2b-256 60a63b3e7f82847d6264247fe567f3bc383a94f595a458acad4822d9bbc507ce

See more details on using hashes here.

Provenance

The following attestation bundles were made for ogopego-0.1.8-py3-none-manylinux_2_28_x86_64.whl:

Publisher: publish.yml on neogeny/ogopego

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ogopego-0.1.8-py3-none-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for ogopego-0.1.8-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 fd617727c3313467e96eecc3a5277048e66abd92d3107f4b78ff9a1d20b23da2
MD5 1bb177b808a5a17b3a42bd48569d210f
BLAKE2b-256 8faeb9679c80c442a567cc77dec5c3012f9dcd8c55e798571def90fcdcb8632e

See more details on using hashes here.

Provenance

The following attestation bundles were made for ogopego-0.1.8-py3-none-macosx_11_0_arm64.whl:

Publisher: publish.yml on neogeny/ogopego

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page