|
DataMuseum.dkPresents historical artifacts from the history of: Rational R1000/400 |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about Rational R1000/400 Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - metrics - download
Length: 5120 (0x1400) Types: Ada Source Notes: 03_class, FILE, R1k_Segment, e3_tag, package body Statements, seg_0381f2
└─⟦8527c1e9b⟧ Bits:30000544 8mm tape, Rational 1000, Arrival backup of disks in PAM's R1000 └─⟦cfc2e13cd⟧ »Space Info Vol 2« └─⟦this⟧
with Expression, More_Statements; with Class_Printer; with Bug_Report; package body Statements is type Node_Structure is record Rule : Natural range 0 .. 2 := 0; Expr : Expression.Node := Expression.Empty_Node; More : More_Statements.Node := More_Statements.Empty_Node; Line : Object.Index := Scanner.Get_Line_Number; end record; procedure Parse (N : in out Node) is use Scanner; begin N := new Node_Structure; if Expression.Is_First (Scanner.Get_Token) then N.Rule := 1; Expression.Parse (N.Expr); More_Statements.Parse (N.More); else case Scanner.Get_Token is when Scanner.Renvoyer => N.Rule := 2; Scanner.Next; Expression.Parse (N.Expr); when others => if not (Scanner.Get_Token = Scanner.Eof or else Scanner.Get_Token = Scanner.Close_Brace) then raise Bug_Report.Unexpected_Token; end if; end case; end if; end Parse; function Is_First (T : Scanner.Token) return Boolean is use Scanner; begin return T = Renvoyer or else Expression.Is_First (T); end Is_First; procedure Unparse (N : Node) is begin case N.Rule is when 0 => null; when 1 => Expression.Unparse (N.Expr); More_Statements.Unparse (N.More); when 2 => Class_Printer.Put_Tab ("renvoyer "); Expression.Unparse (N.Expr); end case; end Unparse; function Interpret (N : Node; Inherited : Object.Reference := Object.Void_Reference) return Object.Reference is Result : Object.Reference; begin Scanner.Put_Line_Number (N.Line); case N.Rule is when 0 => Result := Inherited; when 1 => Result := Expression.Interpret (N.Expr); Result := More_Statements.Interpret (N.More, Result); when 2 => Result := Expression.Interpret (N.Expr); end case; return Result; end Interpret; end Statements;
nblk1=4 nid=3 hdr6=6 [0x00] rec0=1f rec1=00 rec2=01 rec3=05e [0x01] rec0=1e rec1=00 rec2=02 rec3=05e [0x02] rec0=12 rec1=00 rec2=04 rec3=000 [0x03] rec0=05 rec1=00 rec2=04 rec3=000 tail 0x21735bebe84e67e46af12 0x42a00088462060003 Free Block Chain: 0x3: 0000 00 00 01 dd 80 0f 62 65 67 69 6e 20 20 20 20 20 ┆ begin ┆