203 lines
4.5 KiB
Ada
203 lines
4.5 KiB
Ada
with H3.Runes;
|
|
with H3.Strings;
|
|
with H3.Storage;
|
|
with H3.Trees;
|
|
with Ada.Finalization;
|
|
with Ada.Text_IO;
|
|
|
|
generic
|
|
type Rune_Type is (<>);
|
|
with package Storage_Pool_box is new H3.Storage.Pool_Box(<>);
|
|
package H3.Compilers is
|
|
package R is new H3.Runes(Rune_Type);
|
|
package S is new H3.Strings(Rune_Type, Storage_Pool_Box);
|
|
|
|
Syntax_Error: exception;
|
|
Internal_Error: exception;
|
|
|
|
--type Compiler is tagged limited private;
|
|
type Compiler is new Ada.Finalization.Limited_Controlled with private;
|
|
|
|
procedure Feed (C: in out Compiler; Data: in S.Rune_Array);
|
|
procedure End_Feed (C: in out Compiler);
|
|
|
|
overriding procedure Initialize (C: in out Compiler);
|
|
overriding procedure Finalize (C: in out Compiler);
|
|
|
|
private
|
|
type Token_Id is (
|
|
TK_ASSIGN,
|
|
TK_BSTR,
|
|
TK_BYTE,
|
|
TK_CHAR,
|
|
TK_COLON,
|
|
TK_CSTR,
|
|
TK_DIRECTIVE,
|
|
TK_DIV,
|
|
TK_DIVDIV,
|
|
TK_DOLLARED_LBRACE,
|
|
TK_DOLLARED_LBRACK,
|
|
TK_DOLLARED_LPAREN,
|
|
TK_EOF,
|
|
TK_EOL,
|
|
TK_HASHED_LBRACE,
|
|
TK_HASHED_LBRACK,
|
|
TK_HASHED_LPAREN,
|
|
TK_IDENT,
|
|
TK_GE,
|
|
TK_GT,
|
|
TK_LBRACE,
|
|
TK_LBRACK,
|
|
TK_LE,
|
|
TK_LPAREN,
|
|
TK_LT,
|
|
TK_MINUS,
|
|
TK_MINUSMINUS,
|
|
TK_MUL,
|
|
TK_MULMUL,
|
|
TK_PLUS,
|
|
TK_PLUSPLUS,
|
|
TK_RBRACE,
|
|
TK_RBRACK,
|
|
TK_RPAREN,
|
|
TK_SEMICOLON
|
|
);
|
|
type Token is record
|
|
Id: Token_Id := TK_EOF;
|
|
Buf: S.Elastic_String;
|
|
end record;
|
|
|
|
-- ------------------------------------------------------------------
|
|
type Location is record
|
|
line: System_Size := 0;
|
|
colm: System_Size := 0;
|
|
-- file: S.Bounded_String_Pointer := null;
|
|
end record;
|
|
|
|
package Feeder is
|
|
type Lex_State_Code is (LX_START, LX_COMMENT, LX_DT, LX_HC);
|
|
|
|
type Lex_Data(State: Lex_State_Code := LX_START) is record
|
|
case State is
|
|
when LX_START =>
|
|
null;
|
|
when LX_COMMENT =>
|
|
null;
|
|
when LX_DT =>
|
|
Row_Start: Integer;
|
|
Row_End: Integer;
|
|
Col_NexT: Integer;
|
|
when LX_HC =>
|
|
Char_Count: System_Size;
|
|
end case;
|
|
end record;
|
|
|
|
type Lex is record
|
|
loc: Location;
|
|
oloc: Location;
|
|
data: Lex_Data;
|
|
end record;
|
|
|
|
type Read is record
|
|
level: Integer;
|
|
flagv: Integer;
|
|
expect_include_file: Boolean;
|
|
expect_vlist_item: Boolean;
|
|
do_include_file: Boolean;
|
|
-- TODO: obj: Cnode;
|
|
end record;
|
|
|
|
type Feed is record
|
|
lx: Lex;
|
|
rd: Read;
|
|
end record;
|
|
|
|
procedure Start (C: in out Compiler; Code: in R.Code; Consumed: out Boolean);
|
|
procedure Comment (C: in out Compiler; Code: in R.Code; Consumed: out Boolean);
|
|
procedure Delim_Token (C: in out Compiler; Code: in R.Code; Consumed: out Boolean);
|
|
procedure Hmarked_Token (C: in out Compiler; Code: in R.Code; Consumed: out Boolean);
|
|
|
|
procedure Update_Location (C: in out Compiler; Code: in R.Code);
|
|
procedure Begin_Include (C: in out Compiler);
|
|
procedure Feed_From_Includee (C: in out Compiler);
|
|
end Feeder;
|
|
|
|
-- ------------------------------------------------------------------
|
|
|
|
package Parser is
|
|
-- move parser types here.
|
|
end Parser;
|
|
|
|
-- ------------------------------------------------------------------
|
|
|
|
type Parse_State_Code is (
|
|
PS_START,
|
|
|
|
PS_INCLUDE_TARGET,
|
|
PS_INCLUDE_TERMINATOR,
|
|
|
|
PS_CLASS_1,
|
|
PS_CLASS_2,
|
|
|
|
PS_FUN_1,
|
|
PS_FUN_2,
|
|
|
|
PS_PLAIN_STATEMENT_START
|
|
);
|
|
|
|
type Parse_Data_Code is (
|
|
PD_VOID,
|
|
PD_STATEMENT,
|
|
PD_ASSIGNMENT
|
|
);
|
|
|
|
type Parse_Data(Code: Parse_Data_Code := PD_VOID) is record
|
|
case Code is
|
|
when PD_VOID =>
|
|
null;
|
|
when PD_STATEMENT =>
|
|
Stmt_Starter: S.Elastic_String;
|
|
when PD_ASSIGNMENT =>
|
|
Assign_Starter: S.Elastic_String;
|
|
end case;
|
|
end record;
|
|
|
|
type Parse_State is record
|
|
Current: Parse_State_Code := PS_START;
|
|
Data: Parse_Data;
|
|
end record;
|
|
|
|
type Parse_State_Array is array(System_Index range<>) of Parse_State;
|
|
|
|
type Parse_State_Stack(Capa: System_Index) is record
|
|
States: Parse_State_Array(System_Index'First .. Capa);
|
|
Top: System_Size := System_Size'First; -- 0
|
|
end record;
|
|
|
|
-- ------------------------------------------------------------------
|
|
|
|
type Stream is record
|
|
Handle: Ada.Text_IO.File_Type;
|
|
Prs_Level: System_Index;
|
|
end record;
|
|
|
|
type Stream_Array is array(System_Index range <>) of Stream;
|
|
|
|
type Include_Stack(Capa: System_Index) is record
|
|
Streams: Stream_Array(System_Index'First .. Capa);
|
|
Top: System_Size := System_Size'First; -- 0
|
|
end record;
|
|
-- ------------------------------------------------------------------
|
|
|
|
--type Compiler is tagged limited record
|
|
type Compiler is new Ada.Finalization.Limited_Controlled with record
|
|
F: Feeder.Feed;
|
|
|
|
Tk: Token;
|
|
Prs: Parse_State_Stack(128); -- TODO: make this dynamic. single access type. dynamic allocation
|
|
Inc: Include_Stack(32); -- TODO: make this dynamic. single access type. dynamic allocation
|
|
|
|
end record;
|
|
|
|
end H3.Compilers;
|