------------------------------------------------------------------------------
-- --
--- GNAT RUNTIME COMPONENTS --
+-- GNAT RUN-TIME COMPONENTS --
-- --
-- A D A . S T R I N G S . U N B O U N D E D . T E X T _ I O --
-- --
-- B o d y --
-- --
--- $Revision: 1.2 $
--- --
--- Copyright (C) 1997-1999 Free Software Foundation, Inc. --
+-- Copyright (C) 1997-2005, Free Software Foundation, Inc. --
-- --
-- GNAT is free software; you can redistribute it and/or modify it under --
-- terms of the GNU General Public License as published by the Free Soft- --
-- 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 distributed with GNAT; see file COPYING. If not, write --
--- to the Free Software Foundation, 59 Temple Place - Suite 330, Boston, --
--- MA 02111-1307, USA. --
+-- to the Free Software Foundation, 51 Franklin Street, Fifth Floor, --
+-- Boston, MA 02110-1301, 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, --
-- covered by the GNU Public License. --
-- --
-- GNAT was originally developed by the GNAT team at New York University. --
--- It is now maintained by Ada Core Technologies Inc (http://www.gnat.com). --
+-- Extensive contributions were provided by Ada Core Technologies Inc. --
-- --
------------------------------------------------------------------------------
-with Ada.Strings.Unbounded.Aux; use Ada.Strings.Unbounded.Aux;
-with Ada.Text_IO; use Ada.Text_IO;
+with Ada.Text_IO; use Ada.Text_IO;
package body Ada.Strings.Unbounded.Text_IO is
begin
Get_Line (Buffer, Last);
Str1 := new String'(Buffer (1 .. Last));
-
while Last = Buffer'Last loop
Get_Line (Buffer, Last);
Str2 := new String'(Str1.all & Buffer (1 .. Last));
Str1 := Str2;
end loop;
- Set_String (Result, Str1);
+ Result.Reference := Str1;
+ Result.Last := Str1'Length;
return Result;
end Get_Line;
begin
Get_Line (File, Buffer, Last);
Str1 := new String'(Buffer (1 .. Last));
-
while Last = Buffer'Last loop
Get_Line (File, Buffer, Last);
Str2 := new String'(Str1.all & Buffer (1 .. Last));
Str1 := Str2;
end loop;
- Set_String (Result, Str1);
+ Result.Reference := Str1;
+ Result.Last := Str1'Length;
return Result;
end Get_Line;
+ procedure Get_Line (Item : out Unbounded_String) is
+ begin
+ Get_Line (Current_Input, Item);
+ end Get_Line;
+
+ procedure Get_Line
+ (File : Ada.Text_IO.File_Type;
+ Item : out Unbounded_String)
+ is
+ begin
+ -- We are going to read into the string that is already there and
+ -- allocated. Hopefully it is big enough now, if not, we will extend
+ -- it in the usual manner using Realloc_For_Chunk.
+
+ -- Make sure we start with at least 80 characters
+
+ if Item.Reference'Last < 80 then
+ Realloc_For_Chunk (Item, 80);
+ end if;
+
+ -- Loop to read data, filling current string as far as possible.
+ -- Item.Last holds the number of characters read so far.
+
+ Item.Last := 0;
+ loop
+ Get_Line
+ (File,
+ Item.Reference (Item.Last + 1 .. Item.Reference'Last),
+ Item.Last);
+
+ -- If we hit the end of the line before the end of the buffer, then
+ -- we are all done, and the result length is properly set.
+
+ if Item.Last < Item.Reference'Last then
+ return;
+ end if;
+
+ -- If not enough room, double it and keep reading
+
+ Realloc_For_Chunk (Item, Item.Last);
+ end loop;
+ end Get_Line;
+
---------
-- Put --
---------
procedure Put (U : Unbounded_String) is
begin
- Put (Get_String (U).all);
+ Put (U.Reference (1 .. U.Last));
end Put;
procedure Put (File : File_Type; U : Unbounded_String) is
begin
- Put (File, Get_String (U).all);
+ Put (File, U.Reference (1 .. U.Last));
end Put;
--------------
procedure Put_Line (U : Unbounded_String) is
begin
- Put_Line (Get_String (U).all);
+ Put_Line (U.Reference (1 .. U.Last));
end Put_Line;
procedure Put_Line (File : File_Type; U : Unbounded_String) is
begin
- Put_Line (File, Get_String (U).all);
+ Put_Line (File, U.Reference (1 .. U.Last));
end Put_Line;
end Ada.Strings.Unbounded.Text_IO;