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.
k3b/libk3b/tools/k3biso9660.h

454 lines
11 KiB

/*
*
* $Id: k3biso9660.h 619556 2007-01-03 17:38:12Z trueg $
* Copyright (C) 2003 Sebastian Trueg <trueg@k3b.org>
*
* This file is part of the K3b project.
* Copyright (C) 1998-2007 Sebastian Trueg <trueg@k3b.org>
*
* 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.
* See the file "COPYING" for the exact licensing terms.
*/
#ifndef _K3B_ISO9660_H_
#define _K3B_ISO9660_H_
#include <sys/stat.h>
#include <sys/types.h>
#include <tqdatetime.h>
#include <tqstring.h>
#include <tqstringlist.h>
#include <tqdict.h>
#include "k3b_export.h"
namespace K3bDevice {
class Device;
}
class K3bIso9660;
class K3bIso9660Backend;
struct iso_directory_record;
struct el_torito_boot_descriptor;
struct iso_primary_descriptor;
typedef long long sector_t;
/**
* Simplyfied primary descriptor which just contains the fields
* used by K3b.
*/
class LIBK3B_EXPORT K3bIso9660SimplePrimaryDescriptor
{
public:
/**
* Creates an empty descriptor
*/
K3bIso9660SimplePrimaryDescriptor();
TQString volumeId;
TQString systemId;
TQString volumeSetId;
TQString publisherId;
TQString preparerId;
TQString applicationId;
int volumeSetSize;
int volumeSetNumber;
long logicalBlockSize;
long long volumeSpaceSize;
};
LIBK3B_EXPORT bool operator==( const K3bIso9660SimplePrimaryDescriptor& d1,
const K3bIso9660SimplePrimaryDescriptor& d2 );
LIBK3B_EXPORT bool operator!=( const K3bIso9660SimplePrimaryDescriptor& d1,
const K3bIso9660SimplePrimaryDescriptor& d2 );
/**
* Base class for all entries in a K3bIso9660 archive. A lot has been copied
* from KArchive.
*/
class LIBK3B_EXPORT K3bIso9660Entry
{
public:
K3bIso9660Entry( K3bIso9660* archive,
const TQString& isoName,
const TQString& name,
int access,
int date,
int adate,
int cdate,
const TQString& user,
const TQString& group,
const TQString& symlink );
virtual ~K3bIso9660Entry();
int adate() const { return m_adate; }
int cdate() const { return m_cdate; }
/**
* Creation date of the file.
* @return the creation date
*/
TQDateTime datetime() const;
/**
* Creation date of the file.
* @return the creation date in seconds since 1970
*/
int date() const { return m_date; }
/**
* Name of the file without path.
* @return The file name without path.
*/
const TQString& name() const { return m_name; }
/**
* \return The raw name as saved in the ISO9660 tree
*/
const TQString& isoName() const { return m_isoName; }
/**
* The permissions and mode flags as returned by the stat() function
* in st_mode.
* @return the permissions
*/
mode_t permissions() const { return m_access; }
/**
* User who created the file.
* @return the owner of the file
*/
const TQString& user() const { return m_user; }
/**
* Group of the user who created the file.
* @return the group of the file
*/
const TQString& group() const { return m_group; }
/**
* Symlink if there is one.
* @return the symlink, or TQString()
*/
const TQString& symlink() const { return m_symlink; }
/**
* Checks whether the entry is a file.
* @return true if this entry is a file
*/
virtual bool isFile() const { return false; }
/**
* Checks whether the entry is a directory.
* @return true if this entry is a directory
*/
virtual bool isDirectory() const { return false; }
K3bIso9660* archive() const { return m_archive; }
private:
int m_adate;
int m_cdate;
TQString m_name;
TQString m_isoName;
int m_date;
mode_t m_access;
TQString m_user;
TQString m_group;
TQString m_symlink;
K3bIso9660* m_archive;
};
class LIBK3B_EXPORT K3bIso9660Directory : public K3bIso9660Entry
{
public:
K3bIso9660Directory( K3bIso9660* archive,
const TQString& isoName,
const TQString& name,
int access,
int date,
int adate,
int cdate,
const TQString& user,
const TQString& group,
const TQString& symlink,
unsigned int pos = 0,
unsigned int size = 0 );
~K3bIso9660Directory();
/**
* Returns a list of sub-entries.
* @return the names of all entries in this directory (filenames, no path).
*/
TQStringList entries() const;
/**
* Returns the entry with the given name.
* @param name may be "test1", "mydir/test3", "mydir/mysubdir/test3", etc.
* @return a pointer to the entry in the directory.
*/
K3bIso9660Entry* entry( const TQString& name );
/**
* Returns the entry with the given name.
* @param name may be "test1", "mydir/test3", "mydir/mysubdir/test3", etc.
* @return a pointer to the entry in the directory.
*/
const K3bIso9660Entry* entry( const TQString& name ) const;
/**
* Returns a list of sub-entries.
* Searches for Iso9660 names.
* @return the names of all entries in this directory (filenames, no path).
*/
TQStringList iso9660Entries() const;
/**
* Returns the entry with the given name.
* Searches for Iso9660 names.
* @param name may be "test1", "mydir/test3", "mydir/mysubdir/test3", etc.
* @return a pointer to the entry in the directory.
*/
K3bIso9660Entry* iso9660Entry( const TQString& name );
/**
* Returns the entry with the given name.
* Searches for Iso9660 names.
* @param name may be "test1", "mydir/test3", "mydir/mysubdir/test3", etc.
* @return a pointer to the entry in the directory.
*/
const K3bIso9660Entry* iso9660Entry( const TQString& name ) const;
/**
* @internal
* Adds a new entry to the directory.
*/
void addEntry( K3bIso9660Entry* );
/**
* Checks whether this entry is a directory.
* @return true, since this entry is a directory
*/
bool isDirectory() const { return true; }
private:
void expand();
TQDict<K3bIso9660Entry> m_entries;
TQDict<K3bIso9660Entry> m_iso9660Entries;
bool m_bExpanded;
unsigned int m_startSector;
unsigned int m_size;
};
class LIBK3B_EXPORT K3bIso9660File : public K3bIso9660Entry
{
public:
/**
* @param pos start sector
*/
K3bIso9660File( K3bIso9660* archive,
const TQString& isoName,
const TQString& name,
int access,
int date,
int adate,
int cdate,
const TQString& user,
const TQString& group,
const TQString& symlink,
unsigned int pos,
unsigned int size );
~K3bIso9660File();
bool isFile() const { return true; }
void setZF( char algo[2], char parms[2], int realsize );
int realsize() const { return m_realsize; }
/**
* @return size in bytes.
*/
unsigned int size() const { return m_size; }
/**
* Returnes the startSector of the file.
*/
unsigned int startSector() const { return m_startSector; }
/**
* Returnes the startOffset of the file in bytes.
*/
unsigned long long startPostion() const { return (unsigned long long)m_startSector * 2048; }
/**
* @param pos offset in bytes
* @param len max number of bytes to read
*/
int read( unsigned int pos, char* data, int len ) const;
/**
* Copy this file to a url.
*/
bool copyTo( const TQString& url ) const;
private:
char m_algo[2];
char m_parms[2];
int m_realsize;
unsigned int m_curpos;
unsigned int m_startSector;
unsigned int m_size;
};
/**
* This class is based on the KIso class by
* Gy<47>rgy Szombathelyi <gyurco@users.sourceforge.net>.
* A lot has been changed and bugfixed.
* The API has been improved to be useful.
*
* Due to the stupid TQt which does not support large files as default
* we cannot use TQIODevice with DVDs! That's why we have our own
* reading code which is not allowed by KArchive (which is limited to int
* by the way... who the hell designed this?)
* I also removed the KArchive inheritance because of the named reasons.
* So this stuff contains a lot KArchive code which has been made usable.
*
* That does not mean that this class is well designed. No, it's not. :)
*
* Opening a K3bIso9660 object should be fast since creation of the directory
* and file entries is not done until a call to K3bIso9660Directory::entries.
*/
class LIBK3B_EXPORT K3bIso9660
{
public:
/**
* Creates an instance that operates on the given filename.
* using the compression filter associated to given mimetype.
*
* @param filename is a local path (e.g. "/home/weis/myfile.tgz")
*/
K3bIso9660( const TQString& filename );
/**
* Special case which always reads the TOC from the specified sector
* thus supporting multisession CDs.
*/
K3bIso9660( K3bDevice::Device* dev, unsigned int startSector = 0 );
/**
* @param fd open file descriptor
*/
K3bIso9660( int fd );
/**
* Directly specify the backend to read from.
* K3bIso9660 will take ownership of the backend and delete it.
*/
K3bIso9660( K3bIso9660Backend* );
/**
* If the .iso is still opened, then it will be
* closed automatically by the destructor.
*/
virtual ~K3bIso9660();
/**
* Set where to start reading in the source.
*/
void setStartSector( unsigned int startSector );
/**
* If set to true before opening K3bIso9660 will ignore RR and joliet extensions
* and only create plain iso9660 names.
*/
void setPlainIso9660( bool );
bool plainIso9660() const;
/**
* Opens the archive for reading.
* Parses the directory listing of the archive
* and creates the K3bIso9660Directory/K3bIso9660File entries.
*/
bool open();
bool isOpen() const;
/**
* Closes everything.
* This is also called in the destructor
*/
void close();
/**
* @param sector startsector
* @param len number of sectors
* @return number of sectors read or -1 on error
*/
int read( unsigned int sector, char* data, int len );
/**
* The name of the os file, as passed to the constructor
* Null if you did not use the TQString constructor.
*/
const TQString& fileName() { return m_filename; }
const K3bIso9660Directory* firstJolietDirEntry() const;
const K3bIso9660Directory* firstRRDirEntry() const;
const K3bIso9660Directory* firstIsoDirEntry() const;
const K3bIso9660Directory* firstElToritoEntry() const;
/**
* @returns 0 if no joliet desc could be found
* the joliet level (1-3) otherwise
*/
int jolietLevel() const { return m_joliet; }
const K3bIso9660SimplePrimaryDescriptor& primaryDescriptor() const;
void debug() const;
private:
/**
* @internal
*/
void addBoot( struct el_torito_boot_descriptor* bootdesc );
void createSimplePrimaryDesc( struct iso_primary_descriptor* desc );
void debugEntry( const K3bIso9660Entry*, int depth ) const;
int m_joliet;
// only used for creation
static int read_callback( char* buf, sector_t start, long long len, void* udata );
static int isofs_callback( struct iso_directory_record* idr, void *udata );
K3bIso9660Directory *dirent;
bool m_rr;
friend class K3bIso9660Directory;
private:
TQString m_filename;
class Private;
Private * d;
};
#endif