#9023 closed patch
GSOC: Draci Historie (BAR archives, engine stub)
Reported by: | SF/dkasak13 | Owned by: | sev- |
---|---|---|---|
Priority: | normal | Component: | Engine: Draci |
Version: | Keywords: | ||
Cc: | Game: | Dragon History |
Description
I've cleaned up the engine stub, disabled compilation by default and made it properly detect the game. There's also an implementation of the BAR archive reader (nextghost's code served as a model as it was very well written). The engine prints the number of file streams inside INIT.DFW on startup (and does so correctly, yay!). Also, the engine was renamed to "Draci" to be more faithful to the original.
Ticket imported from: #2796171. Ticket imported from: patches/1128.
Attachments (2)
Change History (10)
by , 16 years ago
Attachment: | draci.patch added |
---|
comment:1 by , 16 years ago
Next stop will be implementing the DFW emulation layer for the archiver. While DFW files are no longer used in the engine, some parts rely on accessing the archives through the old interface. I'll take a look at the culprits tomorrow; perhaps rewriting those parts to use the new interface would be a better option.
comment:2 by , 16 years ago
A little remark: The "MODULE_OBJS" list in module.mk should contain only one file per line. You might want to check out other module.mk files, like engines/scumm/module.mk for that. I also see you're using C style comments at the end of #endif blocks, we usually don't use comments at all there for the include guards, of course it's not bad, but I would personally prefer C++ style comments there, if you really decide to keep them.
Apart the patch looks fine to me.
comment:3 by , 16 years ago
I just noticed some implementation specific thing, it seems you are keeping all files in memory when loading a BAR file. I don't know about the usual size of those files, but for systems with low memory, take for example the NDS with 4MB, it might be better to change the code to load them into memory only on demand.
comment:4 by , 16 years ago
Owner: | set to |
---|
comment:5 by , 16 years ago
A /really/ solid start, excellent!
Couple of the remarks: - Please, use AD_ENTRY1s() macro in the detection entries, so it will be more readable. - Try to divide logical blocks by empty lines. I.e. separate asserts, return statements, if() blocks, etc. Lumping them together lowers code readability. - use debug(0, "") instead of printf() even for temporary output. debug functions take varargs too.
comment:6 by , 16 years ago
@lordhoto: I've fixed the formatting in module.mk and the C-style comments. I've also redesigned the archiver so it allocates memory only for those files that have already been accessed. Comments welcome. :-)
@sev: Ah, I knew I missed something! Added those AD_ENTRY1s() macros. I also fixed those other issues you brought up and elaborated a bit on the tests (it now prints the first ten bytes of each opened file).
In other news, I added a closeFile() function to the BAFile struct so individual files could be released without closing the archive. I also changed some of the unsigned int variables to uint32 and uint16. I don't know what the policy for those is but I've seen that lib functions return them. Further input is welcome.
comment:7 by , 15 years ago
Status: | new → closed |
---|
comment:8 by , 6 years ago
Component: | → Engine: Draci |
---|---|
Game: | → Dragon History |
engine stub and detection, BAR archiver