Skip to main content

Reference OpenQASM AST in Python

Project description

OpenQASM 3 Python Reference

LicenseRelease

The openqasm3 package contains the reference abstract syntax tree (AST) for representing OpenQASM 3 programs, tools to parse text into this AST, and tools to manipulate the AST.

The AST is intended to help with writing compiler passes for OpenQASM 3 in Python. It aims to have no dependencies for users who consume the Python tree structure, and minimal dependencies for parsing a string to this tree structure. The AST is simpler than a Concrete Syntax Tree (CST) which preserves comments, spacing, etc for use by editor plugins.

The package consists of the modules:

  • openqasm3.ast: The AST nodes.

  • openqasm3.parser: A parser based on an ANTLR grammar and reference parser also found in this repo. It walks the ANTLR parse tree to generate the AST.

  • openqasm3.visitor: A base AST visitor and transformer.

  • tests: A set of unit tests.

Note: this reference Python package is currently in the early stages of development, and no parts of the API should be considered stable at this time. The AST itself will be subject to change in backwards-incompatible ways, mirroring the development of the OpenQASM 3 languge itself.

Installation

The package can be installed from PyPI (pip) with the command

python -m pip install openqasm3

If you want to use the parser, you will need to install the extra parsing, and to run the tests you need the extra tests, for example pip install openqasm3[tests]. All extras can be installed with the target openqasm3[all].

Development Environment

To work on development, you will need to have a complete ANTLR installation (not just the runtime), and the ANTLR grammar files from the main OpenQASM repository.

Setting up ANTLR

You can most likely get a copy of ANTLR using your system package manager if you are on Linux, or from Homebrew (brew) on macOS. Otherwise, you can follow these instructions. Make a note of the version of ANTLR you have installed, because you will need to ensure your version of antlr4-python3-runtime matches up to the minor version.

Once you have ANTLR installed, change to the directory where the qasm3*.g4 files are located (for example, repo_root/source/grammar), and run

<antlr command> -o <path to here>/openqasm3/_antlr/_<major>_<minor> -Dlanguage=Python3 -visitor qasm3Lexer.g4 qasm3Parser.g4

For example, if this repository is cloned to ~/openqasm and the command to run ANTLR 4.11.1 is antlr4, then you should run

cd ~/openqasm/source/grammar
antlr4 -o ~/openqasm/source/openqasm/openqasm3/_antlr/_4_11 -Dlanguage=Python3 -visitor qasm3Lexer.g4 qasm3Parser.g4

You can install more than one version of the ANTLR files at once, provided you put them in the correct version directories. The package will dynamically choose the correct version based on the installed version of antlr4_python3_runtime when it is imported.

Developer tools

Install the rest of the Python development environment with

python -m pip install -r requirements.txt -r requirements-dev.txt

ensuring that the version of antlr4-python3-runtime exactly matches the version of ANTLR you have.

Install the Python package in editable mode with

python -m pip install -e .

The project is configured to use the code formatter black, linter pylint and tester pytest. The commands to run these are, respectively:

black .
pylint .
pytest

Deployment procedure

The deployment is primarily managed by a GitHub Actions pipeline, triggered by a tag of the form ast-py/v<version>. For example, for package version 0.4.0, the tag should be ast-py/v0.4.0.

To deploy:

  1. create a PR that sets the version number of the package in __init__.py and docs/conf.py to what it should be.
  2. once the PR has merged, tag the merge commit (for example, git fetch origin; git tag -m "Python AST 0.4.0" ast-py/v0.4.0 origin/main).
  3. push the tag to this repository (for example, git push origin ast-py/v0.4.0).

At this point, the deployment pipeline will take over and deploy the package to PyPI. You should be able to see the progress in the Actions tab of this repository.

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

openqasm3-0.4.0.tar.gz (371.6 kB view details)

Uploaded Source

Built Distribution

openqasm3-0.4.0-py3-none-any.whl (385.3 kB view details)

Uploaded Python 3

File details

Details for the file openqasm3-0.4.0.tar.gz.

File metadata

  • Download URL: openqasm3-0.4.0.tar.gz
  • Upload date:
  • Size: 371.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.7

File hashes

Hashes for openqasm3-0.4.0.tar.gz
Algorithm Hash digest
SHA256 34f137790389bd9bdee32c2906cfdcca34afbc249a21ade5d09c44c4429e4a4c
MD5 68b62c267690b81e8835152acc1c154b
BLAKE2b-256 ebd17bdba0830c366c424eece7dd7ccd5566bc08149e27af06554fc79b1b2eb3

See more details on using hashes here.

File details

Details for the file openqasm3-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: openqasm3-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 385.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.7

File hashes

Hashes for openqasm3-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a61428b64d53b7acc51e4f23c30722268ce5dfafaf70666721ef6c1e94f9dd2f
MD5 d2a76ce3fac2ab7ca453cc35ad96a2f4
BLAKE2b-256 9f1afd6743118f18c69763bbd4b9c5f7b62a34e26ace770fb0e7deaa970004a0

See more details on using hashes here.

Supported by

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