]> git.ipfire.org Git - thirdparty/gcc.git/blame - libstdc++-v3/testsuite/27_io/basic_filebuf/sgetn/char/1-in.cc
Update copyright years in libstdc++-v3/
[thirdparty/gcc.git] / libstdc++-v3 / testsuite / 27_io / basic_filebuf / sgetn / char / 1-in.cc
CommitLineData
46c4e5d6
BK
1// 2001-05-21 Benjamin Kosnik <bkoz@redhat.com>
2
aa118a03 3// Copyright (C) 2001-2014 Free Software Foundation, Inc.
46c4e5d6
BK
4//
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
748086b7 8// Free Software Foundation; either version 3, or (at your option)
46c4e5d6
BK
9// any later version.
10
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.
15
16// You should have received a copy of the GNU General Public License along
748086b7
JJ
17// with this library; see the file COPYING3. If not see
18// <http://www.gnu.org/licenses/>.
46c4e5d6 19
517da0ce
MM
20// The ARM simulator does not provide support for "fstat", which
21// causes "in_avail" to return an incorrect value.
049930c8 22// { dg-do run { xfail arm*-*-elf arm*-*-eabi } }
517da0ce 23
46c4e5d6
BK
24// 27.8.1.4 Overridden virtual functions
25
0c20e4ec 26// { dg-require-fileio "" }
f16fd827 27// { dg-require-binary-io "" }
0c20e4ec 28
46c4e5d6
BK
29#include <fstream>
30#include <testsuite_hooks.h>
31#include <testsuite_io.h>
32
33// @require@ %-*.tst %-*.txt
34// @diff@ %-*.tst %*.txt
35
36const char name_01[] = "sgetn.txt"; // file with data in it
37
38// Test overloaded virtual functions.
39void test05()
40{
41 using namespace std;
aecf642c 42 using namespace __gnu_test;
46c4e5d6
BK
43 typedef filebuf::int_type int_type;
44 typedef filebuf::traits_type traits_type;
45
11f10e6b 46 bool test __attribute__((unused)) = true;
46c4e5d6 47
11f10e6b 48 streamsize strmsz_1, strmsz_2;
46c4e5d6
BK
49 char carray1[13] = "";
50 char carray2[8192] = "";
8363b773 51 char buffer[8192] = "";
11f10e6b 52 int_type c1, c4;
46c4e5d6
BK
53
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
58
59 // in
60 {
8363b773
PC
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);
46c4e5d6
BK
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 );
72 c1 = fb_01.sgetc();
73 VERIFY( c1 == 'b' );
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.
5d2a0db5 78 VERIFY( c4 == 'e' );
46c4e5d6
BK
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() );
85 }
86}
87
11f10e6b 88int main()
46c4e5d6
BK
89{
90 test05();
91 return 0;
92}