|
|
DataMuseum.dkPresents historical artifacts from the history of: Rational R1000/400 Tapes |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about Rational R1000/400 Tapes Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - metrics - downloadIndex: B T
Length: 1598 (0x63e)
Types: TextFile
Names: »B«
└─⟦a7d1ea751⟧ Bits:30000550 8mm tape, Rational 1000, !users!projects 94_04_11
└─⟦129cab021⟧ »DATA«
└─⟦this⟧
with Lexical;
use Lexical;
separate (Semantique.Calcul)
procedure Postfixer (Un_Elem : Ptr_Elt) is
Oper : Operateur;
type Priorite is range 0 .. 4;
type Tab_Pr is array (Operateur) of Priorite;
Pr_Pile : constant Tab_Pr :=
Tab_Pr'('+' | '-' => 1, '*' => 2, 'm' | 'p' => 3, others => 0);
Pr_Newop : constant Tab_Pr :=
Tab_Pr'(Finop => 0, '+' | '-' => 1, '*' => 2, others => 4);
begin
if Un_Elem.Isfact then
Calculateur (Un_Elem);
elsif Un_Elem.Op = Finop then
while not Piloper.Empty (Pilop) loop
Oper := Piloper.Top (Pilop);
Piloper.Pop (Pilop);
Calculateur (new Elt'(False, Oper));
end loop;
elsif Un_Elem.Op = ')' then
loop
Oper := Piloper.Top (Pilop);
Piloper.Pop (Pilop);
exit when Oper = '(' or Oper = Finop;
Calculateur (new Elt'(False, Oper));
end loop;
if Oper = Finop then
raise Par_Ferm;
end if;
else
loop
Oper := Piloper.Top (Pilop);
Piloper.Pop (Pilop);
exit when Pr_Newop (Un_Elem.Op) > Pr_Pile (Oper);
Calculateur (new Elt'(False, Oper));
end loop;
Piloper.Push (Oper, Pilop);
Piloper.Push (Un_Elem.Op, Pilop);
end if;
exception
when Par_Ferm =>
Erreurs.Ajouter ("Parenthese fermante incongrue.");
when Err_Op =>
Erreurs.Ajouter ("Operateur inconnu : " & Op_Inconnu);
when Numeric_Error =>
Erreurs.Ajouter ("Nombre trop grand........");
end Postfixer;