An abstract VHDL language model.
Project description
An abstract VHDL language model written in Python.
Main Goals
This package provides a unified abstract language model for VHDL. Projects reading from source files can derive own classes and implement additional logic to create a concrete language model for their tools.
Projects consuming pre-processed VHDL data (parsed, analyzed or elaborated) can build higher level features and services on such a model, while supporting multiple frontends.
Use Cases
pyVHDLModel Generators
- High-level API for GHDL's
libghdl
offered viapyghdl
. - Code Document-Object-Model (Code-DOM) in pyVHDLParser.
pyVHDLModel Consumers
- Create graphical views of VHDL files or designs.
Possible candidates: Symbolator - Created a (re)formatted output of VHDL.
Examples
List all Entities with Generics and Ports
The following tiny example is based on GHDL's pyGHDL.dom
package implementing
pyVHDLModel.
from pathlib import Path
from pyGHDL.dom.NonStandard import Design, Document
sourceFile = Path("example.vhdl")
design = Design()
library = design.GetLibrary("lib")
document = Document(sourceFile)
design.AddDocument(document, library)
for entity in document.Entities.values():
print(f"{entity.Identifier}")
print(" generics:")
for generic in entity.GenericItems:
identifiers = ", ".join([str(i) for i in generic.Identifiers])
print(f" - {identifiers} : {generic.Mode!s} {generic.Subtype}")
print(" ports:")
for port in entity.PortItems:
identifiers = ", ".join([str(i) for i in port.Identifiers])
print(f" - {identifiers} : {port.Mode!s} {port.Subtype}")
Contributors
- Patrick Lehmann (Maintainer)
- Unai Martinez-Corral
- and more...
License
This Python package (source code) licensed under Apache License 2.0.
The accompanying documentation is licensed under Creative Commons - Attribution 4.0 (CC-BY 4.0).
SPDX-License-Identifier: Apache-2.0
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for pyVHDLModel-0.19.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 26250d89fc8ec82fcc271e55ba65e2fa33514ab5f4ec3df7cfad96627e7d9ac5 |
|
MD5 | 30ffa854377c90cb63c5e2d61bcc51a9 |
|
BLAKE2b-256 | f8e7e395cbb8be42e0831b1c3347988fb88f4ffe918d111677f902439c52cbf9 |