diff options
author | Paul Gilbert | 2017-06-17 18:27:24 -0400 |
---|---|---|
committer | Paul Gilbert | 2017-06-17 18:27:24 -0400 |
commit | 2cdb81482c50f40913f9f4751798c5ef1e0cee6a (patch) | |
tree | 9aea813db144bfa6dc9cce65d5e754793fdeb7a9 /devtools/create_titanic | |
parent | cc35a7930104330fe67995a8a71faf1acd6a611d (diff) | |
download | scummvm-rg350-2cdb81482c50f40913f9f4751798c5ef1e0cee6a.tar.gz scummvm-rg350-2cdb81482c50f40913f9f4751798c5ef1e0cee6a.tar.bz2 scummvm-rg350-2cdb81482c50f40913f9f4751798c5ef1e0cee6a.zip |
DEVTOOLS: Add extra German EXE resources to create_titanic
Diffstat (limited to 'devtools/create_titanic')
-rw-r--r-- | devtools/create_titanic/create_titanic_dat.cpp | 38 |
1 files changed, 26 insertions, 12 deletions
diff --git a/devtools/create_titanic/create_titanic_dat.cpp b/devtools/create_titanic/create_titanic_dat.cpp index 32699e4d40..86fa4f16dd 100644 --- a/devtools/create_titanic/create_titanic_dat.cpp +++ b/devtools/create_titanic/create_titanic_dat.cpp @@ -55,7 +55,7 @@ */ #define VERSION_NUMBER 1 -#define HEADER_SIZE 0x1000 +#define HEADER_SIZE 0x1100 Common::File inputFile, outputFile; Common::PEResources resEng, resGer; @@ -1097,25 +1097,34 @@ void writeResource(const char *name, Common::File *file) { delete file; } +void writeResource(const char *resName, const char *sectionStr, uint32 resId, bool isEnglish = true) { + Common::PEResources &res = isEnglish ? resEng : resGer; + Common::File *file = res.getResource(getResId(sectionStr), resId); + assert(file); + writeResource(resName, file); +} + void writeResource(const char *sectionStr, uint32 resId, bool isEnglish = true) { char nameBuffer[256]; sprintf(nameBuffer, "%s/%u", sectionStr, resId); + writeResource(nameBuffer, sectionStr, resId, isEnglish); +} +void writeResource(const char *resName, const char *sectionStr, const char *resId, bool isEnglish = true) { Common::PEResources &res = isEnglish ? resEng : resGer; - Common::File *file = res.getResource(getResId(sectionStr), resId); + Common::File *file = res.getResource(getResId(sectionStr), + Common::WinResourceID(resId)); assert(file); - writeResource(nameBuffer, file); + writeResource(resName, file); } void writeResource(const char *sectionStr, const char *resId, bool isEnglish = true) { char nameBuffer[256]; sprintf(nameBuffer, "%s/%s", sectionStr, resId); + if (!isEnglish) + strcat(nameBuffer, "/DE"); - Common::PEResources &res = isEnglish ? resEng : resGer; - Common::File *file = res.getResource(getResId(sectionStr), - Common::WinResourceID(resId)); - assert(file); - writeResource(nameBuffer, file); + writeResource(nameBuffer, sectionStr, resId, isEnglish); } void writeBitmap(const char *name, Common::File *file) { @@ -1489,14 +1498,19 @@ void writeData() { writeResource("STFONT", 152); writeResource("STFONT", 153); + writeResource("TEXT/STVOCAB", "TEXT", "STVOCAB.TXT"); + writeResource("TEXT/JRQUOTES", "TEXT", "JRQUOTES.TXT"); + writeResource("TEXT", 155); + if (!resGer.empty()) { + writeResource("TEXT/STVOCAB/DE", "TEXT", "STVOCABDE.TXT", false); + writeResource("TEXT/JRQUOTES/DE", "TEXT", "JRQUOTESDE.TXT", false); + writeResource("TEXT/155/DE", "TEXT", 155, false); + } + writeResource("STARFIELD", 132); writeStarfieldPoints(); writeStarfieldPoints2(); - writeResource("TEXT", "STVOCAB.TXT"); - writeResource("TEXT", "JRQUOTES.TXT"); - writeResource("TEXT", 155); - writeStringArray("TEXT/ITEM_DESCRIPTIONS", ITEM_DESCRIPTIONS, 46); writeStringArray("TEXT/ITEM_DESCRIPTIONS/DE", ITEM_DESCRIPTIONS_DE, 46); writeStringArray("TEXT/ITEM_NAMES", ITEM_NAMES, 46); |