Sync usage with man page.
[netbsd-mini2440.git] / gnu / lib / libg++ / g++-include / istream.h
blob1fa10fe594ae2c0781e258af6b1b5ae7426012ff
1 // This may look like C code, but it is really -*- C++ -*-
2 /*
3 Copyright (C) 1989 Free Software Foundation
4 written by Doug Lea (dl@rocky.oswego.edu)
6 This file is part of GNU CC.
8 GNU CC is distributed in the hope that it will be useful,
9 but WITHOUT ANY WARRANTY. No author or distributor
10 accepts responsibility to anyone for the consequences of using it
11 or for whether it serves any particular purpose or works at all,
12 unless he says so in writing. Refer to the GNU CC General Public
13 License for full details.
15 Everyone is granted permission to copy, modify and redistribute
16 GNU CC, but only under the conditions described in the
17 GNU CC General Public License. A copy of this license is
18 supposed to have been given to you along with GNU CC so you
19 can know your rights and responsibilities. It should be in a
20 file named COPYING. Among other things, the copyright notice
21 and this notice must be preserved on all copies.
24 /* *** Version 1.2 -- nearly 100% AT&T 1.2 compatible *** */
26 /* istream.h now separately includable */
28 #ifndef _istream_h
29 #ifdef __GNUG__
30 #pragma once
31 #pragma interface
32 #endif
33 #define _istream_h 1
36 #include <File.h>
37 #include <streambuf.h>
38 #include <filebuf.h>
39 #include <Filebuf.h>
41 class whitespace // a class used only to input and
42 { // discard white space characters
43 char filler;
46 class ostream;
48 class istream
50 friend void eatwhite(istream& s);
51 protected:
52 streambuf* bp;
53 state_value state; // _good/_eof/_fail/_bad
54 ostream* tied_to;
55 char skipws;
56 char ownbuf;
57 void _flush();
58 char* readline (int chunk_number, char terminator);
60 public:
61 istream(const char* filename, io_mode m, access_mode a,
62 int sk=1, ostream* t = 0);
63 istream(const char* filename, const char* m,
64 int sk=1, ostream* t = 0);
65 istream(int filedesc, io_mode m, int sk=1, ostream* t = 0);
66 istream(FILE* fileptr, int sk=1, ostream* t = 0);
67 istream(int sz, char* buf, int sk=1, ostream* t = 0);
68 istream(int filedesc, int sk=1, ostream* t = 0);
69 istream(int filedesc, char* buf, int buflen,
70 int sk, ostream* t = 0);
71 istream(streambuf* s, int sk=1, ostream* t = 0);
73 ~istream();
75 istream& open(const char* filename, io_mode m, access_mode a);
76 istream& open(const char* filename, const char* m);
77 istream& open(int filedesc, io_mode m);
78 istream& open(FILE* fileptr);
79 istream& open(const char* filenam, open_mode m);
81 istream& close();
83 ostream* tie(ostream* s);
84 int skip(int);
86 // stream status
88 int rdstate();
89 int eof();
90 int fail();
91 int bad();
92 int good();
94 // other status queries
96 int readable();
97 int writable();
98 int is_open();
100 operator void*();
101 int operator !();
103 const char* name();
105 char* bufptr();
107 // error handling
109 void error();
110 void clear(state_value f = _good); // poorly named
111 void set(state_value f); // set corresponding bit
112 void unset(state_value f); // clear corresponding bit
113 istream& failif(int cond);
115 // unformatted IO
117 istream& get(char& c);
118 istream& unget(char c);
119 istream& putback(char c); // a synonym for unget
121 istream& get (char* s, int n, char terminator = '\n');
122 istream& getline(char* s, int n, char terminator = '\n');
123 istream& gets (char **s, char terminator = '\n');
126 istream& operator >> (char& c);
127 istream& operator >> (short& n);
128 istream& operator >> (unsigned short& n);
129 istream& operator >> (int& n);
130 istream& operator >> (unsigned int& n);
131 istream& operator >> (long& n);
132 istream& operator >> (unsigned long& n);
133 #ifdef __GNUG__
134 istream& operator >> (long long& n);
135 istream& operator >> (unsigned long long& n);
136 #endif
137 istream& operator >> (float& n);
138 istream& operator >> (double& n);
139 istream& operator >> (char* s);
140 istream& operator >> (whitespace& w);
143 // pre-declared streams
145 extern istream cin; // stdin
147 extern whitespace WS; // for convenience
149 #if defined(__OPTIMIZE__) || defined(USE_LIBGXX_INLINES)
152 inline void istream::clear(state_value flag)
154 state = flag;
157 inline void istream::set(state_value flag)
159 state = state_value(int(state) | int(flag));
162 inline void istream::unset(state_value flag)
164 state = state_value(int(state) & ~int(flag));
167 inline int istream::rdstate()
169 return int(state);
172 inline int istream::good()
174 return state == _good;
177 inline int istream::eof()
179 return int(state) & int(_eof);
182 inline int istream::fail()
184 return int(state) & int(_fail);
187 inline int istream::bad()
189 return int(state) & int(_bad);
192 inline istream::operator void*()
194 return (state == _good)? this : 0;
197 inline int istream::operator !()
199 return (state != _good);
202 inline istream& istream::failif(int cond)
204 if (cond) set(_fail); return *this;
207 inline int istream::is_open()
209 return bp->is_open();
212 inline int istream::readable()
214 return (bp != 0) && (bp->is_open()) && (state == _good);
217 inline int istream::writable()
219 return 0;
223 inline char* istream::bufptr()
225 return bp->base;
229 inline istream& istream::close()
231 bp->close(); return *this;
235 inline int istream::skip(int sk)
237 int was = skipws; skipws = sk; return was;
241 inline istream& istream::unget(char c)
243 if (bp->sputbackc(c) == EOF) set(_fail); return *this;
246 inline istream& istream::putback(char c)
248 if (bp->sputbackc(c) == EOF) set(_fail); return *this;
251 inline void eatwhite(istream& s)
253 s >> WS;
256 #endif
259 #endif