// zlib input file stream wrapper. // // Written by Bernie Bright, 1998 // // Copyright (C) 1998 Bernie Bright - bbright@c031.aone.net.au // // This program is free software; you can redistribute it and/or // modify it under the terms of the GNU General Public License as // published by the Free Software Foundation; either version 2 of the // License, or (at your option) any later version. // // This program is distributed in the hope that it will be useful, but // WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program; if not, write to the Free Software // Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. // // $Id$ // (Log is kept at end of this file) #ifndef _FGSTREAM_HXX #define _FGSTREAM_HXX #ifndef __cplusplus # error This library requires C++ #endif #ifdef HAVE_CONFIG_H # include "config.h" #endif #include #include "Include/fg_stl_config.h" FG_USING_NAMESPACE(std); #include "zfstream.hxx" //----------------------------------------------------------------------------- // // Envelope class for gzifstream. // class fg_gzifstream { public: // fg_gzifstream(); // Attempt to open a file with and without ".gz" extension. fg_gzifstream( const string& name, int io_mode = ios::in|ios::binary ); // fg_gzifstream( int fd, int io_mode = ios::in|ios::binary ); // Attempt to open a file with and without ".gz" extension. void open( const string& name, int io_mode = ios::in|ios::binary ); // Return the underlying stream. istream& stream() { return gzstream; } // Check stream state. bool operator ! () const { return !gzstream; } // Check for end of file. bool eof() const { return gzstream.eof(); } // Remove whitespace from stream. // Whitespace is as defined by isspace(). istream& eat_whitespace(); // Removes comments and whitespace from stream. // A comment is any line starting with '#'. istream& eat_comments(); // Read one character from stream. istream& get( char& c ) { return gzstream.get(c); } // Put a character back into the input buffer. istream& putback( char c ) { return gzstream.putback(c); } private: // The underlying compressed data stream. gzifstream gzstream; private: // Not defined! fg_gzifstream( const fg_gzifstream& ); }; // istream manipulator that skips to end of line. istream& skipeol( istream& in ); // istream manipulator that skips over white space. istream& skipws( istream& in ); // istream manipulator that skips comments and white space. // A comment starts with '#'. istream& skipcomment( istream& in ); #endif /* _FGSTREAM_HXX */ // $Log$ // Revision 1.4 1998/10/16 00:50:56 curt // Remove leading _ from a couple defines. // // Revision 1.3 1998/10/13 00:10:06 curt // More portability changes to help with windoze compilation problems. // // Revision 1.2 1998/09/24 15:22:18 curt // Additional enhancements. // // Revision 1.1 1998/09/01 19:06:29 curt // Initial revision. //