changed to use the subpackaged rune symbols in the rune classification functions
This commit is contained in:
parent
db230f8807
commit
84762f7682
@ -45,6 +45,9 @@ ada.text_io.put_line("");
|
|||||||
null;
|
null;
|
||||||
when TK_CSTR =>
|
when TK_CSTR =>
|
||||||
null;
|
null;
|
||||||
|
when TK_DIRECTIVE =>
|
||||||
|
--Push_Feed_Layer (...
|
||||||
|
null;
|
||||||
when TK_EOF =>
|
when TK_EOF =>
|
||||||
null;
|
null;
|
||||||
when TK_EOL =>
|
when TK_EOL =>
|
||||||
@ -150,10 +153,20 @@ ada.text_io.put_line("");
|
|||||||
Set_Lexer_State (C, LX_OP_LESS, Code);
|
Set_Lexer_State (C, LX_OP_LESS, Code);
|
||||||
elsif R.Is_Rune(Code, R.V.Right_Arrow) then
|
elsif R.Is_Rune(Code, R.V.Right_Arrow) then
|
||||||
Set_Lexer_State (C, LX_OP_GREATER, Code);
|
Set_Lexer_State (C, LX_OP_GREATER, Code);
|
||||||
|
elsif R.Is_Rune(Code, R.V.Number_Sign) then
|
||||||
|
Set_Lexer_State (C, LX_DIRECTIVE);
|
||||||
else
|
else
|
||||||
raise Syntax_Error;
|
raise Syntax_Error;
|
||||||
end if;
|
end if;
|
||||||
|
|
||||||
|
when LX_DIRECTIVE =>
|
||||||
|
if R.Is_Alnum(Code) or else R.Is_Rune(Code, R.V.Underline) then
|
||||||
|
Feed_Token (C, Code);
|
||||||
|
else
|
||||||
|
End_Token (C, TK_DIRECTIVE);
|
||||||
|
goto Start_Over;
|
||||||
|
end if;
|
||||||
|
|
||||||
when LX_OP_GREATER =>
|
when LX_OP_GREATER =>
|
||||||
if R.Is_Rune(Code, R.V.Equal_Sign) then
|
if R.Is_Rune(Code, R.V.Equal_Sign) then
|
||||||
End_Token (C, TK_GE, Code);
|
End_Token (C, TK_GE, Code);
|
||||||
|
@ -18,6 +18,7 @@ private
|
|||||||
type Lexer_State is (
|
type Lexer_State is (
|
||||||
LX_START,
|
LX_START,
|
||||||
LX_COMMENT,
|
LX_COMMENT,
|
||||||
|
LX_DIRECTIVE,
|
||||||
LX_IDENT,
|
LX_IDENT,
|
||||||
LX_NUMBER,
|
LX_NUMBER,
|
||||||
LX_OP_GREATER,
|
LX_OP_GREATER,
|
||||||
@ -32,6 +33,7 @@ private
|
|||||||
TK_BYTE,
|
TK_BYTE,
|
||||||
TK_CHAR,
|
TK_CHAR,
|
||||||
TK_CSTR,
|
TK_CSTR,
|
||||||
|
TK_DIRECTIVE,
|
||||||
TK_EOF,
|
TK_EOF,
|
||||||
TK_EOL,
|
TK_EOL,
|
||||||
TK_IDENT,
|
TK_IDENT,
|
||||||
|
@ -5,9 +5,6 @@ package body H3.Runes is
|
|||||||
package UC renames System.UTF_32;
|
package UC renames System.UTF_32;
|
||||||
use type System.UTF_32.Category;
|
use type System.UTF_32.Category;
|
||||||
|
|
||||||
SP: constant Rune := Rune'Val(32);
|
|
||||||
HT: constant Rune := Rune'Val(9);
|
|
||||||
|
|
||||||
function Is_Alpha (V: in Rune) return Boolean is
|
function Is_Alpha (V: in Rune) return Boolean is
|
||||||
begin
|
begin
|
||||||
return UC.Is_UTF_32_Letter(Rune'Pos(V));
|
return UC.Is_UTF_32_Letter(Rune'Pos(V));
|
||||||
@ -31,7 +28,7 @@ package body H3.Runes is
|
|||||||
|
|
||||||
function Is_Blank (V: in Rune) return Boolean is
|
function Is_Blank (V: in Rune) return Boolean is
|
||||||
begin
|
begin
|
||||||
return V = SP or else V = HT;
|
return V = Runes.V.Space or else V = Runes.V.HT;
|
||||||
end Is_Blank;
|
end Is_Blank;
|
||||||
|
|
||||||
function Is_Blank (C: in Code) return Boolean is
|
function Is_Blank (C: in Code) return Boolean is
|
||||||
@ -61,7 +58,7 @@ package body H3.Runes is
|
|||||||
|
|
||||||
function Is_Graph (V: in Rune) return Boolean is
|
function Is_Graph (V: in Rune) return Boolean is
|
||||||
begin
|
begin
|
||||||
return Is_Print(V) and then V /= SP;
|
return Is_Print(V) and then V /= Runes.V.Space;
|
||||||
end Is_Graph;
|
end Is_Graph;
|
||||||
|
|
||||||
function Is_Graph (C: in Code) return Boolean is
|
function Is_Graph (C: in Code) return Boolean is
|
||||||
@ -104,7 +101,7 @@ package body H3.Runes is
|
|||||||
begin
|
begin
|
||||||
return UC.Is_UTF_32_Space(Rune'Pos(V)) or else
|
return UC.Is_UTF_32_Space(Rune'Pos(V)) or else
|
||||||
UC.Is_UTF_32_Line_Terminator(Rune'Pos(V)) or else
|
UC.Is_UTF_32_Line_Terminator(Rune'Pos(V)) or else
|
||||||
V = HT;
|
V = Runes.V.HT;
|
||||||
end Is_Space;
|
end Is_Space;
|
||||||
|
|
||||||
function Is_Space (C: in Code) return Boolean is
|
function Is_Space (C: in Code) return Boolean is
|
||||||
|
Loading…
x
Reference in New Issue
Block a user