added code to read cdr
This commit is contained in:
parent
73c29ce53b
commit
c7868449f7
@ -48,7 +48,7 @@ package body H2.Scheme is
|
|||||||
|
|
||||||
subtype Moved_Object_Record is Object_Record (Moved_Object, 0);
|
subtype Moved_Object_Record is Object_Record (Moved_Object, 0);
|
||||||
|
|
||||||
subtype Opcode_Type is Object_Integer range 0 .. 8;
|
subtype Opcode_Type is Object_Integer range 0 .. 10;
|
||||||
Opcode_Exit: constant Opcode_Type := Opcode_Type'(0);
|
Opcode_Exit: constant Opcode_Type := Opcode_Type'(0);
|
||||||
Opcode_Evaluate_Object: constant Opcode_Type := Opcode_Type'(1);
|
Opcode_Evaluate_Object: constant Opcode_Type := Opcode_Type'(1);
|
||||||
Opcode_Evaluate_Group: constant Opcode_Type := Opcode_Type'(2); -- (begin ...) and closure apply
|
Opcode_Evaluate_Group: constant Opcode_Type := Opcode_Type'(2); -- (begin ...) and closure apply
|
||||||
@ -57,7 +57,9 @@ package body H2.Scheme is
|
|||||||
Opcode_Apply: constant Opcode_Type := Opcode_Type'(5);
|
Opcode_Apply: constant Opcode_Type := Opcode_Type'(5);
|
||||||
Opcode_Read_Object: constant Opcode_Type := Opcode_Type'(6);
|
Opcode_Read_Object: constant Opcode_Type := Opcode_Type'(6);
|
||||||
Opcode_Read_List: constant Opcode_Type := Opcode_Type'(7);
|
Opcode_Read_List: constant Opcode_Type := Opcode_Type'(7);
|
||||||
Opcode_Close_List: constant Opcode_Type := Opcode_Type'(8);
|
Opcode_Read_List_Cdr: constant Opcode_Type := Opcode_Type'(8);
|
||||||
|
Opcode_Read_List_End: constant Opcode_Type := Opcode_Type'(9);
|
||||||
|
Opcode_Close_List: constant Opcode_Type := Opcode_Type'(10);
|
||||||
|
|
||||||
-----------------------------------------------------------------------------
|
-----------------------------------------------------------------------------
|
||||||
-- COMMON OBJECTS
|
-- COMMON OBJECTS
|
||||||
@ -867,7 +869,8 @@ Text_IO.Put_Line (">>> [GC DONE]");
|
|||||||
end Set_Cdr;
|
end Set_Cdr;
|
||||||
|
|
||||||
|
|
||||||
function Reverse_Cons (Source: in Object_Pointer) return Object_Pointer is
|
function Reverse_Cons (Source: in Object_Pointer;
|
||||||
|
Last_Cdr: in Object_Pointer := Nil_Pointer) return Object_Pointer is
|
||||||
pragma Assert (Is_Cons(Source));
|
pragma Assert (Is_Cons(Source));
|
||||||
|
|
||||||
-- Note: The non-nil cdr in the last cons cell gets lost.
|
-- Note: The non-nil cdr in the last cons cell gets lost.
|
||||||
@ -876,7 +879,8 @@ Text_IO.Put_Line (">>> [GC DONE]");
|
|||||||
Next: Object_Pointer;
|
Next: Object_Pointer;
|
||||||
Prev: Object_Pointer;
|
Prev: Object_Pointer;
|
||||||
begin
|
begin
|
||||||
Prev := Nil_Pointer;
|
--Prev := Nil_Pointer;
|
||||||
|
Prev := Last_Cdr;
|
||||||
Ptr := Source;
|
Ptr := Source;
|
||||||
loop
|
loop
|
||||||
Next := Get_Cdr(Ptr);
|
Next := Get_Cdr(Ptr);
|
||||||
@ -2573,9 +2577,12 @@ Text_IO.Put_Line (">>>>>>>>>>>>>>>>>>>>>>> Token: " & Interp.Token.Value.Ptr(1..
|
|||||||
|
|
||||||
procedure Read_List is
|
procedure Read_List is
|
||||||
V: Object_Pointer;
|
V: Object_Pointer;
|
||||||
Period: Standard.Boolean := Standard.False;
|
|
||||||
begin
|
begin
|
||||||
<<Start_Over>>
|
-- This procedure reads each token in a list.
|
||||||
|
-- If the list contains no period, this procedure reads up to the
|
||||||
|
-- closing right paranthesis; If a period is contained, it transfers
|
||||||
|
-- the control over to Read_List_Cdr.
|
||||||
|
|
||||||
Fetch_Token;
|
Fetch_Token;
|
||||||
|
|
||||||
case Interp.Token.Kind is
|
case Interp.Token.Kind is
|
||||||
@ -2600,26 +2607,18 @@ Ada.Text_IO.Put_Line ("ERROR: PREMATURE LIST END");
|
|||||||
-- . immediately after (
|
-- . immediately after (
|
||||||
raise Syntax_Error;
|
raise Syntax_Error;
|
||||||
else
|
else
|
||||||
Period := Standard.True;
|
Set_Frame_Opcode (Interp.Stack, Opcode_Read_List_Cdr);
|
||||||
goto Start_Over;
|
|
||||||
end if;
|
end if;
|
||||||
|
|
||||||
when String_Token =>
|
when String_Token =>
|
||||||
V := Make_String (Interp.Self, Interp.Token.Value.Ptr.all(1..Interp.Token.Value.Last));
|
V := Make_String (Interp.Self, Interp.Token.Value.Ptr.all(1..Interp.Token.Value.Last));
|
||||||
-- TODO: make V gc-aware
|
-- TODO: make V gc-aware
|
||||||
if Period then
|
Chain_Frame_Return (Interp, Interp.Stack, V);
|
||||||
|
|
||||||
else
|
|
||||||
Chain_Frame_Return (Interp, Interp.Stack, V);
|
|
||||||
end if;
|
|
||||||
|
|
||||||
when Identifier_Token =>
|
when Identifier_Token =>
|
||||||
V := Make_Symbol (Interp.Self, Interp.Token.Value.Ptr.all(1..Interp.Token.Value.Last));
|
V := Make_Symbol (Interp.Self, Interp.Token.Value.Ptr.all(1..Interp.Token.Value.Last));
|
||||||
-- TODO: make V gc-aware
|
-- TODO: make V gc-aware
|
||||||
if Period then
|
Chain_Frame_Return (Interp, Interp.Stack, V);
|
||||||
else
|
|
||||||
Chain_Frame_Return (Interp, Interp.Stack, V);
|
|
||||||
end if
|
|
||||||
|
|
||||||
when others =>
|
when others =>
|
||||||
-- TODO: set various error info
|
-- TODO: set various error info
|
||||||
@ -2627,6 +2626,64 @@ Ada.Text_IO.Put_Line ("ERROR: PREMATURE LIST END");
|
|||||||
end case;
|
end case;
|
||||||
end Read_List;
|
end Read_List;
|
||||||
|
|
||||||
|
procedure Read_List_Cdr is
|
||||||
|
V: Object_Pointer;
|
||||||
|
begin
|
||||||
|
-- This procedure reads the first token after a period has been read.
|
||||||
|
-- It transfers the control over to Read_List_End once it has read
|
||||||
|
-- and processed the token. It chains the value made of the token
|
||||||
|
-- to the front of the frame's return value list expecting Read_List_End
|
||||||
|
-- to handle the first item specially.
|
||||||
|
Fetch_Token;
|
||||||
|
|
||||||
|
case Interp.Token.Kind is
|
||||||
|
when End_Token =>
|
||||||
|
Ada.Text_IO.Put_Line ("ERROR: PREMATURE LIST END");
|
||||||
|
raise Syntax_Error;
|
||||||
|
|
||||||
|
when Left_Parenthesis_Token =>
|
||||||
|
Set_Frame_Opcode (Interp.Stack, Opcode_Read_List_End);
|
||||||
|
Push_Frame (Interp, Opcode_Read_List, Nil_Pointer);
|
||||||
|
|
||||||
|
when String_Token =>
|
||||||
|
V := Make_String (Interp.Self, Interp.Token.Value.Ptr.all(1..Interp.Token.Value.Last));
|
||||||
|
-- TODO: make V gc-aware
|
||||||
|
Set_Frame_Opcode (Interp.Stack, Opcode_Read_List_End);
|
||||||
|
Chain_Frame_Return (Interp, Interp.Stack, V);
|
||||||
|
|
||||||
|
when Identifier_Token =>
|
||||||
|
V := Make_Symbol (Interp.Self, Interp.Token.Value.Ptr.all(1..Interp.Token.Value.Last));
|
||||||
|
-- TODO: make V gc-aware
|
||||||
|
Set_Frame_Opcode (Interp.Stack, Opcode_Read_List_End);
|
||||||
|
Chain_Frame_Return (Interp, Interp.Stack, V);
|
||||||
|
|
||||||
|
when others =>
|
||||||
|
-- TODO: set various error info
|
||||||
|
raise Syntax_Error;
|
||||||
|
end case;
|
||||||
|
|
||||||
|
end Read_List_Cdr;
|
||||||
|
|
||||||
|
procedure Read_List_End is
|
||||||
|
V: Object_Pointer;
|
||||||
|
A: Object_Pointer;
|
||||||
|
begin
|
||||||
|
Fetch_Token;
|
||||||
|
|
||||||
|
case Interp.Token.Kind is
|
||||||
|
when Right_Parenthesis_Token =>
|
||||||
|
V := Get_Frame_Return(Interp.Stack);
|
||||||
|
pragma Assert (V /= Nil_Pointer);
|
||||||
|
-- The first item in the chain is actually Cdr of the last cell.
|
||||||
|
V := Reverse_Cons(Get_Cdr(V), Get_Car(V)); -- TODO: GC
|
||||||
|
Pop_Frame (Interp);
|
||||||
|
Chain_Frame_Return (Interp, Interp.Stack, V);
|
||||||
|
when others =>
|
||||||
|
raise Syntax_Error;
|
||||||
|
end case;
|
||||||
|
end Read_List_End;
|
||||||
|
|
||||||
|
|
||||||
procedure Close_List is
|
procedure Close_List is
|
||||||
V: Object_Pointer;
|
V: Object_Pointer;
|
||||||
begin
|
begin
|
||||||
@ -2758,8 +2815,15 @@ Ada.Text_IO.Put_Line ("INFO: NO MORE TOKEN ");
|
|||||||
when Opcode_Read_List =>
|
when Opcode_Read_List =>
|
||||||
Read_List;
|
Read_List;
|
||||||
|
|
||||||
|
when Opcode_Read_List_Cdr =>
|
||||||
|
Read_List_Cdr;
|
||||||
|
|
||||||
|
when Opcode_Read_List_End =>
|
||||||
|
Read_List_End;
|
||||||
|
|
||||||
when Opcode_Close_List =>
|
when Opcode_Close_List =>
|
||||||
Close_List;
|
Close_List;
|
||||||
|
|
||||||
end case;
|
end case;
|
||||||
end loop;
|
end loop;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user