2014-01-01 14:07:03 +00:00
|
|
|
with H2.Pool;
|
|
|
|
with Ada.Characters.Conversions;
|
2013-12-28 16:52:31 +00:00
|
|
|
|
|
|
|
package body Stream is
|
|
|
|
|
|
|
|
------------------------------------------------------------------
|
|
|
|
|
|
|
|
procedure Open (Stream: in out String_Input_Stream_Record) is
|
|
|
|
begin
|
2014-01-01 14:07:03 +00:00
|
|
|
Ada.Wide_Text_IO.Put_Line ("****** OPEN STRING STREAM ******");
|
2013-12-28 16:52:31 +00:00
|
|
|
Stream.Pos := 0;
|
|
|
|
end Open;
|
|
|
|
|
|
|
|
procedure Close (Stream: in out String_Input_Stream_Record) is
|
|
|
|
begin
|
2014-01-01 14:07:03 +00:00
|
|
|
Ada.Wide_Text_IO.Put_Line ("****** CLOSE STRING STREAM ******");
|
2013-12-28 16:52:31 +00:00
|
|
|
Stream.Pos := Stream.Str'Last;
|
|
|
|
end Close;
|
|
|
|
|
|
|
|
procedure Read (Stream: in out String_Input_Stream_Record;
|
|
|
|
Data: out S.Object_String;
|
|
|
|
Last: out Standard.Natural) is
|
|
|
|
Avail: Standard.Natural;
|
|
|
|
begin
|
|
|
|
Avail := Stream.Str'Last - Stream.Pos;
|
|
|
|
if Avail <= 0 then
|
|
|
|
-- EOF
|
|
|
|
Last := Data'First - 1;
|
|
|
|
else
|
|
|
|
if Avail > Data'Length then
|
|
|
|
Avail := Data'Length;
|
|
|
|
end if;
|
|
|
|
|
|
|
|
Data(Data'First .. Avail) := Stream.Str(Stream.Pos + 1..Stream.Pos + Avail);
|
|
|
|
Stream.Pos := Stream.Pos + Avail;
|
|
|
|
Last := Data'First + Avail - 1;
|
|
|
|
end if;
|
|
|
|
end Read;
|
|
|
|
|
|
|
|
procedure Write (Stream: in out String_Input_Stream_Record;
|
|
|
|
Data: out S.Object_String;
|
|
|
|
Last: out Standard.Natural) is
|
|
|
|
begin
|
|
|
|
--raise S.Stream_Error;
|
|
|
|
Last := Data'First - 1;
|
|
|
|
end Write;
|
|
|
|
|
|
|
|
------------------------------------------------------------------
|
|
|
|
|
|
|
|
procedure Open (Stream: in out File_Stream_Record) is
|
|
|
|
begin
|
2014-01-01 14:07:03 +00:00
|
|
|
Ada.Wide_Text_IO.Put_Line (">>>>> OPEN File STREAM <<<<<");
|
|
|
|
Ada.Wide_Text_IO.Open (Stream.Handle, Ada.Wide_Text_IO.In_File, Ada.Characters.Conversions.To_String(Stream.Name.all));
|
2013-12-28 16:52:31 +00:00
|
|
|
end Open;
|
|
|
|
|
|
|
|
procedure Close (Stream: in out File_Stream_Record) is
|
|
|
|
begin
|
2014-01-01 14:07:03 +00:00
|
|
|
Ada.Wide_Text_IO.Put_Line (">>>>> CLOSE File STREAM <<<<<");
|
|
|
|
Ada.Wide_Text_IO.Close (Stream.Handle);
|
2013-12-28 16:52:31 +00:00
|
|
|
end Close;
|
|
|
|
|
|
|
|
procedure Read (Stream: in out File_Stream_Record;
|
|
|
|
Data: out S.Object_String;
|
|
|
|
Last: out Standard.Natural) is
|
|
|
|
begin
|
|
|
|
for I in Data'First .. Data'Last loop
|
|
|
|
begin
|
2014-01-01 14:07:03 +00:00
|
|
|
Ada.Wide_Text_IO.Get_Immediate (Stream.Handle, Data(I));
|
2013-12-28 16:52:31 +00:00
|
|
|
exception
|
2014-01-01 14:07:03 +00:00
|
|
|
when Ada.Wide_Text_IO.End_Error =>
|
2013-12-28 16:52:31 +00:00
|
|
|
Last := I - 1;
|
|
|
|
return;
|
|
|
|
-- other exceptions must be just raised to indicate errors
|
|
|
|
end;
|
|
|
|
end loop;
|
|
|
|
Last := Data'Last;
|
|
|
|
end Read;
|
|
|
|
|
|
|
|
procedure Write (Stream: in out File_Stream_Record;
|
|
|
|
Data: out S.Object_String;
|
|
|
|
Last: out Standard.Natural) is
|
|
|
|
begin
|
|
|
|
--raise S.Stream_Error;
|
|
|
|
Last := Data'First - 1;
|
|
|
|
end Write;
|
|
|
|
|
|
|
|
------------------------------------------------------------------
|
|
|
|
|
2014-01-01 14:07:03 +00:00
|
|
|
procedure Allocate_Stream (Interp: in out S.Interpreter_Record;
|
|
|
|
Name: in S.Constant_Object_String_Pointer;
|
|
|
|
Result: out S.Stream_Pointer) is
|
|
|
|
subtype FSR is Stream.File_Stream_Record;
|
|
|
|
type FSP is access all FSR;
|
|
|
|
package P is new H2.Pool (FSR, FSP);
|
|
|
|
|
|
|
|
X: FSP;
|
|
|
|
for X'Address use Result'Address;
|
|
|
|
pragma Import (Ada, X);
|
|
|
|
begin
|
|
|
|
X := P.Allocate (S.Get_Storage_Pool(Interp));
|
|
|
|
X.Name := Name;
|
|
|
|
end Allocate_Stream;
|
|
|
|
|
|
|
|
procedure Deallocate_Stream (Interp: in out S.Interpreter_Record;
|
|
|
|
Source: in out S.Stream_Pointer) is
|
|
|
|
subtype FSR is Stream.File_Stream_Record;
|
|
|
|
type FSP is access all FSR;
|
|
|
|
package P is new H2.Pool (FSR, FSP);
|
|
|
|
|
|
|
|
X: FSP;
|
|
|
|
for X'Address use Source'Address;
|
|
|
|
pragma Import (Ada, X);
|
|
|
|
begin
|
|
|
|
P.Deallocate (X, S.Get_Storage_Pool(Interp));
|
|
|
|
end Deallocate_Stream;
|
2013-12-28 16:52:31 +00:00
|
|
|
end Stream;
|