+/*
+ * 'cheat' is a tool for generating save game files to test states that ought
+ * not happen. It leverages chunks of advent, mostly initialize() and
+ * savefile(), so we know we're always outputing save files that advent
+ * can import.
+ */
#include <getopt.h>
#include <stdlib.h>
#include <stdio.h>
#include <stdbool.h>
-#include <time.h>
#include "advent.h"
-#include "dungeon.h"
-FILE *logfp = NULL, *rfp = NULL;
+FILE *logfp = NULL;
bool oldstyle = false;
bool prompt = true;
long numdie = 0;
long saved = 1;
long version = 0;
+ FILE *fp = NULL;
/* Options. */
const char* opts = "d:s:v:o:";
- const char* usage = "Usage: %s [-d numdie] [-s numsaves] [-v version] -o savefilename \n";
+ const char* usage = "Usage: %s [-d numdie] [-s numsaves] [-v version] -o savefilename \n"
+ " -d number of deaths. Signed integer value.\n"
+ " -s number of saves. Signed integer value.\n"
+ " -v version number of save format.\n"
+ " -o required. File name of save game to write.\n";
+
while ((ch = getopt(argc, argv, opts)) != EOF) {
switch (ch) {
case 'd':
default:
fprintf(stderr,
usage, argv[0]);
- fprintf(stderr,
- " -d number of deaths. Signed integer value.'\n");
- fprintf(stderr,
- " -s number of saves. Signed integer value.\n");
- fprintf(stderr,
- " -v version number of save format.\n");
- fprintf(stderr,
- " -o file name of save game to write.\n");
exit(EXIT_FAILURE);
break;
}
}
+ // Save filename required; the point of cheat is to generate save file
if (savefilename == NULL) {
fprintf(stderr,
usage, argv[0]);
exit(EXIT_FAILURE);
}
- FILE *fp = NULL;
-
- /* Initialize game variables */
+ // Initialize game variables
initialise();
- make_zzword(game.zzword);
-
// apply cheats
game.numdie = numdie;
game.saved = saved;
savefile(fp, version);
printf("cheat: %s created.\n", savefilename);
- return 0;
+
+ return EXIT_SUCCESS;
}