library: libCore
#include "TZIPFile.h"

TZIPFile


class description - header file - source file
viewCVS header - viewCVS source

class TZIPFile: public TArchiveFile

Inheritance Inherited Members Includes Libraries
Class Charts

Function Members (Methods)

Display options:
Show inherited
Show non-public
public:
TZIPFile()
TZIPFile(const TZIPFile&)
TZIPFile(const char* archive, const char* member, TFile* file)
virtual~TZIPFile()
voidTObject::AbstractMethod(const char* method) const
virtual voidTObject::AppendPad(Option_t* option = "")
virtual voidTObject::Browse(TBrowser* b)
static TClass*Class()
virtual const char*TObject::ClassName() const
virtual voidTObject::Clear(Option_t* = "")
virtual TObject*TObject::Clone(const char* newname = "") const
virtual Int_tTObject::Compare(const TObject* obj) const
virtual voidTObject::Copy(TObject& object) const
virtual voidTObject::Delete(Option_t* option = "")
virtual Int_tTObject::DistancetoPrimitive(Int_t px, Int_t py)
virtual voidTObject::Draw(Option_t* option = "")
virtual voidTObject::DrawClass() const
virtual TObject*TObject::DrawClone(Option_t* option = "") const
virtual voidTObject::Dump() const
virtual voidTObject::Error(const char* method, const char* msgfmt) const
virtual voidTObject::Execute(const char* method, const char* params, Int_t* error = 0)
virtual voidTObject::Execute(TMethod* method, TObjArray* params, Int_t* error = 0)
virtual voidTObject::ExecuteEvent(Int_t event, Int_t px, Int_t py)
virtual voidTObject::Fatal(const char* method, const char* msgfmt) const
virtual TObject*TObject::FindObject(const char* name) const
virtual TObject*TObject::FindObject(const TObject* obj) const
const char*TArchiveFile::GetArchiveName() const
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
virtual const char*TObject::GetIconName() const
TArchiveMember*TArchiveFile::GetMember() const
Long64_tTArchiveFile::GetMemberFilePosition() const
Int_tTArchiveFile::GetMemberIndex() const
const char*TArchiveFile::GetMemberName() const
TObjArray*TArchiveFile::GetMembers() const
virtual const char*TObject::GetName() const
Int_tTArchiveFile::GetNumberOfMembers() const
virtual char*TObject::GetObjectInfo(Int_t px, Int_t py) const
static Bool_tTObject::GetObjectStat()
virtual Option_t*TObject::GetOption() const
virtual const char*TObject::GetTitle() const
virtual UInt_tTObject::GetUniqueID() const
virtual Bool_tTObject::HandleTimer(TTimer* timer)
virtual ULong_tTObject::Hash() const
virtual voidTObject::Info(const char* method, const char* msgfmt) const
virtual Bool_tTObject::InheritsFrom(const char* classname) const
virtual Bool_tTObject::InheritsFrom(const TClass* cl) const
virtual voidTObject::Inspect() const
voidTObject::InvertBit(UInt_t f)
virtual TClass*IsA() const
virtual Bool_tTObject::IsEqual(const TObject* obj) const
virtual Bool_tTObject::IsFolder() const
Bool_tTObject::IsOnHeap() const
virtual Bool_tTObject::IsSortable() const
Bool_tTObject::IsZombie() const
virtual voidTObject::ls(Option_t* option = "") const
voidTObject::MayNotUse(const char* method) const
virtual Bool_tTObject::Notify()
static TArchiveFile*TArchiveFile::Open(const char* url, TFile* file)
virtual Int_tOpenArchive()
static voidTObject::operator delete(void* ptr)
static voidTObject::operator delete(void* ptr, void* vp)
static voidTObject::operator delete[](void* ptr)
static voidTObject::operator delete[](void* ptr, void* vp)
void*TObject::operator new(size_t sz)
void*TObject::operator new(size_t sz, void* vp)
void*TObject::operator new[](size_t sz)
void*TObject::operator new[](size_t sz, void* vp)
TZIPFile&operator=(const TZIPFile&)
virtual voidTObject::Paint(Option_t* option = "")
virtual voidTObject::Pop()
virtual voidPrint(Option_t* option = "") const
virtual Int_tTObject::Read(const char* name)
virtual voidTObject::RecursiveRemove(TObject* obj)
voidTObject::ResetBit(UInt_t f)
virtual voidTObject::SaveAs(const char* filename = "", Option_t* option = "") const
virtual voidTObject::SavePrimitive(ostream& out, Option_t* option = "")
voidTObject::SetBit(UInt_t f)
voidTObject::SetBit(UInt_t f, Bool_t set)
virtual Int_tSetCurrentMember()
virtual voidTObject::SetDrawOption(Option_t* option = "")
static voidTObject::SetDtorOnly(void* obj)
virtual Int_tTArchiveFile::SetMember(const char* member)
virtual Int_tTArchiveFile::SetMember(Int_t idx)
static voidTObject::SetObjectStat(Bool_t stat)
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidShowMembers(TMemberInspector& insp, char* parent)
virtual voidStreamer(TBuffer& b)
voidStreamerNVirtual(TBuffer& b)
virtual voidTObject::SysError(const char* method, const char* msgfmt) const
Bool_tTObject::TestBit(UInt_t f) const
Int_tTObject::TestBits(UInt_t f) const
virtual voidTObject::UseCurrentStyle()
virtual voidTObject::Warning(const char* method, const char* msgfmt) const
virtual Int_tTObject::Write(const char* name = "0", Int_t option = 0, Int_t bufsize = 0)
virtual Int_tTObject::Write(const char* name = "0", Int_t option = 0, Int_t bufsize = 0) const
protected:
virtual voidTObject::DoError(int level, const char* location, const char* fmt, va_list va) const
Long64_tFindEndHeader()
UInt_tGet(const void* buffer, Int_t bytes)
voidTObject::MakeZombie()
static Bool_tTArchiveFile::ParseUrl(const char* url, TString& archive, TString& member)
Int_tReadDirectory()
Int_tReadEndHeader(Long64_t pos)
Int_tReadMemberHeader(TZIPMember* member)

Data Members

public:
enum EZIPConstants { kARCHIVE_VERSION
kDIR_HEADER_MAGIC
kENTRY_HEADER_MAGIC
kEND_HEADER_MAGIC
kZIP_MAGIC_LEN
kMAX_VAR_LEN
kMAX_SIZE
kDIR_MAGIC_OFF
kDIR_VMADE_OFF
kDIR_VMADE_LEN
kDIR_VREQD_OFF
kDIR_VREQD_LEN
kDIR_FLAG_OFF
kDIR_FLAG_LEN
kDIR_METHOD_OFF
kDIR_METHOD_LEN
kDIR_DATE_OFF
kDIR_DATE_LEN
kDIR_CRC32_OFF
kDIR_CRC32_LEN
kDIR_CSIZE_OFF
kDIR_CSIZE_LEN
kDIR_USIZE_OFF
kDIR_USIZE_LEN
kDIR_NAMELEN_OFF
kDIR_NAMELEN_LEN
kDIR_EXTRALEN_OFF
kDIR_EXTRALEN_LEN
kDIR_COMMENTLEN_OFF
kDIR_COMMENTLEN_LEN
kDIR_DISK_START_OFF
kDIR_DISK_START_LEN
kDIR_INT_ATTR_OFF
kDIR_INT_ATTR_LEN
kDIR_EXT_ATTR_OFF
kDIR_EXT_ATTR_LEN
kDIR_ENTRY_POS_OFF
kDIR_ENTRY_POS_LEN
kDIR_HEADER_SIZE
kEND_MAGIC_OFF
kEND_DISK_OFF
kEND_DISK_LEN
kEND_DIR_DISK_OFF
kEND_DIR_DISK_LEN
kEND_DISK_HDRS_OFF
kEND_DISK_HDRS_LEN
kEND_TOTAL_HDRS_OFF
kEND_TOTAL_HDRS_LEN
kEND_DIR_SIZE_OFF
kEND_DIR_SIZE_LEN
kEND_DIR_OFFSET_OFF
kEND_DIR_OFFSET_LEN
kEND_COMMENTLEN_OFF
kEND_COMMENTLEN_LEN
kEND_HEADER_SIZE
kENTRY_MAGIC_OFF
kENTRY_VREQD_OFF
kENTRY_VREQD_LEN
kENTRY_FLAG_OFF
kENTRY_FLAG_LEN
kENTRY_METHOD_OFF
kENTRY_METHOD_LEN
kENTRY_DATE_OFF
kENTRY_DATE_LEN
kENTRY_CRC32_OFF
kENTRY_CRC32_LEN
kENTRY_CSIZE_OFF
kENTRY_CSIZE_LEN
kENTRY_USIZE_OFF
kENTRY_USIZE_LEN
kENTRY_NAMELEN_OFF
kENTRY_NAMELEN_LEN
kENTRY_EXTRALEN_OFF
kENTRY_EXTRALEN_LEN
kENTRY_HEADER_SIZE
kSTORED
kDEFLATED
};
enum TObject::EStatusBits { kCanDelete
kMustCleanup
kObjInCanvas
kIsReferenced
kHasUUID
kCannotPick
kNoContextMenu
kInvalidObject
};
enum TObject::[unnamed] { kIsOnHeap
kNotDeleted
kZombie
kBitMask
kSingleKey
kOverwrite
kWriteDelete
};
protected:
Long64_tfDirPosCentral directory position
Long64_tfDirSizeCentral directory size
Long64_tfDirOffsetCentral directory offset (from the beginning of the archive)
TStringfCommentArchive comment
TStringTArchiveFile::fArchiveNameArchive file name
TStringTArchiveFile::fMemberNameSub-file name
Int_tTArchiveFile::fMemberIndexIndex of sub-file in archive
TFile*TArchiveFile::fFileFile stream used to access the archive
TObjArray*TArchiveFile::fMembersMembers in this archive
TArchiveMember*TArchiveFile::fCurMemberCurrent archive member

Class Description

                                                                      
 TZIPFile                                                             
                                                                      
 This class describes a ZIP archive file containing multiple          
 sub-files. Typically the sub-files are ROOT files. Notice that       
 the ROOT files should not be compressed when being added to the      
 ZIP file, since ROOT files are normally already compressed.          
 Such a ZIP file should be created like:                              
                                                                      
    zip -n root multi file1.root file2.root                           
                                                                      
 which creates a ZIP file multi.zip.                                  
                                                                      
 A ZIP archive consists of files compressed with the popular ZLIB     
 compression algorithm. The archive format is used among others by    
 PKZip and Info-ZIP. The compression algorithm is also used by        
 GZIP and the PNG graphics standard. The format of the archives is    
 explained briefly below. This class provides an interface to read    
 such archives.                                                       
                                                                      
 A ZIP archive contains a prefix, series of archive members           
 (sub-files), and a central directory. In theory the archive could    
 span multiple disks (or files) with the central directory of the     
 whole archive on the last disk, but this class does not support      
 such multi-part archives. The prefix is only used in self-extracting 
 executable archive files.                                            
                                                                      
 The members are stored in the archive sequentially, each with a      
 local header followed by the (optionally) compressed data; the local 
 header describes the member, including its file name and compressed  
 and real sizes. The central directory includes the member details    
 again, plus allows an extra member comment to be added. The last     
 member in the central directory is an end marker that can contain    
 a comment for the whole archive. Both the local header and the       
 central directory can also carry extra member-specific data; the     
 data in the local and global parts can be different.                 
 The fact that the archive has a global directory makes it efficient  
 and allows for only the reading of the desired data, one does not    
 have to scan through the whole file to find the desired sub-file.    
                                                                      
 Once the archive has been opened, the client can query the members   
 and read their contents by asking the archive for an offset where    
 the sub-file starts. The members can be accessed in any order.       
                                                                      

TZIPFile()
 Default ctor.
TZIPFile(const char *archive, const char *member, TFile *file)
 Specify the archive name and member name. The member can be a decimal
 number which allows to access the n-th member.
Int_t OpenArchive()
 Open archive and read end-header and directory. Returns -1 in case
 of error, 0 otherwise.
Long64_t FindEndHeader()
 Find the end header of the ZIP archive. Returns 0 in case of error.
Int_t ReadEndHeader(Long64_t pos)
 Read the end header of the ZIP archive including the archive comment
 at the current file position. Check that it really was a single-disk
 archive with all the entries as expected. Most importantly, figure
 out where the central directory begins. Returns -1 in case of error,
 0 otherwise.
Int_t ReadDirectory()
 Read the directory of the ZIP archive. Returns -1 in case of error,
 0 otherwise.
Int_t ReadMemberHeader(TZIPMember *member)
 Read the member header of the ZIP archive. Sets the position where
 the data starts in the member object. Returns -1 in case of error,
 0 otherwise.
Int_t SetCurrentMember()
 Find the desired member in the member array and make it the
 current member. Returns -1 in case member is not found, 0 otherwise.
UInt_t Get(const void *buffer, Int_t bytes)
 Read a "bytes" long little-endian integer value from "buffer".
void Print(Option_t *)
 Pretty print ZIP archive members.
TZIPFile()
virtual ~TZIPFile()
{ }
TZIPMember & operator=(const TZIPMember &rhs)

Author: Fons Rademakers and Lassi Tuura 30/6/04
Last update: root/base:$Name: $:$Id: TZIPFile.cxx,v 1.5 2005/05/16 21:40:30 rdm Exp $
Copyright (C) 1995-2004, Rene Brun and Fons Rademakers. *


ROOT page - Class index - Class Hierarchy - Top of the page

This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.