aboutsummaryrefslogtreecommitdiff
path: root/engines
diff options
context:
space:
mode:
authorFilippos Karapetis2010-01-28 01:45:20 +0000
committerFilippos Karapetis2010-01-28 01:45:20 +0000
commitda7d221d4028e1b8c652c77d00eeb74a9576226d (patch)
tree6a5d70ff61badeeb65edaeb400bbd77a068acccb /engines
parent0702bdab820ee6099011868009112b1a79b9deee (diff)
downloadscummvm-rg350-da7d221d4028e1b8c652c77d00eeb74a9576226d.tar.gz
scummvm-rg350-da7d221d4028e1b8c652c77d00eeb74a9576226d.tar.bz2
scummvm-rg350-da7d221d4028e1b8c652c77d00eeb74a9576226d.zip
Introduced a new console command, diskdump, which is able to dump files from resource files to disk
svn-id: r47623
Diffstat (limited to 'engines')
-rw-r--r--engines/sci/console.cpp43
-rw-r--r--engines/sci/console.h1
2 files changed, 44 insertions, 0 deletions
diff --git a/engines/sci/console.cpp b/engines/sci/console.cpp
index ac3f2b719a..8a43738e1f 100644
--- a/engines/sci/console.cpp
+++ b/engines/sci/console.cpp
@@ -91,6 +91,7 @@ Console::Console(SciEngine *vm) : GUI::Debugger() {
DCmd_Register("parse", WRAP_METHOD(Console, cmdParse));
DCmd_Register("set_parse_nodes", WRAP_METHOD(Console, cmdSetParseNodes));
// Resources
+ DCmd_Register("diskdump", WRAP_METHOD(Console, cmdDiskDump));
DCmd_Register("hexdump", WRAP_METHOD(Console, cmdHexDump));
DCmd_Register("resource_id", WRAP_METHOD(Console, cmdResourceId));
DCmd_Register("resource_size", WRAP_METHOD(Console, cmdResourceSize));
@@ -298,6 +299,7 @@ bool Console::cmdHelp(int argc, const char **argv) {
DebugPrintf(" set_parse_nodes - Sets the contents of all parse nodes\n");
DebugPrintf("\n");
DebugPrintf("Resources:\n");
+ DebugPrintf(" diskdump - Dumps the specified resource to disk as a patch file\n");
DebugPrintf(" hexdump - Dumps the specified resource to standard output\n");
DebugPrintf(" resource_id - Identifies a resource number by splitting it up in resource type and resource number\n");
DebugPrintf(" resource_size - Shows the size of a resource\n");
@@ -563,6 +565,41 @@ bool Console::cmdRegisters(int argc, const char **argv) {
return true;
}
+bool Console::cmdDiskDump(int argc, const char **argv) {
+ if (argc != 3) {
+ DebugPrintf("Dumps the specified resource to disk as a patch file\n");
+ DebugPrintf("Usage: %s <resource type> <resource number>\n", argv[0]);
+ cmdResourceTypes(argc, argv);
+ return true;
+ }
+
+ int resNum = atoi(argv[2]);
+ ResourceType res = parseResourceType(argv[1]);
+
+ if (res == kResourceTypeInvalid)
+ DebugPrintf("Resource type '%s' is not valid\n", argv[1]);
+ else {
+ Resource *resource = _vm->getResourceManager()->findResource(ResourceId(res, resNum), 0);
+ if (resource) {
+ char outFileName[50];
+ sprintf(outFileName, "%s.%03d", getResourceTypeName(res), resNum);
+ Common::DumpFile *outFile = new Common::DumpFile();
+ outFile->open(outFileName);
+ outFile->writeByte(res);
+ outFile->writeByte(0);
+ outFile->write(resource->data, resource->size);
+ outFile->finalize();
+ outFile->close();
+ delete outFile;
+ DebugPrintf("Resource %s.%03d has been dumped to disk\n", argv[1], resNum);
+ } else {
+ DebugPrintf("Resource %s.%03d not found\n", argv[1], resNum);
+ }
+ }
+
+ return true;
+}
+
bool Console::cmdHexDump(int argc, const char **argv) {
if (argc != 3) {
DebugPrintf("Dumps the specified resource to standard output\n");
@@ -808,6 +845,12 @@ bool Console::cmdSaveGame(int argc, const char **argv) {
// TODO: enable custom descriptions? force filename into a specific format?
if (gamestate_save(_vm->_gamestate, out, "debugging", version)) {
DebugPrintf("Saving the game state to '%s' failed\n", argv[1]);
+ } else {
+ out->finalize();
+ if (out->err()) {
+ warning("Writing the savegame failed.");
+ }
+ delete out;
}
return true;
diff --git a/engines/sci/console.h b/engines/sci/console.h
index b5e0de19fe..da224bb073 100644
--- a/engines/sci/console.h
+++ b/engines/sci/console.h
@@ -66,6 +66,7 @@ private:
bool cmdParse(int argc, const char **argv);
bool cmdSetParseNodes(int argc, const char **argv);
// Resources
+ bool cmdDiskDump(int argc, const char **argv);
bool cmdHexDump(int argc, const char **argv);
bool cmdResourceId(int argc, const char **argv);
bool cmdResourceSize(int argc, const char **argv);