/StormLib/stormlib/StormLib.h
http://ghostcb.googlecode.com/ · C Header · 644 lines · 329 code · 121 blank · 194 comment · 7 complexity · 1a8ce558f91fbddc79ae4cce0f5be95d MD5 · raw file
- /*****************************************************************************/
- /* StormLib.h Copyright (c) Ladislav Zezula 1999-2005 */
- /*---------------------------------------------------------------------------*/
- /* StormLib library v 5.00 */
- /* */
- /* Author : Ladislav Zezula */
- /* E-mail : ladik@zezula.net */
- /* WWW : http://www.zezula.net */
- /*---------------------------------------------------------------------------*/
- /* Date Ver Who Comment */
- /* -------- ---- --- ------- */
- /* xx.xx.99 1.00 Lad Created */
- /* 24.03.03 2.50 Lad Version 2.50 */
- /* 02.04.03 3.00 Lad Version 3.00 with compression */
- /* 11.04.03 3.01 Lad Renamed to StormLib.h for compatibility with */
- /* original headers for Storm.dll */
- /* 10.05.03 3.02 Lad Added Pkware DCL compression */
- /* 26.05.03 4.00 Lad Completed all compressions */
- /* 18.06.03 4.01 Lad Added SFileSetFileLocale */
- /* Added SFileExtractFile */
- /* 26.07.03 4.02 Lad Implemented nameless rename and delete */
- /* 26.07.03 4.03 Lad Added support for protected MPQs */
- /* 28.08.03 4.10 Lad Fixed bugs that caused StormLib incorrectly work */
- /* with Diablo I savegames and with files having full */
- /* hash table */
- /* 08.12.03 4.11 DCH Fixed bug in reading file block larger than 0x1000 */
- /* on certain files. */
- /* Fixed bug in AddFile with MPQ_FILE_REPLACE_EXISTING */
- /* (Thanx Daniel Chiamarello, dchiamarello@madvawes.com)*/
- /* 21.12.03 4.50 Lad Completed port for Mac */
- /* Fixed bug in compacting (if fsize is mul of 0x1000) */
- /* Fixed bug in SCompCompress */
- /* 27.05.04 4.51 Lad Changed memory management from new/delete to our */
- /* own macros */
- /* 22.06.04 4.60 Lad Optimized search. Support for multiple listfiles. */
- /* 30.09.04 4.61 Lad Fixed some bugs (Aaargh !!!) */
- /* Correctly works if HashTableSize > BlockTableSize */
- /* 29.12.04 4.70 Lad Fixed compatibility problem with MPQs from WoW */
- /* 14.07.05 5.00 Lad Added the BZLIB compression support */
- /* Added suport of files stored as single unit */
- /* 17.04.06 5.01 Lad Converted to MS Visual Studio 8.0 */
- /* Fixed issue with protected Warcraft 3 protected maps */
- /* 15.05.06 5.02 Lad Fixed issue with WoW 1.10+ */
- /* 07.09.06 5.10 Lad Fixed processing files longer than 2GB */
- /* 22.11.06 6.00 Lad Support for MPQ archives V2 */
- /* 12.06.07 6.10 Lad Support for extended file attributes */
- /* 10.09.07 6.12 Lad Support for MPQs protected by corrupting hash table */
- /* 03.12.07 6.13 Lad Support for MPQs with hash tbl size > block tbl size */
- /* 07.04.08 6.20 Lad Added SFileFlushArchive */
- /* 09.04.08 Lad Removed FilePointer variable from TMPQArchive, as */
- /* it caused more problems than benefits */
- /* 12.05.08 6.22 Lad Support for w3xMaster map protector */
- /* 05.10.08 6.23 Lad Support for protectors who set negative values in */
- /* the table of file blocks */
- /* 26.05.09 6.24 Lad Fixed search for multiple lang files with deleted */
- /* entries */
- /* 03.09.09 6.25 Lad Fixed decompression bug in huffmann decompression */
- /*****************************************************************************/
-
- #ifndef __STORMLIB_H_
- #define __STORMLIB_H_
-
- #include "StormPort.h"
-
- //-----------------------------------------------------------------------------
- // Use the apropriate library
- //
- // The library type is encoded in the library name as the following
- // StormLibXYZ.lib
- //
- // X - D for Debug version, R for Release version
- // Y - A for ANSI version, U for Unicode version (Unicode version does not exist yet)
- // Z - S for static C library, D for multithreaded DLL C-library
- //
-
- #if defined(_MSC_VER) && !defined (__STORMLIB_SELF__)
- #ifdef _DEBUG // DEBUG VERSIONS
- #ifdef _DLL
- #pragma comment(lib, "StormLibDAD.lib") // Debug Ansi Dynamic version
- #else
- #pragma comment(lib, "StormLibDAS.lib") // Debug Ansi Static version
- #endif
- #else // RELEASE VERSIONS
- #ifdef _DLL
- #pragma comment(lib, "StormLibRAD.lib") // Release Ansi Dynamic version
- #else
- #pragma comment(lib, "StormLibRAS.lib") // Release Ansi Static version
- #endif
- #endif
- #endif
-
- //-----------------------------------------------------------------------------
- // Defines
-
- #define ID_MPQ 0x1A51504D // MPQ archive header ID ('MPQ\x1A')
- #define ID_MPQ_SHUNT 0x1B51504D // MPQ shunt entry ('MPQ\x1B')
-
- #define ERROR_AVI_FILE 10000 // No MPQ file, but AVI file.
-
- // Values for SFileCreateArchiveEx
- #define HASH_TABLE_SIZE_MIN 0x00004
- #define HASH_TABLE_SIZE_MAX 0x40000
-
- #define HASH_ENTRY_DELETED 0xFFFFFFFE // Block index for deleted hash entry
- #define HASH_ENTRY_FREE 0xFFFFFFFF // Block index for free hash entry
-
- // Values for SFileOpenArchive
- #define SFILE_OPEN_HARD_DISK_FILE 2 // Open the archive on HDD
- #define SFILE_OPEN_CDROM_FILE 3 // Open the archive only if it is on CDROM
-
- // Values for SFileOpenFile
- #define SFILE_OPEN_FROM_MPQ 0 // Open the file from the MPQ archive
- #define SFILE_OPEN_BY_INDEX 1 // The 'szFileName' parameter is actually the file index
- #define SFILE_OPEN_LOCAL_FILE (DWORD)-1 // Open the file from the MPQ archive
-
- // Flags for TMPQArchive::dwFlags
- #define MPQ_FLAG_CHANGED 0x00000001 // If set, the MPQ has been changed
- #define MPQ_FLAG_PROTECTED 0x00000002 // Set on protected MPQs (like W3M maps)
-
- // Flags for SFileAddFile
- // Note: MPQ_FILE_COMPRESS_PKWARE has been replaced by MPQ_FILE_IMPLODE
- // Note: MPQ_FILE_COMPRESS_MULTI has been replaced by MPQ_FILE_COMPRESS
- #define MPQ_FILE_IMPLODE 0x00000100 // Implode method (By PKWARE Data Compression Library)
- #define MPQ_FILE_COMPRESS 0x00000200 // Compress methods (My various methods)
- #define MPQ_FILE_COMPRESSED 0x0000FF00 // File is compressed
- #define MPQ_FILE_ENCRYPTED 0x00010000 // Indicates whether file is encrypted
- #define MPQ_FILE_FIXSEED 0x00020000 // File decrypt seed has to be fixed
- #define MPQ_FILE_SINGLE_UNIT 0x01000000 // File is stored as a single unit, rather than split into sectors (Thx, Quantam)
- #define MPQ_FILE_DUMMY_FILE 0x02000000 // The file is only 1 byte long and its name is a hash
- #define MPQ_FILE_HAS_EXTRA 0x04000000 // The file has extra data appended after regular data.
- // Must be with compressed files only
- #define MPQ_FILE_EXISTS 0x80000000 // Set if file exists, reset when the file was deleted
- #define MPQ_FILE_REPLACEEXISTING 0x80000000 // Replace when the file exist (SFileAddFile)
-
- #define MPQ_FILE_VALID_FLAGS (MPQ_FILE_IMPLODE | \
- MPQ_FILE_COMPRESS | \
- MPQ_FILE_ENCRYPTED | \
- MPQ_FILE_FIXSEED | \
- MPQ_FILE_SINGLE_UNIT | \
- MPQ_FILE_DUMMY_FILE | \
- MPQ_FILE_HAS_EXTRA | \
- MPQ_FILE_EXISTS)
-
- // Compression types for multilpe compressions
- #define MPQ_COMPRESSION_HUFFMANN 0x01 // Huffmann compression (used on WAVE files only)
- #define MPQ_COMPRESSION_ZLIB 0x02 // ZLIB compression
- #define MPQ_COMPRESSION_PKWARE 0x08 // PKWARE DCL compression
- #define MPQ_COMPRESSION_BZIP2 0x10 // BZIP2 compression
- #define MPQ_COMPRESSION_WAVE_MONO 0x40 //
- #define MPQ_COMPRESSION_WAVE_STEREO 0x80 //
-
-
- // Constants for SFileAddWave
- #define MPQ_WAVE_QUALITY_HIGH 0 // Best quality, the worst compression
- #define MPQ_WAVE_QUALITY_MEDIUM 1 // Medium quality, medium compression
- #define MPQ_WAVE_QUALITY_LOW 2 // Low quality, the best compression
-
- // Constants for SFileGetFileInfo
- #define SFILE_INFO_ARCHIVE_SIZE 1 // MPQ size (value from header)
- #define SFILE_INFO_HASH_TABLE_SIZE 2 // Size of hash table, in entries
- #define SFILE_INFO_BLOCK_TABLE_SIZE 3 // Number of entries in the block table
- #define SFILE_INFO_BLOCK_SIZE 4 // Size of file block (in bytes)
- #define SFILE_INFO_HASH_TABLE 5 // Pointer to Hash table (TMPQHash *)
- #define SFILE_INFO_BLOCK_TABLE 6 // Pointer to Block Table (TMPQBlock *)
- #define SFILE_INFO_NUM_FILES 7 // Real number of files within archive
- //------
- #define SFILE_INFO_HASH_INDEX 8 // Hash index of file in MPQ
- #define SFILE_INFO_CODENAME1 9 // The first codename of the file
- #define SFILE_INFO_CODENAME2 10 // The second codename of the file
- #define SFILE_INFO_LOCALEID 11 // Locale ID of file in MPQ
- #define SFILE_INFO_BLOCKINDEX 12 // Index to Block Table
- #define SFILE_INFO_FILE_SIZE 13 // Original file size
- #define SFILE_INFO_COMPRESSED_SIZE 14 // Compressed file size
- #define SFILE_INFO_FLAGS 15 // File flags
- #define SFILE_INFO_POSITION 16 // File position within archive
- #define SFILE_INFO_SEED 17 // File decryption seed
- #define SFILE_INFO_SEED_UNFIXED 18 // Decryption seed not fixed to file pos and size
-
- // Values for compact callback
- #define CCB_CHECKING_FILES 1 // Checking archive (dwParam1 = current, dwParam2 = total)
- #define CCB_CHECKING_HASH_TABLE 2 // Checking hash table (dwParam1 = current, dwParam2 = total)
- #define CCB_COPYING_NON_MPQ_DATA 3 // Copying non-MPQ data: No params used
- #define CCB_COMPACTING_FILES 4 // Compacting archive (dwParam1 = current, dwParam2 = total)
- #define CCB_CLOSING_ARCHIVE 5 // Closing archive: No params used
-
- #define LISTFILE_NAME "(listfile)" // Name of internal listfile
- #define SIGNATURE_NAME "(signature)" // Name of internal signature
- #define ATTRIBUTES_NAME "(attributes)" // Name of internal attributes file
-
- #define STORMLIB_VERSION (0x0619) // Current version of StormLib
-
- #define MPQ_FORMAT_VERSION_1 0 // Up to The Burning Crusade
- #define MPQ_FORMAT_VERSION_2 1 // The Burning Crusade and newer
-
- // Flags for SFileOpenArchiveEx
- #define MPQ_OPEN_NO_LISTFILE 0x00000001 // Don't add the internal listfile
- #define MPQ_OPEN_NO_ATTRIBUTES 0x00000002 // Don't open the attributes
- #define MPQ_OPEN_FORCE_MPQ_V1 0x00000004 // Always open the archive as MPQ v 1.00, ignore the "wFormatVersion" variable in the header
-
- // Flags for MPQ attributes
- #define MPQ_ATTRIBUTE_CRC32 0x00000001 // The "(attributes)" contain array of CRC32s
- #define MPQ_ATTRIBUTE_FILETIME 0x00000002 // The "(attributes)" contain array of FILETIMEs
- #define MPQ_ATTRIBUTE_MD5 0x00000004 // The "(attributes)" contain array of MD5s
-
- // Supports archives with size > 4 GB
- // Additional flags for SFileCreateArchiveEx
- #define MPQ_CREATE_ARCHIVE_V1 0x00000000 // Creates archive with size up to 4GB
- #define MPQ_CREATE_ARCHIVE_V2 0x00010000 // Creates archive larger than 4 GB
- #define MPQ_CREATE_ATTRIBUTES 0x00100000 // Also add the (attributes) file
-
- // Formats of (attributes) file
- #define MPQ_ATTRIBUTES_V1 100 // FOrmat version 1.00
-
- //-----------------------------------------------------------------------------
- // Structures
-
- #if (defined(WIN32) || defined(WIN64))
- #include <pshpack1.h>
- #else
- #pragma pack(push,1)
- #endif
-
- struct TMPQFile;
-
- struct TMPQShunt
- {
- // The ID_MPQ_SHUNT ('MPQ\x1B') signature
- DWORD dwID;
-
- DWORD dwUnknown;
-
- // Position of the MPQ header, relative to the begin of the shunt
- DWORD dwHeaderPos;
- };
-
-
- // MPQ file header
- struct TMPQHeader
- {
- // The ID_MPQ ('MPQ\x1A') signature
- DWORD dwID;
-
- // Size of the archive header
- DWORD dwHeaderSize;
-
- // Size of MPQ archive
- // This field is deprecated in the Burning Crusade MoPaQ format, and the size of the archive
- // is calculated as the size from the beginning of the archive to the end of the hash table,
- // block table, or extended block table (whichever is largest).
- DWORD dwArchiveSize;
-
- // 0 = Original format
- // 1 = Extended format (The Burning Crusade and newer)
- USHORT wFormatVersion;
-
- // Power of two exponent specifying the number of 512-byte disk sectors in each logical sector
- // in the archive. The size of each logical sector in the archive is 512 * 2^SectorSizeShift.
- // Bugs in the Storm library dictate that this should always be 3 (4096 byte sectors).
- USHORT wBlockSize;
-
- // Offset to the beginning of the hash table, relative to the beginning of the archive.
- DWORD dwHashTablePos;
-
- // Offset to the beginning of the block table, relative to the beginning of the archive.
- DWORD dwBlockTablePos;
-
- // Number of entries in the hash table. Must be a power of two, and must be less than 2^16 for
- // the original MoPaQ format, or less than 2^20 for the Burning Crusade format.
- DWORD dwHashTableSize;
-
- // Number of entries in the block table
- DWORD dwBlockTableSize;
- };
-
-
- // Extended MPQ file header. Valid only if wFormatVersion is 1 or higher
- struct TMPQHeader2 : public TMPQHeader
- {
- // Offset to the beginning of the extended block table, relative to the beginning of the archive.
- LARGE_INTEGER ExtBlockTablePos;
-
- // High 16 bits of the hash table offset for large archives.
- USHORT wHashTablePosHigh;
-
- // High 16 bits of the block table offset for large archives.
- USHORT wBlockTablePosHigh;
- };
-
-
- // Hash entry. All files in the archive are searched by their hashes.
- struct TMPQHash
- {
- // The hash of the file path, using method A.
- DWORD dwName1;
-
- // The hash of the file path, using method B.
- DWORD dwName2;
-
- #if PLATFORM_LITTLE_ENDIAN
-
- // The language of the file. This is a Windows LANGID data type, and uses the same values.
- // 0 indicates the default language (American English), or that the file is language-neutral.
- USHORT lcLocale;
-
- // The platform the file is used for. 0 indicates the default platform.
- // No other values have been observed.
- USHORT wPlatform;
-
- #else
-
- USHORT wPlatform;
- USHORT lcLocale;
-
- #endif
-
- // If the hash table entry is valid, this is the index into the block table of the file.
- // Otherwise, one of the following two values:
- // - FFFFFFFFh: Hash table entry is empty, and has always been empty.
- // Terminates searches for a given file.
- // - FFFFFFFEh: Hash table entry is empty, but was valid at some point (a deleted file).
- // Does not terminate searches for a given file.
- DWORD dwBlockIndex;
- };
-
-
- // File description block contains informations about the file
- struct TMPQBlock
- {
- // Offset of the beginning of the block, relative to the beginning of the archive.
- DWORD dwFilePos;
-
- // Compressed file size
- DWORD dwCSize;
-
- // Only valid if the block is a file; otherwise meaningless, and should be 0.
- // If the file is compressed, this is the size of the uncompressed file data.
- DWORD dwFSize;
-
- // Flags for the file. See MPQ_FILE_XXXX constants
- DWORD dwFlags;
- };
-
-
- // The extended block table was added to support archives larger than 4 gigabytes (2^32 bytes).
- // The table contains the upper bits of the archive offsets for each block in the block table.
- // It is simply an array of int16s, which become bits 32-47 of the archive offsets for each block,
- // with bits 48-63 being zero. Individual blocks in the archive are still limited to 4 gigabytes
- // in size. This table is only present in Burning Crusade format archives that exceed 4 gigabytes size.
- struct TMPQBlockEx
- {
- USHORT wFilePosHigh;
- };
-
-
- struct TFileNode
- {
- DWORD dwRefCount; // Number of references
- // There can be more files that have the same name.
- // (e.g. multiple language files). We don't want to
- // have an entry for each of them, so the entries will be referenced.
- // When a number of node references reaches zero,
- // the node will be deleted
-
- size_t nLength; // File name length
- char szFileName[1]; // File name, variable length
- };
-
-
- // CRC32 present in the (attributes) file
- struct TMPQCRC32
- {
- DWORD dwValue; // Value of CRC32 for each block
- };
-
-
- // FILETIME present in the (attributes) file
- struct TMPQFileTime
- {
- DWORD dwFileTimeLow; // Low DWORD of the FILETIME
- DWORD dwFileTimeHigh; // High DWORD of the FILETIME
- };
-
-
- // MD5 presetn in the (attributes) file
- struct TMPQMD5
- {
- BYTE Value[0x10]; // 16 bytes of MD5
- };
-
-
- // Data from (attributes) file
- struct TMPQAttr
- {
- DWORD dwVersion; // Version of the (attributes) file. Must be 100 (0x64)
- DWORD dwFlags; // See MPQ_ATTRIBUTE_XXXX
- TMPQCRC32 * pCrc32; // Array of CRC32 (NULL if none)
- TMPQFileTime * pFileTime; // Array of FILETIME (NULL if not present)
- TMPQMD5 * pMd5; // Array of MD5 (NULL if none)
- };
-
-
- #if (defined(WIN32) || defined(WIN64))
- #include <poppack.h>
- #else
- #pragma pack(pop)
- #endif
-
- // Archive handle structure
- struct TMPQArchive
- {
- // TMPQArchive * pNext; // Next archive (used by Storm.dll only)
- // TMPQArchive * pPrev; // Previous archive (used by Storm.dll only)
- char szFileName[MAX_PATH]; // Opened archive file name
- HANDLE hFile; // File handle
- DWORD dwPriority; // Priority of the archive
- LARGE_INTEGER ShuntPos; // MPQShunt offset (only valid if a shunt is present)
- LARGE_INTEGER MpqPos; // File header offset (relative to the begin of the file)
- LARGE_INTEGER HashTablePos; // Hash table offset (relative to the begin of the file)
- LARGE_INTEGER BlockTablePos; // Block table offset (relative to the begin of the file)
- LARGE_INTEGER ExtBlockTablePos; // Ext. block table offset (relative to the begin of the file)
- LARGE_INTEGER MpqSize; // Size of MPQ archive
-
- TMPQFile * pLastFile; // Recently read file
- DWORD dwBlockPos; // Position of loaded block in the file
- DWORD dwBlockSize; // Size of file block
- BYTE * pbBlockBuffer; // Buffer (cache) for file block
- DWORD dwBuffPos; // Position in block buffer
- TMPQShunt * pShunt; // MPQ shunt (NULL if not present in the file)
- TMPQHeader2 * pHeader; // MPQ file header
- TMPQHash * pHashTable; // Hash table
- TMPQBlock * pBlockTable; // Block table
- TMPQBlockEx * pExtBlockTable; // Extended block table
-
- TMPQShunt Shunt; // MPQ shunt. Valid only when ID_MPQ_SHUNT has been found
- TMPQHeader2 Header; // MPQ header
-
- TMPQAttr * pAttributes; // MPQ attributes from "(attributes)" file (NULL if none)
- TFileNode ** pListFile; // File name array
- DWORD dwFlags; // See MPQ_FLAG_XXXXX
- };
-
-
- // File handle structure
- struct TMPQFile
- {
- HANDLE hFile; // File handle
- TMPQArchive * ha; // Archive handle
- TMPQHash * pHash; // Hash table entry
- TMPQBlockEx * pBlockEx; // Pointer to extended file block entry
- TMPQBlock * pBlock; // File block pointer
- DWORD dwSeed1; // Seed used for file decrypt
- DWORD dwFilePos; // Current file position
- LARGE_INTEGER RawFilePos; // Offset in MPQ archive (relative to file begin)
- LARGE_INTEGER MpqFilePos; // Offset in MPQ archive (relative to MPQ header)
-
- DWORD * pdwBlockPos; // Position of each file block (only for compressed files)
- DWORD nBlocks; // Number of blocks in the file (incl. the last incomplete one)
- BOOL bBlockPosLoaded; // TRUE if block positions loaded
- BYTE * pbFileBuffer; // Decompressed file (for single unit files, size is the uncompressed file size)
-
- TMPQCRC32 * pCrc32; // Pointer to CRC32 (NULL if none)
- TMPQFileTime * pFileTime; // Pointer to file's FILETIME (NULL if none)
- TMPQMD5 * pMd5; // Pointer to file's MD5 (NULL if none)
-
- DWORD dwHashIndex; // Index to Hash table
- DWORD dwBlockIndex; // Index to Block table
- char szFileName[1]; // File name (variable length)
- };
-
- // Used by searching in MPQ archives
- struct TMPQSearch
- {
- TMPQArchive * ha; // Handle to MPQ, where the search runs
- DWORD dwNextIndex; // Next hash index to be checked
- DWORD dwName1; // Lastly found Name1
- DWORD dwName2; // Lastly found Name2
- char szSearchMask[1]; // Search mask (variable length)
- };
-
-
- struct SFILE_FIND_DATA
- {
- char cFileName[MAX_PATH]; // Full name of the found file
- char * szPlainName; // Pointer to file part
- LCID lcLocale; // Locale version
- DWORD dwFileSize; // File size in bytes
- DWORD dwFileFlags; // File flags (compressed or encrypted)
- DWORD dwBlockIndex; // Block index for the file
- DWORD dwCompSize; // Compressed file size
- };
-
- //-----------------------------------------------------------------------------
- // Memory management
- //
- // We use our own macros for allocating/freeing memory. If you want
- // to redefine them, please keep the following rules
- //
- // - The memory allocation must return NULL if not enough memory
- // (i.e not to throw exception)
- // - It is not necessary to fill the allocated block with zeros
- // - Memory freeing function must not test the pointer to NULL.
- //
-
-
- __inline void * DebugMalloc(char * szFile, int nLine, int nSize)
- {
- void * ptr = malloc(nSize + 100);
- char * plain;
-
- plain = strrchr(szFile, '\\');
- if(plain == NULL)
- plain = strrchr(szFile, '/');
- if(plain == NULL)
- plain = szFile;
-
- #if _MSC_VER > 1300
- sprintf_s((char *)ptr, nSize+100, "%s(%u)", plain, nLine);
- #else
- sprintf((char *)ptr, "%s(%u)", plain, nLine);
- #endif
-
- return (char *)ptr + 100;
- }
-
-
- __inline void DebugFree(void * ptr)
- {
- free((char *)ptr - 100);
- }
-
-
- #ifndef ALLOCMEM
- #define ALLOCMEM(type, nitems) (type *)malloc((nitems) * sizeof(type))
- #define FREEMEM(ptr) free(ptr)
- #endif
-
- //#define ALLOCMEM(type, nitems) (type *)DebugMalloc(__FILE__, __LINE__, (nitems) * sizeof(type))
- //#define FREEMEM(ptr) DebugFree(ptr)
-
- //-----------------------------------------------------------------------------
- // Functions in StormLib - compatible with Storm.dll
-
- // Typedefs for functions exported by Storm.dll
- typedef LCID (WINAPI * SFILESETLOCALE)(LCID);
- typedef BOOL (WINAPI * SFILEOPENARCHIVE)(const char *, DWORD, DWORD, HANDLE *);
- typedef BOOL (WINAPI * SFILECLOSEARCHIVE)(HANDLE);
- typedef BOOL (WINAPI * SFILEOPENFILEEX)(HANDLE, const char *, DWORD, HANDLE *);
- typedef BOOL (WINAPI * SFILECLOSEFILE)(HANDLE);
- typedef DWORD (WINAPI * SFILEGETFILESIZE)(HANDLE, DWORD *);
- typedef DWORD (WINAPI * SFILESETFILEPOINTER)(HANDLE, LONG, LONG *, DWORD);
- typedef BOOL (WINAPI * SFILEREADFILE)(HANDLE, VOID *, DWORD, DWORD *, LPOVERLAPPED);
-
- // Archive opening/closing
- LCID WINAPI SFileSetLocale(LCID lcNewLocale);
- LCID WINAPI SFileGetLocale();
- BOOL WINAPI SFileOpenArchive(const char * szMpqName, DWORD dwPriority, DWORD dwFlags, HANDLE * phMpq);
- BOOL WINAPI SFileFlushArchive(HANDLE hMpq);
- BOOL WINAPI SFileCloseArchive(HANDLE hMpq);
-
- // File opening/closing
- BOOL WINAPI SFileOpenFileEx(HANDLE hMpq, const char * szFileName, DWORD dwSearchScope, HANDLE * phFile);
- BOOL WINAPI SFileCloseFile(HANDLE hFile);
-
- // File I/O
- DWORD WINAPI SFileGetFilePos(HANDLE hFile, DWORD * pdwFilePosHigh = NULL);
- DWORD WINAPI SFileGetFileSize(HANDLE hFile, DWORD * pdwFileSizeHigh = NULL);
- DWORD WINAPI SFileSetFilePointer(HANDLE hFile, LONG lFilePos, LONG * pdwFilePosHigh, DWORD dwMethod);
- BOOL WINAPI SFileReadFile(HANDLE hFile, VOID * lpBuffer, DWORD dwToRead, DWORD * pdwRead = NULL, LPOVERLAPPED lpOverlapped = NULL);
-
- // Adds another listfile into MPQ. The currently added listfile(s) remain,
- // so you can use this API to combining more listfiles.
- // Note that this function is internally called by SFileFindFirstFile
- int WINAPI SFileAddListFile(HANDLE hMpq, const char * szListFile);
-
- //-----------------------------------------------------------------------------
- // Functions in StormLib - not implemented in Storm.dll
-
- // Archive creating and editing
- BOOL WINAPI SFileCreateArchiveEx(const char * szMpqName, DWORD dwCreationDisposition, DWORD dwHashTableSize, HANDLE * phMpq);
- BOOL WINAPI SFileAddFile(HANDLE hMpq, const char * szFileName, const char * szArchivedName, DWORD dwFlags);
- BOOL WINAPI SFileAddWave(HANDLE hMpq, const char * szFileName, const char * szArchivedName, DWORD dwFlags, DWORD dwQuality);
- BOOL WINAPI SFileRemoveFile(HANDLE hMpq, const char * szFileName, DWORD dwSearchScope = SFILE_OPEN_BY_INDEX);
- BOOL WINAPI SFileRenameFile(HANDLE hMpq, const char * szOldFileName, const char * szNewFileName);
- BOOL WINAPI SFileSetFileLocale(HANDLE hFile, LCID lcNewLocale);
-
- // Retrieving info about the file
- BOOL WINAPI SFileHasFile(HANDLE hMpq, char * szFileName);
- BOOL WINAPI SFileGetFileName(HANDLE hFile, char * szFileName);
- DWORD_PTR WINAPI SFileGetFileInfo(HANDLE hMpqOrFile, DWORD dwInfoType);
-
- // File search
- // Note that the SFileFindFirstFileEx has been removed. Use SListFileFindFirst/Next
- HANDLE WINAPI SFileFindFirstFile(HANDLE hMpq, const char * szMask, SFILE_FIND_DATA * lpFindFileData, const char * szListFile);
- BOOL WINAPI SFileFindNextFile(HANDLE hFind, SFILE_FIND_DATA * lpFindFileData);
- BOOL WINAPI SFileFindClose(HANDLE hFind);
-
- // Listfile search
- HANDLE SListFileFindFirstFile(HANDLE hMpq, const char * szListFile, const char * szMask, SFILE_FIND_DATA * lpFindFileData);
- BOOL SListFileFindNextFile(HANDLE hFind, SFILE_FIND_DATA * lpFindFileData);
- BOOL SListFileFindClose(HANDLE hFind);
-
- // Archive compacting
- typedef void (WINAPI * COMPACTCB)(void * lpUserData, DWORD dwWorkType, DWORD dwParam1, DWORD dwParam2);
- BOOL WINAPI SFileSetCompactCallback(HANDLE hMpq, COMPACTCB CompactCB, void * lpData);
- BOOL WINAPI SFileCompactArchive(HANDLE hMpq, const char * szListFile = NULL, BOOL bReserved = 0);
-
- // Locale support
- int WINAPI SFileEnumLocales(HANDLE hMpq, const char * szFileName, LCID * plcLocales, DWORD * pdwMaxLocales, DWORD dwSearchScope);
-
- // (De)compression
- int WINAPI SCompCompress (char * pbOutBuffer, int * pdwOutLength, char * pbInBuffer, int dwInLength, int uCompressions, int nCmpType, int nCmpLevel);
- int WINAPI SCompDecompress (char * pbOutBuffer, int * pdwOutLength, char * pbInBuffer, int dwInLength);
-
- // Sets the default data compression for files added to MPQ,
- // if MPQ_FILE_COMPRESS_MULTI has been specified in call to SFileAddFile
- // Use one of the MPQ_COMPRESSION_XXX values
- int WINAPI SCompSetDataCompression(int nDataCompression);
-
- // Verifies file against its extended attributes (depending on dwFlags).
- // For dwFlags, use one or more of MPQ_ATTRIBUTE_MD5
- BOOL WINAPI SFileVerifyFile(HANDLE hMpq, const char * szFileName, DWORD dwFlags);
-
- // High-level extract function
- BOOL WINAPI SFileExtractFile(HANDLE hMpq, const char * szToExtract, const char * szExtracted);
-
- //-----------------------------------------------------------------------------
- // Functions from Storm.dll. They use slightly different names for keeping
- // possibility to use them together with StormLib (StormXXX instead of SFileXXX)
-
- #ifdef __LINK_STORM_DLL__
- #define STORM_ALTERNATE_NAMES // Force Storm.h to use alternate fnc names
- #include "StormDll.h"
- #endif // __LINK_STORM_DLL__
-
- //-----------------------------------------------------------------------------
- // GFX decode functions. See GfxDecode.cpp for details and description
-
- USHORT WINAPI celGetFrameCount(BYTE * fileBuf);
- BYTE * WINAPI celGetFrameData(BYTE *fileBuf, BYTE *palette, USHORT xsize, USHORT frame, USHORT *ysize, USHORT *maxX=NULL);
- USHORT WINAPI cl2GetFrameCount(BYTE *fileBuf);
- BYTE ** WINAPI cl2GetDirData(BYTE *fileBuf, BYTE *palette, USHORT xsize, USHORT dir, USHORT *ysize);
- BYTE * WINAPI pcxGetData(BYTE *filebuf, DWORD filesize, BYTE transcol, USHORT *xsize, USHORT *ysize);
-
- #endif // __STORMLIB_H_