// KDat - a tar-based DAT archiver // Copyright (C) 1998-2000 Sean Vyain, svyain@mail.tds.net // Copyright (C) 2001-2002 Lawrence Widman, kdat@cardiothink.com // // 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA #ifndef _Tape_h_ #define _Tape_h_ #include <tqptrlist.h> #include <tqstring.h> #include "Archive.h" /** * @short This class represents a single tape index. */ class Tape { bool _stubbed; TQCString _id; int _ctime; int _mtime; TQString _name; int _size; TQPtrList<Archive> _children; FILE* _fptr; void readVersion1Index( FILE* fptr ); void readVersion2Index( FILE* fptr ); void readVersion3Index( FILE* fptr ); void readVersion4Index( FILE* fptr ); void calcRanges(); void read(); void readAll( int version ); void write(); public: /** * Create a new tape index, and automatically generate a unique tape ID. */ Tape(); /** * Create a new tape index for the given tape index ID. * * @param id The unique tape index identifier. */ Tape( const char * id ); /** * Destroy the tape index. */ ~Tape(); /** * Writes a KDat header containing the tape ID, at the beginning of the * tape. All data on the tape will be lost. */ void format(); /** * Get the unique ID for the tape. * * @return The tape id. */ TQString getID(); /** * Get the user-specified name for the tape. * * @return The name of the tape. */ TQString getName(); /** * Get the date and time that the tape was formatted. * * @return The tape format time, in seconds since the Epoch. */ int getCTime(); /** * Get the last time that the tape was modified. * * @return The tape modification time, in seconds since the Epoch. */ int getMTime(); /** * Get the total tape capacity. * * @return The tape capacity in kilobytes. */ int getSize(); /** * Get the list of archives on this tape. * * @return The list of all archives on the tape. */ const TQPtrList<Archive>& getChildren(); /** * Set the name for the tape. * * @param name The new name for the tape. */ void setName( const TQString & name ); /** * Set the modification time for the tape to be the current time.. */ void setMTime( int mtime ); /** * Set the total capacity of the tape. * * @param size The total size, in kilobytes, of the tape. */ void setSize( int size ); /** * Add an archive to the tape index. * * @param archive The archive to add. */ void addChild( Archive* archive ); /** * Remove an archive and all the archives that follow it from the index. * * @param archive The archive to remove. */ void removeChild( Archive* archive ); /** * Recursively destroy all children of the tape index. */ void clear(); }; #endif