aboutsummaryrefslogtreecommitdiff
path: root/engines/kyra/plugin.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'engines/kyra/plugin.cpp')
-rw-r--r--engines/kyra/plugin.cpp81
1 files changed, 50 insertions, 31 deletions
diff --git a/engines/kyra/plugin.cpp b/engines/kyra/plugin.cpp
index 16c4f066ad..9c24e243a8 100644
--- a/engines/kyra/plugin.cpp
+++ b/engines/kyra/plugin.cpp
@@ -50,59 +50,73 @@ namespace {
#define ENTRY(f, x) { f, 0, x }
const ADGameFileDescription kyra1EnglishFloppy1[] = {
- ENTRY("GEMCUT.EMC", "3c244298395520bb62b5edfe41688879")
+ ENTRY("GEMCUT.EMC", "3c244298395520bb62b5edfe41688879"),
+ { NULL, 0, NULL}
};
const ADGameFileDescription kyra1EnglishFloppy2[] = {
- ENTRY("GEMCUT.EMC", "796e44863dd22fa635b042df1bf16673")
+ ENTRY("GEMCUT.EMC", "796e44863dd22fa635b042df1bf16673"),
+ { NULL, 0, NULL}
};
const ADGameFileDescription kyra1FrenchFloppy1[] = {
- ENTRY("GEMCUT.EMC", "abf8eb360e79a6c2a837751fbd4d3d24")
+ ENTRY("GEMCUT.EMC", "abf8eb360e79a6c2a837751fbd4d3d24"),
+ { NULL, 0, NULL}
};
const ADGameFileDescription kyra1GermanFloppy1[] = {
- ENTRY("GEMCUT.EMC", "6018e1dfeaca7fe83f8d0b00eb0dd049")
+ ENTRY("GEMCUT.EMC", "6018e1dfeaca7fe83f8d0b00eb0dd049"),
+ { NULL, 0, NULL}
};
const ADGameFileDescription kyra1GermanFloppy2[] = {
- ENTRY("GEMCUT.EMC", "f0b276781f47c130f423ec9679fe9ed9")
+ ENTRY("GEMCUT.EMC", "f0b276781f47c130f423ec9679fe9ed9"),
+ { NULL, 0, NULL}
};
const ADGameFileDescription kyra1SpanishFloppy1[] = {
- ENTRY("GEMCUT.EMC", "8909b41596913b3f5deaf3c9f1017b01")
+ ENTRY("GEMCUT.EMC", "8909b41596913b3f5deaf3c9f1017b01"),
+ { NULL, 0, NULL}
};
const ADGameFileDescription kyra1SpanishFloppy2[] = {
- ENTRY("GEMCUT.EMC", "747861d2a9c643c59fdab570df5b9093")
+ ENTRY("GEMCUT.EMC", "747861d2a9c643c59fdab570df5b9093"),
+ { NULL, 0, NULL}
};
const ADGameFileDescription kyra1ItalianFloppy1[] = {
- ENTRY("GEMCUT.EMC", "ef08c8c237ee1473fd52578303fc36df")
+ ENTRY("GEMCUT.EMC", "ef08c8c237ee1473fd52578303fc36df"),
+ { NULL, 0, NULL}
};
const ADGameFileDescription kyra1EnglishCD1[] = {
- ENTRY("GEMCUT.PAK", "fac399fe62f98671e56a005c5e94e39f")
+ ENTRY("GEMCUT.PAK", "fac399fe62f98671e56a005c5e94e39f"),
+ { NULL, 0, NULL}
};
const ADGameFileDescription kyra1GermanCD1[] = {
- ENTRY("GEMCUT.PAK", "230f54e6afc007ab4117159181a1c722")
+ ENTRY("GEMCUT.PAK", "230f54e6afc007ab4117159181a1c722"),
+ { NULL, 0, NULL}
};
const ADGameFileDescription kyra1FrenchCD1[] = {
- ENTRY("GEMCUT.PAK", "b037c41768b652a040360ffa3556fd2a")
+ ENTRY("GEMCUT.PAK", "b037c41768b652a040360ffa3556fd2a"),
+ { NULL, 0, NULL}
};
const ADGameFileDescription kyra1EnglishDemo1[] = {
- ENTRY("DEMO1.WSA", "fb722947d94897512b13b50cc84fd648")
+ ENTRY("DEMO1.WSA", "fb722947d94897512b13b50cc84fd648"),
+ { NULL, 0, NULL}
};
const ADGameFileDescription kyra2UnknownUnknown1[] = {
- ENTRY("FATE.PAK", "28cbad1c5bf06b2d3825ae57d760d032")
+ ENTRY("FATE.PAK", "28cbad1c5bf06b2d3825ae57d760d032"),
+ { NULL, 0, NULL}
};
const ADGameFileDescription kyra3CD1[] = {
- ENTRY("ONETIME.PAK", "3833ff312757b8e6147f464cca0a6587")
+ ENTRY("ONETIME.PAK", "3833ff312757b8e6147f464cca0a6587"),
+ { NULL, 0, NULL}
};
#define FLAGS(x, y, z, w, id) { UNK_LANG, kPlatformUnknown, x, y, z, w, id }
@@ -116,25 +130,25 @@ const ADGameFileDescription kyra3CD1[] = {
#define KYRA3_CD_FLAGS FLAGS(false, false, false, true, GI_KYRA3)
const KYRAGameDescription adGameDescs[] = {
- { { "The Legend of Kyrandia", 0, ARRAYSIZE(kyra1EnglishFloppy1), kyra1EnglishFloppy1, EN_ANY, kPlatformPC }, "kyra1", KYRA1_FLOPPY_FLAGS },
- { { "The Legend of Kyrandia", 0, ARRAYSIZE(kyra1EnglishFloppy2), kyra1EnglishFloppy2, EN_ANY, kPlatformPC }, "kyra1", KYRA1_FLOPPY_FLAGS },
- { { "The Legend of Kyrandia", 0, ARRAYSIZE(kyra1FrenchFloppy1) , kyra1FrenchFloppy1 , FR_FRA, kPlatformPC }, "kyra1", KYRA1_FLOPPY_FLAGS },
- { { "The Legend of Kyrandia", 0, ARRAYSIZE(kyra1GermanFloppy1) , kyra1GermanFloppy1 , DE_DEU, kPlatformPC }, "kyra1", KYRA1_FLOPPY_FLAGS },
- { { "The Legend of Kyrandia", 0, ARRAYSIZE(kyra1GermanFloppy2) , kyra1GermanFloppy2 , DE_DEU, kPlatformPC }, "kyra1", KYRA1_FLOPPY_FLAGS }, // from Arne.F
- { { "The Legend of Kyrandia", 0, ARRAYSIZE(kyra1SpanishFloppy1), kyra1SpanishFloppy1, ES_ESP, kPlatformPC }, "kyra1", KYRA1_FLOPPY_FLAGS }, // from VooD
- { { "The Legend of Kyrandia", 0, ARRAYSIZE(kyra1SpanishFloppy2), kyra1SpanishFloppy2, ES_ESP, kPlatformPC }, "kyra1", KYRA1_FLOPPY_FLAGS }, // floppy 1.8 from clemmy
- { { "The Legend of Kyrandia", 0, ARRAYSIZE(kyra1ItalianFloppy1), kyra1ItalianFloppy1, IT_ITA, kPlatformPC }, "kyra1", KYRA1_FLOPPY_FLAGS }, // from gourry
+ { { "The Legend of Kyrandia", 0, kyra1EnglishFloppy1, EN_ANY, kPlatformPC }, "kyra1", KYRA1_FLOPPY_FLAGS },
+ { { "The Legend of Kyrandia", 0, kyra1EnglishFloppy2, EN_ANY, kPlatformPC }, "kyra1", KYRA1_FLOPPY_FLAGS },
+ { { "The Legend of Kyrandia", 0, kyra1FrenchFloppy1 , FR_FRA, kPlatformPC }, "kyra1", KYRA1_FLOPPY_FLAGS },
+ { { "The Legend of Kyrandia", 0, kyra1GermanFloppy1 , DE_DEU, kPlatformPC }, "kyra1", KYRA1_FLOPPY_FLAGS },
+ { { "The Legend of Kyrandia", 0, kyra1GermanFloppy2 , DE_DEU, kPlatformPC }, "kyra1", KYRA1_FLOPPY_FLAGS }, // from Arne.F
+ { { "The Legend of Kyrandia", 0, kyra1SpanishFloppy1, ES_ESP, kPlatformPC }, "kyra1", KYRA1_FLOPPY_FLAGS }, // from VooD
+ { { "The Legend of Kyrandia", 0, kyra1SpanishFloppy2, ES_ESP, kPlatformPC }, "kyra1", KYRA1_FLOPPY_FLAGS }, // floppy 1.8 from clemmy
+ { { "The Legend of Kyrandia", 0, kyra1ItalianFloppy1, IT_ITA, kPlatformPC }, "kyra1", KYRA1_FLOPPY_FLAGS }, // from gourry
- { { "The Legend of Kyrandia", "CD", ARRAYSIZE(kyra1EnglishCD1), kyra1EnglishCD1, EN_ANY, kPlatformPC }, "kyra1", KYRA1_CD_FLAGS },
- { { "The Legend of Kyrandia", "CD", ARRAYSIZE(kyra1GermanCD1) , kyra1GermanCD1 , DE_DEU, kPlatformPC }, "kyra1", KYRA1_CD_FLAGS },
- { { "The Legend of Kyrandia", "CD", ARRAYSIZE(kyra1FrenchCD1) , kyra1FrenchCD1 , FR_FRA, kPlatformPC }, "kyra1", KYRA1_CD_FLAGS },
+ { { "The Legend of Kyrandia", "CD", kyra1EnglishCD1, EN_ANY, kPlatformPC }, "kyra1", KYRA1_CD_FLAGS },
+ { { "The Legend of Kyrandia", "CD", kyra1GermanCD1 , DE_DEU, kPlatformPC }, "kyra1", KYRA1_CD_FLAGS },
+ { { "The Legend of Kyrandia", "CD", kyra1FrenchCD1 , FR_FRA, kPlatformPC }, "kyra1", KYRA1_CD_FLAGS },
- { { "The Legend of Kyrandia", "Demo", ARRAYSIZE(kyra1EnglishDemo1), kyra1EnglishDemo1, EN_ANY, kPlatformPC }, "kyra1", KYRA1_DEMO_FLAGS },
+ { { "The Legend of Kyrandia", "Demo", kyra1EnglishDemo1, EN_ANY, kPlatformPC }, "kyra1", KYRA1_DEMO_FLAGS },
- { { "The Legend of Kyrandia: The Hand of Fate", 0, ARRAYSIZE(kyra2UnknownUnknown1), kyra2UnknownUnknown1, UNK_LANG, kPlatformPC }, "kyra2", KYRA2_UNK_FLAGS }, // check this! (cd version?)
+ { { "The Legend of Kyrandia: The Hand of Fate", 0, kyra2UnknownUnknown1, UNK_LANG, kPlatformPC }, "kyra2", KYRA2_UNK_FLAGS }, // check this! (cd version?)
- { { "The Legend of Kyrandia: Malcolm's Revenge", 0, ARRAYSIZE(kyra3CD1), kyra3CD1, UNK_LANG, kPlatformPC }, "kyra3", KYRA3_CD_FLAGS },
- { { NULL, NULL, 0, NULL, UNK_LANG, kPlatformUnknown }, NULL, KYRA2_UNK_FLAGS }
+ { { "The Legend of Kyrandia: Malcolm's Revenge", 0, kyra3CD1, UNK_LANG, kPlatformPC }, "kyra3", KYRA3_CD_FLAGS },
+ { { NULL, NULL, NULL, UNK_LANG, kPlatformUnknown }, NULL, KYRA2_UNK_FLAGS }
};
ADGameDescList getADDescList() {
@@ -170,8 +184,13 @@ bool setupGameFlags(const ADList &list, GameFlags &flags) {
int curID = 0;
// get's the entry which has most files to check (most specialized)
for (ADList::const_iterator i = list.begin(); i != list.end(); ++i, ++curID) {
- if (filesCount < adGameDescs[*i].desc.filesCount) {
- filesCount = adGameDescs[*i].desc.filesCount;
+ int fCount = 0;
+
+ for (int j = 0; adGameDescs[*i].desc.filesDescriptions[j].fileName; j++)
+ fCount++;
+
+ if (filesCount < fCount) {
+ filesCount = fCount;
id = curID;
}
}