aicwl_3.24.1_73939c9e/sources/strings_edit-streams.adb

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
--                                                                    --
--  package                         Copyright (c)  Dmitry A. Kazakov  --
--     Strings_Edit.Streams                        Luebeck            --
--  Implementation                                 Spring, 2009       --
--                                                                    --
--                                Last revision :  13:11 14 Sep 2019  --
--                                                                    --
--  This  library  is  free software; you can redistribute it and/or  --
--  modify it under the terms of the GNU General Public  License  as  --
--  published by the Free Software Foundation; either version  2  of  --
--  the License, or (at your option) any later version. This library  --
--  is distributed in the hope that it will be useful,  but  WITHOUT  --
--  ANY   WARRANTY;   without   even   the   implied   warranty   of  --
--  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU  --
--  General  Public  License  for  more  details.  You  should  have  --
--  received  a  copy  of  the GNU General Public License along with  --
--  this library; if not, write to  the  Free  Software  Foundation,  --
--  Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.    --
--                                                                    --
--  As a special exception, if other files instantiate generics from  --
--  this unit, or you link this unit with other files to produce  an  --
--  executable, this unit does not by  itself  cause  the  resulting  --
--  executable to be covered by the GNU General Public License. This  --
--  exception  does not however invalidate any other reasons why the  --
--  executable file might be covered by the GNU Public License.       --
--____________________________________________________________________--
--
with Ada.IO_Exceptions;  use Ada.IO_Exceptions;

package body Strings_Edit.Streams is

   procedure Increment
             (  Left  : in out Integer;
                Right : Stream_Element_Offset
             )  is
      pragma Inline (Increment);
   begin
      Left := Left + Integer (Right) * Char_Count;
   end Increment;

   function Get (Stream : String_Stream) return String is
   begin
      return Stream.Data (1..Stream.Position - 1);
   end Get;

   function Get_Size (Stream : String_Stream)
      return Stream_Element_Count is
   begin
      return
      (  Stream_Element_Offset (Stream.Data'Last - Stream.Position + 1)
      /  Char_Count
      );
   end Get_Size;

   procedure Read
             (  Stream : in out String_Stream;
                Item   : out Stream_Element_Array;
                Last   : out Stream_Element_Offset
             )  is
   begin
      if Stream.Position > Stream.Length then
         raise End_Error;
      end if;
      declare
         subtype Space is Stream_Element_Array (1..Get_Size (Stream));
         Data : Space;
         pragma Import (Ada, Data);
         for Data'Address use Stream.Data (Stream.Position)'Address;
      begin
         if Space'Length >= Item'Length then
            Last := Item'Last;
            Item := Data (1..Item'Length);
            Increment (Stream.Position, Item'Length);
         else
            Last := Item'First + Data'Length - 1;
            Item (Item'First..Last) := Data;
            Stream.Position := Stream.Data'Last + 1;
         end if;
      end;
   end Read;

   procedure Rewind (Stream : in out String_Stream) is
   begin
      Stream.Position := 1;
   end Rewind;

   procedure Set (Stream : in out String_Stream; Content : String) is
   begin
      if Content'Length > Stream.Length then
         raise Constraint_Error;
      end if;
      Stream.Position := Stream.Length - Content'Length + 1;
      Stream.Data (Stream.Position..Stream.Length) := Content;
   end Set;

   procedure Write
             (  Stream : in out String_Stream;
                Item   : Stream_Element_Array
             )  is
   begin
      if Stream.Position > Stream.Length then
         raise End_Error;
      end if;
      declare
         subtype Space is Stream_Element_Array (1..Get_Size (Stream));
         Data : Space;
         pragma Import (Ada, Data);
         for Data'Address use Stream.Data (Stream.Position)'Address;
      begin
         if Item'Length > Space'Length then
            raise End_Error;
         end if;
         Data (1..Item'Length) := Item;
         Increment (Stream.Position, Item'Length);
      end;
   end Write;

end Strings_Edit.Streams;