scummvm/devtools/create_teenagent/create_teenagent.cpp
2021-03-03 02:15:05 +02:00

143 lines
4.0 KiB
C++

/* ScummVM - Graphic Adventure Engine
*
* ScummVM is the legal property of its developers, whose names
* are too numerous to list here. Please refer to the COPYRIGHT
* file distributed with this source distribution.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
*/
// Disable symbol overrides so that we can use system headers.
#define FORBIDDEN_SYMBOL_ALLOW_ALL
// HACK to allow building with the SDL backend on MinGW
// see bug #3412 "TOOLS: MinGW tools building broken"
#ifdef main
#undef main
#endif // main
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include "util.h"
#include "static_tables.h"
int main(int argc, char *argv[]) {
const char *dat_name = "teenagent.dat";
FILE *fout = fopen(dat_name, "wb");
if (fout == NULL) {
perror("opening output file");
exit(1);
}
if (fwrite(cseg, CSEG_SIZE, 1, fout) != 1) {
perror("Writing code segment");
exit(1);
}
if (fwrite(dsegStartBlock, DSEG_STARTBLK_SIZE, 1, fout) != 1) {
perror("Writing data segment start block");
exit(1);
}
// Write out message string block
for (uint i = 0; i < (sizeof(messages)/sizeof(char*)); i++) {
if (i == 0) {
// Write out reject message pointer block
uint16 off = DSEG_STARTBLK_SIZE + (4 * 2);
writeUint16LE(fout, off);
off += strlen(messages[0]) + 2;
writeUint16LE(fout, off);
off += strlen(messages[1]) + 2;
writeUint16LE(fout, off);
off += strlen(messages[2]) + 2;
writeUint16LE(fout, off);
}
if (i == 327) {
// Write out book color pointer block
uint16 off = DSEG_STARTBLK_SIZE + (4 * 2);
for (uint k = 0; k < 327; k++)
off += strlen(messages[k]) + 2;
off += (6 * 2);
writeUint16LE(fout, off);
off += strlen(messages[327]) + 2;
writeUint16LE(fout, off);
off += strlen(messages[328]) + 2;
writeUint16LE(fout, off);
off += strlen(messages[329]) + 2;
writeUint16LE(fout, off);
off += strlen(messages[330]) + 2;
writeUint16LE(fout, off);
off += strlen(messages[331]) + 2;
writeUint16LE(fout, off);
}
for (uint j = 0; j < strlen(messages[i]); j++) {
if (messages[i][j] == '\n')
writeByte(fout, '\0');
else
writeByte(fout, messages[i][j]);
}
writeByte(fout, '\0');
writeByte(fout, '\0');
}
if (fwrite(dsegEndBlock, DSEG_ENDBLK_SIZE, 1, fout) != 1) {
perror("Writing data segment end block");
exit(1);
}
// Write out dialog string block
static const char nulls[6] = "\0\0\0\0\0";
for (uint i = 0; i < (sizeof(dialogs)/sizeof(char**)); i++) {
//printf("Writing Dialog #%d\n", i);
bool dialogEnd = false;
uint j = 0;
while (!dialogEnd) {
uint nullCount = 0;
if (strcmp(dialogs[i][j], NEW_LINE) == 0) {
nullCount = 1;
} else if (strcmp(dialogs[i][j], DISPLAY_MESSAGE) == 0) {
nullCount = 2;
} else if (strcmp(dialogs[i][j], CHANGE_CHARACTER) == 0) {
nullCount = 3;
} else if (strcmp(dialogs[i][j], END_DIALOG) == 0) {
nullCount = 4;
dialogEnd = true;
} else { // Deals with normal dialogue and ANIM_WAIT cases
if (fwrite(dialogs[i][j], 1, strlen(dialogs[i][j]), fout) != strlen(dialogs[i][j])) {
perror("Writing dialog string");
exit(1);
}
}
if (nullCount != 0 && nullCount < 5) {
if (fwrite(nulls, 1, nullCount, fout) != nullCount) {
perror("Writing dialog string nulls");
exit(1);
}
}
j++;
}
}
fclose(fout);
return 0;
}