// // aegis - project change supervisor // Copyright (C) 1999, 2002, 2005, 2006, 2008, 2010, 2012, 2014 Peter Miller // // 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 3 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, see . // #ifndef LIBAEGIS_INPUT_CRLF_H #define LIBAEGIS_INPUT_CRLF_H #include /** * The input_crlf class is used to transparently filter CRLF sequences * into NL sequences. */ class input_crlf: public input { public: /** * The destructor. */ virtual ~input_crlf(); /** * The create class method is used to create new dynamically * allocated instances of this class. * * @param deeper * The data source we are to filter. * @param esc_nl * true if we are to operate in a mode where \\\n and \\\\r\\n * sequences are to be removed. */ static pointer create(const input::pointer &deeper, bool esc_nl = false); protected: // See base class for documentation. nstring name(void); // See base class for documentation. off_t length(void); // See base class for documentation. void keepalive(void); // See base class for documentation. ssize_t read_inner(void *data, size_t nbytes); // See base class for documentation. off_t ftell_inner(void); // See base class for documentation. bool is_remote(void) const; private: /** * The constructor. * * @param deeper * The data source we are to filter. * @param esc_nl * true if we are to operate in a mode where \\\n and \\\\r\\n * sequences are to be removed. */ input_crlf(const input::pointer &deeper, bool esc_nl); /** * The deeper instance variable is used to remember the deeper * input source of this filter. */ input::pointer deeper; off_t pos; long line_number; bool prev_was_newline; nstring name_cache; /** * The newlines_may_be_escaped instance variable is used to * remember whether we are in the mode where \\\n and \\\\r\\n * sequenes are removed. */ bool newlines_may_be_escaped; /** * The default constructor. Do not use. */ input_crlf(); /** * The copy constructor. Do not use. */ input_crlf(const input_crlf &arg); /** * The assignment operator. Do not use. */ input_crlf &operator=(const input_crlf &arg); }; #endif // LIBAEGIS_INPUT_CRLF_H // vim: set ts=8 sw=4 et :