1 ------------------------------------------------------------------------------
3 -- GNAT COMPILER COMPONENTS --
5 -- I N T E R F A C E S . C _ S T R E A M S --
9 -- Copyright (C) 1996-2003 Free Software Foundation, Inc. --
11 -- GNAT is free software; you can redistribute it and/or modify it under --
12 -- terms of the GNU General Public License as published by the Free Soft- --
13 -- ware Foundation; either version 2, or (at your option) any later ver- --
14 -- sion. GNAT is distributed in the hope that it will be useful, but WITH- --
15 -- OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY --
16 -- or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License --
17 -- for more details. You should have received a copy of the GNU General --
18 -- Public License distributed with GNAT; see file COPYING. If not, write --
19 -- to the Free Software Foundation, 59 Temple Place - Suite 330, Boston, --
20 -- MA 02111-1307, USA. --
22 -- As a special exception, if other files instantiate generics from this --
23 -- unit, or you link this unit with other files to produce an executable, --
24 -- this unit does not by itself cause the resulting executable to be --
25 -- covered by the GNU General Public License. This exception does not --
26 -- however invalidate any other reasons why the executable file might be --
27 -- covered by the GNU Public License. --
29 -- GNAT was originally developed by the GNAT team at New York University. --
30 -- Extensive contributions were provided by Ada Core Technologies Inc. --
32 ------------------------------------------------------------------------------
34 -- This is the Alpha/VMS version.
36 with Unchecked_Conversion
;
37 package body Interfaces
.C_Streams
is
39 use type System
.CRTL
.size_t
;
52 Get_Count
: size_t
:= 0;
53 type Buffer_Type
is array (size_t
range 1 .. count
,
54 size_t
range 1 .. size
) of Character;
55 type Buffer_Access
is access Buffer_Type
;
56 function To_BA
is new Unchecked_Conversion
(voids
, Buffer_Access
);
57 BA
: Buffer_Access
:= To_BA
(buffer
);
61 -- This Fread goes with the Fwrite below.
62 -- The C library fread sometimes can't read fputc generated files.
64 for C
in 1 .. count
loop
65 for S
in 1 .. size
loop
70 BA
.all (C
, S
) := Character'Val (Ch
);
72 Get_Count
:= Get_Count
+ 1;
89 Get_Count
: size_t
:= 0;
90 type Buffer_Type
is array (size_t
range 1 .. count
,
91 size_t
range 1 .. size
) of Character;
92 type Buffer_Access
is access Buffer_Type
;
93 function To_BA
is new Unchecked_Conversion
(voids
, Buffer_Access
);
94 BA
: Buffer_Access
:= To_BA
(buffer
);
98 -- This Fread goes with the Fwrite below.
99 -- The C library fread sometimes can't read fputc generated files.
101 for C
in 1 + index
.. count
+ index
loop
102 for S
in 1 .. size
loop
103 Ch
:= fgetc
(stream
);
107 BA
.all (C
, S
) := Character'Val (Ch
);
109 Get_Count
:= Get_Count
+ 1;
125 Put_Count
: size_t
:= 0;
126 type Buffer_Type
is array (size_t
range 1 .. count
,
127 size_t
range 1 .. size
) of Character;
128 type Buffer_Access
is access Buffer_Type
;
129 function To_BA
is new Unchecked_Conversion
(voids
, Buffer_Access
);
130 BA
: Buffer_Access
:= To_BA
(buffer
);
133 -- Fwrite on VMS has the undesirable effect of always generating at
134 -- least one record of output per call, regardless of buffering. To
135 -- get around this, we do multiple fputc calls instead.
137 for C
in 1 .. count
loop
138 for S
in 1 .. size
loop
139 if fputc
(Character'Pos (BA
.all (C
, S
)), stream
) = EOF
then
143 Put_Count
:= Put_Count
+ 1;
159 use type System
.Address
;
162 -- In order for the above fwrite hack to work, we must always buffer
163 -- stdout and stderr. Is_regular_file on VMS cannot detect when
164 -- these are redirected to a file, so checking for that condition
168 and then (stream
= stdout
or else stream
= stderr
)
170 return System
.CRTL
.setvbuf
171 (stream
, buffer
, IOLBF
, System
.CRTL
.size_t
(size
));
173 return System
.CRTL
.setvbuf
174 (stream
, buffer
, mode
, System
.CRTL
.size_t
(size
));
178 end Interfaces
.C_Streams
;