|
|
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: 6144 (0x1800)
Types: Ada Source
Notes: 03_class, FILE, R1k_Segment, e3_tag, package body Appel, seg_045a61
└─⟦8527c1e9b⟧ Bits:30000544 8mm tape, Rational 1000, Arrival backup of disks in PAM's R1000
└─⟦5a81ac88f⟧ »Space Info Vol 1«
└─⟦this⟧
with Error, Dynamic_Node, Liste_Arguments, Un_Mot_Du_Voca, Nom_Variable;
package body Appel is
procedure Parse (List : in out Action_List.Object) is
use Lexical_Analyzer;
At_Dyn_Node, What_Dyn_Node : Dynamic_Node.Object;
begin
case (Lexical_Analyzer.Get_Token) is
when Ecrire =>
Lexical_Analyzer.Next;
Action_List.Create (List, Action_List.Write_Action);
Liste_Arguments.Parse (List);
when Retirer =>
Lexical_Analyzer.Next;
Action_List.Create (List, Action_List.Remove_From_Set_Of_Word);
Un_Mot_Du_Voca.Parse (What_Dyn_Node);
Action_List.Set_Argument
(List, What_Dyn_Node, Action_List.Source);
if (Lexical_Analyzer.Get_Token /= A) then
Error.Set_Type_Error (Error.A_Expected);
raise Error.Excep_Syntaxe_Error;
end if;
Lexical_Analyzer.Next;
Nom_Variable.Parse (At_Dyn_Node);
Action_List.Set_Argument
(List, At_Dyn_Node, Action_List.Target);
when Ajouter =>
Lexical_Analyzer.Next;
Action_List.Create (List, Action_List.Append_In_Set_Of_Word);
Un_Mot_Du_Voca.Parse (What_Dyn_Node);
Action_List.Set_Argument
(List, What_Dyn_Node, Action_List.Source);
if (Lexical_Analyzer.Get_Token /= A) then
Error.Set_Type_Error (Error.A_Expected);
raise Error.Excep_Syntaxe_Error;
end if;
Lexical_Analyzer.Next;
Nom_Variable.Parse (At_Dyn_Node);
Action_List.Set_Argument
(List, At_Dyn_Node, Action_List.Target);
when Vider =>
Lexical_Analyzer.Next;
Action_List.Create (List, Action_List.Clear_Set_Of_Word);
Nom_Variable.Parse (At_Dyn_Node);
Action_List.Set_Argument
(List, At_Dyn_Node, Action_List.Target);
when Quitter =>
Action_List.Create (List, Action_List.Quit_Action);
Lexical_Analyzer.Next;
when others =>
null;
-- pas erreur car action.parse utilise appel que apres avoir teste les first de appel
end case;
exception
when Lexical_Analyzer.Excep_Eof =>
Error.Set_Type_Error (Error.Unexpected_Eof);
Error.Treat;
raise Error.Excep_Syntaxe_Aborded;
end Parse;
function Is_First (Un_Token : Lexical_Analyzer.Tokens) return Boolean is
use Lexical_Analyzer;
begin
return ((Un_Token = Ecrire) or (Un_Token = Retirer) or
(Un_Token = Ajouter) or
(Un_Token = Vider) or (Un_Token = Quitter));
end Is_First;
end Appel;
nblk1=5
nid=2
hdr6=8
[0x00] rec0=1a rec1=00 rec2=01 rec3=050
[0x01] rec0=17 rec1=00 rec2=04 rec3=034
[0x02] rec0=1a rec1=00 rec2=03 rec3=048
[0x03] rec0=06 rec1=00 rec2=05 rec3=000
[0x04] rec0=06 rec1=00 rec2=05 rec3=000
tail 0x215421410864b88d22d90 0x42a00088462060003
Free Block Chain:
0x2: 0000 00 00 00 04 80 01 79 01 53 79 04 53 79 07 08 09 ┆ y Sy Sy ┆