|
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 Dictionnary, seg_04732a
└─⟦8527c1e9b⟧ Bits:30000544 8mm tape, Rational 1000, Arrival backup of disks in PAM's R1000 └─ ⟦5a81ac88f⟧ »Space Info Vol 1« └─⟦this⟧
with Generic_Binary_Tree, Unbounded_String, Error; package body Dictionnary is package Unlimited_String is new Unbounded_String (10); function "<" (C1, C2 : Unlimited_String.Variable_String) return Boolean; function Are_Equal (C1, C2 : Unlimited_String.Variable_String) return Boolean; procedure Copy (Source : in Unlimited_String.Variable_String; Target : in out Unlimited_String.Variable_String); package Word_Tree is new Generic_Binary_Tree (Unlimited_String.Variable_String, "<", Are_Equal, Copy); Verbs_Dictionnary : Word_Tree.Object; Complements_Dictionnary : Word_Tree.Object; Storage_Kind : Kind_Of_Storage; function "<" (C1, C2 : Unlimited_String.Variable_String) return Boolean is begin return (Unlimited_String.Image (C1) < Unlimited_String.Image (C2)); end "<"; function Are_Equal (C1, C2 : Unlimited_String.Variable_String) return Boolean is begin return (Unlimited_String.Image (C1) = Unlimited_String.Image (C2)); end Are_Equal; procedure Copy (Source : in Unlimited_String.Variable_String; Target : in out Unlimited_String.Variable_String) is begin Unlimited_String.Copy (Target, Source); end Copy; procedure Set_Kind_Of_Storage (Kind : Kind_Of_Storage) is begin Storage_Kind := Kind; end Set_Kind_Of_Storage; procedure Insert (S : String) is begin if Is_Verb (S) then Error.Set_Type_Error (Error.This_Word_Is_Already_A_Verb); raise Error.Excep_Semantic_Error; elsif Is_Complement (S) then Error.Set_Type_Error (Error.This_Word_Is_Already_A_Complement); raise Error.Excep_Semantic_Error; end if; case Storage_Kind is when Verb => Word_Tree.Insert (Verbs_Dictionnary, Unlimited_String.Value (S)); when Complement => Word_Tree.Insert (Complements_Dictionnary, Unlimited_String.Value (S)); end case; end Insert; function Is_Verb (S : String) return Boolean is begin return Word_Tree.Exists (Verbs_Dictionnary, Unlimited_String.Value (S)); end Is_Verb; function Is_Complement (S : String) return Boolean is begin return Word_Tree.Exists (Complements_Dictionnary, Unlimited_String.Value (S)); end Is_Complement; end Dictionnary;
nblk1=4 nid=2 hdr6=6 [0x00] rec0=1d rec1=00 rec2=01 rec3=02c [0x01] rec0=1c rec1=00 rec2=03 rec3=016 [0x02] rec0=14 rec1=00 rec2=04 rec3=000 [0x03] rec0=03 rec1=6e rec2=d1 rec3=742 tail 0x21544249686536ebf66d4 0x42a00088462060003 Free Block Chain: 0x2: 0000 00 00 02 da 80 27 20 20 20 57 6f 72 64 5f 54 72 ┆ ' Word_Tr┆