|
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: 19456 (0x4c00) Types: Ada Source Notes: 03_class, FILE, R1k_Segment, e3_tag, package body Choix_Trt, seg_050733
└─⟦8527c1e9b⟧ Bits:30000544 8mm tape, Rational 1000, Arrival backup of disks in PAM's R1000 └─⟦5a81ac88f⟧ »Space Info Vol 1« └─⟦this⟧
with Trame_Ihm_68; with Objet_Generic; with Bdd; with Lecteur_68; with Lecteur_Zone_68; with Acces_68; with Plage_68; with Carte_Groupe_68; with Carte_68; with General_Defs; with Config_Cl35; with Conversion; with Com_Cl35; with Ss_Zone_68; with Zone_68; with Evenement_68; with Com_Ihm; with Jj_Hh_Mm_68; with Buffer; with Heure; package body Choix_Trt is Max_Taille_Buff_Evt : constant Natural := 200; Max_Evt_Lecteur : constant := 100; package Pack_Buffer is new Buffer (Item => Evenement_68.Object, Taille => Max_Taille_Buff_Evt); Buff_Evt : Pack_Buffer.Object; type T_Action_En_Cours is (Debut, Phase_De_Config, Fonctionnement_Normal); Action_En_Cours : T_Action_En_Cours := Debut; function Trame_Ihm_To_Objet_Generic (Trame : Trame_Ihm_68.Object) return Objet_Generic.Object; procedure Creation_Bdd (Trame : Trame_Ihm_68.Object); procedure Modification_Bdd (Trame : Trame_Ihm_68.Object); procedure Suppression_Bdd (Trame : Trame_Ihm_68.Object); procedure Programmation_Config; procedure Rapport_Cl35; procedure Aiguillage_Error is Trame : Trame_Ihm_68.Object; begin Trame_Ihm_68.Create (O => Trame, Action => Trame_Ihm_68.Nack); Com_Ihm.Ecriture (Trame_Ihm_68.Image (Trame)); end Aiguillage_Error; procedure Aiguillage (S : String) is use Trame_Ihm_68; Trame : Trame_Ihm_68.Object; begin Trame := Trame_Ihm_68.Value (S); case Action_En_Cours is when Debut => if Get_Action (Trame) = Config then Action_En_Cours := Phase_De_Config; else Aiguillage_Error; end if; when Phase_De_Config => case Get_Action (Trame) is when Creation => Creation_Bdd (Trame); when Suppression => Suppression_Bdd (Trame); when Modification => Modification_Bdd (Trame); when Fin_Config => Programmation_Config; Action_En_Cours := Fonctionnement_Normal; when others => Aiguillage_Error; end case; when Fonctionnement_Normal => case Get_Action (Trame) is when Config => Action_En_Cours := Phase_De_Config; when Rapport => Rapport_Cl35; when others => Aiguillage_Error; end case; end case; end Aiguillage; function Trame_Ihm_To_Objet_Generic (Trame : Trame_Ihm_68.Object) return Objet_Generic.Object is O : Objet_Generic.Object; begin Objet_Generic.Create (O => O, Type_Objet => Objet_Generic.T_Type_Objet (Trame_Ihm_68.Get_Type_Objet (Trame)), S => Trame_Ihm_68.Get_Chaine (Trame)); return O; end Trame_Ihm_To_Objet_Generic; procedure Creation_Bdd (Trame : Trame_Ihm_68.Object) is begin Bdd.Add_Item (Trame_Ihm_To_Objet_Generic (Trame)); end Creation_Bdd; procedure Modification_Bdd (Trame : Trame_Ihm_68.Object) is use Trame_Ihm_68; Trame_Mod_Error : exception; P : Natural; Og1, Og2 : Objet_Generic.Object; S : constant String := Get_Chaine (Trame); Lecteur1, Lecteur2 : Lecteur_68.Object; Carte1, Carte2 : Carte_68.Object; Plage1, Plage2 : Plage_68.Object; Acces1, Acces2 : Acces_68.Object; L_Z1, L_Z2 : Lecteur_Zone_68.Object; C_G1, C_G2 : Carte_Groupe_68.Object; begin case Get_Type_Objet (Trame) is when Lecteur => Lecteur_68.Value (S, Lecteur1, P); Lecteur_68.Value (S (P + 1 .. S'Last), Lecteur2, P); Objet_Generic.Create (Og1, Lecteur1); Objet_Generic.Create (Og2, Lecteur2); Bdd.Mod_Item (Item => Og1, Par => Og2); when Plage => Plage_68.Value (S, Plage1, P); Plage_68.Value (S (P + 1 .. S'Last), Plage2, P); Objet_Generic.Create (Og1, Plage1); Objet_Generic.Create (Og2, Plage2); Bdd.Mod_Item (Item => Og1, Par => Og2); when Acces => Acces_68.Value (S, Acces1, P); Acces_68.Value (S (P + 1 .. S'Last), Acces2, P); Objet_Generic.Create (Og1, Acces1); Objet_Generic.Create (Og2, Acces2); Bdd.Mod_Item (Item => Og1, Par => Og2); when Carte => Carte_68.Value (S, Carte1, P); Carte_68.Value (S (P + 1 .. S'Last), Carte2, P); Objet_Generic.Create (Og1, Carte1); Objet_Generic.Create (Og2, Carte2); Bdd.Mod_Item (Item => Og1, Par => Og2); when Lecteur_Zone => Lecteur_Zone_68.Value (S, L_Z1, P); Lecteur_Zone_68.Value (S (P + 1 .. S'Last), L_Z2, P); Objet_Generic.Create (Og1, L_Z1); Objet_Generic.Create (Og2, L_Z2); Bdd.Mod_Item (Item => Og1, Par => Og2); when Carte_Groupe => Carte_Groupe_68.Value (S, C_G1, P); Carte_Groupe_68.Value (S (P + 1 .. S'Last), C_G2, P); Objet_Generic.Create (Og1, C_G1); Objet_Generic.Create (Og2, C_G2); Bdd.Mod_Item (Item => Og1, Par => Og2); when Horaire => Heure.Set (Jj_Hh_Mm_68.Value (S)); when others => raise Trame_Mod_Error; end case; end Modification_Bdd; procedure Suppression_Bdd (Trame : Trame_Ihm_68.Object) is begin Bdd.Rem_Item (Trame_Ihm_To_Objet_Generic (Trame)); end Suppression_Bdd; procedure Lecture_Cl35 is Bs : constant General_Defs.Byte_String := Com_Cl35.Lecture; begin null; --Text_Io.Put_Line (Conversion.Image_Hex (Bs)); end Lecture_Cl35; procedure Invalide_Carte (Lecteur : Lecteur_68.Object) is Carte1, Carte2 : Carte_68.Object; Plage : Plage_68.Object; Ss_Zone : Ss_Zone_68.Object; begin Carte_68.Create (O => Carte1, Numero => Carte_68.T_Carte'First); Carte_68.Create (O => Carte2, Numero => Carte_68.T_Carte'Last); Ss_Zone_68.Initialise (Ss_Zone); Plage_68.Create (O => Plage, Numero => Plage_68.T_Plage'First, Zone => Zone_68.T_Zone'First, Per_1 => Ss_Zone, Per_2 => Ss_Zone, Per_3 => Ss_Zone); for I in Plage_68.T_Plage'First .. Plage_68.T_Plage'Last loop Plage_68.Set_Numero (Plage, I); Com_Cl35.Ecriture (Config_Cl35.Cl35_Invalide_Groupe_Carte (De_La_Carte => Carte1, A_La_Carte => Carte2, Plage => Plage, Lecteur => Lecteur)); Lecture_Cl35; end loop; end Invalide_Carte; procedure Programmation_Lecteur (Lecteur : Objet_Generic.Object) is Lect : Lecteur_68.Object; begin Lect := Objet_Generic.Get_Lecteur (Lecteur); Invalide_Carte (Lect); Com_Cl35.Ecriture (Config_Cl35.Cl35_Parametre (Lect)); Lecture_Cl35; Com_Cl35.Ecriture (Config_Cl35.Cl35_Site (Lect)); Lecture_Cl35; Com_Cl35.Ecriture (Config_Cl35.Cl35_Jjhhmm (Lect, Heure.Get)); Lecture_Cl35; Com_Cl35.Ecriture (Config_Cl35.Cl35_Beep (Lect)); Lecture_Cl35; end Programmation_Lecteur; procedure Programmation_Plage (Lecteur : Objet_Generic.Object; Plage : Objet_Generic.Object) is Lec : Lecteur_68.Object; Pla : Plage_68.Object; begin Lec := Objet_Generic.Get_Lecteur (Lecteur); Pla := Objet_Generic.Get_Plage (Plage); Com_Cl35.Ecriture (Config_Cl35.Cl35_Plage (Lec, Pla)); Lecture_Cl35; end Programmation_Plage; procedure Programmation_Carte (Lecteur : Objet_Generic.Object; Carte : Objet_Generic.Object; Plage : Objet_Generic.Object) is Lec : Lecteur_68.Object; Car : Carte_68.Object; Pla : Plage_68.Object; begin Lec := Objet_Generic.Get_Lecteur (Lecteur); Car := Objet_Generic.Get_Carte (Carte); Pla := Objet_Generic.Get_Plage (Plage); Com_Cl35.Ecriture (Config_Cl35.Cl35_Valide_Carte (Car, Pla, Lec)); Lecture_Cl35; end Programmation_Carte; procedure Programmation_Config is use Objet_Generic; use Bdd; Lec, L_Z, Pla, Acc, C_G, Car : Objet_Generic.Object; begin First_Item (Lecteur); while not End_Iter (Lecteur) loop Lec := Current_Item (Lecteur); Programmation_Lecteur (Lec); Next_Item (Lecteur); end loop; First_Item (Acces); while not End_Iter (Acces) loop Acc := Current_Item (Acces); First_Item (Lecteur_Zone, Acces_68.Get_Zone (Get_Acces (Acc))); while not End_Iter (Lecteur_Zone) loop L_Z := Current_Item (Lecteur_Zone); First_Item (Plage, Lecteur_Zone_68.Get_Zone (Get_Lecteur_Zone (L_Z))); while not End_Iter (Plage) loop Pla := Current_Item (Plage); First_Item (Lecteur, Lecteur_Zone_68.Get_Lecteur (Get_Lecteur_Zone (L_Z))); if not End_Iter (Lecteur) then Lec := Current_Item (Lecteur); Programmation_Plage (Lecteur => Lec, Plage => Pla); First_Item (Carte_Groupe, Acces_68.Get_Groupe (Get_Acces (Acc))); while not End_Iter (Carte_Groupe) loop C_G := Current_Item (Carte_Groupe); First_Item (Carte, Carte_Groupe_68.Get_Carte (Get_Carte_Groupe (C_G))); if not End_Iter (Carte) then Car := Current_Item (Carte); Programmation_Carte (Lecteur => Lec, Carte => Car, Plage => Pla); end if; Next_Item (Carte_Groupe); end loop; end if; Next_Item (Plage); end loop; Next_Item (Lecteur_Zone); end loop; Next_Item (Acces); end loop; end Programmation_Config; procedure Rapport_Lecteur_Cl35 (Lecteur : Objet_Generic.Object) is use Config_Cl35; Lec : Lecteur_68.Object; Fin : Boolean := False; begin Lec := Objet_Generic.Get_Lecteur (Lecteur); Com_Cl35.Ecriture (Cl35_Demande_Evenement (Lec)); while not Fin loop declare Rapport : constant General_Defs.Byte_String := Com_Cl35.Lecture; begin declare Data : constant General_Defs.Byte_String := Get_Data_Rapport (Rapport); Sum : Natural := Get_Size_Rapport (Bs => Rapport); Evt : Evenement_68.Object; P : Natural; begin if Sum = 1 then Fin := True; else P := Data'First; while P < Data'Last loop Get_Evenement (Data => Data (P .. Data'Last), Lecteur => Lecteur_68.Get_Numero (Lec), Evenement => Evt, Indice_Fin => P); Pack_Buffer.Add (Buff_Evt, Evt); P := P + 1; end loop; if Sum /= Pas_La_Fin_Rapport_Evenement then Fin := True; end if; end if; end; end; if not Fin then Com_Cl35.Ecriture (Config_Cl35.Cl35_Ack (Lec)); end if; end loop; end Rapport_Lecteur_Cl35; procedure Charge_Buff_Evt is use Bdd; use Objet_Generic; Lec : Objet_Generic.Object; begin First_Item (Lecteur); while not End_Iter (Lecteur) loop Lec := Current_Item (Lecteur); Rapport_Lecteur_Cl35 (Lec); Next_Item (Lecteur); if Pack_Buffer.Empty_Places (Buff_Evt) < Max_Evt_Lecteur then exit; end if; end loop; end Charge_Buff_Evt; procedure Rapport_Cl35 is Evt : Evenement_68.Object; Trame : Trame_Ihm_68.Object; begin if Pack_Buffer.Is_Empty (Buff_Evt) then Charge_Buff_Evt; if Pack_Buffer.Is_Empty (Buff_Evt) then Trame_Ihm_68.Create (O => Trame, Action => Trame_Ihm_68.Fin_Rapport); else Pack_Buffer.Get (Buff_Evt, Evt); Trame_Ihm_68.Create (O => Trame, Action => Trame_Ihm_68.Creation, Type_Objet => Trame_Ihm_68.Evenement, S => Evenement_68.Image (O => Evt)); end if; else Pack_Buffer.Get (Buff_Evt, Evt); Trame_Ihm_68.Create (O => Trame, Action => Trame_Ihm_68.Creation, Type_Objet => Trame_Ihm_68.Evenement, S => Evenement_68.Image (O => Evt)); end if; Com_Ihm.Ecriture (Trame_Ihm_68.Image (Trame)); end Rapport_Cl35; end Choix_Trt;
nblk1=12 nid=f hdr6=22 [0x00] rec0=26 rec1=00 rec2=01 rec3=004 [0x01] rec0=1b rec1=00 rec2=09 rec3=022 [0x02] rec0=18 rec1=00 rec2=04 rec3=080 [0x03] rec0=11 rec1=00 rec2=0e rec3=062 [0x04] rec0=17 rec1=00 rec2=07 rec3=00e [0x05] rec0=13 rec1=00 rec2=0b rec3=02a [0x06] rec0=1b rec1=00 rec2=0a rec3=020 [0x07] rec0=01 rec1=00 rec2=10 rec3=002 [0x08] rec0=13 rec1=00 rec2=02 rec3=020 [0x09] rec0=19 rec1=00 rec2=08 rec3=062 [0x0a] rec0=1a rec1=00 rec2=0c rec3=028 [0x0b] rec0=1b rec1=00 rec2=06 rec3=00e [0x0c] rec0=1a rec1=00 rec2=05 rec3=020 [0x0d] rec0=1e rec1=00 rec2=03 rec3=016 [0x0e] rec0=1a rec1=00 rec2=11 rec3=034 [0x0f] rec0=20 rec1=00 rec2=12 rec3=006 [0x10] rec0=0e rec1=00 rec2=0d rec3=000 [0x11] rec0=00 rec1=00 rec2=00 rec3=000 tail 0x2154ae600878d570df8d6 0x42a00088462060003 Free Block Chain: 0xf: 0000 00 00 01 96 00 1d 20 20 20 20 70 72 6f 63 65 64 ┆ proced┆