]> git.ipfire.org Git - thirdparty/gcc.git/blame - libstdc++-v3/testsuite/27_io/basic_filebuf/sgetn/char/1-in.cc
Update copyright years.
[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
8d9254fc 3// Copyright (C) 2001-2020 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 streamsize strmsz_1, strmsz_2;
46c4e5d6
BK
47 char carray1[13] = "";
48 char carray2[8192] = "";
8363b773 49 char buffer[8192] = "";
11f10e6b 50 int_type c1, c4;
46c4e5d6
BK
51
52 // streamsize sgetn(char_type *s, streamsize n)
53 // streamsize xsgetn(char_type *s, streamsize n)
54 // assign up to n chars to s from input sequence, indexing in_cur as
55 // approp and returning the number of chars assigned
56
57 // in
58 {
8363b773
PC
59 constraint_filebuf fb_01;
60 // Need this since BUFSIZ is only guaranteed >= 255 and we want
61 // to trigger the same underflow situation everywhere.
62 fb_01.pubsetbuf(buffer, 8192);
46c4e5d6
BK
63 fb_01.open(name_01, ios_base::in);
64 VERIFY( !fb_01.write_position() );
65 strmsz_1 = fb_01.in_avail(); // 8261
66 strmsz_2 = fb_01.sgetn(carray1, 10);
67 VERIFY( strmsz_2 == 10 );
68 strmsz_2 = fb_01.in_avail();
69 VERIFY( strmsz_1 > strmsz_2 );
70 c1 = fb_01.sgetc();
71 VERIFY( c1 == 'b' );
72 strmsz_1 = fb_01.in_avail();
73 strmsz_2 = fb_01.sgetn(carray2, strmsz_1 + 5);
74 VERIFY( strmsz_1 == strmsz_2 - 5 );
75 c4 = fb_01.sgetc(); // buffer should have underflowed from above.
5d2a0db5 76 VERIFY( c4 == 'e' );
46c4e5d6
BK
77 strmsz_1 = fb_01.in_avail();
78 VERIFY( strmsz_1 > 0 );
79 strmsz_2 = fb_01.sgetn(carray2, strmsz_1 + 5);
80 VERIFY( strmsz_1 == strmsz_2 ); //at the end of the actual file
81 VERIFY( !fb_01.write_position() );
82 VERIFY( !fb_01.read_position() );
83 }
84}
85
11f10e6b 86int main()
46c4e5d6
BK
87{
88 test05();
89 return 0;
90}