aboutsummaryrefslogtreecommitdiffstats
path: root/src/vhdl
diff options
context:
space:
mode:
authorTristan Gingold <tgingold@free.fr>2023-01-11 19:33:43 +0100
committerTristan Gingold <tgingold@free.fr>2023-01-12 05:54:21 +0100
commitae9a0e6c531fd0eeceb8e416360312beb25c6a2c (patch)
tree3e7c17958766009b7eac20426ce404ad9f6666ee /src/vhdl
parent3a50554d415e02dfbcfb03155816ef89754b4392 (diff)
downloadghdl-ae9a0e6c531fd0eeceb8e416360312beb25c6a2c.tar.gz
ghdl-ae9a0e6c531fd0eeceb8e416360312beb25c6a2c.tar.bz2
ghdl-ae9a0e6c531fd0eeceb8e416360312beb25c6a2c.zip
vhdl-sem_names: finish prefix of element attribute names
Diffstat (limited to 'src/vhdl')
-rw-r--r--src/vhdl/vhdl-sem_names.adb54
1 files changed, 32 insertions, 22 deletions
diff --git a/src/vhdl/vhdl-sem_names.adb b/src/vhdl/vhdl-sem_names.adb
index 2e98fe6da..800e6183f 100644
--- a/src/vhdl/vhdl-sem_names.adb
+++ b/src/vhdl/vhdl-sem_names.adb
@@ -1002,6 +1002,34 @@ package body Vhdl.Sem_Names is
end loop;
end Get_Object_Type_Staticness;
+ procedure Finish_Sem_Array_Attribute_Prefix (Attr_Name : Iir; Attr : Iir)
+ is
+ Prefix : Iir;
+ Prefix_Name : Iir;
+ begin
+ -- See Sem_Array_Attribute_Name for comments about the prefix.
+ Prefix_Name := Get_Prefix (Attr_Name);
+ if Is_Type_Name (Prefix_Name) /= Null_Iir then
+ Prefix := Sem_Type_Mark (Prefix_Name);
+ else
+ Prefix := Finish_Sem_Name (Prefix_Name, Get_Prefix (Attr));
+ -- Convert function declaration to call.
+ if Get_Kind (Prefix) in Iir_Kinds_Denoting_Name
+ and then
+ (Get_Kind (Get_Named_Entity (Prefix))
+ = Iir_Kind_Function_Declaration)
+ then
+ Prefix := Function_Declaration_To_Call (Prefix);
+ end if;
+ if not Is_Object_Name (Prefix) then
+ Error_Msg_Sem_Relaxed
+ (Attr, Warnid_Attribute,
+ "prefix of array attribute must be an object name");
+ end if;
+ end if;
+ Set_Prefix (Attr, Prefix);
+ end Finish_Sem_Array_Attribute_Prefix;
+
procedure Finish_Sem_Array_Attribute
(Attr_Name : Iir; Attr : Iir; Param : Iir)
is
@@ -1009,7 +1037,6 @@ package body Vhdl.Sem_Names is
Prefix_Type : Iir;
Index_Type : Iir;
Prefix : Iir;
- Prefix_Name : Iir;
Staticness : Iir_Staticness;
begin
-- LRM93 14.1
@@ -1032,28 +1059,9 @@ package body Vhdl.Sem_Names is
end if;
end if;
- -- See Sem_Array_Attribute_Name for comments about the prefix.
- Prefix_Name := Get_Prefix (Attr_Name);
- if Is_Type_Name (Prefix_Name) /= Null_Iir then
- Prefix := Sem_Type_Mark (Prefix_Name);
- else
- Prefix := Finish_Sem_Name (Prefix_Name, Get_Prefix (Attr));
- -- Convert function declaration to call.
- if Get_Kind (Prefix) in Iir_Kinds_Denoting_Name
- and then
- (Get_Kind (Get_Named_Entity (Prefix))
- = Iir_Kind_Function_Declaration)
- then
- Prefix := Function_Declaration_To_Call (Prefix);
- end if;
- if not Is_Object_Name (Prefix) then
- Error_Msg_Sem_Relaxed
- (Attr, Warnid_Attribute,
- "prefix of array attribute must be an object name");
- end if;
- end if;
- Set_Prefix (Attr, Prefix);
+ Finish_Sem_Array_Attribute_Prefix (Attr_Name, Attr);
+ Prefix := Get_Prefix (Attr);
Prefix_Type := Get_Type (Prefix);
if Is_Error (Prefix_Type) then
return;
@@ -2024,6 +2032,8 @@ package body Vhdl.Sem_Names is
Free_Iir (Name);
return Res;
when Iir_Kind_Element_Attribute =>
+ pragma Assert (Get_Kind (Name) = Iir_Kind_Attribute_Name);
+ Finish_Sem_Array_Attribute_Prefix (Name, Res);
Set_Base_Name (Res, Res);
Set_Name_Staticness (Res, Get_Name_Staticness (Get_Prefix (Res)));
Set_Type_Staticness (Res, Get_Type_Staticness (Get_Type (Res)));