diff options
author | Tristan Gingold <tgingold@free.fr> | 2016-07-06 04:46:25 +0200 |
---|---|---|
committer | Tristan Gingold <tgingold@free.fr> | 2016-07-07 19:26:44 +0200 |
commit | 6228aa37e86a693f85cdf97c9f5f0b333cab7c3a (patch) | |
tree | 9ba56394c663f6d729fc2e0ca343a618da6ce4cd | |
parent | e305214943ba24c32b4c4883447d14da0bbf9d02 (diff) | |
download | ghdl-6228aa37e86a693f85cdf97c9f5f0b333cab7c3a.tar.gz ghdl-6228aa37e86a693f85cdf97c9f5f0b333cab7c3a.tar.bz2 ghdl-6228aa37e86a693f85cdf97c9f5f0b333cab7c3a.zip |
disp_vhdl: support context declaration and reference
-rw-r--r-- | src/vhdl/disp_vhdl.adb | 46 |
1 files changed, 39 insertions, 7 deletions
diff --git a/src/vhdl/disp_vhdl.adb b/src/vhdl/disp_vhdl.adb index 63a03ddca..da272c5a9 100644 --- a/src/vhdl/disp_vhdl.adb +++ b/src/vhdl/disp_vhdl.adb @@ -173,6 +173,8 @@ package body Disp_Vhdl is when Iir_Kind_Component_Declaration | Iir_Kind_Entity_Declaration | Iir_Kind_Architecture_Body + | Iir_Kind_Configuration_Declaration + | Iir_Kind_Context_Declaration | Iir_Kind_Interface_Constant_Declaration | Iir_Kind_Interface_Signal_Declaration | Iir_Kind_Interface_Variable_Declaration @@ -181,7 +183,6 @@ package body Disp_Vhdl is | Iir_Kind_Signal_Declaration | Iir_Kind_Guard_Signal_Declaration | Iir_Kind_Variable_Declaration - | Iir_Kind_Configuration_Declaration | Iir_Kind_Type_Declaration | Iir_Kind_File_Declaration | Iir_Kind_Subtype_Declaration @@ -3313,8 +3314,7 @@ package body Disp_Vhdl is end Disp_Block_Configuration; procedure Disp_Configuration_Declaration - (Decl: Iir_Configuration_Declaration) - is + (Decl: Iir_Configuration_Declaration) is begin Put ("configuration "); Disp_Name_Of (Decl); @@ -3327,13 +3327,12 @@ package body Disp_Vhdl is Disp_End (Decl, "configuration"); end Disp_Configuration_Declaration; - procedure Disp_Design_Unit (Unit: Iir_Design_Unit) + procedure Disp_Context_Items (First : Iir; Indent : Count) is - Indent: constant Count := Col; Decl: Iir; Next_Decl : Iir; begin - Decl := Get_Context_Items (Unit); + Decl := First; while Decl /= Null_Iir loop Next_Decl := Get_Chain (Decl); @@ -3351,11 +3350,42 @@ package body Disp_Vhdl is Disp_Identifier (Decl); end loop; Put_Line (";"); + when Iir_Kind_Context_Reference => + Put ("context "); + declare + Ref : Iir; + begin + Ref := Decl; + loop + Disp_Name (Get_Selected_Name (Ref)); + Ref := Get_Context_Reference_Chain (Ref); + exit when Ref = Null_Iir; + Put (", "); + end loop; + Put_Line (";"); + end; when others => - Error_Kind ("disp_design_unit1", Decl); + Error_Kind ("disp_context_items", Decl); end case; Decl := Next_Decl; end loop; + end Disp_Context_Items; + + procedure Disp_Context_Declaration (Decl: Iir) is + begin + Put ("context "); + Disp_Name_Of (Decl); + Put_Line (" is"); + Disp_Context_Items (Get_Context_Items (Decl), Col + Indentation); + Disp_End (Decl, "context"); + end Disp_Context_Declaration; + + procedure Disp_Design_Unit (Unit: Iir_Design_Unit) + is + Indent: constant Count := Col; + Decl: Iir; + begin + Disp_Context_Items (Get_Context_Items (Unit), Indent); Decl := Get_Library_Unit (Unit); Set_Col (Indent); @@ -3372,6 +3402,8 @@ package body Disp_Vhdl is Disp_Package_Instantiation_Declaration (Decl); when Iir_Kind_Configuration_Declaration => Disp_Configuration_Declaration (Decl); + when Iir_Kind_Context_Declaration => + Disp_Context_Declaration (Decl); when others => Error_Kind ("disp_design_unit2", Decl); end case; |