scummvm/devtools/create_hugo/create_hugo.cpp
D G Turner 7956c75e8e DEVTOOLS: Fix Possible Resource Leak in create_hugo tool.
This is part of the fix for bug Trac #10655.
2018-10-07 04:47:57 +01:00

1629 lines
50 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.
*
* This is a utility for storing all the hardcoded data of Hugo in a separate
* data file, used by the game engine
*/
// 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 #1800764 "TOOLS: MinGW tools building broken"
#ifdef main
#undef main
#endif // main
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "common/scummsys.h"
#include "common/events.h"
#include "enums.h"
#include "create_hugo.h"
#include "staticdata.h"
#include "staticdisplay.h"
#include "staticengine.h"
#include "staticintro.h"
#include "staticmouse.h"
#include "staticparser.h"
#include "staticutil.h"
#include "staticfont.h"
static void writeByte(FILE *fp, uint8 b) {
fwrite(&b, 1, 1, fp);
}
static void writeSByte(FILE *fp, int8 b) {
fwrite(&b, 1, 1, fp);
}
static void writeUint16BE(FILE *fp, uint16 value) {
writeByte(fp, (uint8)(value >> 8));
writeByte(fp, (uint8)(value & 0xFF));
}
void writeSint16BE(FILE *fp, int16 value) {
writeUint16BE(fp, (uint16)value);
}
static void writeUint32BE(FILE *fp, uint32 value) {
writeByte(fp, (uint8)(value >> 24));
writeByte(fp, (uint8)((value >> 16) & 0xFF));
writeByte(fp, (uint8)((value >> 8) & 0xFF));
writeByte(fp, (uint8)(value & 0xFF));
}
void writeSint32BE(FILE *fp, int32 value) {
writeUint32BE(fp, (uint16)value);
}
int main(int argc, char *argv[]) {
FILE *outFile;
int i;
int nbrElem, nbrSubElem;
outFile = fopen("hugo.dat", "wb");
// Write header
fwrite("HUGO", 4, 1, outFile);
writeByte(outFile, HUGO_DAT_VER_MAJ);
writeByte(outFile, HUGO_DAT_VER_MIN);
// game versions/variantes
writeUint16BE(outFile, NUM_VARIANTE);
// Write palette
writeUint16BE(outFile, SIZE_PAL_ARRAY);
for (i = 0; i < SIZE_PAL_ARRAY; i++) {
writeByte(outFile, _palette[i]);
}
// The following fonts info have been added to avoid temporarly the .FON
// used in the DOS version
// font5
nbrElem = sizeof(font5) / sizeof(byte);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeByte(outFile, font5[j]);
// font6
nbrElem = sizeof(font6) / sizeof(byte);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeByte(outFile, font6[j]);
// font8
nbrElem = sizeof(font8) / sizeof(byte);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeByte(outFile, font8[j]);
// Write textData
// textData_1w
nbrElem = sizeof(textData_1w) / sizeof(char *);
writeTextArray(outFile, textData_1w, nbrElem);
// textData_2w
nbrElem = sizeof(textData_2w) / sizeof(char *);
writeTextArray(outFile, textData_2w, nbrElem);
// textData_3w
nbrElem = sizeof(textData_3w) / sizeof(char *);
writeTextArray(outFile, textData_3w, nbrElem);
// textData_1d
nbrElem = sizeof(textData_1d) / sizeof(char *);
writeTextArray(outFile, textData_1d, nbrElem);
// textData_2d
nbrElem = sizeof(textData_2d) / sizeof(char *);
writeTextArray(outFile, textData_2d, nbrElem);
// textData_3d
nbrElem = sizeof(textData_3d) / sizeof(char *);
writeTextArray(outFile, textData_3d, nbrElem);
// Write string_t_Data
// string_t_Data_1w
nbrElem = sizeof(string_t_Data_1w) / sizeof(char *);
writeTextArray(outFile, string_t_Data_1w, nbrElem);
// string_t_Data_2w
nbrElem = sizeof(string_t_Data_2w) / sizeof(char *);
writeTextArray(outFile, string_t_Data_2w, nbrElem);
// string_t_Data_3w
nbrElem = sizeof(string_t_Data_3w) / sizeof(char *);
writeTextArray(outFile, string_t_Data_3w, nbrElem);
// string_t_Data_1d
nbrElem = sizeof(string_t_Data_1d) / sizeof(char *);
writeTextArray(outFile, string_t_Data_1d, nbrElem);
// string_t_Data_2d
nbrElem = sizeof(string_t_Data_2d) / sizeof(char *);
writeTextArray(outFile, string_t_Data_2d, nbrElem);
// string_t_Data_3d
nbrElem = sizeof(string_t_Data_3d) / sizeof(char *);
writeTextArray(outFile, string_t_Data_3d, nbrElem);
// arrayNouns_1w
nbrElem = sizeof(arrayNouns_1w) / sizeof(char **);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
for (nbrSubElem = 1; strcmp(arrayNouns_1w[j][nbrSubElem], ""); nbrSubElem++)
;
nbrSubElem++;
writeTextArray(outFile, arrayNouns_1w[j], nbrSubElem);
}
// arrayNouns_2w
nbrElem = sizeof(arrayNouns_2w) / sizeof(char **);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
for (nbrSubElem = 1; strcmp(arrayNouns_2w[j][nbrSubElem], ""); nbrSubElem++)
;
nbrSubElem++;
writeTextArray(outFile, arrayNouns_2w[j], nbrSubElem);
}
// arrayNouns_3w
nbrElem = sizeof(arrayNouns_3w) / sizeof(char **);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
for (nbrSubElem = 1; strcmp(arrayNouns_3w[j][nbrSubElem], ""); nbrSubElem++)
;
nbrSubElem++;
writeTextArray(outFile, arrayNouns_3w[j], nbrSubElem);
}
// arrayNouns_1d
nbrElem = sizeof(arrayNouns_1d) / sizeof(char **);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
for (nbrSubElem = 1; strcmp(arrayNouns_1d[j][nbrSubElem], ""); nbrSubElem++)
;
nbrSubElem++;
writeTextArray(outFile, arrayNouns_1d[j], nbrSubElem);
}
// arrayNouns_2d
nbrElem = sizeof(arrayNouns_2d) / sizeof(char **);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
for (nbrSubElem = 1; strcmp(arrayNouns_2d[j][nbrSubElem], ""); nbrSubElem++)
;
nbrSubElem++;
writeTextArray(outFile, arrayNouns_2d[j], nbrSubElem);
}
// arrayNouns_3d
nbrElem = sizeof(arrayNouns_3d) / sizeof(char **);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
for (nbrSubElem = 1; strcmp(arrayNouns_3d[j][nbrSubElem], ""); nbrSubElem++)
;
nbrSubElem++;
writeTextArray(outFile, arrayNouns_3d[j], nbrSubElem);
}
// arrayVerbs_1w
nbrElem = sizeof(arrayVerbs_1w) / sizeof(char **);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
for (nbrSubElem = 1; strcmp(arrayVerbs_1w[j][nbrSubElem], ""); nbrSubElem++)
;
nbrSubElem++;
writeTextArray(outFile, arrayVerbs_1w[j], nbrSubElem);
}
// arrayVerbs_2w
nbrElem = sizeof(arrayVerbs_2w) / sizeof(char **);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
for (nbrSubElem = 1; strcmp(arrayVerbs_2w[j][nbrSubElem], ""); nbrSubElem++)
;
nbrSubElem++;
writeTextArray(outFile, arrayVerbs_2w[j], nbrSubElem);
}
// arrayVerbs_3w
nbrElem = sizeof(arrayVerbs_3w) / sizeof(char **);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
for (nbrSubElem = 1; strcmp(arrayVerbs_3w[j][nbrSubElem], ""); nbrSubElem++)
;
nbrSubElem++;
writeTextArray(outFile, arrayVerbs_3w[j], nbrSubElem);
}
// arrayVerbs_1d
nbrElem = sizeof(arrayVerbs_1d) / sizeof(char **);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
for (nbrSubElem = 1; strcmp(arrayVerbs_1d[j][nbrSubElem], ""); nbrSubElem++)
;
nbrSubElem++;
writeTextArray(outFile, arrayVerbs_1d[j], nbrSubElem);
}
// arrayVerbs_2d
nbrElem = sizeof(arrayVerbs_2d) / sizeof(char **);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
for (nbrSubElem = 1; strcmp(arrayVerbs_2d[j][nbrSubElem], ""); nbrSubElem++)
;
nbrSubElem++;
writeTextArray(outFile, arrayVerbs_2d[j], nbrSubElem);
}
// arrayVerbs_3d
nbrElem = sizeof(arrayVerbs_3d) / sizeof(char **);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
for (nbrSubElem = 1; strcmp(arrayVerbs_3d[j][nbrSubElem], ""); nbrSubElem++)
;
nbrSubElem++;
writeTextArray(outFile, arrayVerbs_3d[j], nbrSubElem);
}
// Write screenNames
// screenNames_1w
nbrElem = sizeof(screenNames_1w) / sizeof(char *);
writeTextArray(outFile, screenNames_1w, nbrElem);
// screenNames_2w
nbrElem = sizeof(screenNames_2w) / sizeof(char *);
writeTextArray(outFile, screenNames_2w, nbrElem);
// screenNames_3w
nbrElem = sizeof(screenNames_3w) / sizeof(char *);
writeTextArray(outFile, screenNames_3w, nbrElem);
// screenNames_1d
nbrElem = sizeof(screenNames_1d) / sizeof(char *);
writeTextArray(outFile, screenNames_1d, nbrElem);
// screenNames_2d
nbrElem = sizeof(screenNames_2d) / sizeof(char *);
writeTextArray(outFile, screenNames_2d, nbrElem);
// screenNames_3d
nbrElem = sizeof(screenNames_3d) / sizeof(char *);
writeTextArray(outFile, screenNames_3d, nbrElem);
// Write textEngine
writeTextArray(outFile, textEngine, NUM_ENGINE_TEXT);
// Write textIntro
writeTextArray(outFile, textIntro_dummy, NUM_INTRO_TEXT_DUMMY);
writeTextArray(outFile, textIntro_dummy, NUM_INTRO_TEXT_DUMMY);
writeTextArray(outFile, textIntro_v3, NUM_INTRO_TEXT_V3);
writeTextArray(outFile, textIntro_dummy, NUM_INTRO_TEXT_DUMMY);
writeTextArray(outFile, textIntro_dummy, NUM_INTRO_TEXT_DUMMY);
writeTextArray(outFile, textIntro_v3, NUM_INTRO_TEXT_V3);
// Write textMouse
writeTextArray(outFile, textMouse, NUM_MOUSE_TEXT);
// Write textParser
writeTextArray(outFile, textParser, NUM_PARSER_TEXT);
// Write textUtil
writeTextArray(outFile, textUtil_v1w, NUM_UTIL_TEXT);
writeTextArray(outFile, textUtil_v1w, NUM_UTIL_TEXT);
writeTextArray(outFile, textUtil_v1w, NUM_UTIL_TEXT);
writeTextArray(outFile, textUtil_v1d, NUM_UTIL_TEXT);
writeTextArray(outFile, textUtil_v1d, NUM_UTIL_TEXT);
writeTextArray(outFile, textUtil_v1d, NUM_UTIL_TEXT);
// Write x_intro and y_intro
writeUint16BE(outFile, NUM_INTRO_TICK_DUMMY);
for (i = 0; i < NUM_INTRO_TICK_DUMMY; i++) {
writeByte(outFile, x_intro_dummy[i]);
writeByte(outFile, y_intro_dummy[i]);
}
writeUint16BE(outFile, NUM_INTRO_TICK_DUMMY);
for (i = 0; i < NUM_INTRO_TICK_DUMMY; i++) {
writeByte(outFile, x_intro_dummy[i]);
writeByte(outFile, y_intro_dummy[i]);
}
writeUint16BE(outFile, NUM_INTRO_TICK_V3);
for (i = 0; i < NUM_INTRO_TICK_V3; i++) {
writeByte(outFile, x_intro_v3[i]);
writeByte(outFile, y_intro_v3[i]);
}
writeUint16BE(outFile, NUM_INTRO_TICK_V1D);
for (i = 0; i < NUM_INTRO_TICK_V1D; i++) {
writeByte(outFile, x_intro_v1d[i]);
writeByte(outFile, y_intro_v1d[i]);
}
writeUint16BE(outFile, NUM_INTRO_TICK_DUMMY);
for (i = 0; i < NUM_INTRO_TICK_DUMMY; i++) {
writeByte(outFile, x_intro_dummy[i]);
writeByte(outFile, y_intro_dummy[i]);
}
writeUint16BE(outFile, NUM_INTRO_TICK_V3);
for (i = 0; i < NUM_INTRO_TICK_V3; i++) {
writeByte(outFile, x_intro_v3[i]);
writeByte(outFile, y_intro_v3[i]);
}
// arrayReqs_1w
nbrElem = sizeof(arrayReqs_1w) / sizeof(uint16 *);
writeUint16Array(outFile, arrayReqs_1w, nbrElem);
// arrayReqs_2w
nbrElem = sizeof(arrayReqs_2w) / sizeof(uint16 *);
writeUint16Array(outFile, arrayReqs_2w, nbrElem);
// arrayReqs_3w
nbrElem = sizeof(arrayReqs_3w) / sizeof(uint16 *);
writeUint16Array(outFile, arrayReqs_3w, nbrElem);
// arrayReqs_1d
nbrElem = sizeof(arrayReqs_1d) / sizeof(uint16 *);
writeUint16Array(outFile, arrayReqs_1d, nbrElem);
// arrayReqs_2d
nbrElem = sizeof(arrayReqs_2d) / sizeof(uint16 *);
writeUint16Array(outFile, arrayReqs_2d, nbrElem);
// arrayReqs_3d
nbrElem = sizeof(arrayReqs_3d) / sizeof(uint16 *);
writeUint16Array(outFile, arrayReqs_3d, nbrElem);
// catchall_1w
nbrElem = sizeof(catchall_1w) / sizeof(background_t);
writeBackgroundArray(outFile, catchall_1w, nbrElem);
// catchall_2w
nbrElem = sizeof(catchall_2w) / sizeof(background_t);
writeBackgroundArray(outFile, catchall_2w, nbrElem);
// catchall_3w
nbrElem = sizeof(catchall_3w) / sizeof(background_t);
writeBackgroundArray(outFile, catchall_3w, nbrElem);
// catchall_1d
nbrElem = sizeof(catchall_1d) / sizeof(background_t);
writeBackgroundArray(outFile, catchall_1d, nbrElem);
// catchall_2d
nbrElem = sizeof(catchall_2d) / sizeof(background_t);
writeBackgroundArray(outFile, catchall_2d, nbrElem);
// catchall_3d
nbrElem = sizeof(catchall_3d) / sizeof(background_t);
writeBackgroundArray(outFile, catchall_3d, nbrElem);
// backgroundList_1w
nbrElem = sizeof(backgroundList_1w) / sizeof(background_t *);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
nbrSubElem = 1;
for (int k = 0; backgroundList_1w[j][k].verbIndex != 0; k++)
nbrSubElem ++;
writeBackgroundArray(outFile, backgroundList_1w[j], nbrSubElem);
}
// backgroundList_2w
nbrElem = sizeof(backgroundList_2w) / sizeof(background_t *);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
nbrSubElem = 1;
for (int k = 0; backgroundList_2w[j][k].verbIndex != 0; k++)
nbrSubElem ++;
writeBackgroundArray(outFile, backgroundList_2w[j], nbrSubElem);
}
// backgroundList_3w
nbrElem = sizeof(backgroundList_3w) / sizeof(background_t *);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
nbrSubElem = 1;
for (int k = 0; backgroundList_3w[j][k].verbIndex != 0; k++)
nbrSubElem ++;
writeBackgroundArray(outFile, backgroundList_3w[j], nbrSubElem);
}
// backgroundList_1d
nbrElem = sizeof(backgroundList_1d) / sizeof(background_t *);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
nbrSubElem = 1;
for (int k = 0; backgroundList_1d[j][k].verbIndex != 0; k++)
nbrSubElem ++;
writeBackgroundArray(outFile, backgroundList_1d[j], nbrSubElem);
}
// backgroundList_2d
nbrElem = sizeof(backgroundList_2d) / sizeof(background_t *);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
nbrSubElem = 1;
for (int k = 0; backgroundList_2d[j][k].verbIndex != 0; k++)
nbrSubElem ++;
writeBackgroundArray(outFile, backgroundList_2d[j], nbrSubElem);
}
// backgroundList_3d
nbrElem = sizeof(backgroundList_3d) / sizeof(background_t *);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
nbrSubElem = 1;
for (int k = 0; backgroundList_3d[j][k].verbIndex != 0; k++)
nbrSubElem ++;
writeBackgroundArray(outFile, backgroundList_3d[j], nbrSubElem);
}
// cmdList_1w
nbrElem = sizeof(cmdList_1w) / sizeof(cmd **);
writeCmdArray(outFile, cmdList_1w, nbrElem);
// cmdList_2w
nbrElem = sizeof(cmdList_2w) / sizeof(cmd **);
writeCmdArray(outFile, cmdList_2w, nbrElem);
// cmdList_3w
nbrElem = sizeof(cmdList_3w) / sizeof(cmd **);
writeCmdArray(outFile, cmdList_3w, nbrElem);
// cmdList_1d
nbrElem = sizeof(cmdList_1d) / sizeof(cmd **);
writeCmdArray(outFile, cmdList_1d, nbrElem);
// cmdList_2d
nbrElem = sizeof(cmdList_2d) / sizeof(cmd **);
writeCmdArray(outFile, cmdList_2d, nbrElem);
// cmdList_3d
nbrElem = sizeof(cmdList_3d) / sizeof(cmd **);
writeCmdArray(outFile, cmdList_3d, nbrElem);
// hotspots_1w
nbrElem = sizeof(hotspots_1w) / sizeof(hotspot_t);
writeHotspot(outFile, hotspots_1w, nbrElem);
// hotspots_2w
nbrElem = sizeof(hotspots_2w) / sizeof(hotspot_t);
writeHotspot(outFile, hotspots_2w, nbrElem);
// hotspots_3w
nbrElem = sizeof(hotspots_3w) / sizeof(hotspot_t);
writeHotspot(outFile, hotspots_3w, nbrElem);
// hotspots_1d
nbrElem = sizeof(hotspots_1d) / sizeof(hotspot_t);
writeHotspot(outFile, hotspots_1d, nbrElem);
// hotspots_2d
nbrElem = sizeof(hotspots_2d) / sizeof(hotspot_t);
writeHotspot(outFile, hotspots_2d, nbrElem);
// hotspots_3d
nbrElem = sizeof(hotspots_3d) / sizeof(hotspot_t);
writeHotspot(outFile, hotspots_3d, nbrElem);
// invent_1w
nbrElem = sizeof(invent_1w) / sizeof(int16);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeSint16BE(outFile, invent_1w[j]);
// invent_2w
nbrElem = sizeof(invent_2w) / sizeof(int16);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeSint16BE(outFile, invent_2w[j]);
// invent_3w
nbrElem = sizeof(invent_3w) / sizeof(int16);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeSint16BE(outFile, invent_3w[j]);
// invent_1d
nbrElem = sizeof(invent_1d) / sizeof(int16);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeSint16BE(outFile, invent_1d[j]);
// invent_2d
nbrElem = sizeof(invent_2d) / sizeof(int16);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeSint16BE(outFile, invent_2d[j]);
// invent_3d
nbrElem = sizeof(invent_3d) / sizeof(int16);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeSint16BE(outFile, invent_3d[j]);
// uses_1w
nbrElem = sizeof(uses_1w) / sizeof(uses_t);
writeUseArray(outFile, uses_1w, nbrElem);
// uses_2w
nbrElem = sizeof(uses_2w) / sizeof(uses_t);
writeUseArray(outFile, uses_2w, nbrElem);
// uses_3w
nbrElem = sizeof(uses_3w) / sizeof(uses_t);
writeUseArray(outFile, uses_3w, nbrElem);
// uses_1d
nbrElem = sizeof(uses_1d) / sizeof(uses_t);
writeUseArray(outFile, uses_1d, nbrElem);
// uses_2d
nbrElem = sizeof(uses_2d) / sizeof(uses_t);
writeUseArray(outFile, uses_2d, nbrElem);
// uses_3d
nbrElem = sizeof(uses_3d) / sizeof(uses_t);
writeUseArray(outFile, uses_3d, nbrElem);
// objects_1w
nbrElem = sizeof(objects_1w) / sizeof(object_t);
writeObjectArray(outFile, objects_1w, nbrElem);
// objects_2w
nbrElem = sizeof(objects_2w) / sizeof(object_t);
writeObjectArray(outFile, objects_2w, nbrElem);
// objects_3w
nbrElem = sizeof(objects_3w) / sizeof(object_t);
writeObjectArray(outFile, objects_3w, nbrElem);
// objects_1d
nbrElem = sizeof(objects_1d) / sizeof(object_t);
writeObjectArray(outFile, objects_1d, nbrElem);
// objects_2d
nbrElem = sizeof(objects_2d) / sizeof(object_t);
writeObjectArray(outFile, objects_2d, nbrElem);
// objects_3d
nbrElem = sizeof(objects_3d) / sizeof(object_t);
writeObjectArray(outFile, objects_3d, nbrElem);
// Save LASTOBJ
writeUint16BE(outFile, LASTOBJ_1w);
writeUint16BE(outFile, LASTOBJ_2w);
writeUint16BE(outFile, LASTOBJ_3w);
writeUint16BE(outFile, LASTOBJ_1d); //(not set in original, as Hugo1 DOS doesn't use a DAT file to pack the screens)
writeUint16BE(outFile, LASTOBJ_2d);
writeUint16BE(outFile, LASTOBJ_3d);
// points_1w
nbrElem = sizeof(points_1w) / sizeof(byte);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeByte(outFile, points_1w[j]);
// points_2w
nbrElem = sizeof(points_2w) / sizeof(byte);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeByte(outFile, points_2w[j]);
// points_3w
nbrElem = sizeof(points_3w) / sizeof(byte);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeByte(outFile, points_3w[j]);
// points_1d
nbrElem = sizeof(points_1d) / sizeof(byte);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeByte(outFile, points_1d[j]);
// points_2d
nbrElem = sizeof(points_2d) / sizeof(byte);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeByte(outFile, points_2d[j]);
// points_3d
nbrElem = sizeof(points_3d) / sizeof(byte);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeByte(outFile, points_3d[j]);
// screenActs_1w
nbrElem = sizeof(screenActs_1w) / sizeof(uint16 *);
writeScreenActs(outFile, screenActs_1w, nbrElem);
// screenActs_2w
nbrElem = sizeof(screenActs_2w) / sizeof(uint16 *);
writeScreenActs(outFile, screenActs_2w, nbrElem);
// screenActs_3w
nbrElem = sizeof(screenActs_3w) / sizeof(uint16 *);
writeScreenActs(outFile, screenActs_3w, nbrElem);
// screenActs_1d
nbrElem = sizeof(screenActs_1d) / sizeof(uint16 *);
writeScreenActs(outFile, screenActs_1d, nbrElem);
// screenActs_2d
nbrElem = sizeof(screenActs_2d) / sizeof(uint16 *);
writeScreenActs(outFile, screenActs_2d, nbrElem);
// screenActs_3d
nbrElem = sizeof(screenActs_3d) / sizeof(uint16 *);
writeScreenActs(outFile, screenActs_3d, nbrElem);
// actlistArr_1w
nbrElem = sizeof(actListArr_1w) / sizeof(actList);
writeActListArray(outFile, actListArr_1w, nbrElem);
// actlistArr_2w
nbrElem = sizeof(actListArr_2w) / sizeof(actList);
writeActListArray(outFile, actListArr_2w, nbrElem);
// actlistArr_3w
nbrElem = sizeof(actListArr_3w) / sizeof(actList);
writeActListArray(outFile, actListArr_3w, nbrElem);
// actlistArr_1d
nbrElem = sizeof(actListArr_1d) / sizeof(actList);
writeActListArray(outFile, actListArr_1d, nbrElem);
// actlistArr_2d
nbrElem = sizeof(actListArr_2d) / sizeof(actList);
writeActListArray(outFile, actListArr_2d, nbrElem);
// actlistArr_3d
nbrElem = sizeof(actListArr_3d) / sizeof(actList);
writeActListArray(outFile, actListArr_3d, nbrElem);
// Maze ALnewscr
writeUint16BE(outFile, 0);
writeUint16BE(outFile, kALnewscr_2w);
writeUint16BE(outFile, 0);
writeUint16BE(outFile, 0);
writeUint16BE(outFile, kALnewscr_2d);
writeUint16BE(outFile, 0);
writeSByte(outFile, NUM_TUNES_1w);
writeSByte(outFile, SILENCE_1w);
writeSByte(outFile, TEST_SOUND_1w);
writeSByte(outFile, NUM_TUNES_2w);
writeSByte(outFile, SILENCE_2w);
writeSByte(outFile, TEST_SOUND_2w);
writeSByte(outFile, NUM_TUNES_3w);
writeSByte(outFile, SILENCE_3w);
writeSByte(outFile, TEST_SOUND_3w);
writeSByte(outFile, NUM_TUNES_1d);
writeSByte(outFile, SILENCE_1d);
writeSByte(outFile, TEST_SOUND_1d);
writeSByte(outFile, NUM_TUNES_2d);
writeSByte(outFile, SILENCE_2d);
writeSByte(outFile, TEST_SOUND_2d);
writeSByte(outFile, NUM_TUNES_3d);
writeSByte(outFile, SILENCE_3d);
writeSByte(outFile, TEST_SOUND_3d);
// def_tunes_1w
nbrElem = sizeof(def_tunes_1w) / sizeof(int16);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeSint16BE(outFile, def_tunes_1w[j]);
// def_tunes_2w
nbrElem = sizeof(def_tunes_2w) / sizeof(int16);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeSint16BE(outFile, def_tunes_2w[j]);
// def_tunes_3w
nbrElem = sizeof(def_tunes_3w) / sizeof(int16);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeSint16BE(outFile, def_tunes_3w[j]);
// def_tunes_1d
nbrElem = sizeof(def_tunes_1d) / sizeof(int16);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeSint16BE(outFile, def_tunes_1d[j]);
// def_tunes_2d
nbrElem = sizeof(def_tunes_2d) / sizeof(int16);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeSint16BE(outFile, def_tunes_2d[j]);
// def_tunes_3d
nbrElem = sizeof(def_tunes_3d) / sizeof(int16);
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++)
writeSint16BE(outFile, def_tunes_3d[j]);
// Save _screnStates array size
writeUint16BE(outFile, LASTOBJ_1w);
writeUint16BE(outFile, LASTOBJ_2w);
writeUint16BE(outFile, NUM_PICS_3w);
writeUint16BE(outFile, NUM_PICS_1d); //(not set in original, as Hugo1 DOS doesn't use a DAT file to pack the screens)
writeUint16BE(outFile, LASTOBJ_2d);
writeUint16BE(outFile, NUM_PICS_3d);
// Save Look, Take and Drop constants
writeUint16BE(outFile, kVLook_1w);
writeUint16BE(outFile, kVTake_1w);
writeUint16BE(outFile, kVDrop_1w);
writeUint16BE(outFile, kVLook_2w);
writeUint16BE(outFile, kVTake_2w);
writeUint16BE(outFile, kVDrop_2w);
writeUint16BE(outFile, kVLook_3w);
writeUint16BE(outFile, kVTake_3w);
writeUint16BE(outFile, kVDrop_3w);
writeUint16BE(outFile, kVLook_1d);
writeUint16BE(outFile, kVTake_1d);
writeUint16BE(outFile, kVDrop_1d);
writeUint16BE(outFile, kVLook_2d);
writeUint16BE(outFile, kVTake_2d);
writeUint16BE(outFile, kVDrop_2d);
writeUint16BE(outFile, kVLook_3d);
writeUint16BE(outFile, kVTake_3d);
writeUint16BE(outFile, kVDrop_3d);
// DOS Intro music
// Win version do not use it
// H1 Dos doesn't have an intro
// H2 Dos handles the intro song in its scripts
writeUint16BE(outFile, 0);
writeUint16BE(outFile, 0);
writeUint16BE(outFile, 0);
writeUint16BE(outFile, 0);
writeUint16BE(outFile, 0);
writeUint16BE(outFile, kDTsong11_3d);
//bitmap images for menu
writeUint16BE(outFile, 18);
FILE* src_file;
char buf[2];
src_file = fopen("btn_1.bmp", "rb");
if (src_file == NULL) {
perror("btn_1.bmp");
fclose(outFile);
return -1;
}
fseek(src_file , 0 , SEEK_END);
nbrElem = ftell(src_file);
writeUint16BE(outFile, nbrElem);
rewind(src_file);
for (int j = 0; j < nbrElem; j++) {
fread(buf, 1, 1, src_file);
writeByte(outFile, buf[0]);
}
fclose(src_file);
src_file = fopen("btn_1_off.bmp", "rb");
if (src_file == NULL) {
perror("btn_1_off.bmp");
fclose(outFile);
return -1;
}
fseek(src_file , 0 , SEEK_END);
nbrElem = ftell(src_file);
writeUint16BE(outFile, nbrElem);
rewind(src_file);
for (int j = 0; j < nbrElem; j++) {
fread(buf, 1, 1, src_file);
writeByte(outFile, buf[0]);
}
fclose(src_file);
src_file = fopen("btn_2.bmp", "rb");
if (src_file == NULL) {
perror("btn_2.bmp");
fclose(outFile);
return -1;
}
fseek(src_file , 0 , SEEK_END);
nbrElem = ftell(src_file);
writeUint16BE(outFile, nbrElem);
rewind(src_file);
for (int j = 0; j < nbrElem; j++) {
fread(buf, 1, 1, src_file);
writeByte(outFile, buf[0]);
}
fclose(src_file);
src_file = fopen("btn_2_off.bmp", "rb");
if (src_file == NULL) {
perror("btn_2_off.bmp");
fclose(outFile);
return -1;
}
fseek(src_file , 0 , SEEK_END);
nbrElem = ftell(src_file);
writeUint16BE(outFile, nbrElem);
rewind(src_file);
for (int j = 0; j < nbrElem; j++) {
fread(buf, 1, 1, src_file);
writeByte(outFile, buf[0]);
}
fclose(src_file);
src_file = fopen("btn_3.bmp", "rb");
if (src_file == NULL) {
perror("btn_3.bmp");
fclose(outFile);
return -1;
}
fseek(src_file , 0 , SEEK_END);
nbrElem = ftell(src_file);
writeUint16BE(outFile, nbrElem);
rewind(src_file);
for (int j = 0; j < nbrElem; j++) {
fread(buf, 1, 1, src_file);
writeByte(outFile, buf[0]);
}
fclose(src_file);
src_file = fopen("btn_3_off.bmp", "rb");
if (src_file == NULL) {
perror("btn_3_off.bmp");
fclose(outFile);
return -1;
}
fseek(src_file , 0 , SEEK_END);
nbrElem = ftell(src_file);
writeUint16BE(outFile, nbrElem);
rewind(src_file);
for (int j = 0; j < nbrElem; j++) {
fread(buf, 1, 1, src_file);
writeByte(outFile, buf[0]);
}
fclose(src_file);
src_file = fopen("btn_4.bmp", "rb");
if (src_file == NULL) {
perror("btn_4.bmp");
fclose(outFile);
return -1;
}
fseek(src_file , 0 , SEEK_END);
nbrElem = ftell(src_file);
writeUint16BE(outFile, nbrElem);
rewind(src_file);
for (int j = 0; j < nbrElem; j++) {
fread(buf, 1, 1, src_file);
writeByte(outFile, buf[0]);
}
fclose(src_file);
src_file = fopen("btn_4_off.bmp", "rb");
if (src_file == NULL) {
perror("btn_4_off.bmp");
fclose(outFile);
return -1;
}
fseek(src_file , 0 , SEEK_END);
nbrElem = ftell(src_file);
writeUint16BE(outFile, nbrElem);
rewind(src_file);
for (int j = 0; j < nbrElem; j++) {
fread(buf, 1, 1, src_file);
writeByte(outFile, buf[0]);
}
fclose(src_file);
src_file = fopen("btn_5.bmp", "rb");
if (src_file == NULL) {
perror("btn_5.bmp");
fclose(outFile);
return -1;
}
fseek(src_file , 0 , SEEK_END);
nbrElem = ftell(src_file);
writeUint16BE(outFile, nbrElem);
rewind(src_file);
for (int j = 0; j < nbrElem; j++) {
fread(buf, 1, 1, src_file);
writeByte(outFile, buf[0]);
}
fclose(src_file);
src_file = fopen("btn_5_off.bmp", "rb");
if (src_file == NULL) {
perror("btn_5_off.bmp");
fclose(outFile);
return -1;
}
fseek(src_file , 0 , SEEK_END);
nbrElem = ftell(src_file);
writeUint16BE(outFile, nbrElem);
rewind(src_file);
for (int j = 0; j < nbrElem; j++) {
fread(buf, 1, 1, src_file);
writeByte(outFile, buf[0]);
}
fclose(src_file);
src_file = fopen("btn_6.bmp", "rb");
if (src_file == NULL) {
perror("btn_6.bmp");
fclose(outFile);
return -1;
}
fseek(src_file , 0 , SEEK_END);
nbrElem = ftell(src_file);
writeUint16BE(outFile, nbrElem);
rewind(src_file);
for (int j = 0; j < nbrElem; j++) {
fread(buf, 1, 1, src_file);
writeByte(outFile, buf[0]);
}
fclose(src_file);
src_file = fopen("btn_6_off.bmp", "rb");
if (src_file == NULL) {
perror("btn_6_off.bmp");
fclose(outFile);
return -1;
}
fseek(src_file , 0 , SEEK_END);
nbrElem = ftell(src_file);
writeUint16BE(outFile, nbrElem);
rewind(src_file);
for (int j = 0; j < nbrElem; j++) {
fread(buf, 1, 1, src_file);
writeByte(outFile, buf[0]);
}
fclose(src_file);
src_file = fopen("btn_7.bmp", "rb");
if (src_file == NULL) {
perror("btn_7.bmp");
fclose(outFile);
return -1;
}
fseek(src_file , 0 , SEEK_END);
nbrElem = ftell(src_file);
writeUint16BE(outFile, nbrElem);
rewind(src_file);
for (int j = 0; j < nbrElem; j++) {
fread(buf, 1, 1, src_file);
writeByte(outFile, buf[0]);
}
fclose(src_file);
src_file = fopen("btn_7_off.bmp", "rb");
if (src_file == NULL) {
perror("btn_7_off.bmp");
fclose(outFile);
return -1;
}
fseek(src_file , 0 , SEEK_END);
nbrElem = ftell(src_file);
writeUint16BE(outFile, nbrElem);
rewind(src_file);
for (int j = 0; j < nbrElem; j++) {
fread(buf, 1, 1, src_file);
writeByte(outFile, buf[0]);
}
fclose(src_file);
src_file = fopen("btn_8.bmp", "rb");
if (src_file == NULL) {
perror("btn_8.bmp");
fclose(outFile);
return -1;
}
fseek(src_file , 0 , SEEK_END);
nbrElem = ftell(src_file);
writeUint16BE(outFile, nbrElem);
rewind(src_file);
for (int j = 0; j < nbrElem; j++) {
fread(buf, 1, 1, src_file);
writeByte(outFile, buf[0]);
}
fclose(src_file);
src_file = fopen("btn_8_off.bmp", "rb");
if (src_file == NULL) {
perror("btn_8_off.bmp");
fclose(outFile);
return -1;
}
fseek(src_file , 0 , SEEK_END);
nbrElem = ftell(src_file);
writeUint16BE(outFile, nbrElem);
rewind(src_file);
for (int j = 0; j < nbrElem; j++) {
fread(buf, 1, 1, src_file);
writeByte(outFile, buf[0]);
}
fclose(src_file);
src_file = fopen("btn_9.bmp", "rb");
if (src_file == NULL) {
perror("btn_9.bmp");
fclose(outFile);
return -1;
}
fseek(src_file , 0 , SEEK_END);
nbrElem = ftell(src_file);
writeUint16BE(outFile, nbrElem);
rewind(src_file);
for (int j = 0; j < nbrElem; j++) {
fread(buf, 1, 1, src_file);
writeByte(outFile, buf[0]);
}
fclose(src_file);
src_file = fopen("btn_9_off.bmp", "rb");
if (src_file == NULL) {
perror("btn_9_off.bmp");
fclose(outFile);
return -1;
}
fseek(src_file , 0 , SEEK_END);
nbrElem = ftell(src_file);
writeUint16BE(outFile, nbrElem);
rewind(src_file);
for (int j = 0; j < nbrElem; j++) {
fread(buf, 1, 1, src_file);
writeByte(outFile, buf[0]);
}
fclose(src_file);
fclose(outFile);
return 0;
}
void writeTextArray(FILE *outFile, const char *textArray[], int nbrText) {
int len, len1, pad;
uint8 padBuf[DATAALIGNMENT];
for (int i = 0; i < DATAALIGNMENT; i++)
padBuf[i] = 0;
writeUint16BE(outFile, nbrText);
len = DATAALIGNMENT - 2;
for (int i = 0; i < nbrText; i++) {
len1 = strlen(textArray[i]) + 1;
pad = DATAALIGNMENT - (len1 + 2) % DATAALIGNMENT;
len += 2 + len1 + pad;
}
writeUint16BE(outFile, len);
fwrite(padBuf, DATAALIGNMENT - 2, 1, outFile); // padding
for (int i = 0; i < nbrText; i++) {
len = strlen(textArray[i]) + 1;
pad = DATAALIGNMENT - (len + 2) % DATAALIGNMENT;
writeUint16BE(outFile, len + pad + 2);
fwrite(textArray[i], len, 1, outFile);
fwrite(padBuf, pad, 1, outFile);
}
}
void writeUint16Array(FILE *outFile, const uint16 *uint16Array[], int nbrElem) {
int nbrSubElem;
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
for (nbrSubElem = 1; uint16Array[j][nbrSubElem] != 0; nbrSubElem++)
;
nbrSubElem++;
writeUint16BE(outFile, nbrSubElem);
for (int i = 0; i < nbrSubElem; i++) {
writeUint16BE(outFile, uint16Array[j][i]);
}
}
}
void writeHotspot(FILE *outFile, const hotspot_t hotspots[], int nbrElem) {
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
writeSint16BE(outFile, hotspots[j].screenIndex);
writeSint16BE(outFile, hotspots[j].x1);
writeSint16BE(outFile, hotspots[j].y1);
writeSint16BE(outFile, hotspots[j].x2);
writeSint16BE(outFile, hotspots[j].y2);
writeUint16BE(outFile, hotspots[j].actIndex);
writeSint16BE(outFile, hotspots[j].viewx);
writeSint16BE(outFile, hotspots[j].viewy);
writeSint16BE(outFile, hotspots[j].direction);
}
}
void writeUseArray(FILE *outFile, const uses_t uses[], int nbrElem) {
int nbrSubElem;
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
writeSint16BE(outFile, uses[j].objid);
writeUint16BE(outFile, uses[j].dataIndex);
nbrSubElem = sizeof(uses_1w[j].targets) / sizeof(target_t);
writeUint16BE(outFile, nbrSubElem);
for (int k = 0; k < nbrSubElem; k++) {
writeUint16BE(outFile, uses[j].targets[k].nounIndex);
writeUint16BE(outFile, uses[j].targets[k].verbIndex);
}
}
}
void writeBackgroundArray(FILE *outFile, const background_t background[], int nbrElem) {
writeUint16BE(outFile, nbrElem);
for (int j = 0; j < nbrElem; j++) {
writeUint16BE(outFile, background[j].verbIndex);
writeUint16BE(outFile, background[j].nounIndex);
writeSint16BE(outFile, background[j].commentIndex);
writeByte(outFile, (background[j].matchFl) ? 1 : 0);
writeByte(outFile, background[j].roomState);
writeByte(outFile, background[j].bonusIndex);
}
}
void writeCmdArray(FILE *outFile, const cmd *cmdList[], int nbrElem) {
int nbrSubElem;
writeUint16BE(outFile, nbrElem);
for (int i = 0; i < nbrElem; i++) {
nbrSubElem = 1;
for (int j = 0; cmdList[i][j].verbIndex != 0; j++)
nbrSubElem ++;
writeUint16BE(outFile, nbrSubElem);
for (int j = 0; j < nbrSubElem; j++) {
writeUint16BE(outFile, cmdList[i][j].verbIndex);
writeUint16BE(outFile, cmdList[i][j].reqIndex);
writeUint16BE(outFile, cmdList[i][j].textDataNoCarryIndex);
writeByte(outFile, cmdList[i][j].reqstate);
writeByte(outFile, cmdList[i][j].newstate);
writeUint16BE(outFile, cmdList[i][j].textDataWrongIndex);
writeUint16BE(outFile, cmdList[i][j].textDataDoneIndex);
writeUint16BE(outFile, cmdList[i][j].actIndex);
}
}
}
void writeScreenActs(FILE *outFile, const uint16 *screenActs[], int nbrElem) {
int nbrSubElem;
writeUint16BE(outFile, nbrElem);
for (int i = 0; i < nbrElem; i++) {
if (screenActs[i] == 0)
writeUint16BE(outFile, 0);
else {
nbrSubElem = 1;
for (int j = 0; screenActs[i][j] != 0; j++)
nbrSubElem ++;
writeUint16BE(outFile, nbrSubElem);
for (int j = 0; j < nbrSubElem; j++)
writeUint16BE(outFile, screenActs[i][j]);
}
}
}
void writeObjectArray(FILE *outFile, const object_t objects[], int nbrElem) {
int nbrSubElem;
writeUint16BE(outFile, nbrElem);
for (int i = 0; i < nbrElem; i++) {
writeUint16BE(outFile, objects[i].nounIndex);
writeUint16BE(outFile, objects[i].dataIndex);
if (objects[i].stateDataIndex == NULL)
writeUint16BE(outFile, 0);
else {
nbrSubElem = 1;
for (int j = 0; objects[i].stateDataIndex[j] != 0; j++)
nbrSubElem ++;
writeUint16BE(outFile, nbrSubElem);
for (int j = 0; j < nbrSubElem; j++)
writeUint16BE(outFile, objects[i].stateDataIndex[j]);
}
writeSint16BE(outFile, objects[i].pathType);
writeSint16BE(outFile, objects[i].vxPath);
writeSint16BE(outFile, objects[i].vyPath);
writeUint16BE(outFile, objects[i].actIndex);
writeByte(outFile, objects[i].seqNumb);
// curr_seq_p is skipped: always equal to zero during initialization
for (int j = 0; j < objects[i].seqNumb; j++)
writeUint16BE(outFile, objects[i].seqList[j].imageNbr);
// seq_list[].seq_p is always null during initialization, thus skipped
writeByte(outFile, objects[i].cycling);
writeByte(outFile, objects[i].cycleNumb);
writeByte(outFile, objects[i].frameInterval);
writeByte(outFile, objects[i].frameTimer);
writeByte(outFile, objects[i].radius);
writeByte(outFile, objects[i].screenIndex);
writeSint16BE(outFile, objects[i].x);
writeSint16BE(outFile, objects[i].y);
writeSint16BE(outFile, objects[i].oldx);
writeSint16BE(outFile, objects[i].oldy);
writeByte(outFile, objects[i].vx);
writeByte(outFile, objects[i].vy);
writeByte(outFile, objects[i].objValue);
writeSint16BE(outFile, objects[i].genericCmd);
writeUint16BE(outFile, objects[i].cmdIndex);
writeByte(outFile, (objects[i].carriedFl) ? 1 : 0);
writeByte(outFile, objects[i].state);
writeByte(outFile, (objects[i].verbOnlyFl) ? 1 : 0);
writeByte(outFile, objects[i].priority);
writeSint16BE(outFile, objects[i].viewx);
writeSint16BE(outFile, objects[i].viewy);
writeSint16BE(outFile, objects[i].direction);
writeByte(outFile, objects[i].curSeqNumb);
writeByte(outFile, objects[i].curImageNumb);
writeByte(outFile, objects[i].oldvx);
writeByte(outFile, objects[i].oldvy);
}
}
void writeActListArray(FILE *outFile, const actList actListArr[], int nbrElem) {
int nbrSubElem, nbrCpt;
byte subElemType;
writeUint16BE(outFile, nbrElem);
for (int i = 0; i < nbrElem; i++) {
for (nbrSubElem = 0; actListArr[i][nbrSubElem] != NULL; nbrSubElem++)
;
writeUint16BE(outFile, nbrSubElem);
for (int j = 0; j < nbrSubElem; j++) {
subElemType = ((act *) actListArr[i][j])->a0.actType;
writeByte(outFile, subElemType);
switch (subElemType) {
case ANULL: // -1
break;
case ASCHEDULE: // 0
writeSint16BE(outFile, ((act *) actListArr[i][j])->a0.timer);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a0.actIndex);
break;
case START_OBJ: // 1
writeSint16BE(outFile, ((act *) actListArr[i][j])->a1.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a1.objNumb);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a1.cycleNumb);
writeByte(outFile, ((act *) actListArr[i][j])->a1.cycle);
break;
case INIT_OBJXY: // 2
writeSint16BE(outFile, ((act *) actListArr[i][j])->a2.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a2.objNumb);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a2.x);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a2.y);
break;
case PROMPT: // 3
writeSint16BE(outFile, ((act *) actListArr[i][j])->a3.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a3.promptIndex);
for (nbrCpt = 0; ((act *) actListArr[i][j])->a3.responsePtr[nbrCpt] != -1; nbrCpt++)
;
nbrCpt++;
writeUint16BE(outFile, nbrCpt);
for (int k = 0; k < nbrCpt; k++)
writeSint16BE(outFile, ((act *) actListArr[i][j])->a3.responsePtr[k]);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a3.actPassIndex);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a3.actFailIndex);
writeByte(outFile, (((act *) actListArr[i][j])->a3.encoded) ? 1 : 0);
break;
case BKGD_COLOR: // 4
writeSint16BE(outFile, ((act *) actListArr[i][j])->a4.timer);
writeUint32BE(outFile, ((act *) actListArr[i][j])->a4.newBkgColor);
break;
case INIT_OBJVXY: // 5
writeSint16BE(outFile, ((act *) actListArr[i][j])->a5.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a5.objNumb);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a5.vx);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a5.vy);
break;
case INIT_CARRY: // 6
writeSint16BE(outFile, ((act *) actListArr[i][j])->a6.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a6.objNumb);
writeByte(outFile, (((act *) actListArr[i][j])->a6.carriedFl) ? 1 : 0);
break;
case INIT_HF_COORD: // 7
writeSint16BE(outFile, ((act *) actListArr[i][j])->a7.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a7.objNumb);
break;
case NEW_SCREEN: // 8
writeSint16BE(outFile, ((act *) actListArr[i][j])->a8.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a8.screenIndex);
break;
case INIT_OBJSTATE: // 9
writeSint16BE(outFile, ((act *) actListArr[i][j])->a9.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a9.objNumb);
writeByte(outFile, ((act *) actListArr[i][j])->a9.newState);
break;
case INIT_PATH: // 10
writeSint16BE(outFile, ((act *) actListArr[i][j])->a10.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a10.objNumb);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a10.newPathType);
writeByte(outFile, ((act *) actListArr[i][j])->a10.vxPath);
writeByte(outFile, ((act *) actListArr[i][j])->a10.vyPath);
break;
case COND_R: // 11
writeSint16BE(outFile, ((act *) actListArr[i][j])->a11.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a11.objNumb);
writeByte(outFile, ((act *) actListArr[i][j])->a11.stateReq);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a11.actPassIndex);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a11.actFailIndex);
break;
case TEXT: // 12
writeSint16BE(outFile, ((act *) actListArr[i][j])->a12.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a12.stringIndex);
break;
case SWAP_IMAGES: // 13
writeSint16BE(outFile, ((act *) actListArr[i][j])->a13.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a13.obj1);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a13.obj2);
break;
case COND_SCR: // 14
writeSint16BE(outFile, ((act *) actListArr[i][j])->a14.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a14.objNumb);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a14.screenReq);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a14.actPassIndex);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a14.actFailIndex);
break;
case AUTOPILOT: // 15
writeSint16BE(outFile, ((act *) actListArr[i][j])->a15.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a15.obj1);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a15.obj2);
writeByte(outFile, ((act *) actListArr[i][j])->a15.vx);
writeByte(outFile, ((act *) actListArr[i][j])->a15.vy);
break;
case INIT_OBJ_SEQ: // 16
writeSint16BE(outFile, ((act *) actListArr[i][j])->a16.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a16.objNumb);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a16.seqIndex);
break;
case SET_STATE_BITS: // 17
writeSint16BE(outFile, ((act *) actListArr[i][j])->a17.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a17.objNumb);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a17.stateMask);
break;
case CLEAR_STATE_BITS: // 18
writeSint16BE(outFile, ((act *) actListArr[i][j])->a18.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a18.objNumb);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a18.stateMask);
break;
case TEST_STATE_BITS: // 19
writeSint16BE(outFile, ((act *) actListArr[i][j])->a19.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a19.objNumb);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a19.stateMask);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a19.actPassIndex);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a19.actFailIndex);
break;
case DEL_EVENTS: // 20
writeSint16BE(outFile, ((act *) actListArr[i][j])->a20.timer);
writeByte(outFile, ((act *) actListArr[i][j])->a20.actTypeDel);
break;
case GAMEOVER: // 21
writeSint16BE(outFile, ((act *) actListArr[i][j])->a21.timer);
break;
case INIT_HH_COORD: // 22
writeSint16BE(outFile, ((act *) actListArr[i][j])->a22.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a22.objNumb);
break;
case EXIT: // 23
writeSint16BE(outFile, ((act *) actListArr[i][j])->a23.timer);
break;
case BONUS: // 24
writeSint16BE(outFile, ((act *) actListArr[i][j])->a24.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a24.pointIndex);
break;
case COND_BOX: // 25
writeSint16BE(outFile, ((act *) actListArr[i][j])->a25.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a25.objNumb);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a25.x1);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a25.y1);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a25.x2);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a25.y2);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a25.actPassIndex);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a25.actFailIndex);
break;
case SOUND: // 26
writeSint16BE(outFile, ((act *) actListArr[i][j])->a26.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a26.soundIndex);
break;
case ADD_SCORE: // 27
writeSint16BE(outFile, ((act *) actListArr[i][j])->a27.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a27.objNumb);
break;
case SUB_SCORE: // 28
writeSint16BE(outFile, ((act *) actListArr[i][j])->a28.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a28.objNumb);
break;
case COND_CARRY: // 29
writeSint16BE(outFile, ((act *) actListArr[i][j])->a29.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a29.objNumb);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a29.actPassIndex);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a29.actFailIndex);
break;
case INIT_MAZE: // 30
writeSint16BE(outFile, ((act *) actListArr[i][j])->a30.timer);
writeByte(outFile, ((act *) actListArr[i][j])->a30.mazeSize);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a30.x1);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a30.y1);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a30.x2);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a30.y2);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a30.x3);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a30.x4);
writeByte(outFile, ((act *) actListArr[i][j])->a30.firstScreenIndex);
break;
case EXIT_MAZE: // 31
writeSint16BE(outFile, ((act *) actListArr[i][j])->a31.timer);
break;
case INIT_PRIORITY: // 32
writeSint16BE(outFile, ((act *) actListArr[i][j])->a32.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a32.objNumb);
writeByte(outFile, ((act *) actListArr[i][j])->a32.priority);
break;
case INIT_SCREEN: // 33
writeSint16BE(outFile, ((act *) actListArr[i][j])->a33.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a33.objNumb);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a33.screenIndex);
break;
case AGSCHEDULE: // 34
writeSint16BE(outFile, ((act *) actListArr[i][j])->a34.timer);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a34.actIndex);
break;
case REMAPPAL: // 35
writeSint16BE(outFile, ((act *) actListArr[i][j])->a35.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a35.oldColorIndex);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a35.newColorIndex);
break;
case COND_NOUN: // 36
writeSint16BE(outFile, ((act *) actListArr[i][j])->a36.timer);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a36.nounIndex);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a36.actPassIndex);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a36.actFailIndex);
break;
case SCREEN_STATE: // 37
writeSint16BE(outFile, ((act *) actListArr[i][j])->a37.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a37.screenIndex);
writeByte(outFile, ((act *) actListArr[i][j])->a37.newState);
break;
case INIT_LIPS: // 38
writeSint16BE(outFile, ((act *) actListArr[i][j])->a38.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a38.lipsObjNumb);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a38.objNumb);
writeByte(outFile, ((act *) actListArr[i][j])->a38.dxLips);
writeByte(outFile, ((act *) actListArr[i][j])->a38.dyLips);
break;
case INIT_STORY_MODE: // 39
writeSint16BE(outFile, ((act *) actListArr[i][j])->a39.timer);
writeByte(outFile, (((act *) actListArr[i][j])->a39.storyModeFl) ? 1 : 0);
break;
case WARN: // 40
writeSint16BE(outFile, ((act *) actListArr[i][j])->a40.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a40.stringIndex);
break;
case COND_BONUS: // 41
writeSint16BE(outFile, ((act *) actListArr[i][j])->a41.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a41.BonusIndex);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a41.actPassIndex);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a41.actFailIndex);
break;
case TEXT_TAKE: // 42
writeSint16BE(outFile, ((act *) actListArr[i][j])->a42.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a42.objNumb);
break;
case YESNO: // 43
writeSint16BE(outFile, ((act *) actListArr[i][j])->a43.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a43.prompt);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a43.actYesIndex);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a43.actNoIndex);
break;
case STOP_ROUTE: // 44
writeSint16BE(outFile, ((act *) actListArr[i][j])->a44.timer);
break;
case COND_ROUTE: // 45
writeSint16BE(outFile, ((act *) actListArr[i][j])->a45.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a45.routeIndex);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a45.actPassIndex);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a45.actFailIndex);
break;
case INIT_JUMPEXIT: // 46
writeSint16BE(outFile, ((act *) actListArr[i][j])->a46.timer);
writeByte(outFile, (((act *) actListArr[i][j])->a46.jumpExitFl) ? 1 : 0);
break;
case INIT_VIEW: // 47
writeSint16BE(outFile, ((act *) actListArr[i][j])->a47.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a47.objNumb);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a47.viewx);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a47.viewy);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a47.direction);
break;
case INIT_OBJ_FRAME: // 48
writeSint16BE(outFile, ((act *) actListArr[i][j])->a48.timer);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a48.objNumb);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a48.seqIndex);
writeSint16BE(outFile, ((act *) actListArr[i][j])->a48.frameIndex);
break;
case OLD_SONG: // 49, Added by Strangerke for DOS versions
writeSint16BE(outFile, ((act *) actListArr[i][j])->a49.timer);
writeUint16BE(outFile, ((act *) actListArr[i][j])->a49.songIndex);
break;
default:
printf("Unknown action %d", subElemType);
exit(-1);
}
}
}
}