aboutsummaryrefslogtreecommitdiffstats
path: root/pyGHDL/libghdl
diff options
context:
space:
mode:
authorPatrick Lehmann <Patrick.Lehmann@plc2.de>2021-01-09 00:54:05 +0100
committertgingold <tgingold@users.noreply.github.com>2021-01-10 10:14:16 +0100
commitb2a98ec0674c031688ebf479664db6fd4975b428 (patch)
tree7557451e8240f0df7ad2ebb6780391fce05377b7 /pyGHDL/libghdl
parent00274e966e0e10cca9707d489cf75090ae7f1b96 (diff)
downloadghdl-b2a98ec0674c031688ebf479664db6fd4975b428.tar.gz
ghdl-b2a98ec0674c031688ebf479664db6fd4975b428.tar.bz2
ghdl-b2a98ec0674c031688ebf479664db6fd4975b428.zip
Improved docstrings.
Diffstat (limited to 'pyGHDL/libghdl')
-rw-r--r--pyGHDL/libghdl/__init__.py218
-rw-r--r--pyGHDL/libghdl/files_map.py4
2 files changed, 118 insertions, 104 deletions
diff --git a/pyGHDL/libghdl/__init__.py b/pyGHDL/libghdl/__init__.py
index 1b400c5c1..030c1bea2 100644
--- a/pyGHDL/libghdl/__init__.py
+++ b/pyGHDL/libghdl/__init__.py
@@ -46,103 +46,103 @@ from pyGHDL.libghdl.version import __version__
def _get_libghdl_name() -> Path:
- """Get the name of the libghdl library (with version and extension)"""
- ver = __version__.replace("-", "_").replace(".", "_")
- ext = {"win32": "dll", "cygwin": "dll", "darwin": "dylib"}.get(sys.platform, "so")
- return Path("libghdl-{version}.{ext}".format(version=ver, ext=ext))
+ """Get the name of the libghdl library (with version and extension)"""
+ ver = __version__.replace("-", "_").replace(".", "_")
+ ext = {"win32": "dll", "cygwin": "dll", "darwin": "dylib"}.get(sys.platform, "so")
+ return Path("libghdl-{version}.{ext}".format(version=ver, ext=ext))
def _check_libghdl_libdir(libdir: Path, basename: Path) -> Path:
- """Returns libghdl path in :obj:`libdir`, if found."""
- if libdir is None:
- raise ValueError("Parameter 'libdir' is None.")
- # print('libghdl: check in {}'.format(libdir))
- res = libdir / basename
- if res.exists():
- return res
+ """Returns libghdl path in :obj:`libdir`, if found."""
+ if libdir is None:
+ raise ValueError("Parameter 'libdir' is None.")
+ # print('libghdl: check in {}'.format(libdir))
+ res = libdir / basename
+ if res.exists():
+ return res
- raise FileNotFoundError(str(res))
+ raise FileNotFoundError(str(res))
def _check_libghdl_bindir(bindir: Path, basename: Path) -> Path:
- if bindir is None:
- raise ValueError("Parameter 'bindir' is None.")
+ if bindir is None:
+ raise ValueError("Parameter 'bindir' is None.")
- return _check_libghdl_libdir((bindir / "../lib").resolve(), basename)
+ return _check_libghdl_libdir((bindir / "../lib").resolve(), basename)
def _get_libghdl_path():
- """
- Locate the directory where the shared library is installed.
-
- Search order:
-
- 1. `GHDL_PREFIX` - directory (prefix) of the vhdl libraries.
- 2. `VUNIT_GHDL_PATH` - path of the `ghdl` binary when using VUnit.
- 3. `GHDL` - name of, or path to the `ghdl` binary.
- 4. Try within `libghdl/` Python installation.
- 5. Try when running from the build directory.
- """
- basename = _get_libghdl_name()
-
- # Try GHDL_PREFIX
- # GHDL_PREFIX is the prefix of the vhdl libraries, so remove the
- # last path component.
- r = os.environ.get("GHDL_PREFIX")
- try:
- return _check_libghdl_libdir(Path(r).parent, basename)
- except (TypeError, FileNotFoundError):
- pass
-
- # Try VUNIT_GHDL_PATH (path of the ghdl binary when using VUnit).
- r = os.environ.get("VUNIT_GHDL_PATH")
- try:
- return _check_libghdl_bindir(Path(r), basename)
- except (TypeError, FileNotFoundError):
- pass
-
- # Try GHDL (name/path of the ghdl binary)
- r = os.environ.get("GHDL", "ghdl")
- r = which(r)
- try:
- return _check_libghdl_bindir(Path(r).parent, basename)
- except (TypeError, FileNotFoundError):
- pass
-
- # Try within libghdl/ python installation
- r = Path(__file__)
- try:
- return _check_libghdl_bindir(r.parent, basename)
- except (TypeError, FileNotFoundError):
- pass
-
- # Try when running from the build directory
- r = (r.parent / "../../lib").resolve()
- try:
- return _check_libghdl_libdir(r, basename)
- except (TypeError, FileNotFoundError):
- pass
-
- # Failed.
- raise Exception("Cannot find libghdl {}".format(basename))
+ """
+ Locate the directory where the shared library is installed.
+
+ Search order:
+
+ 1. `GHDL_PREFIX` - directory (prefix) of the vhdl libraries.
+ 2. `VUNIT_GHDL_PATH` - path of the `ghdl` binary when using VUnit.
+ 3. `GHDL` - name of, or path to the `ghdl` binary.
+ 4. Try within `libghdl/` Python installation.
+ 5. Try when running from the build directory.
+ """
+ basename = _get_libghdl_name()
+
+ # Try GHDL_PREFIX
+ # GHDL_PREFIX is the prefix of the vhdl libraries, so remove the
+ # last path component.
+ r = os.environ.get("GHDL_PREFIX")
+ try:
+ return _check_libghdl_libdir(Path(r).parent, basename)
+ except (TypeError, FileNotFoundError):
+ pass
+
+ # Try VUNIT_GHDL_PATH (path of the ghdl binary when using VUnit).
+ r = os.environ.get("VUNIT_GHDL_PATH")
+ try:
+ return _check_libghdl_bindir(Path(r), basename)
+ except (TypeError, FileNotFoundError):
+ pass
+
+ # Try GHDL (name/path of the ghdl binary)
+ r = os.environ.get("GHDL", "ghdl")
+ r = which(r)
+ try:
+ return _check_libghdl_bindir(Path(r).parent, basename)
+ except (TypeError, FileNotFoundError):
+ pass
+
+ # Try within libghdl/ python installation
+ r = Path(__file__)
+ try:
+ return _check_libghdl_bindir(r.parent, basename)
+ except (TypeError, FileNotFoundError):
+ pass
+
+ # Try when running from the build directory
+ r = (r.parent / "../../lib").resolve()
+ try:
+ return _check_libghdl_libdir(r, basename)
+ except (TypeError, FileNotFoundError):
+ pass
+
+ # Failed.
+ raise Exception("Cannot find libghdl {}".format(basename))
def _initialize():
- # Load the shared library
- _libghdl_path = _get_libghdl_path()
- # print("Load {}".format(_libghdl_path))
- libghdl = CDLL(str(_libghdl_path))
+ # Load the shared library
+ _libghdl_path = _get_libghdl_path()
+ # print("Load {}".format(_libghdl_path))
+ libghdl = CDLL(str(_libghdl_path))
- # Initialize it.
- # First Ada elaboration (must be the first call)
- libghdl.libghdl_init()
- # Then 'normal' initialization (set hooks)
- libghdl.libghdl__set_hooks_for_analysis()
+ # Initialize it.
+ # First Ada elaboration (must be the first call)
+ libghdl.libghdl_init()
+ # Then 'normal' initialization (set hooks)
+ libghdl.libghdl__set_hooks_for_analysis()
- # Set the prefix in order to locate the VHDL libraries.
- prefix = str(_libghdl_path.parent.parent).encode("utf-8")
- libghdl.libghdl__set_exec_prefix(c_char_p(prefix), len(prefix))
+ # Set the prefix in order to locate the VHDL libraries.
+ prefix = str(_libghdl_path.parent.parent).encode("utf-8")
+ libghdl.libghdl__set_exec_prefix(c_char_p(prefix), len(prefix))
- return libghdl
+ return libghdl
# Initialize shared library when package is loaded
libghdl = _initialize()
@@ -150,48 +150,62 @@ libghdl = _initialize()
@export
def finalize() -> None:
- """Free all the memory, be ready for a new initialization."""
- libghdl.options__finalize()
+ """Free all the memory, be ready for a new initialization."""
+ libghdl.options__finalize()
@export
def initialize() -> None:
- """Initialize or re-initialize the shared library."""
- libghdl.options__initialize()
+ """Initialize or re-initialize the shared library."""
+ libghdl.options__initialize()
@export
-def set_option(opt: str) -> bool:
- """Set option :obj:`opt`. Return true, if the option is known and handled."""
- opt = opt.encode("utf-8")
- return libghdl.libghdl__set_option(c_char_p(opt), len(opt)) == 0
+def set_option(Opt: str) -> bool:
+ """
+ Set option :obj:`opt`.
+
+ :param Opt: Option to set.
+ :return: Return ``True``, if the option is known and handled.
+ """
+ Opt = Opt.encode("utf-8")
+ return libghdl.libghdl__set_option(c_char_p(Opt), len(Opt)) == 0
@export
def analyze_init() -> None:
- """
- Initialize the analyzer.
+ """
+ Initialize the analyzer.
- .. deprecated:: 1.0.0
- Deprecated as it may raise an exception. Use :func:`analyze_init_status`.
- """
- libghdl.libghdl__analyze_init()
+ .. deprecated:: 1.0.0
+ Deprecated as it may raise an exception. Use :func:`analyze_init_status`.
+ """
+ libghdl.libghdl__analyze_init()
@export
def analyze_init_status() -> int:
- """Initialize the analyzer. Returns 0 in case of success."""
- return libghdl.libghdl__analyze_init_status()
+ """
+ Initialize the analyzer.
+
+ :return: Returns 0 in case of success.
+ """
+ return libghdl.libghdl__analyze_init_status()
@export
def analyze_file(fname: str) -> Iir:
- """Analyze a given filename :obj:`fname`."""
- fname = fname.encode("utf-8")
- return libghdl.libghdl__analyze_file(c_char_p(fname), len(fname))
+ """
+ Analyze a given filename :obj:`fname`.
+
+ :param fname: File name
+ :return: Internal Intermediate Representation (IIR)
+ """
+ fname = fname.encode("utf-8")
+ return libghdl.libghdl__analyze_file(c_char_p(fname), len(fname))
@export
def disp_config() -> None:
- """Display the configured prefixes for libghdl."""
- libghdl.ghdllocal__disp_config_prefixes()
+ """Display the configured prefixes for libghdl."""
+ libghdl.ghdllocal__disp_config_prefixes()
diff --git a/pyGHDL/libghdl/files_map.py b/pyGHDL/libghdl/files_map.py
index 423cec480..ba937a776 100644
--- a/pyGHDL/libghdl/files_map.py
+++ b/pyGHDL/libghdl/files_map.py
@@ -242,9 +242,9 @@ def Discard_Source_File(File: SourceFileEntry) -> None:
"""
Mark :obj:`File` as unavailable: clear the name and directory.
- .. hint:: This is needed before creating a new source file with the same name.
+ .. hint:: This is needed before creating a new source file with the same name.
- :param File: Source file to discard.
+ :param File: Source file to discard.
"""
libghdl.files_map__discard_source_file(File)