diff options
Diffstat (limited to 'src/vhdl/vhdl-elocations_meta.adb')
-rw-r--r-- | src/vhdl/vhdl-elocations_meta.adb | 405 |
1 files changed, 405 insertions, 0 deletions
diff --git a/src/vhdl/vhdl-elocations_meta.adb b/src/vhdl/vhdl-elocations_meta.adb new file mode 100644 index 000000000..0b993f62c --- /dev/null +++ b/src/vhdl/vhdl-elocations_meta.adb @@ -0,0 +1,405 @@ +-- Meta description of Elocations. +-- Copyright (C) 2017 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 Vhdl.Elocations; use Vhdl.Elocations; + +package body Vhdl.Elocations_Meta is + function Get_Field_Image (F : Fields_Enum) return String is + begin + case F is + when Field_Start_Location => + return "start_location"; + when Field_Right_Paren_Location => + return "right_paren_location"; + when Field_End_Location => + return "end_location"; + when Field_Is_Location => + return "is_location"; + when Field_Begin_Location => + return "begin_location"; + when Field_Then_Location => + return "then_location"; + when Field_Loop_Location => + return "loop_location"; + when Field_Generate_Location => + return "generate_location"; + when Field_Generic_Location => + return "generic_location"; + when Field_Port_Location => + return "port_location"; + when Field_Generic_Map_Location => + return "generic_map_location"; + when Field_Port_Map_Location => + return "port_map_location"; + when Field_Arrow_Location => + return "arrow_location"; + when Field_Colon_Location => + return "colon_location"; + when Field_Assign_Location => + return "assign_location"; + end case; + end Get_Field_Image; + + type Field_Type is (Type_Location_Type); + + function Fields_Type (F : Fields_Enum) return Field_Type + is + pragma Unreferenced (F); + begin + return Type_Location_Type; + end Fields_Type; + + pragma Warnings (Off, """others"" choice is redundant"); + + function Get_Location_Type + (N : Iir; F : Fields_Enum) return Location_Type is + begin + pragma Assert (Fields_Type (F) = Type_Location_Type); + case F is + when Field_Start_Location => + return Get_Start_Location (N); + when Field_Right_Paren_Location => + return Get_Right_Paren_Location (N); + when Field_End_Location => + return Get_End_Location (N); + when Field_Is_Location => + return Get_Is_Location (N); + when Field_Begin_Location => + return Get_Begin_Location (N); + when Field_Then_Location => + return Get_Then_Location (N); + when Field_Loop_Location => + return Get_Loop_Location (N); + when Field_Generate_Location => + return Get_Generate_Location (N); + when Field_Generic_Location => + return Get_Generic_Location (N); + when Field_Port_Location => + return Get_Port_Location (N); + when Field_Generic_Map_Location => + return Get_Generic_Map_Location (N); + when Field_Port_Map_Location => + return Get_Port_Map_Location (N); + when Field_Arrow_Location => + return Get_Arrow_Location (N); + when Field_Colon_Location => + return Get_Colon_Location (N); + when Field_Assign_Location => + return Get_Assign_Location (N); + when others => + raise Internal_Error; + end case; + end Get_Location_Type; + + procedure Set_Location_Type + (N : Iir; F : Fields_Enum; V: Location_Type) is + begin + pragma Assert (Fields_Type (F) = Type_Location_Type); + case F is + when Field_Start_Location => + Set_Start_Location (N, V); + when Field_Right_Paren_Location => + Set_Right_Paren_Location (N, V); + when Field_End_Location => + Set_End_Location (N, V); + when Field_Is_Location => + Set_Is_Location (N, V); + when Field_Begin_Location => + Set_Begin_Location (N, V); + when Field_Then_Location => + Set_Then_Location (N, V); + when Field_Loop_Location => + Set_Loop_Location (N, V); + when Field_Generate_Location => + Set_Generate_Location (N, V); + when Field_Generic_Location => + Set_Generic_Location (N, V); + when Field_Port_Location => + Set_Port_Location (N, V); + when Field_Generic_Map_Location => + Set_Generic_Map_Location (N, V); + when Field_Port_Map_Location => + Set_Port_Map_Location (N, V); + when Field_Arrow_Location => + Set_Arrow_Location (N, V); + when Field_Colon_Location => + Set_Colon_Location (N, V); + when Field_Assign_Location => + Set_Assign_Location (N, V); + when others => + raise Internal_Error; + end case; + end Set_Location_Type; + + function Has_Start_Location (K : Iir_Kind) return Boolean is + begin + case K is + when Iir_Kind_Library_Clause + | Iir_Kind_Attribute_Specification + | Iir_Kind_Protected_Type_Declaration + | Iir_Kind_Protected_Type_Body + | Iir_Kind_Type_Declaration + | Iir_Kind_Anonymous_Type_Declaration + | Iir_Kind_Subtype_Declaration + | Iir_Kind_Entity_Declaration + | Iir_Kind_Configuration_Declaration + | Iir_Kind_Context_Declaration + | Iir_Kind_Package_Declaration + | Iir_Kind_Package_Instantiation_Declaration + | Iir_Kind_Package_Body + | Iir_Kind_Architecture_Body + | Iir_Kind_Component_Declaration + | Iir_Kind_Attribute_Declaration + | Iir_Kind_Group_Template_Declaration + | Iir_Kind_Group_Declaration + | Iir_Kind_Function_Declaration + | Iir_Kind_Procedure_Declaration + | Iir_Kind_Function_Body + | Iir_Kind_Procedure_Body + | Iir_Kind_Object_Alias_Declaration + | Iir_Kind_File_Declaration + | Iir_Kind_Signal_Declaration + | Iir_Kind_Variable_Declaration + | Iir_Kind_Constant_Declaration + | Iir_Kind_Iterator_Declaration + | Iir_Kind_Interface_Constant_Declaration + | Iir_Kind_Interface_Variable_Declaration + | Iir_Kind_Interface_Signal_Declaration + | Iir_Kind_Interface_File_Declaration + | Iir_Kind_Interface_Type_Declaration + | Iir_Kind_Interface_Package_Declaration + | Iir_Kind_Sensitized_Process_Statement + | Iir_Kind_Process_Statement + | Iir_Kind_Concurrent_Simple_Signal_Assignment + | Iir_Kind_Concurrent_Conditional_Signal_Assignment + | Iir_Kind_Concurrent_Selected_Signal_Assignment + | Iir_Kind_If_Generate_Statement + | Iir_Kind_For_Generate_Statement + | Iir_Kind_Generate_Statement_Body + | Iir_Kind_If_Generate_Else_Clause + | Iir_Kind_For_Loop_Statement + | Iir_Kind_While_Loop_Statement + | Iir_Kind_If_Statement + | Iir_Kind_Elsif => + return True; + when others => + return False; + end case; + end Has_Start_Location; + + function Has_Right_Paren_Location (K : Iir_Kind) return Boolean is + begin + return K = Iir_Kind_Parenthesis_Expression; + end Has_Right_Paren_Location; + + function Has_End_Location (K : Iir_Kind) return Boolean is + begin + case K is + when Iir_Kind_Protected_Type_Declaration + | Iir_Kind_Record_Type_Definition + | Iir_Kind_Protected_Type_Body + | Iir_Kind_Entity_Declaration + | Iir_Kind_Configuration_Declaration + | Iir_Kind_Context_Declaration + | Iir_Kind_Package_Declaration + | Iir_Kind_Package_Instantiation_Declaration + | Iir_Kind_Package_Body + | Iir_Kind_Architecture_Body + | Iir_Kind_Component_Declaration + | Iir_Kind_Function_Body + | Iir_Kind_Procedure_Body + | Iir_Kind_Sensitized_Process_Statement + | Iir_Kind_Process_Statement + | Iir_Kind_Block_Statement + | Iir_Kind_If_Generate_Statement + | Iir_Kind_For_Generate_Statement + | Iir_Kind_Generate_Statement_Body + | Iir_Kind_If_Generate_Else_Clause + | Iir_Kind_For_Loop_Statement + | Iir_Kind_While_Loop_Statement + | Iir_Kind_Case_Statement + | Iir_Kind_If_Statement + | Iir_Kind_Elsif => + return True; + when others => + return False; + end case; + end Has_End_Location; + + function Has_Is_Location (K : Iir_Kind) return Boolean is + begin + case K is + when Iir_Kind_Type_Declaration + | Iir_Kind_Subtype_Declaration + | Iir_Kind_Entity_Declaration + | Iir_Kind_Architecture_Body + | Iir_Kind_Function_Body + | Iir_Kind_Procedure_Body + | Iir_Kind_Sensitized_Process_Statement + | Iir_Kind_Process_Statement + | Iir_Kind_Block_Statement => + return True; + when others => + return False; + end case; + end Has_Is_Location; + + function Has_Begin_Location (K : Iir_Kind) return Boolean is + begin + case K is + when Iir_Kind_Entity_Declaration + | Iir_Kind_Architecture_Body + | Iir_Kind_Function_Body + | Iir_Kind_Procedure_Body + | Iir_Kind_Sensitized_Process_Statement + | Iir_Kind_Process_Statement + | Iir_Kind_Block_Statement + | Iir_Kind_Generate_Statement_Body => + return True; + when others => + return False; + end case; + end Has_Begin_Location; + + function Has_Then_Location (K : Iir_Kind) return Boolean is + begin + case K is + when Iir_Kind_If_Statement + | Iir_Kind_Elsif => + return True; + when others => + return False; + end case; + end Has_Then_Location; + + function Has_Loop_Location (K : Iir_Kind) return Boolean is + begin + case K is + when Iir_Kind_For_Loop_Statement + | Iir_Kind_While_Loop_Statement => + return True; + when others => + return False; + end case; + end Has_Loop_Location; + + function Has_Generate_Location (K : Iir_Kind) return Boolean is + begin + case K is + when Iir_Kind_If_Generate_Statement + | Iir_Kind_For_Generate_Statement + | Iir_Kind_If_Generate_Else_Clause => + return True; + when others => + return False; + end case; + end Has_Generate_Location; + + function Has_Generic_Location (K : Iir_Kind) return Boolean is + begin + case K is + when Iir_Kind_Block_Header + | Iir_Kind_Entity_Declaration + | Iir_Kind_Package_Header + | Iir_Kind_Component_Declaration => + return True; + when others => + return False; + end case; + end Has_Generic_Location; + + function Has_Port_Location (K : Iir_Kind) return Boolean is + begin + case K is + when Iir_Kind_Block_Header + | Iir_Kind_Entity_Declaration + | Iir_Kind_Component_Declaration => + return True; + when others => + return False; + end case; + end Has_Port_Location; + + function Has_Generic_Map_Location (K : Iir_Kind) return Boolean is + begin + case K is + when Iir_Kind_Block_Header + | Iir_Kind_Package_Instantiation_Declaration + | Iir_Kind_Package_Header + | Iir_Kind_Component_Instantiation_Statement => + return True; + when others => + return False; + end case; + end Has_Generic_Map_Location; + + function Has_Port_Map_Location (K : Iir_Kind) return Boolean is + begin + case K is + when Iir_Kind_Block_Header + | Iir_Kind_Component_Instantiation_Statement => + return True; + when others => + return False; + end case; + end Has_Port_Map_Location; + + function Has_Arrow_Location (K : Iir_Kind) return Boolean is + begin + case K is + when Iir_Kind_Association_Element_By_Expression + | Iir_Kind_Association_Element_By_Individual + | Iir_Kind_Association_Element_Open + | Iir_Kind_Association_Element_Package + | Iir_Kind_Association_Element_Type + | Iir_Kind_Association_Element_Subprogram => + return True; + when others => + return False; + end case; + end Has_Arrow_Location; + + function Has_Colon_Location (K : Iir_Kind) return Boolean is + begin + case K is + when Iir_Kind_Interface_Constant_Declaration + | Iir_Kind_Interface_Variable_Declaration + | Iir_Kind_Interface_Signal_Declaration + | Iir_Kind_Interface_File_Declaration => + return True; + when others => + return False; + end case; + end Has_Colon_Location; + + function Has_Assign_Location (K : Iir_Kind) return Boolean is + begin + case K is + when Iir_Kind_Interface_Constant_Declaration + | Iir_Kind_Interface_Variable_Declaration + | Iir_Kind_Interface_Signal_Declaration + | Iir_Kind_Interface_File_Declaration => + return True; + when others => + return False; + end case; + end Has_Assign_Location; + + + pragma Warnings (On, """others"" choice is redundant"); +end Vhdl.Elocations_Meta; |