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

⟦df9a8c469⟧ Ada Source

    Length: 12288 (0x3000)
    Types: Ada Source
    Notes: 03_class, FILE, R1k_Segment, e3_tag, package body Scanner, seg_032fa2

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



-- table des symboles

with Text_Io;
with Fichier_Io;
with Bounded_String;
with Reserved_Word;

package body Scanner is
    procedure Open (Name : in Standard.String) is
    begin  
        Fichier_Io.Open (Fichier_Source, Name);
        Scanner.Next;
    end Open;

    procedure Close is
    begin
        Fichier_Io.Close (Fichier_Source);
    end Close;

    function At_End return Boolean is
    begin
        return Fichier_Io.At_End (Fichier_Source);
    end At_End;

    function At_Line return Boolean is
    begin
        return Fichier_Io.At_Line (Fichier_Source);
    end At_Line;

    procedure Next is
        C : Character;
        State : Etat;

    begin  
        Bounded_String.Free (Current_Value);
        if Fichier_Io.At_End (Fichier_Source) then
            Current_Token := Token'(Eof);
        else
            State := Etat'(Normal);
            loop
                if Fichier_Io.At_End (Fichier_Source) then
                    C := Ascii.Eot;
                else
                    C := Fichier_Io.Get (Fichier_Source);
                end if;

                case State is
                    when Normal =>
                        case C is
                            when Ascii.Eot =>
                                Current_Token := Token'(Eof);
                                State := Etat'(Found);

                            when ' ' | Ascii.Cr | Ascii.Ht =>
                                null;

                            when '<' =>
                                Bounded_String.Copy (Current_Value, "Inf");
                                Current_Token := Token'(Binary);
                                State := Etat'(Inf);

                            when '>' =>
                                Bounded_String.Copy (Current_Value, "Sup");
                                Current_Token := Token'(Binary);
                                State := Etat'(Sup);

                            when '=' =>
                                Bounded_String.Copy (Current_Value, "Egal");
                                Current_Token := Token'(Binary);
                                State := Etat'(Found);

                            when '{' | '}' | '(' | ')' | '.' =>
                                Bounded_String.Append (Current_Value, C);
                                Current_Token := Token'(Special);
                                State := Etat'(Found);

                            when '+' =>
                                Bounded_String.Copy (Current_Value, "Plus");
                                Current_Token := Token'(Binary);
                                State := Etat'(Found);

                            when '-' =>
                                Bounded_String.Copy (Current_Value, "Moins");
                                Current_Token := Token'(Binary);
                                State := Etat'(Found);

                            when '*' =>
                                Bounded_String.Copy (Current_Value, "Mul");
                                Current_Token := Token'(Binary);
                                State := Etat'(Found);

                            when '/' =>
                                Bounded_String.Copy (Current_Value, "Div");
                                Current_Token := Token'(Binary);
                                State := Etat'(Found);

                            when '"' =>
                                Bounded_String.Append (Current_Value, C);
                                State := Etat'(String);

                            when '[' =>
                                State := Etat'(Comment);

                            when others =>
                                if C in 'a' .. 'z' or else
                                   C in 'A' .. 'Z' or else C = '_' then  
                                    Bounded_String.Append (Current_Value, C);
                                    State := Etat'(Identifier);
                                elsif C in '0' .. '9' then
                                    Bounded_String.Append (Current_Value, C);
                                    State := Etat'(Number);
                                else
                                    Bounded_String.Append (Current_Value, C);
                                    Current_Token := Token'(Unknown);
                                    State := Etat'(Found);
                                end if;

                        end case;

                    when Number =>
                        if C in '0' .. '9' then
                            Bounded_String.Append (Current_Value, C);
                        else
                            Fichier_Io.Unget (Fichier_Source);
                            Current_Token := Token'(Integer);
                            State := Etat'(Found);
                        end if;

                    when Identifier =>
                        if C in 'a' .. 'z' or else
                           C in 'A' .. 'Z' or else C = '_' then
                            Bounded_String.Append (Current_Value, C);
                        elsif C = ':' then
                            Current_Token := Token'(Keyword);
                            State := Etat'(Found);  
                        else
                            Fichier_Io.Unget (Fichier_Source);
                            Current_Token := Token'(Identifier);
                            Current_Token := Reserved_Word.Reserved_To_Token
                                                (Bounded_String.Image
                                                    (Current_Value));
                            State := Etat'(Found);
                        end if;

                    when String =>
                        Bounded_String.Append (Current_Value, C);
                        if C /= '"' then
                            Current_Token := Token'(String);
                        else
                            State := Etat'(Found_String);
                        end if;

                    when Found_String =>
                        if C /= '"' then
                            Current_Token := Token'(String);
                            State := Etat'(Found);
                            Fichier_Io.Unget (Fichier_Source);
                        else
                            Current_Token := Token'(String);
                            State := Etat'(String);
                        end if;

                    when Sup =>
                        if C = '=' then
                            Bounded_String.Copy (Current_Value, "Sup_Egal");
                            Current_Token := Token'(Binary);
                        else
                            Fichier_Io.Unget (Fichier_Source);
                            State := Etat'(Found);
                        end if;

                    when Inf =>
                        if C = '=' then
                            Bounded_String.Copy (Current_Value, "Inf_Egal");
                            Current_Token := Token'(Binary);
                        else
                            Fichier_Io.Unget (Fichier_Source);
                            State := Etat'(Found);
                        end if;

                    when Comment =>
                        if C = ']' then
                            State := Etat'(Normal);
                        end if;

                    when Found =>
                        null;
                end case;
                exit when (State = Found);
            end loop;
        end if;
    end Next;

    function Get_Value return Object.Tiny_String is
    begin
        return Scanner.Current_Value;
    end Get_Value;

    function Get_Token return Token is
    begin
        -- Next;
        return Scanner.Current_Token;
    end Get_Token;

end Scanner;

E3 Meta Data

    nblk1=b
    nid=2
    hdr6=14
        [0x00] rec0=2a rec1=00 rec2=01 rec3=070
        [0x01] rec0=18 rec1=00 rec2=05 rec3=05c
        [0x02] rec0=14 rec1=00 rec2=04 rec3=064
        [0x03] rec0=03 rec1=00 rec2=08 rec3=01c
        [0x04] rec0=14 rec1=00 rec2=03 rec3=044
        [0x05] rec0=02 rec1=00 rec2=09 rec3=016
        [0x06] rec0=15 rec1=00 rec2=07 rec3=05e
        [0x07] rec0=13 rec1=00 rec2=06 rec3=058
        [0x08] rec0=18 rec1=00 rec2=0b rec3=040
        [0x09] rec0=21 rec1=00 rec2=0a rec3=000
        [0x0a] rec0=1a rec1=00 rec2=04 rec3=000
    tail 0x2152bb35284cc8a91cf00 0x42a00088462060003
Free Block Chain:
  0x2: 0000  00 00 00 3a 80 26 20 20 20 20 20 20 20 20 20 20  ┆   : &          ┆