diff options
-rw-r--r-- | src/vhdl/parse.adb | 33 | ||||
-rw-r--r-- | src/vhdl/scanner.adb | 75 | ||||
-rw-r--r-- | src/vhdl/scanner.ads | 7 |
3 files changed, 69 insertions, 46 deletions
diff --git a/src/vhdl/parse.adb b/src/vhdl/parse.adb index fc00c431b..b0c8f1287 100644 --- a/src/vhdl/parse.adb +++ b/src/vhdl/parse.adb @@ -23,7 +23,6 @@ with Errorout; use Errorout; with Std_Names; use Std_Names; with Flags; use Flags; with Parse_Psl; -with Name_Table; with Str_Table; with Xrefs; with Elocations; use Elocations; @@ -4907,33 +4906,27 @@ package body Parse is -- Simply create the node for a bit string. function Parse_Bit_String return Iir is - use Name_Table; + use Str_Table; Res : Iir; - C : Character; B : Number_Base_Type; begin Res := Create_Iir (Iir_Kind_String_Literal8); Set_Location (Res); Set_String8_Id (Res, Current_String_Id); Set_String_Length (Res, Current_String_Length); - if Nam_Buffer (1) = 's' then - Set_Has_Sign (Res, True); - Set_Has_Signed (Res, True); - pragma Assert (Nam_Length = 2); - C := Name_Table.Nam_Buffer (2); - elsif Nam_Buffer (1) = 'u' then - Set_Has_Sign (Res, True); - Set_Has_Signed (Res, False); - pragma Assert (Nam_Length = 2); - C := Nam_Buffer (2); - else - Set_Has_Sign (Res, False); - Set_Has_Signed (Res, False); - pragma Assert (Nam_Length = 1); - C := Nam_Buffer (1); - end if; + case Get_Bit_String_Sign is + when 's' => + Set_Has_Sign (Res, True); + Set_Has_Signed (Res, True); + when 'u' => + Set_Has_Sign (Res, True); + Set_Has_Signed (Res, False); + when others => + Set_Has_Sign (Res, False); + Set_Has_Signed (Res, False); + end case; - case C is + case Get_Bit_String_Base is when 'b' => B := Base_2; when 'o' => diff --git a/src/vhdl/scanner.adb b/src/vhdl/scanner.adb index ab4695b78..c5003666f 100644 --- a/src/vhdl/scanner.adb +++ b/src/vhdl/scanner.adb @@ -150,6 +150,8 @@ package body Scanner is File_Len: Source_Ptr; Token: Token_Type; Prev_Token: Token_Type; + Bit_Str_Base : Character; + Bit_Str_Sign : Character; Str_Id : String8_Id; Str_Len : Nat32; Identifier: Name_Id; @@ -170,6 +172,8 @@ package body Scanner is Token => Tok_Invalid, Prev_Token => Tok_Invalid, Identifier => Null_Identifier, + Bit_Str_Base => ' ', + Bit_Str_Sign => ' ', Str_Id => Null_String8, Str_Len => 0, Int64 => 0, @@ -209,6 +213,16 @@ package body Scanner is return Current_Context.Str_Len; end Current_String_Length; + function Get_Bit_String_Base return Character is + begin + return Current_Context.Bit_Str_Base; + end Get_Bit_String_Base; + + function Get_Bit_String_Sign return Character is + begin + return Current_Context.Bit_Str_Sign; + end Get_Bit_String_Sign; + function Current_Iir_Int64 return Iir_Int64 is begin return Current_Context.Int64; @@ -282,6 +296,8 @@ package body Scanner is Token => Tok_Invalid, Prev_Token => Tok_Invalid, Identifier => Null_Identifier, + Bit_Str_Base => ' ', + Bit_Str_Sign => ' ', Str_Id => Null_String8, Str_Len => 0, Int64 => -1, @@ -917,6 +933,7 @@ package body Scanner is procedure Scan_Identifier (Allow_PSL : Boolean) is use Name_Table; + Buffer : String (1 .. Max_Nam_Length); C : Character; Len : Natural; begin @@ -967,7 +984,7 @@ package body Scanner is -- Put character in name buffer. FIXME: compute the hash at the same -- time ? Len := Len + 1; - Nam_Buffer (Len) := C; + Buffer (Len) := C; -- Next character. Pos := Pos + 1; @@ -983,7 +1000,6 @@ package body Scanner is Len := Len - 1; C := '_'; end if; - Nam_Length := Len; -- LRM93 13.2 -- At least one separator is required between an identifier or an @@ -1019,9 +1035,10 @@ package body Scanner is -- with the same meaning. declare Base : Nat32; - Cl : constant Character := Nam_Buffer (Len); - Cf : constant Character := Nam_Buffer (1); + Cl : constant Character := Buffer (Len); + Cf : constant Character := Buffer (1); begin + Current_Context.Bit_Str_Base := Cl; if Cl = 'b' then Base := 1; elsif Cl = 'o' then @@ -1029,6 +1046,7 @@ package body Scanner is elsif Cl = 'x' then Base := 4; elsif Vhdl_Std >= Vhdl_08 and Len = 1 and Cf = 'd' then + Current_Context.Bit_Str_Sign := ' '; Scan_Dec_Bit_String; return; else @@ -1036,11 +1054,13 @@ package body Scanner is end if; if Base > 0 then if Len = 1 then + Current_Context.Bit_Str_Sign := ' '; Scan_Bit_String (Base); return; elsif Vhdl_Std >= Vhdl_08 and then (Cf = 's' or Cf = 'u') then + Current_Context.Bit_Str_Sign := Cf; Scan_Bit_String (Base); return; end if; @@ -1057,7 +1077,7 @@ package body Scanner is -- quote marks, there are invalid character (in the 128-160 -- range). if C = Character'Val (16#80#) - and then Nam_Buffer (Len) = Character'Val (16#e2#) + and then Buffer (Len) = Character'Val (16#e2#) and then (Source (Pos + 1) = Character'Val (16#98#) or else Source (Pos + 1) = Character'Val (16#99#)) then @@ -1067,7 +1087,7 @@ package body Scanner is -- error will be detected as the next byte (0x80) is -- invalid. Remove the first byte from the identifier, and -- let's catch the error later. - Nam_Length := Len - 1; + Len := Len - 1; Pos := Pos - 1; else Error_Msg_Scan ("invalid use of UTF8 character for '"); @@ -1105,7 +1125,7 @@ package body Scanner is end case; -- Hash it. - Current_Context.Identifier := Name_Table.Get_Identifier; + Current_Context.Identifier := Get_Identifier (Buffer (1 .. Len)); Current_Token := Tok_Identifier; end Scan_Identifier; @@ -1230,13 +1250,15 @@ package body Scanner is procedure Scan_Extended_Identifier is use Name_Table; + Buffer : String (1 .. Max_Nam_Length); + Len : Natural; begin -- LRM93 13.3.2 -- Moreover, every extended identifiers is distinct from any basic -- identifier. -- This is satisfied by storing '\' in the name table. - Nam_Length := 1; - Nam_Buffer (1) := '\'; + Len := 1; + Buffer (1) := '\'; loop -- Next character. Pos := Pos + 1; @@ -1247,8 +1269,8 @@ package body Scanner is -- of an extended literal, it must be doubled. -- LRM93 13.3.2 -- (a doubled backslash couting as one character) - Nam_Length := Nam_Length + 1; - Nam_Buffer (Nam_Length) := '\'; + Len := Len + 1; + Buffer (Len) := '\'; Pos := Pos + 1; @@ -1265,14 +1287,15 @@ package body Scanner is when Invalid => Error_Msg_Scan ("invalid character in extended identifier"); end case; - Nam_Length := Nam_Length + 1; + Len := Len + 1; + -- LRM93 13.3.2 -- Extended identifiers differing only in the use of corresponding -- upper and lower case letters are distinct. - Nam_Buffer (Nam_Length) := Source (Pos); + Buffer (Len) := Source (Pos); end loop; - if Nam_Length <= 2 then + if Len <= 2 then Error_Msg_Scan ("empty extended identifier is not allowed"); end if; @@ -1293,7 +1316,7 @@ package body Scanner is end case; -- Hash it. - Current_Context.Identifier := Name_Table.Get_Identifier; + Current_Context.Identifier := Get_Identifier (Buffer (1 .. Len)); Current_Token := Tok_Identifier; end Scan_Extended_Identifier; @@ -1343,7 +1366,7 @@ package body Scanner is when Graphic_Character => if C = '\' then if Id (I + 1) /= '\' - or else I = Nam_Length - 1 + or else I = Id'Last - 1 then Error_Msg_Option ("anti-slash must be doubled " & "in extended identifier"); @@ -1429,17 +1452,19 @@ package body Scanner is -- Scan an identifier within a comment. Only lower case letters are -- allowed. - function Scan_Comment_Identifier return Boolean + procedure Scan_Comment_Identifier (Id : out Name_Id) is use Name_Table; + Buffer : String (1 .. Max_Nam_Length); Len : Natural; C : Character; begin + Id := Null_Identifier; Skip_Spaces; -- The identifier shall start with a lower case letter. if Source (Pos) not in 'a' .. 'z' then - return False; + return; end if; -- Scan the identifier (in lower cases). @@ -1448,17 +1473,16 @@ package body Scanner is C := Source (Pos); exit when C not in 'a' .. 'z' and C /= '_'; Len := Len + 1; - Nam_Buffer (Len) := C; + Buffer (Len) := C; Pos := Pos + 1; end loop; -- Shall be followed by a space or a new line. if not (C = ' ' or else C = HT or else Is_EOL (C)) then - return False; + return; end if; - Nam_Length := Len; - return True; + Id := Get_Identifier (Buffer (1 .. Len)); end Scan_Comment_Identifier; package Directive_Protect is @@ -1518,13 +1542,12 @@ package body Scanner is use Std_Names; Id : Name_Id; begin - if not Scan_Comment_Identifier then + Scan_Comment_Identifier (Id); + + if Id = Null_Identifier then return False; end if; - -- Hash it. - Id := Name_Table.Get_Identifier; - case Id is when Name_Psl => -- Accept tokens after '-- psl'. diff --git a/src/vhdl/scanner.ads b/src/vhdl/scanner.ads index 610d63140..8907975f4 100644 --- a/src/vhdl/scanner.ads +++ b/src/vhdl/scanner.ads @@ -42,6 +42,13 @@ package Scanner is pragma Inline (Current_String_Id); pragma Inline (Current_String_Length); + -- When the current token is Tok_Bit_String, return the base ('b', 'o', + -- 'x' or 'd') and the sign ('s', 'u', or ' ' for none). + function Get_Bit_String_Base return Character; + function Get_Bit_String_Sign return Character; + pragma Inline (Get_Bit_String_Base); + pragma Inline (Get_Bit_String_Sign); + -- Set Current_identifier to null_identifier. -- Can be used to catch bugs. procedure Invalidate_Current_Identifier; |