|
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 - download
Length: 5120 (0x1400) Types: Ada Source Notes: 03_class, FILE, R1k_Segment, e3_tag, package body More_Binary, seg_0381bf
└─⟦8527c1e9b⟧ Bits:30000544 8mm tape, Rational 1000, Arrival backup of disks in PAM's R1000 └─ ⟦cfc2e13cd⟧ »Space Info Vol 2« └─⟦this⟧
with Message; with Class_Printer; with Unary; with Bounded_String; package body More_Binary is type Node_Structure is record Rule : Natural range 0 .. 1 := 0; Unar : Unary.Node := Unary.Empty_Node; More : More_Binary.Node := More_Binary.Empty_Node; Mess : Message.Binary; Line : Object.Index := Scanner.Get_Line_Number; end record; procedure Parse (N : in out Node) is use Scanner; begin N := new Node_Structure; N.Rule := 0; Message.Put (Scanner.Get_Value, N.Mess); Scanner.Next; Unary.Parse (N.Unar); if Scanner.Get_Token = Scanner.Binary then N.Rule := 1; More_Binary.Parse (N.More); end if; end Parse; function Is_First (T : Scanner.Token) return Boolean is use Scanner; begin return T = Scanner.Binary; end Is_First; procedure Unparse (N : Node) is type E_Message is (Plus, Moins, Mul, Div, Egal, Diff, Sup, Sup_Egal, Inf, Inf_Egal, Et, Ou, Eou); Token : E_Message; begin Token := E_Message'Value (Bounded_String.Image (Message.Get (N.Mess))); case Token is when Plus => Class_Printer.Put (" + "); when Moins => Class_Printer.Put (" - "); when Mul => Class_Printer.Put (" * "); when Div => Class_Printer.Put (" / "); when Egal => Class_Printer.Put (" = "); when Diff => Class_Printer.Put (" <> "); when Sup => Class_Printer.Put (" > "); when Sup_Egal => Class_Printer.Put (" >= "); when Inf => Class_Printer.Put (" < "); when Inf_Egal => Class_Printer.Put (" <= "); when Et => Class_Printer.Put (" & "); when Ou => Class_Printer.Put (" | "); when Eou => Class_Printer.Put (" # "); end case; Unary.Unparse (N.Unar); if N.Rule = 1 then More_Binary.Unparse (N.More); end if; 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); Result := Unary.Interpret (N.Unar); Message.Put (Result, N.Mess); Result := Message.Send (N.Mess, Inherited); if N.Rule = 1 then Result := More_Binary.Interpret (N.More, Result); end if; return Result; end Interpret; end More_Binary;
nblk1=4 nid=4 hdr6=6 [0x00] rec0=26 rec1=00 rec2=01 rec3=00a [0x01] rec0=1d rec1=00 rec2=03 rec3=012 [0x02] rec0=1e rec1=00 rec2=02 rec3=000 [0x03] rec0=02 rec1=b7 rec2=30 rec3=342 tail 0x21735bbae84e67d238807 0x42a00088462060003 Free Block Chain: 0x4: 0000 00 00 00 0c 80 06 69 6e 61 72 79 3b 06 00 00 00 ┆ inary; ┆