diff options
author | Florian Kagerer | 2009-02-21 17:24:50 +0000 |
---|---|---|
committer | Florian Kagerer | 2009-02-21 17:24:50 +0000 |
commit | 8a95f02abfabb04972a6c85fbc655e53ae7a54f6 (patch) | |
tree | 66acc3d8e8b616b7f329888c8a529f922bfb370c /tools/create_kyradat/create_kyradat.cpp | |
parent | 51bb24626a422664684e1d70484944b7c9809557 (diff) | |
download | scummvm-rg350-8a95f02abfabb04972a6c85fbc655e53ae7a54f6.tar.gz scummvm-rg350-8a95f02abfabb04972a6c85fbc655e53ae7a54f6.tar.bz2 scummvm-rg350-8a95f02abfabb04972a6c85fbc655e53ae7a54f6.zip |
LOL: some work on inventory/item handling
svn-id: r38711
Diffstat (limited to 'tools/create_kyradat/create_kyradat.cpp')
-rw-r--r-- | tools/create_kyradat/create_kyradat.cpp | 27 |
1 files changed, 26 insertions, 1 deletions
diff --git a/tools/create_kyradat/create_kyradat.cpp b/tools/create_kyradat/create_kyradat.cpp index 3b1b43a2b1..4ec75d653c 100644 --- a/tools/create_kyradat/create_kyradat.cpp +++ b/tools/create_kyradat/create_kyradat.cpp @@ -31,7 +31,7 @@ #include "md5.h" enum { - kKyraDatVersion = 38, + kKyraDatVersion = 39, kIndexSize = 12 }; @@ -74,6 +74,7 @@ bool extractPaddedStrings(PAKFile &out, const Game *g, const byte *data, const u bool extractRaw16to8(PAKFile &out, const Game *g, const byte *data, const uint32 size, const char *filename, int fmtPatch = 0); bool extractMrShapeAnimData(PAKFile &out, const Game *g, const byte *data, const uint32 size, const char *filename, int fmtPatch = 0); bool extractRaw16(PAKFile &out, const Game *g, const byte *data, const uint32 size, const char *filename, int fmtPatch = 0); +bool extractRaw32(PAKFile &out, const Game *g, const byte *data, const uint32 size, const char *filename, int fmtPatch = 0); bool extractLolButtonDefs(PAKFile &out, const Game *g, const byte *data, const uint32 size, const char *filename, int fmtPatch = 0); int extractHofSeqData_checkString(const void *ptr, uint8 checkSize); @@ -100,6 +101,7 @@ const ExtractType extractTypeTable[] = { { k3TypeShpData, extractMrShapeAnimData, createFilename }, { lolTypeRaw16, extractRaw16, createFilename }, + { lolTypeRaw32, extractRaw32, createFilename }, { lolTypeButtonDef, extractLolButtonDefs, createFilename }, { -1, 0, 0} @@ -274,6 +276,15 @@ const ExtractFilename extractFilenames[] = { //{ lolADLSfxIndex, kTypeRawData, "SFX_ADL.MAP" }, { lolSpellProperties, kTypeRawData, "SPELLS.DEF" }, { lolGameShapeMap, kTypeRawData, "GAMESHP.MAP" }, + { lolCharInvIndex, k3TypeRaw16to8, "CHARINV.MAP" }, + { lolCharInvDefs, kTypeRawData, "CHARINV.DEF" }, + { lolCharDefsMan, lolTypeRaw16, "CHMAN.DEF" }, + { lolCharDefsWoman, lolTypeRaw16, "CHWOMAN.DEF" }, + { lolCharDefsKieran, lolTypeRaw16, "CHKIERAN.DEF" }, + //{ lolCharDefsUnk, lolTypeRaw16, "CHUNK.DEF" }, + { lolCharDefsAkshel, lolTypeRaw16, "CHAKSHEL.DEF" }, + { lolExpRequirements, lolTypeRaw32, "EXPERIENCE.DEF" }, + { lolInventoryDesc, lolTypeRaw16, "INVDESC.DEF" }, { lolLevelShpList, kTypeStringList, "SHPFILES.TXT" }, { lolLevelDatList, kTypeStringList, "DATFILES.TXT" }, { lolCompassDefs, k3TypeRaw16to8, "COMPASS.DEF" }, @@ -1083,6 +1094,20 @@ bool extractRaw16(PAKFile &out, const Game *g, const byte *data, const uint32 si return out.addFile(filename, buffer, size); } +bool extractRaw32(PAKFile &out, const Game *g, const byte *data, const uint32 size, const char *filename, int fmtPatch) { + uint8 *buffer = new uint8[size]; + const uint8 *src = data; + uint8 *dst = buffer; + + for (uint32 i = 0; i < (size >> 2); i++) { + WRITE_BE_UINT32(dst, READ_LE_UINT32(src)); + src += 4; + dst += 4; + } + + return out.addFile(filename, buffer, size); +} + bool extractLolButtonDefs(PAKFile &out, const Game *g, const byte *data, const uint32 size, const char *filename, int fmtPatch) { int num = size / 22; uint8 *buffer = new uint8[size]; |