]>
git.ipfire.org Git - thirdparty/gcc.git/blob - libstdc++-v3/testsuite/27_io/basic_filebuf/sgetn/char/1-in.cc
1 // 2001-05-21 Benjamin Kosnik <bkoz@redhat.com>
3 // Copyright (C) 2001, 2002, 2003, 2006 Free Software Foundation, Inc.
5 // This file is part of the GNU ISO C++ Library. This library is free
6 // software; you can redistribute it and/or modify it under the
7 // terms of the GNU General Public License as published by the
8 // Free Software Foundation; either version 2, or (at your option)
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 // GNU General Public License for more details.
16 // You should have received a copy of the GNU General Public License along
17 // with this library; see the file COPYING. If not, write to the Free
18 // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
21 // The ARM simulator does not provide support for "fstat", which
22 // causes "in_avail" to return an incorrect value.
23 // { dg-do run { xfail arm*-*-elf arm*-*-eabi } }
25 // 27.8.1.4 Overridden virtual functions
27 // { dg-require-fileio "" }
30 #include <testsuite_hooks.h>
31 #include <testsuite_io.h>
33 // @require@ %-*.tst %-*.txt
34 // @diff@ %-*.tst %*.txt
36 const char name_01
[] = "sgetn.txt"; // file with data in it
38 // Test overloaded virtual functions.
42 using namespace __gnu_test
;
43 typedef filebuf::int_type int_type
;
44 typedef filebuf::traits_type traits_type
;
46 bool test
__attribute__((unused
)) = true;
48 streamsize strmsz_1
, strmsz_2
;
49 char carray1
[13] = "";
50 char carray2
[8192] = "";
51 char buffer
[8192] = "";
54 // streamsize sgetn(char_type *s, streamsize n)
55 // streamsize xsgetn(char_type *s, streamsize n)
56 // assign up to n chars to s from input sequence, indexing in_cur as
57 // approp and returning the number of chars assigned
61 constraint_filebuf fb_01
;
62 // Need this since BUFSIZ is only guaranteed >= 255 and we want
63 // to trigger the same underflow situation everywhere.
64 fb_01
.pubsetbuf(buffer
, 8192);
65 fb_01
.open(name_01
, ios_base::in
);
66 VERIFY( !fb_01
.write_position() );
67 strmsz_1
= fb_01
.in_avail(); // 8261
68 strmsz_2
= fb_01
.sgetn(carray1
, 10);
69 VERIFY( strmsz_2
== 10 );
70 strmsz_2
= fb_01
.in_avail();
71 VERIFY( strmsz_1
> strmsz_2
);
74 strmsz_1
= fb_01
.in_avail();
75 strmsz_2
= fb_01
.sgetn(carray2
, strmsz_1
+ 5);
76 VERIFY( strmsz_1
== strmsz_2
- 5 );
77 c4
= fb_01
.sgetc(); // buffer should have underflowed from above.
79 strmsz_1
= fb_01
.in_avail();
80 VERIFY( strmsz_1
> 0 );
81 strmsz_2
= fb_01
.sgetn(carray2
, strmsz_1
+ 5);
82 VERIFY( strmsz_1
== strmsz_2
); //at the end of the actual file
83 VERIFY( !fb_01
.write_position() );
84 VERIFY( !fb_01
.read_position() );