You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdeutils/ark/arch.h

223 lines
8.0 KiB

/*
ark -- archiver for the KDE project
Copyright (C)
1997-1999: Rob Palmbos palm9744@kettering.edu
1999: Francois-Xavier Duranceau duranceau@kde.org
1999-2000: Corel Corporation (author: Emily Ezust, emilye@corel.com)
2001: Corel Corporation (author: Michael Jarrett, michaelj@corel.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.
*/
/* The following class is the base class for all of the archive types.
* In order for it to work properly with the KProcess, you have to
* connect the ProcessExited signal appropriately before spawning
* the core operations. Then the signal that the process exited can
* be intercepted by the viewer (in ark, ArkWidget) and dealt with
* appropriately. See LhaArch or ZipArch for a good model. Don't use
* TarArch or CompressedFile as models - they're too complicated!
*
* Don't forget to set m_archiver_program and m_unarchiver_program
* and add a call to
* verifyUtilityIsAvailable(m_archiver_program, m_unarchiver_program);
* in the constructor of your class. It's OK to leave out the second argument.
*
* To add a new archive type:
* 1. Create a new header file and a source code module
* 2. Add an entry to the ArchType enum in arch.h.
* 3. Add appropriate types to buildFormatInfo() in archiveformatinfo.cpp
* and archFactory() in arch.cpp
*/
#ifndef ARCH_H
#define ARCH_H
#include <tqobject.h>
#include <tqptrlist.h> // Some very annoying hackery in arkwidgetpart
#include <tqregexp.h>
#include <tqstring.h>
#include <kurl.h>
#include <tqpair.h>
class TQCString;
class TQStringList;
class KProcess;
class FileListView;
class ArkWidget;
enum ArchType { UNKNOWN_FORMAT, ZIP_FORMAT, TAR_FORMAT, AA_FORMAT,
LHA_FORMAT, RAR_FORMAT, ZOO_FORMAT, COMPRESSED_FORMAT,
SEVENZIP_FORMAT, ACE_FORMAT };
typedef TQValueList< TQPair< TQString, TQt::AlignmentFlags > > ColumnList;
/**
* Pure virtual base class for archives - provides a framework as well as
* useful common functionality.
*/
class Arch : public TQObject
{
Q_OBJECT
TQ_OBJECT
protected:
/**
* A struct representing column data. This makes it possible to abstract
* archive output, and save writing the same function for every archive
* type. It is also much more robust than sscanf (which was breaking).
*/
struct ArchColumns
{
int colRef; // Which column to load to in processLine
TQRegExp pattern;
int maxLength;
bool optional;
ArchColumns( int col, TQRegExp reg, int length = 64, bool opt = false );
};
public:
Arch( ArkWidget *_viewer, const TQString & _fileName );
virtual ~Arch();
virtual void open() = 0;
virtual void create() = 0;
virtual void remove( TQStringList * ) = 0;
virtual void addFile( const TQStringList & ) = 0;
virtual void addDir( const TQString & ) = 0;
// unarch the files in m_fileList or all files if m_fileList is empty.
// if m_destDir is empty, abort with error.
// m_viewFriendly forces certain options like directory junking required by view/edit
virtual void unarchFileInternal() = 0;
// returns true if a password is required
virtual bool passwordRequired() { return false; }
void unarchFile( TQStringList *, const TQString & _destDir,
bool viewFriendly = false );
TQString fileName() const { return m_filename; }
enum EditProperties{ Add = 1, Delete = 2, Extract = 4,
View = 8, Integrity = 16 };
// is the archive readonly?
bool isReadOnly() { return m_bReadOnly; }
void setReadOnly( bool bVal ) { m_bReadOnly = bVal; }
bool isError() { return m_error; }
void resetError() { m_error = false; }
// check to see if the utility exists in the PATH of the user
void verifyUtilityIsAvailable( const TQString &,
const TQString & = TQString() );
void verifyCompressUtilityIsAvailable( const TQString &utility );
void verifyUncompressUtilityIsAvailable( const TQString &utility );
bool archUtilityIsAvailable() { return m_bArchUtilityIsAvailable; }
bool unarchUtilityIsAvailable() { return m_bUnarchUtilityIsAvailable; }
TQString getArchUtility() { return m_archiver_program; }
TQString getUnarchUtility() { return m_unarchiver_program; }
void appendShellOutputData( const char * data ) { m_lastShellOutput.append( TQString::fromLocal8Bit( data ) ); }
void clearShellOutput() { m_lastShellOutput.truncate( 0 ); }
const TQString& getLastShellOutput() const { return m_lastShellOutput; }
static Arch *archFactory( ArchType aType, ArkWidget *parent,
const TQString &filename,
const TQString &openAsMimeType = TQString() );
protected slots:
void slotOpenExited( KProcess* );
void slotExtractExited( KProcess* );
void slotDeleteExited( KProcess* );
void slotAddExited( KProcess* );
void slotReceivedOutput( KProcess *, char*, int );
virtual bool processLine( const TQCString &line );
virtual void slotReceivedTOC( KProcess *, char *, int );
signals:
void sigOpen( Arch * archive, bool success, const TQString &filename, int );
void sigCreate( Arch *, bool, const TQString &, int );
void sigDelete( bool );
void sigExtract( bool );
void sigAdd( bool );
void headers( const ColumnList& columns );
protected: // data
TQString m_filename;
TQString m_lastShellOutput;
TQCString m_buffer;
ArkWidget *m_gui;
bool m_bReadOnly; // for readonly archives
bool m_error;
// lets tar delete unsuccessfully before adding without confusing the user
bool m_bNotifyWhenDeleteFails;
// set to whether if the compressing utility is in the user's PATH
bool m_bArchUtilityIsAvailable;
// set to whether if the uncompressing utility is in the user's PATH
bool m_bUnarchUtilityIsAvailable;
TQString m_archiver_program;
TQString m_unarchiver_program;
// Archive parsing information
TQCString m_headerString;
bool m_header_removed, m_finished;
TQPtrList<ArchColumns> m_archCols;
int m_numCols, m_dateCol, m_fixYear, m_fixMonth, m_fixDay, m_fixTime;
int m_repairYear, m_repairMonth, m_repairTime;
KProcess *m_currentProcess;
TQStringList *m_fileList;
TQString m_destDir;
bool m_viewFriendly;
TQCString m_password;
};
// Columns
// don't forget to change common_texts.cpp if you change something here
#define FILENAME_COLUMN tqMakePair( i18n(" Filename "), TQt::AlignLeft )
#define PERMISSION_COLUMN tqMakePair( i18n(" Permissions "), TQt::AlignLeft )
#define OWNER_GROUP_COLUMN tqMakePair( i18n(" Owner/Group "), TQt::AlignLeft )
#define SIZE_COLUMN tqMakePair( i18n(" Size "), TQt::AlignRight )
#define TIMESTAMP_COLUMN tqMakePair( i18n(" Timestamp "), TQt::AlignRight )
#define LINK_COLUMN tqMakePair( i18n(" Link "), TQt::AlignLeft )
#define PACKED_COLUMN tqMakePair( i18n(" Size Now "), TQt::AlignRight )
#define RATIO_COLUMN tqMakePair( i18n(" Ratio "), TQt::AlignRight )
#define CRC_COLUMN tqMakePair( i18n("Cyclic Redundancy Check"," CRC "), TQt::AlignLeft )
#define METHOD_COLUMN tqMakePair( i18n(" Method "), TQt::AlignLeft )
#define VERSION_COLUMN tqMakePair( i18n(" Version "), TQt::AlignLeft )
#define OWNER_COLUMN tqMakePair( i18n(" Owner "), TQt::AlignLeft )
#define GROUP_COLUMN tqMakePair( i18n(" Group "), TQt::AlignLeft )
#endif /* ARCH_H */