DataMuseum.dk

Presents historical artifacts from the history of:

Rational R1000/400

This is an automatic "excavation" of a thematic subset of
artifacts from Datamuseum.dk's BitArchive.

See our Wiki for more about Rational R1000/400

Excavated with: AutoArchaeologist - Free & Open Source Software.


top - download

⟦7f35c5c1a⟧ Ada Source

    Length: 9216 (0x2400)
    Types: Ada Source
    Notes: 03_class, FILE, R1k_Segment, e3_tag, package body Plant, package body Self, seg_03aff8

Derivation

└─⟦8527c1e9b⟧ Bits:30000544 8mm tape, Rational 1000, Arrival backup of disks in PAM's R1000
    └─ ⟦cfc2e13cd⟧ »Space Info Vol 2« 
        └─⟦this⟧ 

E3 Source Code



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;

E3 Meta Data

    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 :  ┆