summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/vhdl/parse.adb52
1 files changed, 8 insertions, 44 deletions
diff --git a/src/vhdl/parse.adb b/src/vhdl/parse.adb
index cb8537e..d3d6442 100644
--- a/src/vhdl/parse.adb
+++ b/src/vhdl/parse.adb
@@ -272,7 +272,7 @@ package body Parse is
end if;
end Parse_Signal_Kind;
- -- precond : next token
+ -- precond : TO, DOWNTO
-- postcond: next token
--
-- Parse a range.
@@ -285,59 +285,26 @@ package body Parse is
-- [3.1]
-- range ::= RANGE_attribute_name
-- | simple_expression direction simple_expression
- function Parse_Range_Expression (Left: Iir; Discrete: Boolean := False)
- return Iir
+ function Parse_Range_Expression (Left : Iir) return Iir
is
Res : Iir;
- Left1: Iir;
begin
- if Left /= Null_Iir then
- Left1 := Left;
- else
- Left1 := Parse_Simple_Expression;
- end if;
+ Res := Create_Iir (Iir_Kind_Range_Expression);
+ Set_Left_Limit (Res, Left);
+ Location_Copy (Res, Left);
case Current_Token is
when Tok_To =>
- Res := Create_Iir (Iir_Kind_Range_Expression);
Set_Direction (Res, Iir_To);
when Tok_Downto =>
- Res := Create_Iir (Iir_Kind_Range_Expression);
Set_Direction (Res, Iir_Downto);
- when Tok_Range =>
- if not Discrete then
- Unexpected ("range definition");
- end if;
- Scan;
- if Current_Token = Tok_Box then
- Unexpected ("range expression expected");
- Scan;
- return Null_Iir;
- end if;
- Res := Parse_Range_Expression (Null_Iir, False);
- if Res /= Null_Iir then
- Set_Type (Res, Left1);
- end if;
- return Res;
when others =>
- if Left1 = Null_Iir then
- return Null_Iir;
- end if;
- if Is_Range_Attribute_Name (Left1) then
- return Left1;
- end if;
- if Discrete
- and then Get_Kind (Left1) in Iir_Kinds_Denoting_Name
- then
- return Left1;
- end if;
- Error_Msg_Parse ("'to' or 'downto' expected");
- return Null_Iir;
+ raise Internal_Error;
end case;
- Set_Left_Limit (Res, Left1);
- Location_Copy (Res, Left1);
+ -- Skip TO or DOWNTO.
Scan;
+
Set_Right_Limit (Res, Parse_Simple_Expression);
return Res;
end Parse_Range_Expression;
@@ -2031,9 +1998,6 @@ package body Parse is
Append_Element (El_List, El);
Set_Element_Position (El, Pos);
Pos := Pos + 1;
- if First = Null_Iir then
- First := El;
- end if;
-- Skip identifier
Scan;