* contrib/hbziparch/_features.h
* contrib/hbziparch/_platform.h
* contrib/hbziparch/Aes.cpp
* contrib/hbziparch/Aes.h
* contrib/hbziparch/BaseLibCompressor.cpp
* contrib/hbziparch/BaseLibCompressor.h
* contrib/hbziparch/BytesWriter.h
* contrib/hbziparch/Bzip2Compressor.cpp
* contrib/hbziparch/Bzip2Compressor.h
* contrib/hbziparch/DeflateCompressor.cpp
* contrib/hbziparch/DeflateCompressor.h
* contrib/hbziparch/DirEnumerator.cpp
* contrib/hbziparch/DirEnumerator.h
* contrib/hbziparch/FileFilter.cpp
* contrib/hbziparch/FileFilter.h
* contrib/hbziparch/FileInfo.h
* contrib/hbziparch/Hmac.cpp
* contrib/hbziparch/Hmac.h
* contrib/hbziparch/RandomPool.cpp
* contrib/hbziparch/RandomPool.h
* contrib/hbziparch/Sha1.cpp
* contrib/hbziparch/Sha1.h
* contrib/hbziparch/std_mfc.h
* contrib/hbziparch/std_stl.h
* contrib/hbziparch/Wildcard.cpp
* contrib/hbziparch/Wildcard.h
* contrib/hbziparch/ZipAbstractFile.h
* contrib/hbziparch/ZipAesCryptograph.cpp
* contrib/hbziparch/ZipAesCryptograph.h
* contrib/hbziparch/ZipArchive.cpp
* contrib/hbziparch/ZipArchive.h
* contrib/hbziparch/ZipAutoBuffer.cpp
* contrib/hbziparch/ZipAutoBuffer.h
* contrib/hbziparch/ZipBaseException.h
* contrib/hbziparch/ZipCallback.h
* contrib/hbziparch/ZipCallbackProvider.h
* contrib/hbziparch/ZipCentralDir.cpp
* contrib/hbziparch/ZipCentralDir.h
* contrib/hbziparch/ZipCollections.h
* contrib/hbziparch/ZipCollections_mfc.h
* contrib/hbziparch/ZipCollections_stl.h
* contrib/hbziparch/ZipCompatibility.cpp
* contrib/hbziparch/ZipCompatibility.h
* contrib/hbziparch/ZipCompressor.cpp
* contrib/hbziparch/ZipCompressor.h
* contrib/hbziparch/ZipCrc32Cryptograph.cpp
* contrib/hbziparch/ZipCrc32Cryptograph.h
* contrib/hbziparch/ZipCryptograph.cpp
* contrib/hbziparch/ZipCryptograph.h
* contrib/hbziparch/ZipException.cpp
* contrib/hbziparch/ZipException.h
* contrib/hbziparch/ZipExtraData.cpp
* contrib/hbziparch/ZipExtraData.h
* contrib/hbziparch/ZipExtraField.cpp
* contrib/hbziparch/ZipExtraField.h
* contrib/hbziparch/ZipFile.h
* contrib/hbziparch/ZipFile_mfc.cpp
* contrib/hbziparch/ZipFile_mfc.h
* contrib/hbziparch/ZipFile_stl.cpp
* contrib/hbziparch/ZipFile_stl.h
* contrib/hbziparch/ZipFileHeader.cpp
* contrib/hbziparch/ZipFileHeader.h
* contrib/hbziparch/ZipFileMapping.h
* contrib/hbziparch/ZipFileMapping_lnx.h
* contrib/hbziparch/ZipFileMapping_win.h
* contrib/hbziparch/ZipMemFile.cpp
* contrib/hbziparch/ZipMemFile.h
* contrib/hbziparch/ZipMutex.h
* contrib/hbziparch/ZipMutex_lnx.h
* contrib/hbziparch/ZipMutex_win.h
* contrib/hbziparch/ZipPathComponent.h
* contrib/hbziparch/ZipPlatform.h
* contrib/hbziparch/ZipPlatformComm.cpp
* contrib/hbziparch/ZipStorage.cpp
* contrib/hbziparch/ZipStorage.h
* contrib/hbziparch/ZipString.h
* contrib/hbziparch/ZipString_mfc.h
* contrib/hbziparch/ZipString_stl.h
* contrib/hbziparch/ZipStringStoreSettings.h
+ ZipArchive lib update finished.
; Pass 2/2
; Please test.
159 lines
3.2 KiB
C++
159 lines
3.2 KiB
C++
////////////////////////////////////////////////////////////////////////////////
|
|
// This source file is part of the ZipArchive library source distribution and
|
|
// is Copyrighted 2000 - 2007 by Artpol Software - Tadeusz Dracz
|
|
//
|
|
// 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.
|
|
//
|
|
// For the licensing details refer to the License.txt file.
|
|
//
|
|
// Web Site: http://www.artpol-software.com
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
/**
|
|
* \file ZipExtraData.h
|
|
* Includes the CZipExtraData class.
|
|
*
|
|
*/
|
|
|
|
#if !defined(ZIPARCHIVE_ZIPEXTRADATA_DOT_H)
|
|
#define ZIPARCHIVE_ZIPEXTRADATA_DOT_H
|
|
|
|
#if _MSC_VER > 1000
|
|
#pragma once
|
|
#endif
|
|
|
|
#include "ZipExport.h"
|
|
#include "ZipAutoBuffer.h"
|
|
#include "ZipExtraField.h"
|
|
#include "memory.h"
|
|
|
|
/**
|
|
Represents a single data record in an extra field.
|
|
|
|
\see
|
|
<a href="kb">0610242300</a>
|
|
*/
|
|
class ZIP_API CZipExtraData
|
|
{
|
|
friend class CZipExtraField;
|
|
public:
|
|
|
|
/**
|
|
The custom data contained by this record.
|
|
*/
|
|
CZipAutoBuffer m_data;
|
|
|
|
CZipExtraData()
|
|
{
|
|
m_uHeaderID = 0;
|
|
}
|
|
|
|
CZipExtraData(const CZipExtraData& extra)
|
|
{
|
|
*this = extra;
|
|
}
|
|
|
|
/**
|
|
Initializes a new instance of the CZipExtraData class.
|
|
|
|
\param uHeaderID
|
|
The unique ID of the data.
|
|
*/
|
|
CZipExtraData(WORD uHeaderID)
|
|
{
|
|
m_uHeaderID = uHeaderID;
|
|
}
|
|
|
|
CZipExtraData& operator=(const CZipExtraData& extra)
|
|
{
|
|
m_uHeaderID = extra.m_uHeaderID;
|
|
DWORD uSize = extra.m_data.GetSize();
|
|
m_data.Allocate(uSize);
|
|
if (uSize > 0)
|
|
memcpy(m_data, extra.m_data, uSize);
|
|
return *this;
|
|
}
|
|
bool operator==(const CZipExtraData& extra)
|
|
{
|
|
return m_uHeaderID == extra.m_uHeaderID && m_data.GetSize() == extra.m_data.GetSize() && memcmp(m_data, extra.m_data, m_data.GetSize()) == 0;
|
|
}
|
|
bool operator != (const CZipExtraData& extra)
|
|
{
|
|
return !(*this == extra);
|
|
}
|
|
bool operator > (const CZipExtraData& extra)
|
|
{
|
|
return m_uHeaderID > extra.m_uHeaderID;
|
|
}
|
|
bool operator < (const CZipExtraData& extra)
|
|
{
|
|
return m_uHeaderID < extra.m_uHeaderID;
|
|
}
|
|
bool operator >= (const CZipExtraData& extra)
|
|
{
|
|
return m_uHeaderID > extra.m_uHeaderID || *this == extra;
|
|
}
|
|
|
|
bool operator <= (const CZipExtraData& extra)
|
|
{
|
|
return m_uHeaderID < extra.m_uHeaderID || *this == extra;
|
|
}
|
|
|
|
/**
|
|
Gets the total size, the extra data will occupy in the archive.
|
|
|
|
\return
|
|
The size in bytes.
|
|
*/
|
|
int GetTotalSize() const
|
|
{
|
|
return 4 + m_data.GetSize();
|
|
}
|
|
|
|
/**
|
|
Gets the data ID.
|
|
|
|
\return
|
|
The data ID.
|
|
*/
|
|
WORD GetHeaderID() const
|
|
{
|
|
return m_uHeaderID;
|
|
}
|
|
|
|
protected:
|
|
|
|
/**
|
|
Reads the extra data record from \a buffer.
|
|
|
|
\param buffer
|
|
The buffer to read the data from.
|
|
|
|
\param uSize
|
|
The size of the data to read.
|
|
|
|
\return
|
|
\c false, if \a uSize was smaller than the declared extra data size; \c true otherwise.
|
|
*/
|
|
bool Read(char* buffer, WORD uSize);
|
|
|
|
/**
|
|
Writes the extra data record to \a buffer.
|
|
|
|
\param buffer
|
|
The buffer to write to.
|
|
|
|
\return
|
|
The total size of extra data in bytes.
|
|
*/
|
|
WORD Write(char* buffer)const;
|
|
|
|
private:
|
|
WORD m_uHeaderID;
|
|
};
|
|
|
|
#endif // !defined(ZIPARCHIVE_ZIPEXTRADATA_DOT_H)
|