|
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: 9216 (0x2400) Types: Ada Source Notes: 03_class, FILE, R1k_Segment, e3_tag, package body Plant, package body Self, seg_03aff8
└─⟦8527c1e9b⟧ Bits:30000544 8mm tape, Rational 1000, Arrival backup of disks in PAM's R1000 └─⟦cfc2e13cd⟧ »Space Info Vol 2« └─⟦this⟧
with Leaf; with List_Generic; with Log_Report; with Oo_Ada_Exception; with Unchecked_Conversion; with Unchecked_Deallocation; package body Plant is type State is record X : Natural; Has_Leaves : Ref_Of_Leaves; Offspring : Natural := 0; Heir : Root.Object; Origin : Root.Object; Multiple : Root.Object; end record; package Leaves is new List_Generic (Element => Leaf.Object); type List_Of_Leaves is record Leaf_Type : Leaves.List; Leaf_Iter : Leaves.Iterator; end record; procedure Free is new Unchecked_Deallocation (State, Object); function Plant_View_Of is new Unchecked_Conversion (Source => Root.Object, Target => Object); function Root_View_Of is new Unchecked_Conversion (Source => Object, Target => Root.Object); function Create (Offspring : Natural := 0; Nb_Leaves : Natural := 1) return Object is separate; procedure Delete (This_Object : in out Object; Marker : Boolean := False) is separate; procedure Set_X (This_Object : Object; This_X : Natural) is begin This_Object.X := This_X; end Set_X; function Get_X (This_Object : Object) return Natural is begin return This_Object.X; end Get_X; procedure Set_Leaves (This_Object : Object; With_Leaves : Ref_Of_Leaves) is begin This_Object.Has_Leaves := With_Leaves; end Set_Leaves; function Get_Leaves (This_Object : Object) return Ref_Of_Leaves is begin return This_Object.Has_Leaves; end Get_Leaves; package Self is procedure Grow (This_Object : Object; Marker : Boolean := False); end Self; package body Self is separate; procedure Grow (This_Object : Object; Marker : Boolean := False) is separate; procedure Image (This_Object : Object) is separate; procedure Free (List : in out Ref_Of_Leaves) is begin Leaves.Free (List.Leaf_Type); end Free; procedure Insert (Element : Leaf.Object; In_List : Ref_Of_Leaves) is A_List : Leaves.List; begin A_List := Leaves.Make (Element, In_List.Leaf_Type); In_List.Leaf_Type := A_List; end Insert; function Nil return Ref_Of_Leaves is A_Ref_Of_Leaves : Ref_Of_Leaves := new List_Of_Leaves; begin A_Ref_Of_Leaves.Leaf_Type := Leaves.Nil; return A_Ref_Of_Leaves; end Nil; function Is_Empty (List : Ref_Of_Leaves) return Boolean is begin return Leaves.Is_Empty (List.Leaf_Type); end Is_Empty; function Arg_Number (List : Ref_Of_Leaves) return Natural is begin return Leaves.Length (List.Leaf_Type); end Arg_Number; procedure Init (A_List : Ref_Of_Leaves) is begin Leaves.Init (A_List.Leaf_Iter, A_List.Leaf_Type); end Init; procedure Next (A_List : Ref_Of_Leaves) is begin Leaves.Next (A_List.Leaf_Iter); end Next; function Value (A_List : Ref_Of_Leaves) return Leaf.Object is begin return Leaves.Value (A_List.Leaf_Iter); end Value; function Done (A_List : Ref_Of_Leaves) return Boolean is begin return Leaves.Done (A_List.Leaf_Iter); end Done; function Part_Of (This_Origin_Object : Root.Object) return Object is This_Object : Object; begin This_Object := Plant_View_Of (S => Root.Get_Heir (This_Origin_Object)); return This_Object; end Part_Of; function Protected_Conv (Source : Root.Object) return Object is begin return Plant_View_Of (Source); end Protected_Conv; procedure Set_Heir (This_Object : in out Object; Heir : Root.Object) is begin This_Object.Heir := Heir; end Set_Heir; function Get_Heir (This_Object : Object) return Root.Object is begin return This_Object.Heir; end Get_Heir; procedure Set_Origin (This_Object : in out Object; Origin : Root.Object) is begin This_Object.Origin := Origin; end Set_Origin; function Get_Origin (This_Object : Object) return Root.Object is begin return This_Object.Origin; end Get_Origin; procedure Set_Multiple (This_Object : in out Object; Multiple : Root.Object) is begin This_Object.Multiple := Multiple; end Set_Multiple; function Get_Multiple (This_Object : Object) return Root.Object is begin return This_Object.Multiple; end Get_Multiple; end Plant;
nblk1=8 nid=3 hdr6=c [0x00] rec0=26 rec1=00 rec2=01 rec3=080 [0x01] rec0=27 rec1=00 rec2=04 rec3=040 [0x02] rec0=27 rec1=00 rec2=05 rec3=00a [0x03] rec0=22 rec1=00 rec2=06 rec3=078 [0x04] rec0=27 rec1=00 rec2=08 rec3=03a [0x05] rec0=04 rec1=00 rec2=07 rec3=000 [0x06] rec0=11 rec1=00 rec2=05 rec3=000 [0x07] rec0=04 rec1=00 rec2=03 rec3=001 tail 0x217383c2285126b0c3bf1 0x42a00088462060003 Free Block Chain: 0x3: 0000 00 02 01 26 80 36 28 54 68 69 73 5f 4f 62 6a 65 ┆ & 6(This_Obje┆ 0x2: 0000 00 00 03 fc 80 2c 64 65 6c 65 74 65 20 3a 20 20 ┆ ,delete : ┆