-- Common operations on nodes. -- Copyright (C) 2002, 2003, 2004, 2005 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. with Types; use Types; with Iirs; use Iirs; package Iirs_Utils is -- Transform the current token into an iir literal. -- The current token must be either a character, a string or an identifier. function Current_Text return Iir; -- Get identifier of NODE as a string. function Image_Identifier (Node : Iir) return String; function Image_String_Lit (Str : Iir) return String; -- Return True iff N is an error node. function Is_Error (N : Iir) return Boolean; pragma Inline (Is_Error); -- Find LIT in the list of identifiers or characters LIST. -- Return the literal (whose name is LIT) or null_iir if not found. function Find_Name_In_Chain (Chain: Iir; Lit: Name_Id) return Iir; function Find_Name_In_List (List : Iir_List; Lit: Name_Id) return Iir; -- Return TRUE if EL in an element of chain CHAIN. function Is_In_Chain (Chain : Iir; El : Iir) return Boolean; -- Convert an operator node to a name. function Get_Operator_Name (Op : Iir) return Name_Id; -- Get the longuest static prefix of EXPR. -- See LRM §8.1 function Get_Longuest_Static_Prefix (Expr: Iir) return Iir; -- Get the prefix of NAME, ie the declaration at the base of NAME. -- Return NAME itself if NAME is not an object or a subelement of -- an object. If WITH_ALIAS is true, continue with the alias name when an -- alias is found, else return the alias. -- FIXME: clarify when NAME is returned. function Get_Object_Prefix (Name: Iir; With_Alias : Boolean := True) return Iir; -- Get the interface associated by the association ASSOC. This is always -- an interface, even if the formal is a name. function Get_Association_Interface (Assoc : Iir) return Iir; -- Duplicate enumeration literal LIT. function Copy_Enumeration_Literal (Lit : Iir) return Iir; -- Make TARGETS depends on UNIT. -- UNIT must be either a design unit or a entity_aspect_entity. procedure Add_Dependence (Target: Iir_Design_Unit; Unit: Iir); -- Clear configuration field of all component instantiation of -- the concurrent statements of PARENT. procedure Clear_Instantiation_Configuration (Parent : Iir; Full : Boolean); -- Free Node and its prefixes, if any. procedure Free_Name (Node : Iir); -- Free NODE and its sub-nodes. procedure Free_Recursive (Node : Iir; Free_List : Boolean := False); -- Name of FUNC. function Get_Predefined_Function_Name (Func : Iir_Predefined_Functions) return String; -- Mark SUBPRG as used. If SUBPRG is an instance, its generic is also -- marked. procedure Mark_Subprogram_Used (Subprg : Iir); -- Create the range_constraint node for an enumeration type. procedure Create_Range_Constraint_For_Enumeration_Type (Def : Iir_Enumeration_Type_Definition); -- Return the node containing the Callees_List (ie the subprogram body if -- SUBPRG is a subprogram spec, SUBPRG if SUBPRG is a process). function Get_Callees_List_Holder (Subprg : Iir) return Iir; -- Clear flag of TOP and all of its callees. procedure Clear_Seen_Flag (Top : Iir); -- Return TRUE iff DEF is an anonymous type (or subtype) definition. -- Note: DEF is required to be a type (or subtype) definition. -- Note: type (and not subtype) are never anonymous. function Is_Anonymous_Type_Definition (Def : Iir) return Boolean; pragma Inline (Is_Anonymous_Type_Definition); -- Return TRUE iff DEF is a fully constrained type (or subtype) definition. function Is_Fully_Constrained_Type (Def : Iir) return Boolean; -- Return the type definition/subtype indication of NAME if NAME denotes -- a type or subtype name. Otherwise, return Null_Iir; function Is_Type_Name (Name : Iir) return Iir; -- Return TRUE iff SPEC is the subprogram specification of a subprogram -- body which was previously declared. In that case, the only use of SPEC -- is to match the body with its declaration. function Is_Second_Subprogram_Specification (Spec : Iir) return Boolean; -- Return True iif SPEC is the specification of an implicit subprogram. -- False for explicit subprograms. function Is_Implicit_Subprogram (Spec : Iir) return Boolean; pragma Inline (Is_Implicit_Subprogram); -- If NAME is a simple or an expanded name, return the denoted declaration. -- Otherwise, return NAME. function Strip_Denoting_Name (Name : Iir) return Iir; -- Build a simple name node whose named entity is REF and location LOC. function Build_Simple_Name (Ref : Iir; Loc : Location_Type) return Iir; function Build_Simple_Name (Ref : Iir; Loc : Iir) return Iir; -- If SUBTYP has a resolution indication that is a function name, returns -- the function declaration (not the name). function Has_Resolution_Function (Subtyp : Iir) return Iir; -- Return a simple name for the primary unit of physical type PHYSICAL_DEF. -- This is the artificial unit name for the value of the primary unit, thus -- its location is the location of the primary unit. Used mainly to build -- evaluated literals. function Get_Primary_Unit_Name (Physical_Def : Iir) return Iir; -- Get the type of any node representing a subtype indication. This simply -- skip over denoting names. function Get_Type_Of_Subtype_Indication (Ind : Iir) return Iir; -- Get the type of an index_subtype_definition or of a discrete_range from -- an index_constraint. function Get_Index_Type (Index_Type : Iir) return Iir renames Get_Type_Of_Subtype_Indication; -- Return the IDX-th index type for index subtype definition list or -- index_constraint INDEXES. Return Null_Iir if IDX is out of dimension -- bounds, so that this function can be used to iterator over indexes of -- a type (or subtype). Note that IDX starts at 0. function Get_Index_Type (Indexes : Iir_List; Idx : Natural) return Iir; -- Likewise but for array type or subtype ARRAY_TYPE. function Get_Index_Type (Array_Type : Iir; Idx : Natural) return Iir; -- Return the type or subtype definition of the SUBTYP type mark. function Get_Denoted_Type_Mark (Subtyp : Iir) return Iir; -- Return true iff L and R have the same profile. -- L and R must be subprograms specification (or spec_body). function Is_Same_Profile (L, R: Iir) return Boolean; -- From a block_specification, returns the block. -- Roughly speaking, this get prefix of indexed and sliced name. function Get_Block_From_Block_Specification (Block_Spec : Iir) return Iir; -- Wrapper around Get_Entity_Name: return the entity declaration of the -- entity name of DECL. function Get_Entity (Decl : Iir) return Iir; -- Wrapper around get_Configuration_Name: return the configuration -- declaration of ASPECT. function Get_Configuration (Aspect : Iir) return Iir; -- Return the identifier of the entity for architecture ARCH. function Get_Entity_Identifier_Of_Architecture (Arch : Iir) return Name_Id; -- Return True is component instantiation statement INST instantiate a -- component. function Is_Component_Instantiation (Inst : Iir_Component_Instantiation_Statement) return Boolean; -- Return True is component instantiation statement INST instantiate a -- design entity. function Is_Entity_Instantiation (Inst : Iir_Component_Instantiation_Statement) return Boolean; -- Return the bound type of a string type, ie the type of the (first) -- dimension of a one-dimensional array type. function Get_String_Type_Bound_Type (Sub_Type : Iir) return Iir; -- Return left or right limit according to the direction. procedure Get_Low_High_Limit (Arange : Iir_Range_Expression; Low, High : out Iir); function Get_Low_Limit (Arange : Iir_Range_Expression) return Iir; function Get_High_Limit (Arange : Iir_Range_Expression) return Iir; -- Return TRUE iff type/subtype definition A_TYPE is an undim array. function Is_One_Dimensional_Array_Type (A_Type : Iir) return Boolean; -- Return TRUE iff unsemantized EXPR is a range attribute. function Is_Range_Attribute_Name (Expr : Iir) return Boolean; -- Create an array subtype from array_type or array_subtype ARR_TYPE. -- All fields of the returned node are filled, except the index_list. -- The type_staticness is set with the type staticness of the element -- subtype and therefore must be updated. -- The type_declarator field is set to null_iir. function Create_Array_Subtype (Arr_Type : Iir; Loc : Location_Type) return Iir_Array_Subtype_Definition; -- Return TRUE iff SPEC is declared inside a protected type or a protected -- body. function Is_Subprogram_Method (Spec : Iir) return Boolean; -- Return the protected type for method SPEC. function Get_Method_Type (Spec : Iir) return Iir; -- Create an error node for node ORIG, and set its type to ATYPE. -- Set its staticness to locally. function Create_Error_Expr (Orig : Iir; Atype : Iir) return Iir; -- Create an error node for node ORIG, which is supposed to be a type. function Create_Error_Type (Orig : Iir) return Iir; -- Extract the entity from ASPECT. -- Note: if ASPECT is a component declaration, returns ASPECT. -- if ASPECT is open, return Null_Iir; function Get_Entity_From_Entity_Aspect (Aspect : Iir) return Iir; -- Definitions from LRM08 4.7 Package declarations. -- PKG must denote a package declaration. function Is_Simple_Package (Pkg : Iir) return Boolean; function Is_Uninstantiated_Package (Pkg : Iir) return Boolean; function Is_Generic_Mapped_Package (Pkg : Iir) return Boolean; -- Return TRUE if the base name of NAME is a signal object. function Is_Signal_Object (Name: Iir) return Boolean; -- Return True IFF kind of N is K1 or K2. function Kind_In (N : Iir; K1, K2 : Iir_Kind) return Boolean; pragma Inline (Kind_In); -- IIR wrapper around Get_HDL_Node/Set_HDL_Node. function Get_HDL_Node (N : PSL_Node) return Iir; procedure Set_HDL_Node (N : PSL_Node; Expr : Iir); end Iirs_Utils;