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

⟦f8583d169⟧ Ada Source

    Length: 9216 (0x2400)
    Types: Ada Source
    Notes: 03_class, FILE, R1k_Segment, e3_tag, package body Liste_Mots_Voca, seg_04682b

Derivation

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

E3 Source Code



with Error, Un_Mot_Du_Voca, Dynamic_Value;

package body Liste_Mots_Voca is

--c'est en fait une liste de complement

    procedure Parse (Dyn_Node : in out Dynamic_Node.Object) is  
        use Lexical_Analyzer;  
        Dyn_Val_Default : Dynamic_Value.Object;
        Dyn_Node_Complement1, Dyn_Node_Complement2, Dyn_Node_Default :
           Dynamic_Node.Object;

    begin

        if (Liste_Mots_Voca.Is_First (Lexical_Analyzer.Get_Token)) then

            Dynamic_Node.Create_Ternary_Operator
               (Dyn_Node, Dynamic_Node.Sentence);

            Un_Mot_Du_Voca.Parse (Dyn_Node_Complement1);
            if Dynamic_Node.Get_Operator (Dyn_Node_Complement1) /=
               "COMPLEMENT" then  
                Error.Set_Type_Error (Error.Complement_Was_Expected_Before);
                raise Error.Excep_Semantic_Error;
            end if;
            if Dynamic_Value.Get_Value
                  (Dynamic_Node.Get_Value
                      (Dynamic_Node.Get_Argument (Dyn_Node_Complement1))) =
               "complement2" then
                Error.Set_Type_Error
                   (Error.Complement2_Sould_Be_In_Second_Place_After_Verb);
                raise Error.Excep_Semantic_Error;
            end if;
            Dynamic_Node.Set_Argument (Dyn_Node, Dyn_Node_Complement1,
                                       Dynamic_Node.Cplt1_Position);

            --creation d'un complement1 et 2 contenant la chaine null par defaut

            Dynamic_Value.Set_Value (Dyn_Val_Default, "",
                                     Dynamic_Value.Voca_Value);
            Dynamic_Node.Create_Value (Dyn_Node_Default);
            Dynamic_Node.Set_Value (Dyn_Node_Default, Dyn_Val_Default);

            Dynamic_Node.Create_Unary_Operator
               (Dyn_Node_Complement2, Dynamic_Node.Complement);
            Dynamic_Node.Set_Argument (Dyn_Node_Complement2, Dyn_Node_Default);

            Dynamic_Node.Set_Argument (Dyn_Node, Dyn_Node_Complement2,
                                       Dynamic_Node.Cplt2_Position);


            if (Liste_Mots_Voca.Is_First (Lexical_Analyzer.Get_Token)) then

                if Dynamic_Node.Does_Exists (Dyn_Node_Complement2) then

                    Un_Mot_Du_Voca.Parse (Dyn_Node_Complement2);

                    if Dynamic_Node.Get_Operator (Dyn_Node_Complement2) /=
                       "COMPLEMENT" then
                        Error.Set_Type_Error (Error.Complement_Expected);
                        raise Error.Excep_Semantic_Error;
                    end if;

                    if Dynamic_Value.Get_Value
                          (Dynamic_Node.Get_Value (Dynamic_Node.Get_Argument
                                                      (Dyn_Node_Complement2))) =
                       "complement1" then
                        Error.Set_Type_Error
                           (Error.
                            Complement1_Sould_Be_In_First_Place_After_Verb);
                        raise Error.Excep_Semantic_Error;
                    end if;

                    Dynamic_Node.Set_Argument (Dyn_Node, Dyn_Node_Complement2,
                                               Dynamic_Node.Cplt2_Position);

                    --else

                    --Text_Io.Put_Line (Lexical_Analyzer.Tokens'Image
                    --                     (Lexical_Analyzer.Get_Token));
                    --if (Is_Follow (Lexical_Analyzer.Get_Token)) then
                    --    Dynamic_Value.Set_Value (Dyn_Val_Default, "", True);
                    --   Dynamic_Node.Create_Value (Dyn_Node_Default);
                    --   Dynamic_Node.Set_Value (Dyn_Node_Default, Dyn_Val_Default);

                    --   Dynamic_Node.Create_Unary_Operator
                    --     (Dyn_Node_Complement2, Dynamic_Node.Complement);
                    --  Dynamic_Node.Set_Argument
                    --    (Dyn_Node_Complement2, Dyn_Node_Default);

                    --  Dynamic_Node.Set_Argument (Dyn_Node, Dyn_Node_Complement2,
                    --                            Dynamic_Node.Cplt2_Position);
                end if;
            end if;
        end if;
    end Parse;


    function Is_First (Un_Token : Lexical_Analyzer.Tokens) return Boolean is
        use Lexical_Analyzer;
    begin
        return ((Un_Token = Complement_Or_Verbe) or
                (Un_Token = Complement1) or (Un_Token = Complement2));
    end Is_First;

    function Is_Follow (Un_Token : Lexical_Analyzer.Tokens) return Boolean is
        use Lexical_Analyzer;
    begin
        return ((Un_Token = Right_Bracket) or
                (Un_Token = Terminator) or (Un_Token = Alors));  
    end Is_Follow;


end Liste_Mots_Voca;

E3 Meta Data

    nblk1=8
    nid=4
    hdr6=c
        [0x00] rec0=1d rec1=00 rec2=01 rec3=02c
        [0x01] rec0=00 rec1=00 rec2=05 rec3=018
        [0x02] rec0=14 rec1=00 rec2=08 rec3=064
        [0x03] rec0=16 rec1=00 rec2=03 rec3=07a
        [0x04] rec0=13 rec1=00 rec2=02 rec3=06c
        [0x05] rec0=1a rec1=00 rec2=07 rec3=000
        [0x06] rec0=5b rec1=2c rec2=00 rec3=026
        [0x07] rec0=08 rec1=60 rec2=48 rec3=359
    tail 0x215433a9086515b8449f9 0x42a00088462060003
Free Block Chain:
  0x4: 0000  00 06 00 09 80 06 74 31 5f 53 6f 75 06 72 2e 09  ┆      t1_Sou r. ┆
  0x6: 0000  00 00 03 fc 80 38 20 20 20 20 20 20 20 20 20 44  ┆     8         D┆