]> git.ipfire.org Git - thirdparty/gcc.git/blame - libstdc++-v3/testsuite/27_io/basic_filebuf/sgetn/char/1-in.cc
Licensing changes to GPLv3 resp. GPLv3 with GCC Runtime Exception.
[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
748086b7 3// Copyright (C) 2001, 2002, 2003, 2006, 2009 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
NS
26// { dg-require-fileio "" }
27
46c4e5d6
BK
28#include <fstream>
29#include <testsuite_hooks.h>
30#include <testsuite_io.h>
31
32// @require@ %-*.tst %-*.txt
33// @diff@ %-*.tst %*.txt
34
35const char name_01[] = "sgetn.txt"; // file with data in it
36
37// Test overloaded virtual functions.
38void test05()
39{
40 using namespace std;
aecf642c 41 using namespace __gnu_test;
46c4e5d6
BK
42 typedef filebuf::int_type int_type;
43 typedef filebuf::traits_type traits_type;
44
11f10e6b 45 bool test __attribute__((unused)) = true;
46c4e5d6 46
11f10e6b 47 streamsize strmsz_1, strmsz_2;
46c4e5d6
BK
48 char carray1[13] = "";
49 char carray2[8192] = "";
8363b773 50 char buffer[8192] = "";
11f10e6b 51 int_type c1, c4;
46c4e5d6
BK
52
53 // streamsize sgetn(char_type *s, streamsize n)
54 // streamsize xsgetn(char_type *s, streamsize n)
55 // assign up to n chars to s from input sequence, indexing in_cur as
56 // approp and returning the number of chars assigned
57
58 // in
59 {
8363b773
PC
60 constraint_filebuf fb_01;
61 // Need this since BUFSIZ is only guaranteed >= 255 and we want
62 // to trigger the same underflow situation everywhere.
63 fb_01.pubsetbuf(buffer, 8192);
46c4e5d6
BK
64 fb_01.open(name_01, ios_base::in);
65 VERIFY( !fb_01.write_position() );
66 strmsz_1 = fb_01.in_avail(); // 8261
67 strmsz_2 = fb_01.sgetn(carray1, 10);
68 VERIFY( strmsz_2 == 10 );
69 strmsz_2 = fb_01.in_avail();
70 VERIFY( strmsz_1 > strmsz_2 );
71 c1 = fb_01.sgetc();
72 VERIFY( c1 == 'b' );
73 strmsz_1 = fb_01.in_avail();
74 strmsz_2 = fb_01.sgetn(carray2, strmsz_1 + 5);
75 VERIFY( strmsz_1 == strmsz_2 - 5 );
76 c4 = fb_01.sgetc(); // buffer should have underflowed from above.
5d2a0db5 77 VERIFY( c4 == 'e' );
46c4e5d6
BK
78 strmsz_1 = fb_01.in_avail();
79 VERIFY( strmsz_1 > 0 );
80 strmsz_2 = fb_01.sgetn(carray2, strmsz_1 + 5);
81 VERIFY( strmsz_1 == strmsz_2 ); //at the end of the actual file
82 VERIFY( !fb_01.write_position() );
83 VERIFY( !fb_01.read_position() );
84 }
85}
86
11f10e6b 87int main()
46c4e5d6
BK
88{
89 test05();
90 return 0;
91}