DataMuseum.dkPresents historical artifacts from the history of: Rational R1000/400 Tapes |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about Rational R1000/400 Tapes Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - downloadIndex: ┃ B T ┃
Length: 3265 (0xcc1) Types: TextFile Names: »B«
└─⟦149519bd4⟧ Bits:30000546 8mm tape, Rational 1000, !projects 93-07-13 └─ ⟦124ff5788⟧ »DATA« └─⟦this⟧ └─⟦a7d1ea751⟧ Bits:30000550 8mm tape, Rational 1000, !users!projects 94_04_11 └─ ⟦129cab021⟧ »DATA« └─⟦this⟧ └─⟦f64eaa120⟧ Bits:30000752 8mm tape, Rational 1000, !projects 93 02 16 └─ ⟦6f12a12be⟧ »DATA« └─⟦this⟧ └─⟦2f6cfab89⟧ Bits:30000547 8mm tape, Rational 1000, !projects 94-01-04 └─ ⟦d65440be7⟧ »DATA« └─⟦this⟧
with Byte_Defs; with Transport_Name; with Utils; separate (Message_Transport) procedure Start_Server (Local_Socket : Socket; Buffer_Size : Positive; Wait_For_Identification : Boolean := True) is C : T.Connection_Id; S : T_Defs.Status_Code; N : constant T_Defs.Network_Name := "TCP/IP"; Lsid : constant Transport_Defs.Socket_Id := (Byte_Defs.Byte (Local_Socket / 256), Byte_Defs.Byte (Local_Socket mod 256)); Cnt : Positive; procedure Close is begin T.Close (Connection => C); end Close; begin T.Open (Connection => C, Status => S, Network => N, Local_Socket => Lsid); Register_Service (Host => Transport_Name.Local_Host_Name (Network => "TCP/IP"), Local_Socket => Socket (Utils.Byte_String_To_Integer (Bs => Byte_Defs.Byte_String (Transport.Local_Socket (Connection => C))))); if S /= Transport_Defs.Ok then Close; raise Connection_Error; end if; if Wait_For_Identification then loop declare Buffer : Byte_Defs.Byte_String (1 .. Buffer_Size) := (others => 0); begin T.Connect (C, S); if S /= Transport_Defs.Ok then Close; raise Connection_Error; end if; T.Receive (Connection => C, Status => S, Data => Buffer, Count => Cnt, Max_Wait => Duration'Last); if S /= Transport_Defs.Ok then Close; raise Connection_Error; end if; T.Disconnect (Connection => C); exit when Service_Identified (Utils.Byte_String_To_String (Buffer (Buffer'First .. Buffer'First + Cnt - 1))); end; end loop; end if; Ready_To_Receive; Server_Main: loop declare Buffer : Byte_Defs.Byte_String (1 .. Buffer_Size) := (others => 0); begin T.Connect (C, S); if S /= Transport_Defs.Ok then Close; raise Connection_Error; end if; T.Receive (Connection => C, Status => S, Data => Buffer, Count => Cnt, Max_Wait => Duration'Last); if S /= Transport_Defs.Ok then Close; raise Connection_Error; end if; T.Disconnect (Connection => C); Receive_Callback (Utils.Byte_String_To_String (Buffer (Buffer'First .. Buffer'First + Cnt - 1))); end; end loop Server_Main; Close; end Start_Server;