Skip to main content

Pure Python HDL parser, plus symbol generator and sphinx domain

Project description

HDLTree

HDLTree is a pure Python HDL parser that uses Lark to create a parse tree, then transform it into a syntax tree. Currently only VHDL-2008 is supported.

The HDLTree repo also includes the Hdlparse and Symbolator packages, originally written by kevinpt. This repo is based on a fork maintained by zebreus which consolidated the two packages and applied several patches. The version of Hdlparse in this repo has been rewritten to use HDLTree for parsing VHDL instead of the simple partial parser in the original. Verilog is still handled by the original parser, until such time as HDLTree supports parsing Verilog.

Included with Symbolator are the symbolator_sphinx package for embedding symbolator symbols in Sphinx documentation, and the nucanvas package as a wrapper around Pycairo and PyGObject.

Getting HDLTree

Prerequisites

HDLTree and Hdlparse don't have any dependencies besides python packages automatically installed by pip. Symbolator requires Cairo and Pango. On Linux, these are likely packaged by your distribution and can be installed with pacman, apt-get, dnf, etc. On Windows, the best way is probably to install GTK.

Installing releases from pip

HDLTree is available on PyPI:

pip install hdltree

Installing from latest source

The GitHub repo may be ahead of the released package. You can install the bleeding edge version:

pip install git+https://github.com/rpatel3001/hdltree.git

Extra Dependencies

Symbolator Dependencies

Symbolator requires the pygobject and pycairo packages as bindings for Cairo and Pango.

pip install hdltree[symbolator]

Regex Library

Lark can use the regex library instead of the builtin re library for regular expressions. HDLTree will automatically use the regex library if it is installed.

pip install hdltree[regex]

CLI Scripts

After a successful install the hdltree, hdlparse, and symbolator executables will be available. On Linux they should be immediately accessible on your $PATH. On Windows you may need to add the <Python root>\Scripts directory to your %PATH%.

The hdltree and hdlparse scripts are not particularly useful for end use. hdltree will print the syntax tree for the input files. hdlparse will print the parsed information from a fixed piece of code. symbolator is the only one meant to be used primarily from a terminal and its use is described below.

Usage

Coming soon. For now, see an example that parses input files, generates a Graphviz/DOT based symbol as an alternative to symbolator, and compares the input file to a recreation from the syntax tree for equivalency (minus comments and whitespace).

Hdlparse

Hdlparse is a simple package implementing a rudimentary parser for VHDL and Verilog. It is not capable of fully parsing the entire language. Rather, it is meant to extract enough key information from a source file to create generated documentation.

For VHDL this library can extract component, subprogram, type, subtype, and constant declarations from a package. For Verilog it can extract module declarations (both 1995 and 2001 syntax). Because this version of Hdlparse replaces the VHDL parser with HDLTree, it's behavior may not exactly match other versions of Hdlparse for VHDL files. One restriction is that input files must be full, valid VHDL files. Partial files with bare component or entity declarations are not supported.

Full documentation can be found at here.

Symbolator

Symbolator is a component diagramming tool for VHDL and Verilog. It will parse HDL source files, extract components or entities and render them as an image.

Full documentation can be found here. Due to limitations of the Lark based parser, symbol sections defined in metacomments are not supported by this version of symbolator.

library ieee;
use ieee.std_logic_1164.all;

package demo is
  component demo_device_comp is
    generic (
      SIZE : positive;
      RESET_ACTIVE_LEVEL : std_ulogic := '1'
    );
    port (
      Clock : in std_ulogic;
      Reset : in std_ulogic;

      Enable : in std_ulogic;
      Data_in : in std_ulogic_vector(SIZE-1 downto 0);
      Data_out : out std_ulogic_vector(SIZE-1 downto 0)
    );
  end component;
end package;
$ symbolator -i docs/images/demo_device.vhdl
Created demo_device_comp.svg from demo_device_comp (docs/images/demo_device.vhdl)

Produces the following:

Demo device diagram

Symbolator can render to PNG bitmap images or SVG, PDF, PS, and EPS vector images. SVG is the default.

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

hdltree-0.4.1.tar.gz (71.6 kB view details)

Uploaded Source

Built Distribution

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

hdltree-0.4.1-py3-none-any.whl (77.0 kB view details)

Uploaded Python 3

File details

Details for the file hdltree-0.4.1.tar.gz.

File metadata

  • Download URL: hdltree-0.4.1.tar.gz
  • Upload date:
  • Size: 71.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for hdltree-0.4.1.tar.gz
Algorithm Hash digest
SHA256 03ea73ff0eb5d8b4827ae29565df1711fc3ad09a07930cab27eb2db6c1dabb8e
MD5 e0bd33feb923b8879993421013649835
BLAKE2b-256 311cd3ab20938e9bf4b6cd4536dfdc35a1af38b3145d1cfee428d49217f893e6

See more details on using hashes here.

Provenance

The following attestation bundles were made for hdltree-0.4.1.tar.gz:

Publisher: publish-to-pypi.yml on rpatel3001/hdltree

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

File details

Details for the file hdltree-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: hdltree-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 77.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for hdltree-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 5eb58e7f9ecf7b5270771958eb373e77f4e759b319a839e466e70c4e3ecf9e1b
MD5 df81c3c896f36cd9f8e684c407399862
BLAKE2b-256 4d0c5aee68e8f2c340fc2506af2ca6718c4ac9e5a29fbd4c6124886c1e619a0c

See more details on using hashes here.

Provenance

The following attestation bundles were made for hdltree-0.4.1-py3-none-any.whl:

Publisher: publish-to-pypi.yml on rpatel3001/hdltree

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