# ============================================================================= # ____ _ _ ____ _ _ _ _ _ _ _ # _ __ _ _ / ___| | | | _ \| | | (_) |__ __ _| |__ __| | | # | '_ \| | | | | _| |_| | | | | | | | | '_ \ / _` | '_ \ / _` | | # | |_) | |_| | |_| | _ | |_| | |___ _| | | |_) | (_| | | | | (_| | | # | .__/ \__, |\____|_| |_|____/|_____(_)_|_|_.__/ \__, |_| |_|\__,_|_| # |_| |___/ |___/ # ============================================================================= # Authors: Tristan Gingold # Patrick Lehmann # # Package package: Python binding and low-level API for shared library 'libghdl'. # # License: # ============================================================================ # Copyright (C) 2019-2021 Tristan Gingold # # GHDL is free software; you can redistribute it and/or modify it under # the terms of the GNU General Public License as published by the Free # Software Foundation; either version 2, or (at your option) any later # version. # # GHDL is distributed in the hope that it will be useful, but WITHOUT ANY # WARRANTY; without even the implied warranty of MERCHANTABILITY or # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License # for more details. # # You should have received a copy of the GNU General Public License # along with GHDL; see the file COPYING. If not, write to the Free # Software Foundation, 59 Temple Place - Suite 330, Boston, MA # 02111-1307, USA. # # SPDX-License-Identifier: GPL-2.0-or-later # ============================================================================ # from ctypes import c_char_p from pydecor import export from pyGHDL.libghdl import libghdl from pyGHDL.libghdl._types import NameId __all__ = [ 'Null_Identifier' ] Null_Identifier = 0 @export def Get_Name_Length(Id: NameId) -> int: """ Get the length of an identifier denoted by a ``NameId``. :param Id: NameId for the identifier to query. :return: Length of the identifier. """ return libghdl.name_table__get_name_length(Id) @export def Get_Name_Ptr(Id: NameId) -> str: """ Get the address of the first character of ID. The address is valid until the next call to Get_Identifier (which may reallocate the string table). The string is NUL-terminated (this is done by get_identifier). :param Id: NameId for the identifier to query. :return: """ func = libghdl.name_table__get_name_ptr func.restype = c_char_p return func(Id).decode("utf-8") @export def Get_Identifier(string: str) -> NameId: """ Get or create an entry in the name table. .. note:: * an identifier is represented in all lower case letter, * an extended identifier is represented in backslashes, double internal backslashes are simplified. :param string: String to create or lookup. :return: Id in name table. """ string = string.encode("utf-8") return libghdl.name_table__get_identifier_with_len(c_char_p(string), len(string))