mirror of
https://github.com/libretro/scummvm.git
synced 2025-01-10 11:51:52 +00:00
143 lines
4.0 KiB
C++
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;
|
|
}
|