diff options
-rw-r--r-- | python/libghdl/thin/vhdl/nodes.py | 4 | ||||
-rw-r--r-- | python/libghdl/thin/vhdl/nodes_meta.py | 540 | ||||
-rw-r--r-- | src/vhdl/vhdl-nodes.adb | 16 | ||||
-rw-r--r-- | src/vhdl/vhdl-nodes.ads | 7 | ||||
-rw-r--r-- | src/vhdl/vhdl-nodes_meta.adb | 522 | ||||
-rw-r--r-- | src/vhdl/vhdl-nodes_meta.ads | 2 | ||||
-rw-r--r-- | src/vhdl/vhdl-sem_expr.adb | 4 |
7 files changed, 515 insertions, 580 deletions
diff --git a/python/libghdl/thin/vhdl/nodes.py b/python/libghdl/thin/vhdl/nodes.py index 05782b97f..5983c4972 100644 --- a/python/libghdl/thin/vhdl/nodes.py +++ b/python/libghdl/thin/vhdl/nodes.py @@ -1371,10 +1371,6 @@ Get_Time = libghdl.vhdl__nodes__get_time Set_Time = libghdl.vhdl__nodes__set_time -Get_Choice_Order = libghdl.vhdl__nodes__get_choice_order - -Set_Choice_Order = libghdl.vhdl__nodes__set_choice_order - Get_Associated_Expr = libghdl.vhdl__nodes__get_associated_expr Set_Associated_Expr = libghdl.vhdl__nodes__set_associated_expr diff --git a/python/libghdl/thin/vhdl/nodes_meta.py b/python/libghdl/thin/vhdl/nodes_meta.py index 8d717732e..97a8cab8b 100644 --- a/python/libghdl/thin/vhdl/nodes_meta.py +++ b/python/libghdl/thin/vhdl/nodes_meta.py @@ -119,275 +119,274 @@ class fields: After_Drivers_Flag = 55 We_Value = 56 Time = 57 - Choice_Order = 58 - Associated_Expr = 59 - Associated_Block = 60 - Associated_Chain = 61 - Choice_Name = 62 - Choice_Expression = 63 - Choice_Range = 64 - Same_Alternative_Flag = 65 - Element_Type_Flag = 66 - Architecture = 67 - Block_Specification = 68 - Prev_Block_Configuration = 69 - Configuration_Item_Chain = 70 - Attribute_Value_Chain = 71 - Spec_Chain = 72 - Value_Chain = 73 - Attribute_Value_Spec_Chain = 74 - Entity_Name = 75 - Package = 76 - Package_Body = 77 - Instance_Package_Body = 78 - Need_Body = 79 - Macro_Expanded_Flag = 80 - Need_Instance_Bodies = 81 - Block_Configuration = 82 - Concurrent_Statement_Chain = 83 - Chain = 84 - Port_Chain = 85 - Generic_Chain = 86 - Type = 87 - Subtype_Indication = 88 - Discrete_Range = 89 - Type_Definition = 90 - Subtype_Definition = 91 - Incomplete_Type_Declaration = 92 - Interface_Type_Subprograms = 93 - Nature = 94 - Mode = 95 - Guarded_Signal_Flag = 96 - Signal_Kind = 97 - Base_Name = 98 - Interface_Declaration_Chain = 99 - Subprogram_Specification = 100 - Sequential_Statement_Chain = 101 - Subprogram_Body = 102 - Overload_Number = 103 - Subprogram_Depth = 104 - Subprogram_Hash = 105 - Impure_Depth = 106 - Return_Type = 107 - Implicit_Definition = 108 - Default_Value = 109 - Deferred_Declaration = 110 - Deferred_Declaration_Flag = 111 - Shared_Flag = 112 - Design_Unit = 113 - Block_Statement = 114 - Signal_Driver = 115 - Declaration_Chain = 116 - File_Logical_Name = 117 - File_Open_Kind = 118 - Element_Position = 119 - Use_Clause_Chain = 120 - Context_Reference_Chain = 121 - Selected_Name = 122 - Type_Declarator = 123 - Complete_Type_Definition = 124 - Incomplete_Type_Ref_Chain = 125 - Associated_Type = 126 - Enumeration_Literal_List = 127 - Entity_Class_Entry_Chain = 128 - Group_Constituent_List = 129 - Unit_Chain = 130 - Primary_Unit = 131 - Identifier = 132 - Label = 133 - Visible_Flag = 134 - Range_Constraint = 135 - Direction = 136 - Left_Limit = 137 - Right_Limit = 138 - Left_Limit_Expr = 139 - Right_Limit_Expr = 140 - Base_Type = 141 - Resolution_Indication = 142 - Record_Element_Resolution_Chain = 143 - Tolerance = 144 - Plus_Terminal = 145 - Minus_Terminal = 146 - Simultaneous_Left = 147 - Simultaneous_Right = 148 - Text_File_Flag = 149 - Only_Characters_Flag = 150 - Is_Character_Type = 151 - Type_Staticness = 152 - Constraint_State = 153 - Index_Subtype_List = 154 - Index_Subtype_Definition_List = 155 - Element_Subtype_Indication = 156 - Element_Subtype = 157 - Index_Constraint_List = 158 - Array_Element_Constraint = 159 - Elements_Declaration_List = 160 - Owned_Elements_Chain = 161 - Designated_Type = 162 - Designated_Subtype_Indication = 163 - Index_List = 164 - Reference = 165 - Nature_Declarator = 166 - Across_Type = 167 - Through_Type = 168 - Target = 169 - Waveform_Chain = 170 - Guard = 171 - Delay_Mechanism = 172 - Reject_Time_Expression = 173 - Sensitivity_List = 174 - Process_Origin = 175 - Package_Origin = 176 - Condition_Clause = 177 - Timeout_Clause = 178 - Postponed_Flag = 179 - Callees_List = 180 - Passive_Flag = 181 - Resolution_Function_Flag = 182 - Wait_State = 183 - All_Sensitized_State = 184 - Seen_Flag = 185 - Pure_Flag = 186 - Foreign_Flag = 187 - Resolved_Flag = 188 - Signal_Type_Flag = 189 - Has_Signal_Flag = 190 - Purity_State = 191 - Elab_Flag = 192 - Configuration_Mark_Flag = 193 - Configuration_Done_Flag = 194 - Index_Constraint_Flag = 195 - Hide_Implicit_Flag = 196 - Assertion_Condition = 197 - Report_Expression = 198 - Severity_Expression = 199 - Instantiated_Unit = 200 - Generic_Map_Aspect_Chain = 201 - Port_Map_Aspect_Chain = 202 - Configuration_Name = 203 - Component_Configuration = 204 - Configuration_Specification = 205 - Default_Binding_Indication = 206 - Default_Configuration_Declaration = 207 - Expression = 208 - Conditional_Expression = 209 - Allocator_Designated_Type = 210 - Selected_Waveform_Chain = 211 - Conditional_Waveform_Chain = 212 - Guard_Expression = 213 - Guard_Decl = 214 - Guard_Sensitivity_List = 215 - Signal_Attribute_Chain = 216 - Block_Block_Configuration = 217 - Package_Header = 218 - Block_Header = 219 - Uninstantiated_Package_Name = 220 - Uninstantiated_Package_Decl = 221 - Instance_Source_File = 222 - Generate_Block_Configuration = 223 - Generate_Statement_Body = 224 - Alternative_Label = 225 - Generate_Else_Clause = 226 - Condition = 227 - Else_Clause = 228 - Parameter_Specification = 229 - Parent = 230 - Loop_Label = 231 - Component_Name = 232 - Instantiation_List = 233 - Entity_Aspect = 234 - Default_Entity_Aspect = 235 - Binding_Indication = 236 - Named_Entity = 237 - Alias_Declaration = 238 - Referenced_Name = 239 - Expr_Staticness = 240 - Error_Origin = 241 - Operand = 242 - Left = 243 - Right = 244 - Unit_Name = 245 - Name = 246 - Group_Template_Name = 247 - Name_Staticness = 248 - Prefix = 249 - Signature_Prefix = 250 - External_Pathname = 251 - Pathname_Suffix = 252 - Pathname_Expression = 253 - In_Formal_Flag = 254 - Slice_Subtype = 255 - Suffix = 256 - Index_Subtype = 257 - Parameter = 258 - Attr_Chain = 259 - Signal_Attribute_Declaration = 260 - Actual_Type = 261 - Actual_Type_Definition = 262 - Association_Chain = 263 - Individual_Association_Chain = 264 - Subprogram_Association_Chain = 265 - Aggregate_Info = 266 - Sub_Aggregate_Info = 267 - Aggr_Dynamic_Flag = 268 - Aggr_Min_Length = 269 - Aggr_Low_Limit = 270 - Aggr_High_Limit = 271 - Aggr_Others_Flag = 272 - Aggr_Named_Flag = 273 - Aggregate_Expand_Flag = 274 - Association_Choices_Chain = 275 - Case_Statement_Alternative_Chain = 276 - Choice_Staticness = 277 - Procedure_Call = 278 - Implementation = 279 - Parameter_Association_Chain = 280 - Method_Object = 281 - Subtype_Type_Mark = 282 - Type_Conversion_Subtype = 283 - Type_Mark = 284 - File_Type_Mark = 285 - Return_Type_Mark = 286 - Has_Disconnect_Flag = 287 - Has_Active_Flag = 288 - Is_Within_Flag = 289 - Type_Marks_List = 290 - Implicit_Alias_Flag = 291 - Alias_Signature = 292 - Attribute_Signature = 293 - Overload_List = 294 - Simple_Name_Identifier = 295 - Simple_Name_Subtype = 296 - Protected_Type_Body = 297 - Protected_Type_Declaration = 298 - Use_Flag = 299 - End_Has_Reserved_Id = 300 - End_Has_Identifier = 301 - End_Has_Postponed = 302 - Has_Label = 303 - Has_Begin = 304 - Has_End = 305 - Has_Is = 306 - Has_Pure = 307 - Has_Body = 308 - Has_Parameter = 309 - Has_Component = 310 - Has_Identifier_List = 311 - Has_Mode = 312 - Has_Class = 313 - Suspend_Flag = 314 - Is_Ref = 315 - Is_Forward_Ref = 316 - Psl_Property = 317 - Psl_Sequence = 318 - Psl_Declaration = 319 - Psl_Expression = 320 - Psl_Boolean = 321 - PSL_Clock = 322 - PSL_NFA = 323 - PSL_Nbr_States = 324 - PSL_Clock_Sensitivity = 325 - PSL_EOS_Flag = 326 + Associated_Expr = 58 + Associated_Block = 59 + Associated_Chain = 60 + Choice_Name = 61 + Choice_Expression = 62 + Choice_Range = 63 + Same_Alternative_Flag = 64 + Element_Type_Flag = 65 + Architecture = 66 + Block_Specification = 67 + Prev_Block_Configuration = 68 + Configuration_Item_Chain = 69 + Attribute_Value_Chain = 70 + Spec_Chain = 71 + Value_Chain = 72 + Attribute_Value_Spec_Chain = 73 + Entity_Name = 74 + Package = 75 + Package_Body = 76 + Instance_Package_Body = 77 + Need_Body = 78 + Macro_Expanded_Flag = 79 + Need_Instance_Bodies = 80 + Block_Configuration = 81 + Concurrent_Statement_Chain = 82 + Chain = 83 + Port_Chain = 84 + Generic_Chain = 85 + Type = 86 + Subtype_Indication = 87 + Discrete_Range = 88 + Type_Definition = 89 + Subtype_Definition = 90 + Incomplete_Type_Declaration = 91 + Interface_Type_Subprograms = 92 + Nature = 93 + Mode = 94 + Guarded_Signal_Flag = 95 + Signal_Kind = 96 + Base_Name = 97 + Interface_Declaration_Chain = 98 + Subprogram_Specification = 99 + Sequential_Statement_Chain = 100 + Subprogram_Body = 101 + Overload_Number = 102 + Subprogram_Depth = 103 + Subprogram_Hash = 104 + Impure_Depth = 105 + Return_Type = 106 + Implicit_Definition = 107 + Default_Value = 108 + Deferred_Declaration = 109 + Deferred_Declaration_Flag = 110 + Shared_Flag = 111 + Design_Unit = 112 + Block_Statement = 113 + Signal_Driver = 114 + Declaration_Chain = 115 + File_Logical_Name = 116 + File_Open_Kind = 117 + Element_Position = 118 + Use_Clause_Chain = 119 + Context_Reference_Chain = 120 + Selected_Name = 121 + Type_Declarator = 122 + Complete_Type_Definition = 123 + Incomplete_Type_Ref_Chain = 124 + Associated_Type = 125 + Enumeration_Literal_List = 126 + Entity_Class_Entry_Chain = 127 + Group_Constituent_List = 128 + Unit_Chain = 129 + Primary_Unit = 130 + Identifier = 131 + Label = 132 + Visible_Flag = 133 + Range_Constraint = 134 + Direction = 135 + Left_Limit = 136 + Right_Limit = 137 + Left_Limit_Expr = 138 + Right_Limit_Expr = 139 + Base_Type = 140 + Resolution_Indication = 141 + Record_Element_Resolution_Chain = 142 + Tolerance = 143 + Plus_Terminal = 144 + Minus_Terminal = 145 + Simultaneous_Left = 146 + Simultaneous_Right = 147 + Text_File_Flag = 148 + Only_Characters_Flag = 149 + Is_Character_Type = 150 + Type_Staticness = 151 + Constraint_State = 152 + Index_Subtype_List = 153 + Index_Subtype_Definition_List = 154 + Element_Subtype_Indication = 155 + Element_Subtype = 156 + Index_Constraint_List = 157 + Array_Element_Constraint = 158 + Elements_Declaration_List = 159 + Owned_Elements_Chain = 160 + Designated_Type = 161 + Designated_Subtype_Indication = 162 + Index_List = 163 + Reference = 164 + Nature_Declarator = 165 + Across_Type = 166 + Through_Type = 167 + Target = 168 + Waveform_Chain = 169 + Guard = 170 + Delay_Mechanism = 171 + Reject_Time_Expression = 172 + Sensitivity_List = 173 + Process_Origin = 174 + Package_Origin = 175 + Condition_Clause = 176 + Timeout_Clause = 177 + Postponed_Flag = 178 + Callees_List = 179 + Passive_Flag = 180 + Resolution_Function_Flag = 181 + Wait_State = 182 + All_Sensitized_State = 183 + Seen_Flag = 184 + Pure_Flag = 185 + Foreign_Flag = 186 + Resolved_Flag = 187 + Signal_Type_Flag = 188 + Has_Signal_Flag = 189 + Purity_State = 190 + Elab_Flag = 191 + Configuration_Mark_Flag = 192 + Configuration_Done_Flag = 193 + Index_Constraint_Flag = 194 + Hide_Implicit_Flag = 195 + Assertion_Condition = 196 + Report_Expression = 197 + Severity_Expression = 198 + Instantiated_Unit = 199 + Generic_Map_Aspect_Chain = 200 + Port_Map_Aspect_Chain = 201 + Configuration_Name = 202 + Component_Configuration = 203 + Configuration_Specification = 204 + Default_Binding_Indication = 205 + Default_Configuration_Declaration = 206 + Expression = 207 + Conditional_Expression = 208 + Allocator_Designated_Type = 209 + Selected_Waveform_Chain = 210 + Conditional_Waveform_Chain = 211 + Guard_Expression = 212 + Guard_Decl = 213 + Guard_Sensitivity_List = 214 + Signal_Attribute_Chain = 215 + Block_Block_Configuration = 216 + Package_Header = 217 + Block_Header = 218 + Uninstantiated_Package_Name = 219 + Uninstantiated_Package_Decl = 220 + Instance_Source_File = 221 + Generate_Block_Configuration = 222 + Generate_Statement_Body = 223 + Alternative_Label = 224 + Generate_Else_Clause = 225 + Condition = 226 + Else_Clause = 227 + Parameter_Specification = 228 + Parent = 229 + Loop_Label = 230 + Component_Name = 231 + Instantiation_List = 232 + Entity_Aspect = 233 + Default_Entity_Aspect = 234 + Binding_Indication = 235 + Named_Entity = 236 + Alias_Declaration = 237 + Referenced_Name = 238 + Expr_Staticness = 239 + Error_Origin = 240 + Operand = 241 + Left = 242 + Right = 243 + Unit_Name = 244 + Name = 245 + Group_Template_Name = 246 + Name_Staticness = 247 + Prefix = 248 + Signature_Prefix = 249 + External_Pathname = 250 + Pathname_Suffix = 251 + Pathname_Expression = 252 + In_Formal_Flag = 253 + Slice_Subtype = 254 + Suffix = 255 + Index_Subtype = 256 + Parameter = 257 + Attr_Chain = 258 + Signal_Attribute_Declaration = 259 + Actual_Type = 260 + Actual_Type_Definition = 261 + Association_Chain = 262 + Individual_Association_Chain = 263 + Subprogram_Association_Chain = 264 + Aggregate_Info = 265 + Sub_Aggregate_Info = 266 + Aggr_Dynamic_Flag = 267 + Aggr_Min_Length = 268 + Aggr_Low_Limit = 269 + Aggr_High_Limit = 270 + Aggr_Others_Flag = 271 + Aggr_Named_Flag = 272 + Aggregate_Expand_Flag = 273 + Association_Choices_Chain = 274 + Case_Statement_Alternative_Chain = 275 + Choice_Staticness = 276 + Procedure_Call = 277 + Implementation = 278 + Parameter_Association_Chain = 279 + Method_Object = 280 + Subtype_Type_Mark = 281 + Type_Conversion_Subtype = 282 + Type_Mark = 283 + File_Type_Mark = 284 + Return_Type_Mark = 285 + Has_Disconnect_Flag = 286 + Has_Active_Flag = 287 + Is_Within_Flag = 288 + Type_Marks_List = 289 + Implicit_Alias_Flag = 290 + Alias_Signature = 291 + Attribute_Signature = 292 + Overload_List = 293 + Simple_Name_Identifier = 294 + Simple_Name_Subtype = 295 + Protected_Type_Body = 296 + Protected_Type_Declaration = 297 + Use_Flag = 298 + End_Has_Reserved_Id = 299 + End_Has_Identifier = 300 + End_Has_Postponed = 301 + Has_Label = 302 + Has_Begin = 303 + Has_End = 304 + Has_Is = 305 + Has_Pure = 306 + Has_Body = 307 + Has_Parameter = 308 + Has_Component = 309 + Has_Identifier_List = 310 + Has_Mode = 311 + Has_Class = 312 + Suspend_Flag = 313 + Is_Ref = 314 + Is_Forward_Ref = 315 + Psl_Property = 316 + Psl_Sequence = 317 + Psl_Declaration = 318 + Psl_Expression = 319 + Psl_Boolean = 320 + PSL_Clock = 321 + PSL_NFA = 322 + PSL_Nbr_States = 323 + PSL_Clock_Sensitivity = 324 + PSL_EOS_Flag = 325 Get_Boolean = libghdl.vhdl__nodes_meta__get_boolean @@ -627,9 +626,6 @@ Has_We_Value =\ Has_Time =\ libghdl.vhdl__nodes_meta__has_time -Has_Choice_Order =\ - libghdl.vhdl__nodes_meta__has_choice_order - Has_Associated_Expr =\ libghdl.vhdl__nodes_meta__has_associated_expr diff --git a/src/vhdl/vhdl-nodes.adb b/src/vhdl/vhdl-nodes.adb index 780f13b5b..0755f61dc 100644 --- a/src/vhdl/vhdl-nodes.adb +++ b/src/vhdl/vhdl-nodes.adb @@ -2247,22 +2247,6 @@ package body Vhdl.Nodes is Set_Field3 (We, An_Iir); end Set_Time; - function Get_Choice_Order (Choice : Iir) return Int32 is - begin - pragma Assert (Choice /= Null_Iir); - pragma Assert (Has_Choice_Order (Get_Kind (Choice)), - "no field Choice_Order"); - return Int32'Val (Get_Field1 (Choice)); - end Get_Choice_Order; - - procedure Set_Choice_Order (Choice : Iir; Pos : Int32) is - begin - pragma Assert (Choice /= Null_Iir); - pragma Assert (Has_Choice_Order (Get_Kind (Choice)), - "no field Choice_Order"); - Set_Field1 (Choice, Int32'Pos (Pos)); - end Set_Choice_Order; - function Get_Associated_Expr (Target : Iir) return Iir is begin pragma Assert (Target /= Null_Iir); diff --git a/src/vhdl/vhdl-nodes.ads b/src/vhdl/vhdl-nodes.ads index 73cc7d4aa..7a2cfaf28 100644 --- a/src/vhdl/vhdl-nodes.ads +++ b/src/vhdl/vhdl-nodes.ads @@ -541,9 +541,6 @@ package Vhdl.Nodes is -- associations have the same_alternative_flag set. -- Get/Set_Chain (Field2) -- - -- Ordered position of the choice from 1 to N. 0 is reserved for others. - -- Get/Set_Choice_Order (Field1) - -- -- Should be a simple_name. -- Only for Iir_Kind_Choice_By_Name: -- Get/Set_Choice_Name (Field5) @@ -6354,10 +6351,6 @@ package Vhdl.Nodes is function Get_Time (We : Iir_Waveform_Element) return Iir; procedure Set_Time (We : Iir_Waveform_Element; An_Iir : Iir); - -- Field: Field1 (pos) - function Get_Choice_Order (Choice : Iir) return Int32; - procedure Set_Choice_Order (Choice : Iir; Pos : Int32); - -- Node associated with a choice. -- Field: Field3 function Get_Associated_Expr (Target : Iir) return Iir; diff --git a/src/vhdl/vhdl-nodes_meta.adb b/src/vhdl/vhdl-nodes_meta.adb index 4a933e382..002b60cc0 100644 --- a/src/vhdl/vhdl-nodes_meta.adb +++ b/src/vhdl/vhdl-nodes_meta.adb @@ -77,7 +77,6 @@ package body Vhdl.Nodes_Meta is Field_After_Drivers_Flag => Type_Boolean, Field_We_Value => Type_Iir, Field_Time => Type_Iir, - Field_Choice_Order => Type_Int32, Field_Associated_Expr => Type_Iir, Field_Associated_Block => Type_Iir, Field_Associated_Chain => Type_Iir, @@ -472,8 +471,6 @@ package body Vhdl.Nodes_Meta is return "we_value"; when Field_Time => return "time"; - when Field_Choice_Order => - return "choice_order"; when Field_Associated_Expr => return "associated_expr"; when Field_Associated_Block => @@ -1682,8 +1679,6 @@ package body Vhdl.Nodes_Meta is return Attr_None; when Field_Time => return Attr_None; - when Field_Choice_Order => - return Attr_None; when Field_Associated_Expr => return Attr_None; when Field_Associated_Block => @@ -2397,7 +2392,6 @@ package body Vhdl.Nodes_Meta is Field_Chain, Field_Actual, -- Iir_Kind_Choice_By_Range - Field_Choice_Order, Field_Same_Alternative_Flag, Field_Element_Type_Flag, Field_Choice_Staticness, @@ -2407,7 +2401,6 @@ package body Vhdl.Nodes_Meta is Field_Associated_Expr, Field_Associated_Chain, -- Iir_Kind_Choice_By_Expression - Field_Choice_Order, Field_Same_Alternative_Flag, Field_Element_Type_Flag, Field_Choice_Staticness, @@ -2417,7 +2410,6 @@ package body Vhdl.Nodes_Meta is Field_Associated_Expr, Field_Associated_Chain, -- Iir_Kind_Choice_By_Others - Field_Choice_Order, Field_Same_Alternative_Flag, Field_Element_Type_Flag, Field_Parent, @@ -2425,7 +2417,6 @@ package body Vhdl.Nodes_Meta is Field_Associated_Expr, Field_Associated_Chain, -- Iir_Kind_Choice_By_None - Field_Choice_Order, Field_Same_Alternative_Flag, Field_Element_Type_Flag, Field_Parent, @@ -2433,7 +2424,6 @@ package body Vhdl.Nodes_Meta is Field_Associated_Expr, Field_Associated_Chain, -- Iir_Kind_Choice_By_Name - Field_Choice_Order, Field_Same_Alternative_Flag, Field_Element_Type_Flag, Field_Parent, @@ -4492,253 +4482,253 @@ package body Vhdl.Nodes_Meta is Iir_Kind_Association_Element_Package => 131, Iir_Kind_Association_Element_Type => 139, Iir_Kind_Association_Element_Subprogram => 145, - Iir_Kind_Choice_By_Range => 154, - Iir_Kind_Choice_By_Expression => 163, - Iir_Kind_Choice_By_Others => 170, - Iir_Kind_Choice_By_None => 177, - Iir_Kind_Choice_By_Name => 185, - Iir_Kind_Entity_Aspect_Entity => 187, - Iir_Kind_Entity_Aspect_Configuration => 188, - Iir_Kind_Entity_Aspect_Open => 188, - Iir_Kind_Block_Configuration => 194, - Iir_Kind_Block_Header => 198, - Iir_Kind_Component_Configuration => 205, - Iir_Kind_Binding_Indication => 209, - Iir_Kind_Entity_Class => 211, - Iir_Kind_Attribute_Value => 219, - Iir_Kind_Signature => 222, - Iir_Kind_Aggregate_Info => 229, - Iir_Kind_Procedure_Call => 233, - Iir_Kind_Record_Element_Constraint => 239, - Iir_Kind_Array_Element_Resolution => 241, - Iir_Kind_Record_Resolution => 242, - Iir_Kind_Record_Element_Resolution => 245, - Iir_Kind_Attribute_Specification => 253, - Iir_Kind_Disconnection_Specification => 259, - Iir_Kind_Configuration_Specification => 265, - Iir_Kind_Access_Type_Definition => 273, - Iir_Kind_Incomplete_Type_Definition => 281, - Iir_Kind_Interface_Type_Definition => 288, - Iir_Kind_File_Type_Definition => 295, - Iir_Kind_Protected_Type_Declaration => 304, - Iir_Kind_Record_Type_Definition => 315, - Iir_Kind_Array_Type_Definition => 327, - Iir_Kind_Array_Subtype_Definition => 342, - Iir_Kind_Record_Subtype_Definition => 355, - Iir_Kind_Access_Subtype_Definition => 363, - Iir_Kind_Physical_Subtype_Definition => 373, - Iir_Kind_Floating_Subtype_Definition => 384, - Iir_Kind_Integer_Subtype_Definition => 394, - Iir_Kind_Enumeration_Subtype_Definition => 404, - Iir_Kind_Enumeration_Type_Definition => 415, - Iir_Kind_Integer_Type_Definition => 423, - Iir_Kind_Floating_Type_Definition => 431, - Iir_Kind_Physical_Type_Definition => 442, - Iir_Kind_Range_Expression => 450, - Iir_Kind_Protected_Type_Body => 457, - Iir_Kind_Wildcard_Type_Definition => 462, - Iir_Kind_Subtype_Definition => 469, - Iir_Kind_Scalar_Nature_Definition => 473, - Iir_Kind_Overload_List => 474, - Iir_Kind_Type_Declaration => 481, - Iir_Kind_Anonymous_Type_Declaration => 487, - Iir_Kind_Subtype_Declaration => 494, - Iir_Kind_Nature_Declaration => 500, - Iir_Kind_Subnature_Declaration => 506, - Iir_Kind_Entity_Declaration => 518, - Iir_Kind_Configuration_Declaration => 527, - Iir_Kind_Context_Declaration => 533, - Iir_Kind_Package_Declaration => 548, - Iir_Kind_Package_Instantiation_Declaration => 562, - Iir_Kind_Package_Body => 570, - Iir_Kind_Architecture_Body => 582, - Iir_Kind_Package_Header => 584, - Iir_Kind_Unit_Declaration => 593, - Iir_Kind_Library_Declaration => 600, - Iir_Kind_Component_Declaration => 610, - Iir_Kind_Attribute_Declaration => 617, - Iir_Kind_Group_Template_Declaration => 623, - Iir_Kind_Group_Declaration => 630, - Iir_Kind_Element_Declaration => 637, - Iir_Kind_Non_Object_Alias_Declaration => 645, - Iir_Kind_Psl_Declaration => 653, - Iir_Kind_Psl_Endpoint_Declaration => 667, - Iir_Kind_Terminal_Declaration => 674, - Iir_Kind_Free_Quantity_Declaration => 685, - Iir_Kind_Across_Quantity_Declaration => 697, - Iir_Kind_Through_Quantity_Declaration => 709, - Iir_Kind_Enumeration_Literal => 720, - Iir_Kind_Function_Declaration => 745, - Iir_Kind_Procedure_Declaration => 769, - Iir_Kind_Function_Body => 779, - Iir_Kind_Procedure_Body => 790, - Iir_Kind_Object_Alias_Declaration => 801, - Iir_Kind_File_Declaration => 815, - Iir_Kind_Guard_Signal_Declaration => 828, - Iir_Kind_Signal_Declaration => 845, - Iir_Kind_Variable_Declaration => 858, - Iir_Kind_Constant_Declaration => 872, - Iir_Kind_Iterator_Declaration => 883, - Iir_Kind_Interface_Constant_Declaration => 899, - Iir_Kind_Interface_Variable_Declaration => 915, - Iir_Kind_Interface_Signal_Declaration => 936, - Iir_Kind_Interface_File_Declaration => 952, - Iir_Kind_Interface_Type_Declaration => 962, - Iir_Kind_Interface_Package_Declaration => 974, - Iir_Kind_Interface_Function_Declaration => 991, - Iir_Kind_Interface_Procedure_Declaration => 1004, - Iir_Kind_Anonymous_Signal_Declaration => 1012, - Iir_Kind_Signal_Attribute_Declaration => 1015, - Iir_Kind_Identity_Operator => 1019, - Iir_Kind_Negation_Operator => 1023, - Iir_Kind_Absolute_Operator => 1027, - Iir_Kind_Not_Operator => 1031, - Iir_Kind_Implicit_Condition_Operator => 1035, - Iir_Kind_Condition_Operator => 1039, - Iir_Kind_Reduction_And_Operator => 1043, - Iir_Kind_Reduction_Or_Operator => 1047, - Iir_Kind_Reduction_Nand_Operator => 1051, - Iir_Kind_Reduction_Nor_Operator => 1055, - Iir_Kind_Reduction_Xor_Operator => 1059, - Iir_Kind_Reduction_Xnor_Operator => 1063, - Iir_Kind_And_Operator => 1068, - Iir_Kind_Or_Operator => 1073, - Iir_Kind_Nand_Operator => 1078, - Iir_Kind_Nor_Operator => 1083, - Iir_Kind_Xor_Operator => 1088, - Iir_Kind_Xnor_Operator => 1093, - Iir_Kind_Equality_Operator => 1098, - Iir_Kind_Inequality_Operator => 1103, - Iir_Kind_Less_Than_Operator => 1108, - Iir_Kind_Less_Than_Or_Equal_Operator => 1113, - Iir_Kind_Greater_Than_Operator => 1118, - Iir_Kind_Greater_Than_Or_Equal_Operator => 1123, - Iir_Kind_Match_Equality_Operator => 1128, - Iir_Kind_Match_Inequality_Operator => 1133, - Iir_Kind_Match_Less_Than_Operator => 1138, - Iir_Kind_Match_Less_Than_Or_Equal_Operator => 1143, - Iir_Kind_Match_Greater_Than_Operator => 1148, - Iir_Kind_Match_Greater_Than_Or_Equal_Operator => 1153, - Iir_Kind_Sll_Operator => 1158, - Iir_Kind_Sla_Operator => 1163, - Iir_Kind_Srl_Operator => 1168, - Iir_Kind_Sra_Operator => 1173, - Iir_Kind_Rol_Operator => 1178, - Iir_Kind_Ror_Operator => 1183, - Iir_Kind_Addition_Operator => 1188, - Iir_Kind_Substraction_Operator => 1193, - Iir_Kind_Concatenation_Operator => 1198, - Iir_Kind_Multiplication_Operator => 1203, - Iir_Kind_Division_Operator => 1208, - Iir_Kind_Modulus_Operator => 1213, - Iir_Kind_Remainder_Operator => 1218, - Iir_Kind_Exponentiation_Operator => 1223, - Iir_Kind_Function_Call => 1231, - Iir_Kind_Aggregate => 1238, - Iir_Kind_Parenthesis_Expression => 1241, - Iir_Kind_Qualified_Expression => 1245, - Iir_Kind_Type_Conversion => 1250, - Iir_Kind_Allocator_By_Expression => 1254, - Iir_Kind_Allocator_By_Subtype => 1259, - Iir_Kind_Selected_Element => 1267, - Iir_Kind_Dereference => 1272, - Iir_Kind_Implicit_Dereference => 1277, - Iir_Kind_Slice_Name => 1284, - Iir_Kind_Indexed_Name => 1290, - Iir_Kind_Psl_Expression => 1292, - Iir_Kind_Sensitized_Process_Statement => 1313, - Iir_Kind_Process_Statement => 1333, - Iir_Kind_Concurrent_Simple_Signal_Assignment => 1345, - Iir_Kind_Concurrent_Conditional_Signal_Assignment => 1357, - Iir_Kind_Concurrent_Selected_Signal_Assignment => 1370, - Iir_Kind_Concurrent_Assertion_Statement => 1378, - Iir_Kind_Concurrent_Procedure_Call_Statement => 1385, - Iir_Kind_Psl_Assert_Directive => 1398, - Iir_Kind_Psl_Assume_Directive => 1409, - Iir_Kind_Psl_Cover_Directive => 1421, - Iir_Kind_Psl_Restrict_Directive => 1432, - Iir_Kind_Block_Statement => 1446, - Iir_Kind_If_Generate_Statement => 1457, - Iir_Kind_Case_Generate_Statement => 1466, - Iir_Kind_For_Generate_Statement => 1475, - Iir_Kind_Component_Instantiation_Statement => 1486, - Iir_Kind_Psl_Default_Clock => 1490, - Iir_Kind_Simple_Simultaneous_Statement => 1497, - Iir_Kind_Generate_Statement_Body => 1508, - Iir_Kind_If_Generate_Else_Clause => 1514, - Iir_Kind_Simple_Signal_Assignment_Statement => 1524, - Iir_Kind_Conditional_Signal_Assignment_Statement => 1534, - Iir_Kind_Selected_Waveform_Assignment_Statement => 1545, - Iir_Kind_Null_Statement => 1549, - Iir_Kind_Assertion_Statement => 1556, - Iir_Kind_Report_Statement => 1562, - Iir_Kind_Wait_Statement => 1570, - Iir_Kind_Variable_Assignment_Statement => 1577, - Iir_Kind_Conditional_Variable_Assignment_Statement => 1584, - Iir_Kind_Return_Statement => 1590, - Iir_Kind_For_Loop_Statement => 1599, - Iir_Kind_While_Loop_Statement => 1608, - Iir_Kind_Next_Statement => 1615, - Iir_Kind_Exit_Statement => 1622, - Iir_Kind_Case_Statement => 1630, - Iir_Kind_Procedure_Call_Statement => 1636, - Iir_Kind_If_Statement => 1646, - Iir_Kind_Elsif => 1652, - Iir_Kind_Character_Literal => 1660, - Iir_Kind_Simple_Name => 1668, - Iir_Kind_Selected_Name => 1677, - Iir_Kind_Operator_Symbol => 1683, - Iir_Kind_Reference_Name => 1687, - Iir_Kind_External_Constant_Name => 1695, - Iir_Kind_External_Signal_Name => 1703, - Iir_Kind_External_Variable_Name => 1712, - Iir_Kind_Selected_By_All_Name => 1718, - Iir_Kind_Parenthesis_Name => 1723, - Iir_Kind_Package_Pathname => 1727, - Iir_Kind_Absolute_Pathname => 1728, - Iir_Kind_Relative_Pathname => 1729, - Iir_Kind_Pathname_Element => 1734, - Iir_Kind_Base_Attribute => 1736, - Iir_Kind_Subtype_Attribute => 1741, - Iir_Kind_Element_Attribute => 1746, - Iir_Kind_Left_Type_Attribute => 1751, - Iir_Kind_Right_Type_Attribute => 1756, - Iir_Kind_High_Type_Attribute => 1761, - Iir_Kind_Low_Type_Attribute => 1766, - Iir_Kind_Ascending_Type_Attribute => 1771, - Iir_Kind_Image_Attribute => 1777, - Iir_Kind_Value_Attribute => 1783, - Iir_Kind_Pos_Attribute => 1789, - Iir_Kind_Val_Attribute => 1795, - Iir_Kind_Succ_Attribute => 1801, - Iir_Kind_Pred_Attribute => 1807, - Iir_Kind_Leftof_Attribute => 1813, - Iir_Kind_Rightof_Attribute => 1819, - Iir_Kind_Delayed_Attribute => 1828, - Iir_Kind_Stable_Attribute => 1837, - Iir_Kind_Quiet_Attribute => 1846, - Iir_Kind_Transaction_Attribute => 1855, - Iir_Kind_Event_Attribute => 1859, - Iir_Kind_Active_Attribute => 1863, - Iir_Kind_Last_Event_Attribute => 1867, - Iir_Kind_Last_Active_Attribute => 1871, - Iir_Kind_Last_Value_Attribute => 1875, - Iir_Kind_Driving_Attribute => 1879, - Iir_Kind_Driving_Value_Attribute => 1883, - Iir_Kind_Behavior_Attribute => 1883, - Iir_Kind_Structure_Attribute => 1883, - Iir_Kind_Simple_Name_Attribute => 1890, - Iir_Kind_Instance_Name_Attribute => 1895, - Iir_Kind_Path_Name_Attribute => 1900, - Iir_Kind_Left_Array_Attribute => 1907, - Iir_Kind_Right_Array_Attribute => 1914, - Iir_Kind_High_Array_Attribute => 1921, - Iir_Kind_Low_Array_Attribute => 1928, - Iir_Kind_Length_Array_Attribute => 1935, - Iir_Kind_Ascending_Array_Attribute => 1942, - Iir_Kind_Range_Array_Attribute => 1949, - Iir_Kind_Reverse_Range_Array_Attribute => 1956, - Iir_Kind_Attribute_Name => 1965 + Iir_Kind_Choice_By_Range => 153, + Iir_Kind_Choice_By_Expression => 161, + Iir_Kind_Choice_By_Others => 167, + Iir_Kind_Choice_By_None => 173, + Iir_Kind_Choice_By_Name => 180, + Iir_Kind_Entity_Aspect_Entity => 182, + Iir_Kind_Entity_Aspect_Configuration => 183, + Iir_Kind_Entity_Aspect_Open => 183, + Iir_Kind_Block_Configuration => 189, + Iir_Kind_Block_Header => 193, + Iir_Kind_Component_Configuration => 200, + Iir_Kind_Binding_Indication => 204, + Iir_Kind_Entity_Class => 206, + Iir_Kind_Attribute_Value => 214, + Iir_Kind_Signature => 217, + Iir_Kind_Aggregate_Info => 224, + Iir_Kind_Procedure_Call => 228, + Iir_Kind_Record_Element_Constraint => 234, + Iir_Kind_Array_Element_Resolution => 236, + Iir_Kind_Record_Resolution => 237, + Iir_Kind_Record_Element_Resolution => 240, + Iir_Kind_Attribute_Specification => 248, + Iir_Kind_Disconnection_Specification => 254, + Iir_Kind_Configuration_Specification => 260, + Iir_Kind_Access_Type_Definition => 268, + Iir_Kind_Incomplete_Type_Definition => 276, + Iir_Kind_Interface_Type_Definition => 283, + Iir_Kind_File_Type_Definition => 290, + Iir_Kind_Protected_Type_Declaration => 299, + Iir_Kind_Record_Type_Definition => 310, + Iir_Kind_Array_Type_Definition => 322, + Iir_Kind_Array_Subtype_Definition => 337, + Iir_Kind_Record_Subtype_Definition => 350, + Iir_Kind_Access_Subtype_Definition => 358, + Iir_Kind_Physical_Subtype_Definition => 368, + Iir_Kind_Floating_Subtype_Definition => 379, + Iir_Kind_Integer_Subtype_Definition => 389, + Iir_Kind_Enumeration_Subtype_Definition => 399, + Iir_Kind_Enumeration_Type_Definition => 410, + Iir_Kind_Integer_Type_Definition => 418, + Iir_Kind_Floating_Type_Definition => 426, + Iir_Kind_Physical_Type_Definition => 437, + Iir_Kind_Range_Expression => 445, + Iir_Kind_Protected_Type_Body => 452, + Iir_Kind_Wildcard_Type_Definition => 457, + Iir_Kind_Subtype_Definition => 464, + Iir_Kind_Scalar_Nature_Definition => 468, + Iir_Kind_Overload_List => 469, + Iir_Kind_Type_Declaration => 476, + Iir_Kind_Anonymous_Type_Declaration => 482, + Iir_Kind_Subtype_Declaration => 489, + Iir_Kind_Nature_Declaration => 495, + Iir_Kind_Subnature_Declaration => 501, + Iir_Kind_Entity_Declaration => 513, + Iir_Kind_Configuration_Declaration => 522, + Iir_Kind_Context_Declaration => 528, + Iir_Kind_Package_Declaration => 543, + Iir_Kind_Package_Instantiation_Declaration => 557, + Iir_Kind_Package_Body => 565, + Iir_Kind_Architecture_Body => 577, + Iir_Kind_Package_Header => 579, + Iir_Kind_Unit_Declaration => 588, + Iir_Kind_Library_Declaration => 595, + Iir_Kind_Component_Declaration => 605, + Iir_Kind_Attribute_Declaration => 612, + Iir_Kind_Group_Template_Declaration => 618, + Iir_Kind_Group_Declaration => 625, + Iir_Kind_Element_Declaration => 632, + Iir_Kind_Non_Object_Alias_Declaration => 640, + Iir_Kind_Psl_Declaration => 648, + Iir_Kind_Psl_Endpoint_Declaration => 662, + Iir_Kind_Terminal_Declaration => 669, + Iir_Kind_Free_Quantity_Declaration => 680, + Iir_Kind_Across_Quantity_Declaration => 692, + Iir_Kind_Through_Quantity_Declaration => 704, + Iir_Kind_Enumeration_Literal => 715, + Iir_Kind_Function_Declaration => 740, + Iir_Kind_Procedure_Declaration => 764, + Iir_Kind_Function_Body => 774, + Iir_Kind_Procedure_Body => 785, + Iir_Kind_Object_Alias_Declaration => 796, + Iir_Kind_File_Declaration => 810, + Iir_Kind_Guard_Signal_Declaration => 823, + Iir_Kind_Signal_Declaration => 840, + Iir_Kind_Variable_Declaration => 853, + Iir_Kind_Constant_Declaration => 867, + Iir_Kind_Iterator_Declaration => 878, + Iir_Kind_Interface_Constant_Declaration => 894, + Iir_Kind_Interface_Variable_Declaration => 910, + Iir_Kind_Interface_Signal_Declaration => 931, + Iir_Kind_Interface_File_Declaration => 947, + Iir_Kind_Interface_Type_Declaration => 957, + Iir_Kind_Interface_Package_Declaration => 969, + Iir_Kind_Interface_Function_Declaration => 986, + Iir_Kind_Interface_Procedure_Declaration => 999, + Iir_Kind_Anonymous_Signal_Declaration => 1007, + Iir_Kind_Signal_Attribute_Declaration => 1010, + Iir_Kind_Identity_Operator => 1014, + Iir_Kind_Negation_Operator => 1018, + Iir_Kind_Absolute_Operator => 1022, + Iir_Kind_Not_Operator => 1026, + Iir_Kind_Implicit_Condition_Operator => 1030, + Iir_Kind_Condition_Operator => 1034, + Iir_Kind_Reduction_And_Operator => 1038, + Iir_Kind_Reduction_Or_Operator => 1042, + Iir_Kind_Reduction_Nand_Operator => 1046, + Iir_Kind_Reduction_Nor_Operator => 1050, + Iir_Kind_Reduction_Xor_Operator => 1054, + Iir_Kind_Reduction_Xnor_Operator => 1058, + Iir_Kind_And_Operator => 1063, + Iir_Kind_Or_Operator => 1068, + Iir_Kind_Nand_Operator => 1073, + Iir_Kind_Nor_Operator => 1078, + Iir_Kind_Xor_Operator => 1083, + Iir_Kind_Xnor_Operator => 1088, + Iir_Kind_Equality_Operator => 1093, + Iir_Kind_Inequality_Operator => 1098, + Iir_Kind_Less_Than_Operator => 1103, + Iir_Kind_Less_Than_Or_Equal_Operator => 1108, + Iir_Kind_Greater_Than_Operator => 1113, + Iir_Kind_Greater_Than_Or_Equal_Operator => 1118, + Iir_Kind_Match_Equality_Operator => 1123, + Iir_Kind_Match_Inequality_Operator => 1128, + Iir_Kind_Match_Less_Than_Operator => 1133, + Iir_Kind_Match_Less_Than_Or_Equal_Operator => 1138, + Iir_Kind_Match_Greater_Than_Operator => 1143, + Iir_Kind_Match_Greater_Than_Or_Equal_Operator => 1148, + Iir_Kind_Sll_Operator => 1153, + Iir_Kind_Sla_Operator => 1158, + Iir_Kind_Srl_Operator => 1163, + Iir_Kind_Sra_Operator => 1168, + Iir_Kind_Rol_Operator => 1173, + Iir_Kind_Ror_Operator => 1178, + Iir_Kind_Addition_Operator => 1183, + Iir_Kind_Substraction_Operator => 1188, + Iir_Kind_Concatenation_Operator => 1193, + Iir_Kind_Multiplication_Operator => 1198, + Iir_Kind_Division_Operator => 1203, + Iir_Kind_Modulus_Operator => 1208, + Iir_Kind_Remainder_Operator => 1213, + Iir_Kind_Exponentiation_Operator => 1218, + Iir_Kind_Function_Call => 1226, + Iir_Kind_Aggregate => 1233, + Iir_Kind_Parenthesis_Expression => 1236, + Iir_Kind_Qualified_Expression => 1240, + Iir_Kind_Type_Conversion => 1245, + Iir_Kind_Allocator_By_Expression => 1249, + Iir_Kind_Allocator_By_Subtype => 1254, + Iir_Kind_Selected_Element => 1262, + Iir_Kind_Dereference => 1267, + Iir_Kind_Implicit_Dereference => 1272, + Iir_Kind_Slice_Name => 1279, + Iir_Kind_Indexed_Name => 1285, + Iir_Kind_Psl_Expression => 1287, + Iir_Kind_Sensitized_Process_Statement => 1308, + Iir_Kind_Process_Statement => 1328, + Iir_Kind_Concurrent_Simple_Signal_Assignment => 1340, + Iir_Kind_Concurrent_Conditional_Signal_Assignment => 1352, + Iir_Kind_Concurrent_Selected_Signal_Assignment => 1365, + Iir_Kind_Concurrent_Assertion_Statement => 1373, + Iir_Kind_Concurrent_Procedure_Call_Statement => 1380, + Iir_Kind_Psl_Assert_Directive => 1393, + Iir_Kind_Psl_Assume_Directive => 1404, + Iir_Kind_Psl_Cover_Directive => 1416, + Iir_Kind_Psl_Restrict_Directive => 1427, + Iir_Kind_Block_Statement => 1441, + Iir_Kind_If_Generate_Statement => 1452, + Iir_Kind_Case_Generate_Statement => 1461, + Iir_Kind_For_Generate_Statement => 1470, + Iir_Kind_Component_Instantiation_Statement => 1481, + Iir_Kind_Psl_Default_Clock => 1485, + Iir_Kind_Simple_Simultaneous_Statement => 1492, + Iir_Kind_Generate_Statement_Body => 1503, + Iir_Kind_If_Generate_Else_Clause => 1509, + Iir_Kind_Simple_Signal_Assignment_Statement => 1519, + Iir_Kind_Conditional_Signal_Assignment_Statement => 1529, + Iir_Kind_Selected_Waveform_Assignment_Statement => 1540, + Iir_Kind_Null_Statement => 1544, + Iir_Kind_Assertion_Statement => 1551, + Iir_Kind_Report_Statement => 1557, + Iir_Kind_Wait_Statement => 1565, + Iir_Kind_Variable_Assignment_Statement => 1572, + Iir_Kind_Conditional_Variable_Assignment_Statement => 1579, + Iir_Kind_Return_Statement => 1585, + Iir_Kind_For_Loop_Statement => 1594, + Iir_Kind_While_Loop_Statement => 1603, + Iir_Kind_Next_Statement => 1610, + Iir_Kind_Exit_Statement => 1617, + Iir_Kind_Case_Statement => 1625, + Iir_Kind_Procedure_Call_Statement => 1631, + Iir_Kind_If_Statement => 1641, + Iir_Kind_Elsif => 1647, + Iir_Kind_Character_Literal => 1655, + Iir_Kind_Simple_Name => 1663, + Iir_Kind_Selected_Name => 1672, + Iir_Kind_Operator_Symbol => 1678, + Iir_Kind_Reference_Name => 1682, + Iir_Kind_External_Constant_Name => 1690, + Iir_Kind_External_Signal_Name => 1698, + Iir_Kind_External_Variable_Name => 1707, + Iir_Kind_Selected_By_All_Name => 1713, + Iir_Kind_Parenthesis_Name => 1718, + Iir_Kind_Package_Pathname => 1722, + Iir_Kind_Absolute_Pathname => 1723, + Iir_Kind_Relative_Pathname => 1724, + Iir_Kind_Pathname_Element => 1729, + Iir_Kind_Base_Attribute => 1731, + Iir_Kind_Subtype_Attribute => 1736, + Iir_Kind_Element_Attribute => 1741, + Iir_Kind_Left_Type_Attribute => 1746, + Iir_Kind_Right_Type_Attribute => 1751, + Iir_Kind_High_Type_Attribute => 1756, + Iir_Kind_Low_Type_Attribute => 1761, + Iir_Kind_Ascending_Type_Attribute => 1766, + Iir_Kind_Image_Attribute => 1772, + Iir_Kind_Value_Attribute => 1778, + Iir_Kind_Pos_Attribute => 1784, + Iir_Kind_Val_Attribute => 1790, + Iir_Kind_Succ_Attribute => 1796, + Iir_Kind_Pred_Attribute => 1802, + Iir_Kind_Leftof_Attribute => 1808, + Iir_Kind_Rightof_Attribute => 1814, + Iir_Kind_Delayed_Attribute => 1823, + Iir_Kind_Stable_Attribute => 1832, + Iir_Kind_Quiet_Attribute => 1841, + Iir_Kind_Transaction_Attribute => 1850, + Iir_Kind_Event_Attribute => 1854, + Iir_Kind_Active_Attribute => 1858, + Iir_Kind_Last_Event_Attribute => 1862, + Iir_Kind_Last_Active_Attribute => 1866, + Iir_Kind_Last_Value_Attribute => 1870, + Iir_Kind_Driving_Attribute => 1874, + Iir_Kind_Driving_Value_Attribute => 1878, + Iir_Kind_Behavior_Attribute => 1878, + Iir_Kind_Structure_Attribute => 1878, + Iir_Kind_Simple_Name_Attribute => 1885, + Iir_Kind_Instance_Name_Attribute => 1890, + Iir_Kind_Path_Name_Attribute => 1895, + Iir_Kind_Left_Array_Attribute => 1902, + Iir_Kind_Right_Array_Attribute => 1909, + Iir_Kind_High_Array_Attribute => 1916, + Iir_Kind_Low_Array_Attribute => 1923, + Iir_Kind_Length_Array_Attribute => 1930, + Iir_Kind_Ascending_Array_Attribute => 1937, + Iir_Kind_Range_Array_Attribute => 1944, + Iir_Kind_Reverse_Range_Array_Attribute => 1951, + Iir_Kind_Attribute_Name => 1960 ); function Get_Fields_First (K : Iir_Kind) return Fields_Index is @@ -6349,8 +6339,6 @@ package body Vhdl.Nodes_Meta is return Get_String_Length (N); when Field_Literal_Length => return Get_Literal_Length (N); - when Field_Choice_Order => - return Get_Choice_Order (N); when Field_PSL_Nbr_States => return Get_PSL_Nbr_States (N); when others => @@ -6371,8 +6359,6 @@ package body Vhdl.Nodes_Meta is Set_String_Length (N, V); when Field_Literal_Length => Set_Literal_Length (N, V); - when Field_Choice_Order => - Set_Choice_Order (N, V); when Field_PSL_Nbr_States => Set_PSL_Nbr_States (N, V); when others => @@ -7105,20 +7091,6 @@ package body Vhdl.Nodes_Meta is return K = Iir_Kind_Waveform_Element; end Has_Time; - function Has_Choice_Order (K : Iir_Kind) return Boolean is - begin - case K is - when Iir_Kind_Choice_By_Range - | Iir_Kind_Choice_By_Expression - | Iir_Kind_Choice_By_Others - | Iir_Kind_Choice_By_None - | Iir_Kind_Choice_By_Name => - return True; - when others => - return False; - end case; - end Has_Choice_Order; - function Has_Associated_Expr (K : Iir_Kind) return Boolean is begin case K is diff --git a/src/vhdl/vhdl-nodes_meta.ads b/src/vhdl/vhdl-nodes_meta.ads index c9cfe3a99..34b54e8af 100644 --- a/src/vhdl/vhdl-nodes_meta.ads +++ b/src/vhdl/vhdl-nodes_meta.ads @@ -119,7 +119,6 @@ package Vhdl.Nodes_Meta is Field_After_Drivers_Flag, Field_We_Value, Field_Time, - Field_Choice_Order, Field_Associated_Expr, Field_Associated_Block, Field_Associated_Chain, @@ -648,7 +647,6 @@ package Vhdl.Nodes_Meta is function Has_After_Drivers_Flag (K : Iir_Kind) return Boolean; function Has_We_Value (K : Iir_Kind) return Boolean; function Has_Time (K : Iir_Kind) return Boolean; - function Has_Choice_Order (K : Iir_Kind) return Boolean; function Has_Associated_Expr (K : Iir_Kind) return Boolean; function Has_Associated_Block (K : Iir_Kind) return Boolean; function Has_Associated_Chain (K : Iir_Kind) return Boolean; diff --git a/src/vhdl/vhdl-sem_expr.adb b/src/vhdl/vhdl-sem_expr.adb index 4225d0802..90db825b5 100644 --- a/src/vhdl/vhdl-sem_expr.adb +++ b/src/vhdl/vhdl-sem_expr.adb @@ -2578,10 +2578,6 @@ package body Vhdl.Sem_Expr is Fill_Choices_Array (Info, Choice_Chain); Sort_Discrete_Choices (Info); - for I in Info.Arr'Range loop - Set_Choice_Order (Info.Arr (I), Int32 (I)); - end loop; - -- Set low and high bounds. if Info.Nbr_Choices > 0 then Low := Get_Assoc_Low (Info.Arr (Info.Arr'First)); |