// // aegis - project change supervisor // Copyright (C) 2004-2006, 2008, 2012 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_CROP_H #define LIBAEGIS_INPUT_CROP_H #include /** * The input_crop class is used to represent an input which will read * only a portion of the deeper input, from the current position. */ class input_crop: public input_ty { public: /** * The destructor. */ virtual ~input_crop(); /** * The constructor. * * @param deeper * the data source for this filter. * @param length * How many bytes of data are in the cropped region. */ input_crop(input &deeper, size_t length); // See base class for documentation. nstring name(); // See base class for documentation. off_t length(); // See base class for documentation. void keepalive(); // See base class for documentation. ssize_t read_inner(void *data, size_t nbytes); // See base class for documentation. off_t ftell_inner(); // See base class for documentation. bool is_remote() const; void set_name(const nstring &arg) { name_cache = arg; } private: /** * The deeper instance variable is used to remember the data source * for this filter. */ input deeper; /** * The maximum instance variable is used to remember how many bytes * of data are in the cropped region. */ size_t maximum; /** * The pos instance variable is used to remember where we are up to * in the crop region. */ size_t pos; /** * The name_cache instance variable is used to remember the name of * the deeper input stream. */ nstring name_cache; /** * The default constructor. Do not use. */ input_crop(); /** * The copy constructor. Do not use. */ input_crop(const input_crop &arg); /** * The assignment operator. Do not use. */ input_crop &operator=(const input_crop &arg); }; #endif // LIBAEGIS_INPUT_CROP_H // vim: set ts=8 sw=4 et :