2001-01-25 10:37:55 +01:00
|
|
|
|
/* vi: set ts=2:
|
|
|
|
|
*
|
2001-12-10 01:13:39 +01:00
|
|
|
|
*
|
2001-01-25 10:37:55 +01:00
|
|
|
|
* Eressea PB(E)M host Copyright (C) 1998-2000
|
|
|
|
|
* Christian Schlittchen (corwin@amber.kn-bremen.de)
|
|
|
|
|
* Katja Zedel (katze@felidae.kn-bremen.de)
|
|
|
|
|
* Henning Peters (faroul@beyond.kn-bremen.de)
|
|
|
|
|
* Enno Rehling (enno@eressea-pbem.de)
|
|
|
|
|
* Ingo Wilken (Ingo.Wilken@informatik.uni-oldenburg.de)
|
|
|
|
|
*
|
|
|
|
|
* based on:
|
|
|
|
|
*
|
|
|
|
|
* Atlantis v1.0 13 September 1993 Copyright 1993 by Russell Wallace
|
|
|
|
|
* Atlantis v1.7 Copyright 1996 by Alex Schr<EFBFBD>der
|
|
|
|
|
*
|
|
|
|
|
* This program may not be used, modified or distributed without
|
|
|
|
|
* prior permission by the authors of Eressea.
|
|
|
|
|
* This program may not be sold or used commercially without prior written
|
|
|
|
|
* permission from the authors.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#define LOCALE_CHECK
|
|
|
|
|
#ifdef __LCC__
|
|
|
|
|
#undef LOCALE_CHECK
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#include <config.h>
|
|
|
|
|
#include <eressea.h>
|
|
|
|
|
|
2001-02-03 14:45:35 +01:00
|
|
|
|
#include "korrektur.h"
|
|
|
|
|
|
2001-01-26 17:19:41 +01:00
|
|
|
|
/* initialization - TODO: init in separate module */
|
|
|
|
|
#include <attributes/attributes.h>
|
2001-02-03 14:45:35 +01:00
|
|
|
|
#include <spells/spells.h>
|
|
|
|
|
#include <triggers/triggers.h>
|
|
|
|
|
#include <items/items.h>
|
2001-01-26 17:19:41 +01:00
|
|
|
|
|
2001-01-25 10:37:55 +01:00
|
|
|
|
/* modules includes */
|
|
|
|
|
#include <modules/arena.h>
|
2002-01-09 09:20:33 +01:00
|
|
|
|
#include <modules/dungeon.h>
|
2001-01-25 10:37:55 +01:00
|
|
|
|
#include <modules/museum.h>
|
|
|
|
|
#include <modules/score.h>
|
|
|
|
|
#include <modules/xmas2000.h>
|
2001-01-30 21:26:06 +01:00
|
|
|
|
#include <modules/gmcmd.h>
|
2001-12-10 01:13:39 +01:00
|
|
|
|
#include <modules/infocmd.h>
|
2001-01-25 10:37:55 +01:00
|
|
|
|
|
|
|
|
|
/* gamecode includes */
|
|
|
|
|
#include <creation.h>
|
2001-12-10 01:13:39 +01:00
|
|
|
|
#include <economy.h>
|
2001-04-13 16:39:57 +02:00
|
|
|
|
#include <goodies.h>
|
2001-01-25 10:37:55 +01:00
|
|
|
|
#include <laws.h>
|
|
|
|
|
|
|
|
|
|
/* kernel includes */
|
|
|
|
|
#include <building.h>
|
|
|
|
|
#include <unit.h>
|
|
|
|
|
#include <message.h>
|
|
|
|
|
#include <teleport.h>
|
|
|
|
|
#include <faction.h>
|
2001-02-05 17:11:59 +01:00
|
|
|
|
#include <plane.h>
|
2001-01-25 10:37:55 +01:00
|
|
|
|
#include <race.h>
|
|
|
|
|
#include <reports.h>
|
- Neue Messages fertig
Messages werden jetzt in einem anderen Meta-Format (message* of
message_type*) gespeichert, das man in beliebige Formate (CR oder NR)
rendern kann. crmessage.c und nrmessage.c sind die render-engines dafür.
Die Messagetypen werden in res/{de,en}/messages.xml gesammelt, ultimativ
kann das aber durchaus eine einzelne Datei sein. Die ist derzeit nicht
wirklich xml (Umlaute drin, keine Definitionsdatei), aber gut lesbar.
- make_message
Diese Funktion ersetzt new_message, und ist etwas einfacher in der Syntax:
make_message("dumb_mistake", "unit region command", u, r, cmd) erzeugt
eine neue Nachricht, die dann einfach mit add_message wie bisher an die
Nachrichtenliste gehängt werden kann.
TODO: Messages könnte man durchaus reference-counten, und in mehrere Listen
einfügen, solang sie a) mehrfachverwendet (Kampf!) und b) vom Betrachter
unabhängig sind. Das spart einigen Speicher.
- CR Version erhöht.
Weil die MESSAGETYPES Blocks anders sind als früher
- OFFENSIVE_DELAY
Verbietet Einheiten, deren Partei eine Reigon niht bewachen, den
Angriff in der Region, wenn sie sich in der Runde zuvor bewegt haben.
Status der letzten Runde wird in neuem Attribut at_moved gespeichert.
- SHORT_ATTACKS
ein define, das angibt ob Kämpfen grundsätzlich keine lange Aktion ist.
- XML Parser
xml.[hc] enthält einen XML-Parser, dem man ein plugin mit callbacks
übergibt, die nach dem Parsen eines tokens aufgerufen werden.
2001-04-12 19:21:57 +02:00
|
|
|
|
#include <creport.h>
|
2001-02-05 17:11:59 +01:00
|
|
|
|
#include <region.h>
|
2001-12-10 01:13:39 +01:00
|
|
|
|
#include <resources.h>
|
2001-01-25 10:37:55 +01:00
|
|
|
|
#include <save.h>
|
2001-02-18 11:06:10 +01:00
|
|
|
|
#include <ship.h>
|
2001-01-25 10:37:55 +01:00
|
|
|
|
#include <border.h>
|
|
|
|
|
#include <region.h>
|
|
|
|
|
#include <item.h>
|
|
|
|
|
|
|
|
|
|
/* util includes */
|
|
|
|
|
#include <rand.h>
|
|
|
|
|
#include <base36.h>
|
|
|
|
|
|
|
|
|
|
/* libc includes */
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
#include <ctype.h>
|
|
|
|
|
#include <string.h>
|
2001-04-13 16:39:57 +02:00
|
|
|
|
#include <time.h>
|
2001-01-25 10:37:55 +01:00
|
|
|
|
#include <locale.h>
|
|
|
|
|
|
2001-12-10 01:13:39 +01:00
|
|
|
|
/**
|
2001-02-05 17:11:59 +01:00
|
|
|
|
** global variables we are importing from other modules
|
|
|
|
|
**/
|
2001-01-25 10:37:55 +01:00
|
|
|
|
extern char * g_reportdir;
|
|
|
|
|
extern char * g_datadir;
|
|
|
|
|
extern char * g_basedir;
|
2001-02-03 14:45:35 +01:00
|
|
|
|
extern char * g_resourcedir;
|
2001-12-10 01:13:39 +01:00
|
|
|
|
extern item_type * i_silver;
|
2001-01-25 10:37:55 +01:00
|
|
|
|
|
|
|
|
|
extern boolean nonr;
|
|
|
|
|
extern boolean nocr;
|
|
|
|
|
extern boolean nomer;
|
|
|
|
|
extern boolean nomsg;
|
|
|
|
|
extern boolean nobattle;
|
|
|
|
|
extern boolean nobattledebug;
|
2001-09-05 21:40:40 +02:00
|
|
|
|
extern boolean dirtyload;
|
|
|
|
|
|
2001-03-04 19:41:27 +01:00
|
|
|
|
static boolean printpotions;
|
2001-12-10 01:13:39 +01:00
|
|
|
|
static int insertfaction;
|
2001-01-25 10:37:55 +01:00
|
|
|
|
|
2001-04-13 16:39:57 +02:00
|
|
|
|
extern void debug_messagetypes(FILE * out);
|
2001-12-10 01:13:39 +01:00
|
|
|
|
extern void free_region(region * r);
|
2001-04-13 16:39:57 +02:00
|
|
|
|
extern void render_init(void);
|
2001-12-10 01:13:39 +01:00
|
|
|
|
extern void free_borders(void);
|
|
|
|
|
|
2001-04-13 16:39:57 +02:00
|
|
|
|
|
2001-02-05 17:11:59 +01:00
|
|
|
|
#ifdef FUZZY_BASE36
|
|
|
|
|
extern int fuzzy_hits;
|
|
|
|
|
#endif /* FUZZY_BASE36 */
|
|
|
|
|
|
2001-12-10 01:13:39 +01:00
|
|
|
|
/**
|
|
|
|
|
** global variables wthat we are exporting
|
2001-02-05 17:11:59 +01:00
|
|
|
|
**/
|
2001-04-13 16:39:57 +02:00
|
|
|
|
static char * orders = NULL;
|
2001-12-13 23:00:33 +01:00
|
|
|
|
static char * xmlfile = NULL;
|
2001-04-13 16:39:57 +02:00
|
|
|
|
static int nowrite = 0;
|
2001-09-05 21:40:40 +02:00
|
|
|
|
static boolean g_writemap = false;
|
2001-12-10 01:13:39 +01:00
|
|
|
|
static boolean g_killeiswald = false;
|
2001-04-13 16:39:57 +02:00
|
|
|
|
|
2001-02-05 17:11:59 +01:00
|
|
|
|
struct settings global = {
|
|
|
|
|
"Eressea", /* gamename */
|
2001-12-15 15:44:18 +01:00
|
|
|
|
"eressea", /* resourcepath */
|
2001-12-15 13:26:04 +01:00
|
|
|
|
1000, /* maxunits */
|
2001-02-05 17:11:59 +01:00
|
|
|
|
};
|
|
|
|
|
|
2001-09-05 21:40:40 +02:00
|
|
|
|
static int
|
|
|
|
|
crwritemap(void)
|
|
|
|
|
{
|
|
|
|
|
FILE * F = fopen("world.cr", "w+");
|
|
|
|
|
region * r;
|
|
|
|
|
for (r=regions;r;r=r->next) {
|
|
|
|
|
plane * p = rplane(r);
|
|
|
|
|
fprintf(F, "REGION %d %d %d\n", r->x, r->y, p?p->id:0);
|
|
|
|
|
fprintf(F, "\"%s\";Name\n\"%s\";Terrain\n", rname(r, default_locale), LOC(default_locale, terrain[rterrain(r)].name));
|
|
|
|
|
}
|
|
|
|
|
fclose(F);
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
2001-02-05 17:27:07 +01:00
|
|
|
|
static void
|
|
|
|
|
print_potions(FILE * F)
|
|
|
|
|
{
|
|
|
|
|
potion_type * p;
|
|
|
|
|
for (p=potiontypes;p;p=p->next) {
|
|
|
|
|
requirement * req = p->itype->construction->materials;
|
|
|
|
|
int i;
|
|
|
|
|
fprintf(F, "%s\n", locale_string(NULL, p->itype->rtype->_name[0]));
|
|
|
|
|
for (i=0;req[i].number;++i) {
|
|
|
|
|
fprintf(F, " %s\n", locale_string(NULL, resname(req[i].type, 0)));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2001-01-25 10:37:55 +01:00
|
|
|
|
|
|
|
|
|
static void
|
2001-02-05 17:11:59 +01:00
|
|
|
|
game_init(void)
|
2001-01-25 10:37:55 +01:00
|
|
|
|
{
|
2001-02-03 14:45:35 +01:00
|
|
|
|
init_triggers();
|
2001-01-25 10:37:55 +01:00
|
|
|
|
|
- Neue Messages fertig
Messages werden jetzt in einem anderen Meta-Format (message* of
message_type*) gespeichert, das man in beliebige Formate (CR oder NR)
rendern kann. crmessage.c und nrmessage.c sind die render-engines dafür.
Die Messagetypen werden in res/{de,en}/messages.xml gesammelt, ultimativ
kann das aber durchaus eine einzelne Datei sein. Die ist derzeit nicht
wirklich xml (Umlaute drin, keine Definitionsdatei), aber gut lesbar.
- make_message
Diese Funktion ersetzt new_message, und ist etwas einfacher in der Syntax:
make_message("dumb_mistake", "unit region command", u, r, cmd) erzeugt
eine neue Nachricht, die dann einfach mit add_message wie bisher an die
Nachrichtenliste gehängt werden kann.
TODO: Messages könnte man durchaus reference-counten, und in mehrere Listen
einfügen, solang sie a) mehrfachverwendet (Kampf!) und b) vom Betrachter
unabhängig sind. Das spart einigen Speicher.
- CR Version erhöht.
Weil die MESSAGETYPES Blocks anders sind als früher
- OFFENSIVE_DELAY
Verbietet Einheiten, deren Partei eine Reigon niht bewachen, den
Angriff in der Region, wenn sie sich in der Runde zuvor bewegt haben.
Status der letzten Runde wird in neuem Attribut at_moved gespeichert.
- SHORT_ATTACKS
ein define, das angibt ob Kämpfen grundsätzlich keine lange Aktion ist.
- XML Parser
xml.[hc] enthält einen XML-Parser, dem man ein plugin mit callbacks
übergibt, die nach dem Parsen eines tokens aufgerufen werden.
2001-04-12 19:21:57 +02:00
|
|
|
|
report_init();
|
|
|
|
|
creport_init();
|
|
|
|
|
|
2001-04-16 16:34:19 +02:00
|
|
|
|
debug_language("locales.log");
|
2002-01-09 09:20:33 +01:00
|
|
|
|
register_races();
|
|
|
|
|
register_resources();
|
2002-01-31 23:18:00 +01:00
|
|
|
|
register_ships();
|
2002-01-09 09:20:33 +01:00
|
|
|
|
register_items();
|
|
|
|
|
register_spells();
|
|
|
|
|
register_dungeon();
|
2001-12-10 01:13:39 +01:00
|
|
|
|
|
2001-12-13 23:00:33 +01:00
|
|
|
|
init_data(xmlfile?xmlfile:"eressea.xml");
|
2001-12-10 01:13:39 +01:00
|
|
|
|
init_locales();
|
|
|
|
|
|
2001-01-26 17:19:41 +01:00
|
|
|
|
init_attributes();
|
2002-01-09 09:20:33 +01:00
|
|
|
|
init_resources();
|
|
|
|
|
init_items();
|
2001-12-10 01:13:39 +01:00
|
|
|
|
init_economy();
|
2001-12-15 13:26:04 +01:00
|
|
|
|
#if NEW_RESOURCEGROWTH
|
2001-12-10 01:13:39 +01:00
|
|
|
|
init_rawmaterials();
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-01-30 21:26:06 +01:00
|
|
|
|
init_gmcmd();
|
2001-12-10 01:13:39 +01:00
|
|
|
|
init_info();
|
2001-01-25 10:37:55 +01:00
|
|
|
|
init_conversion();
|
|
|
|
|
|
|
|
|
|
init_museum();
|
|
|
|
|
init_arena();
|
|
|
|
|
init_xmas2000();
|
2001-02-14 02:38:51 +01:00
|
|
|
|
#ifdef REMOVE_THIS
|
2001-02-05 17:27:07 +01:00
|
|
|
|
render_init();
|
2001-02-14 02:38:51 +01:00
|
|
|
|
{
|
|
|
|
|
FILE * F = fopen("messagetypes.txt", "w");
|
|
|
|
|
debug_messagetypes(F);
|
|
|
|
|
fclose(F);
|
|
|
|
|
abort();
|
|
|
|
|
}
|
|
|
|
|
#endif
|
2001-03-04 19:41:27 +01:00
|
|
|
|
if (printpotions) {
|
|
|
|
|
FILE * F = fopen("recipes.txt", "w");
|
|
|
|
|
print_potions(F);
|
|
|
|
|
fclose(F);
|
|
|
|
|
}
|
2001-02-05 17:27:07 +01:00
|
|
|
|
}
|
|
|
|
|
|
2001-02-05 17:11:59 +01:00
|
|
|
|
static void
|
2001-01-25 10:37:55 +01:00
|
|
|
|
getgarbage(void)
|
|
|
|
|
{
|
|
|
|
|
faction *f;
|
|
|
|
|
|
|
|
|
|
/* Get rid of stuff that was only relevant last turn */
|
|
|
|
|
|
|
|
|
|
for (f = factions; f; f = f->next) {
|
|
|
|
|
/* memset(f->showdata, 0, sizeof f->showdata); */
|
|
|
|
|
|
|
|
|
|
freestrlist(f->mistakes);
|
|
|
|
|
f->mistakes = 0;
|
|
|
|
|
/* TODO: free msgs */
|
|
|
|
|
}
|
|
|
|
|
#if 0
|
|
|
|
|
for (r = regions; r; r = r->next) {
|
|
|
|
|
freestrlist(r->comments);
|
|
|
|
|
r->comments = 0;
|
|
|
|
|
freestrlist(r->botschaften);
|
|
|
|
|
r->botschaften = 0;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
2001-02-05 17:11:59 +01:00
|
|
|
|
static void
|
2001-01-25 10:37:55 +01:00
|
|
|
|
writepasswd(void)
|
|
|
|
|
{
|
2001-02-03 14:45:35 +01:00
|
|
|
|
FILE * F;
|
|
|
|
|
char zText[128];
|
2001-01-25 10:37:55 +01:00
|
|
|
|
|
2001-02-03 14:45:35 +01:00
|
|
|
|
sprintf(zText, "%s/passwd", basepath());
|
|
|
|
|
F = cfopen(zText, "w");
|
|
|
|
|
if (F) {
|
|
|
|
|
faction *f;
|
|
|
|
|
puts("Schreibe Passw<73>rter...");
|
|
|
|
|
|
|
|
|
|
for (f = factions; f; f = f->next) {
|
|
|
|
|
fprintf(F, "%s:%s:%s\n", factionid(f), f->email, f->passw);
|
|
|
|
|
}
|
|
|
|
|
fclose(F);
|
2001-01-25 10:37:55 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2001-02-05 17:11:59 +01:00
|
|
|
|
static int
|
2001-01-25 10:37:55 +01:00
|
|
|
|
processturn(char *filename)
|
|
|
|
|
{
|
|
|
|
|
struct summary * begin, * end;
|
2001-02-05 17:11:59 +01:00
|
|
|
|
int i;
|
|
|
|
|
|
2001-01-25 10:37:55 +01:00
|
|
|
|
begin = make_summary(false);
|
|
|
|
|
printf(" - Korrekturen Runde %d\n", turn);
|
|
|
|
|
korrektur();
|
|
|
|
|
turn++;
|
2001-02-05 17:11:59 +01:00
|
|
|
|
puts(" - entferne Texte der letzten Runde");
|
|
|
|
|
getgarbage();
|
|
|
|
|
puts(" - Nehme Korrekturen am Datenbestand vor");
|
|
|
|
|
if ((i=readorders(filename))!=0) return i;
|
2001-01-25 10:37:55 +01:00
|
|
|
|
#if BENCHMARK
|
2001-02-05 17:11:59 +01:00
|
|
|
|
exit(0);
|
2001-01-25 10:37:55 +01:00
|
|
|
|
#endif
|
2001-02-05 17:11:59 +01:00
|
|
|
|
processorders();
|
|
|
|
|
score();
|
2001-01-25 10:37:55 +01:00
|
|
|
|
#ifdef WACH_WAFF
|
|
|
|
|
remove_unequipped_guarded();
|
|
|
|
|
#endif
|
|
|
|
|
korrektur_end();
|
|
|
|
|
reports();
|
|
|
|
|
free_units();
|
|
|
|
|
puts(" - Beseitige leere Parteien");
|
|
|
|
|
remove_empty_factions();
|
|
|
|
|
end = make_summary(true);
|
|
|
|
|
report_summary(end, begin, false);
|
|
|
|
|
report_summary(end, begin, true);
|
|
|
|
|
free(end);
|
|
|
|
|
free(begin);
|
|
|
|
|
writepasswd();
|
|
|
|
|
#ifdef FUZZY_BASE36
|
|
|
|
|
fputs("==--------------------------==\n", stdout);
|
|
|
|
|
fprintf(stdout, "## fuzzy base10 hits: %5d ##\n", fuzzy_hits);
|
|
|
|
|
fputs("==--------------------------==\n", stdout);
|
|
|
|
|
#endif /* FUZZY_BASE36 */
|
|
|
|
|
if (!nowrite) {
|
|
|
|
|
char ztext[64];
|
2001-01-28 09:01:52 +01:00
|
|
|
|
sprintf(ztext, "%s/%d", datapath(), turn);
|
2001-01-25 10:37:55 +01:00
|
|
|
|
writegame(ztext, 0);
|
|
|
|
|
}
|
2001-02-05 17:11:59 +01:00
|
|
|
|
return 0;
|
2001-01-25 10:37:55 +01:00
|
|
|
|
}
|
|
|
|
|
|
2001-12-10 01:13:39 +01:00
|
|
|
|
#ifdef CLEANUP_CODE
|
2001-02-05 17:11:59 +01:00
|
|
|
|
static void
|
|
|
|
|
game_done(void)
|
2001-01-25 10:37:55 +01:00
|
|
|
|
{
|
|
|
|
|
/* Diese Routine enfernt allen allokierten Speicher wieder. Das ist nur
|
|
|
|
|
* zum Debugging interessant, wenn man Leak Detection hat, und nach
|
|
|
|
|
* nicht freigegebenem Speicher sucht, der nicht bis zum Ende ben<EFBFBD>tigt
|
|
|
|
|
* wird (tempor<EFBFBD>re Hilsstrukturen) */
|
|
|
|
|
unit *u, *u2;
|
|
|
|
|
region *r, *r2;
|
|
|
|
|
building *b, *b2;
|
|
|
|
|
faction *f, *f2;
|
|
|
|
|
ship *s, *s2;
|
|
|
|
|
|
|
|
|
|
free(used_faction_ids);
|
|
|
|
|
for (r = regions; r; r = r2) {
|
|
|
|
|
#if 0
|
|
|
|
|
msg * m = r->msgs;
|
|
|
|
|
while (m) {
|
|
|
|
|
msg * x = m;
|
|
|
|
|
m = m->next;
|
|
|
|
|
if (x->type->finalize) x->type->finalize(x);
|
|
|
|
|
free(x);
|
|
|
|
|
}
|
|
|
|
|
rm = rm->next;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
for (u = r->units; u; u = u2) {
|
|
|
|
|
u2 = u->next;
|
|
|
|
|
stripunit(u);
|
|
|
|
|
uunhash(u);
|
|
|
|
|
free(u);
|
|
|
|
|
}
|
|
|
|
|
for (b = r->buildings; b; b = b2) {
|
|
|
|
|
free(b->name);
|
|
|
|
|
free(b->display);
|
|
|
|
|
b2 = b->next;
|
|
|
|
|
free(b);
|
|
|
|
|
}
|
|
|
|
|
for (s = r->ships; s; s = s2) {
|
|
|
|
|
free(s->name);
|
|
|
|
|
free(s->display);
|
|
|
|
|
s2 = s->next;
|
|
|
|
|
free(s);
|
|
|
|
|
}
|
|
|
|
|
r2 = r->next;
|
2001-12-10 01:13:39 +01:00
|
|
|
|
free_region(r);
|
2001-01-25 10:37:55 +01:00
|
|
|
|
}
|
|
|
|
|
for (f = factions; f; f = f2) {
|
|
|
|
|
stripfaction(f);
|
|
|
|
|
f2 = f->next;
|
|
|
|
|
free(f);
|
|
|
|
|
}
|
|
|
|
|
while (planes) {
|
|
|
|
|
plane * pl = planes;
|
|
|
|
|
planes = planes->next;
|
|
|
|
|
free(pl);
|
|
|
|
|
}
|
|
|
|
|
#ifdef LEAK_DETECT
|
|
|
|
|
leak_report(stderr);
|
|
|
|
|
#endif
|
2001-02-05 17:11:59 +01:00
|
|
|
|
creport_cleanup();
|
- Neue Messages fertig
Messages werden jetzt in einem anderen Meta-Format (message* of
message_type*) gespeichert, das man in beliebige Formate (CR oder NR)
rendern kann. crmessage.c und nrmessage.c sind die render-engines dafür.
Die Messagetypen werden in res/{de,en}/messages.xml gesammelt, ultimativ
kann das aber durchaus eine einzelne Datei sein. Die ist derzeit nicht
wirklich xml (Umlaute drin, keine Definitionsdatei), aber gut lesbar.
- make_message
Diese Funktion ersetzt new_message, und ist etwas einfacher in der Syntax:
make_message("dumb_mistake", "unit region command", u, r, cmd) erzeugt
eine neue Nachricht, die dann einfach mit add_message wie bisher an die
Nachrichtenliste gehängt werden kann.
TODO: Messages könnte man durchaus reference-counten, und in mehrere Listen
einfügen, solang sie a) mehrfachverwendet (Kampf!) und b) vom Betrachter
unabhängig sind. Das spart einigen Speicher.
- CR Version erhöht.
Weil die MESSAGETYPES Blocks anders sind als früher
- OFFENSIVE_DELAY
Verbietet Einheiten, deren Partei eine Reigon niht bewachen, den
Angriff in der Region, wenn sie sich in der Runde zuvor bewegt haben.
Status der letzten Runde wird in neuem Attribut at_moved gespeichert.
- SHORT_ATTACKS
ein define, das angibt ob Kämpfen grundsätzlich keine lange Aktion ist.
- XML Parser
xml.[hc] enthält einen XML-Parser, dem man ein plugin mit callbacks
übergibt, die nach dem Parsen eines tokens aufgerufen werden.
2001-04-12 19:21:57 +02:00
|
|
|
|
report_cleanup();
|
2001-01-25 10:37:55 +01:00
|
|
|
|
}
|
2001-12-10 01:13:39 +01:00
|
|
|
|
#endif
|
2001-01-25 10:37:55 +01:00
|
|
|
|
|
|
|
|
|
#include "magic.h"
|
|
|
|
|
|
|
|
|
|
#if MALLOCDBG
|
2001-02-05 17:11:59 +01:00
|
|
|
|
static void
|
2001-01-25 10:37:55 +01:00
|
|
|
|
init_malloc_debug(void)
|
|
|
|
|
{
|
|
|
|
|
#if (defined(_MSC_VER))
|
|
|
|
|
# if MALLOCDBG == 2
|
|
|
|
|
# define CHECKON() _CrtSetDbgFlag(_CrtSetDbgFlag(_CRTDBG_REPORT_FLAG) | _CRTDBG_LEAK_CHECK_DF | _CRTDBG_DELAY_FREE_MEM_DF | _CRTDBG_CHECK_ALWAYS_DF)
|
|
|
|
|
# elif MALLOCDBG == 1
|
|
|
|
|
# define CHECKON() _CrtSetDbgFlag(_CrtSetDbgFlag(_CRTDBG_REPORT_FLAG) | _CRTDBG_ALLOC_MEM_DF | _CRTDBG_CHECK_CRT_DF | _CRTDBG_DELAY_FREE_MEM_DF)
|
|
|
|
|
# endif
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-02-05 17:11:59 +01:00
|
|
|
|
#if 0
|
2001-12-10 01:13:39 +01:00
|
|
|
|
static void
|
2001-02-05 17:11:59 +01:00
|
|
|
|
write_stats(void)
|
2001-01-25 10:37:55 +01:00
|
|
|
|
{
|
2001-02-05 17:11:59 +01:00
|
|
|
|
FILE * F;
|
|
|
|
|
char zText[MAX_PATH];
|
|
|
|
|
strcat(strcpy(zText, resourcepath()), "/spells");
|
|
|
|
|
F = fopen(zText, "wt");
|
|
|
|
|
if (F) {
|
|
|
|
|
int i, m = -1;
|
|
|
|
|
for (i=0;spelldaten[i].id;++i) {
|
|
|
|
|
if (spelldaten[i].magietyp!=m) {
|
|
|
|
|
m=spelldaten[i].magietyp;
|
|
|
|
|
fprintf(F, "\n%s\n", magietypen[m]);
|
|
|
|
|
}
|
|
|
|
|
fprintf(F, "%d\t%s\n", spelldaten[i].level, spelldaten[i].name);
|
|
|
|
|
}
|
|
|
|
|
fclose(F);
|
|
|
|
|
} else {
|
|
|
|
|
sprintf(buf, "fopen(%s): ", zText);
|
|
|
|
|
perror(buf);
|
|
|
|
|
}
|
|
|
|
|
strcat(strcpy(zText, resourcepath()), "/bonus");
|
|
|
|
|
F = fopen(buf, "wt");
|
|
|
|
|
if (F) {
|
|
|
|
|
race_t r;
|
|
|
|
|
for (r=0;r!=MAXRACES;++r) {
|
|
|
|
|
skill_t sk;
|
|
|
|
|
int i = 0;
|
|
|
|
|
fprintf(F, "const bonus %s_bonus = {\n\t", race[r].name[0]);
|
|
|
|
|
for (sk=0;sk!=MAXSKILLS;sk++) {
|
|
|
|
|
if (race[r].bonus[sk]) {
|
|
|
|
|
if (i==8) {
|
|
|
|
|
i = 0;
|
|
|
|
|
fputs("\n\t", F);
|
|
|
|
|
}
|
2001-04-16 16:34:19 +02:00
|
|
|
|
fprintf(F, "{ SK_%s, %d }, ", skillname(sk, NULL), race[r].bonus[sk]);
|
2001-02-05 17:11:59 +01:00
|
|
|
|
++i;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
fputs("{ SK_NONE, 0 }\n};\n", F);
|
|
|
|
|
}
|
|
|
|
|
fclose(F);
|
|
|
|
|
} else {
|
|
|
|
|
sprintf(buf, "fopen(%s): ", zText);
|
|
|
|
|
perror(zText);
|
|
|
|
|
}
|
|
|
|
|
}
|
2001-01-25 10:37:55 +01:00
|
|
|
|
#endif
|
|
|
|
|
|
2001-12-10 01:13:39 +01:00
|
|
|
|
static int
|
2001-02-05 17:11:59 +01:00
|
|
|
|
usage(const char * prog, const char * arg)
|
|
|
|
|
{
|
|
|
|
|
if (arg) {
|
|
|
|
|
fprintf(stderr, "unknown argument: %s\n\n", arg);
|
|
|
|
|
}
|
|
|
|
|
fprintf(stderr, "Usage: %s [options]\n"
|
|
|
|
|
"-x n : L<>dt nur die ersten n regionen\n"
|
|
|
|
|
"-f x y : L<>dt nur die regionen ab (x,y)\n"
|
|
|
|
|
"-v befehlsdatei : verarbeitet automatisch die angegebene Befehlsdatei\n"
|
|
|
|
|
"-d datadir : gibt das datenverzeichnis an\n"
|
|
|
|
|
"-b basedir : gibt das basisverzeichnis an\n"
|
|
|
|
|
"-r resdir : gibt das resourceverzeichnis an\n"
|
|
|
|
|
"-t turn : read this datafile, not the most current one\n"
|
|
|
|
|
"-o reportdir : gibt das reportverzeichnis an\n"
|
2001-03-04 19:41:27 +01:00
|
|
|
|
"-l logfile : specify an alternative logfile\n"
|
2001-12-10 01:13:39 +01:00
|
|
|
|
"--noeiswald : beruhigt ungemein\n"
|
2001-02-05 17:11:59 +01:00
|
|
|
|
"--nomsg : keine Messages (RAM sparen)\n"
|
|
|
|
|
"--nobattle : keine K<>mpfe\n"
|
|
|
|
|
"--nodebug : keine Logfiles f<>r K<>mpfe\n"
|
|
|
|
|
"--debug : schreibt Debug-Ausgaben in die Datei debug\n"
|
|
|
|
|
"--nocr : keine CRs\n"
|
|
|
|
|
"--nonr : keine Reports\n"
|
|
|
|
|
#ifdef USE_MERIAN
|
|
|
|
|
"--nomer : keine Meriankarten\n"
|
|
|
|
|
#endif
|
|
|
|
|
"--help : help\n", prog);
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
2001-01-25 10:37:55 +01:00
|
|
|
|
|
2001-02-05 17:11:59 +01:00
|
|
|
|
static int
|
|
|
|
|
read_args(int argc, char **argv)
|
|
|
|
|
{
|
|
|
|
|
int i;
|
|
|
|
|
for (i=1;i!=argc;++i) {
|
|
|
|
|
if (argv[i][0]!='-') {
|
|
|
|
|
return usage(argv[0], argv[i]);
|
|
|
|
|
} else if (argv[i][1]=='-') { /* long format */
|
|
|
|
|
if (strcmp(argv[i]+1, "nocr")==0) nocr = true;
|
|
|
|
|
else if (strcmp(argv[i]+2, "nosave")==0) nowrite = true;
|
2001-12-13 23:00:33 +01:00
|
|
|
|
else if (strcmp(argv[i]+2, "xml")==0) xmlfile = argv[++i];
|
2001-09-05 21:40:40 +02:00
|
|
|
|
else if (strcmp(argv[i]+2, "dirtyload")==0) dirtyload = true;
|
2001-02-05 17:11:59 +01:00
|
|
|
|
else if (strcmp(argv[i]+2, "nonr")==0) nonr = true;
|
2001-02-14 21:09:49 +01:00
|
|
|
|
else if (strcmp(argv[i]+2, "nocr")==0) nocr = true;
|
2001-02-05 17:11:59 +01:00
|
|
|
|
else if (strcmp(argv[i]+2, "nomsg")==0) nomsg = true;
|
2001-12-10 01:13:39 +01:00
|
|
|
|
else if (strcmp(argv[i]+2, "noeiswald")==0) g_killeiswald = true;
|
2001-02-05 17:11:59 +01:00
|
|
|
|
else if (strcmp(argv[i]+2, "nobattle")==0) nobattle = true;
|
|
|
|
|
else if (strcmp(argv[i]+2, "nodebug")==0) nobattledebug = true;
|
|
|
|
|
#ifdef USE_MERIAN
|
|
|
|
|
else if (strcmp(argv[i]+2, "nomer")==0) nomer = true;
|
|
|
|
|
#endif
|
2001-12-10 01:13:39 +01:00
|
|
|
|
else if (strcmp(argv[i]+2, "help")==0)
|
2001-02-05 17:11:59 +01:00
|
|
|
|
return usage(argv[0], NULL);
|
|
|
|
|
else
|
|
|
|
|
return usage(argv[0], argv[i]);
|
|
|
|
|
} else switch(argv[i][1]) {
|
2001-01-25 10:37:55 +01:00
|
|
|
|
case 'o':
|
|
|
|
|
g_reportdir = argv[++i];
|
|
|
|
|
break;
|
2001-03-04 19:41:27 +01:00
|
|
|
|
case 'D': /* DEBUG */
|
|
|
|
|
printpotions = true;
|
|
|
|
|
break;
|
2001-01-25 10:37:55 +01:00
|
|
|
|
case 'd':
|
|
|
|
|
g_datadir = argv[++i];
|
|
|
|
|
break;
|
2001-02-03 14:45:35 +01:00
|
|
|
|
case 'r':
|
|
|
|
|
g_resourcedir = argv[++i];
|
|
|
|
|
break;
|
2001-01-25 10:37:55 +01:00
|
|
|
|
case 'b':
|
|
|
|
|
g_basedir = argv[++i];
|
|
|
|
|
break;
|
|
|
|
|
case 't':
|
|
|
|
|
turn = atoi(argv[++i]);
|
|
|
|
|
break;
|
2001-12-10 01:13:39 +01:00
|
|
|
|
case 'i':
|
|
|
|
|
insertfaction = atoi36(argv[++i]);
|
|
|
|
|
break;
|
2001-01-25 10:37:55 +01:00
|
|
|
|
case 'f':
|
|
|
|
|
firstx = atoi(argv[++i]);
|
|
|
|
|
firsty = atoi(argv[++i]);
|
|
|
|
|
break;
|
|
|
|
|
case 'q':
|
|
|
|
|
quiet = 1;
|
|
|
|
|
break;
|
2001-02-05 17:11:59 +01:00
|
|
|
|
case 'v':
|
|
|
|
|
if (i<argc) orders = argv[++i];
|
|
|
|
|
else return usage(argv[0], argv[i]);
|
2001-01-25 10:37:55 +01:00
|
|
|
|
break;
|
|
|
|
|
case 'x':
|
|
|
|
|
maxregions = atoi(argv[++i]);
|
|
|
|
|
maxregions = (maxregions*81+80) / 81;
|
|
|
|
|
break;
|
2001-09-05 21:40:40 +02:00
|
|
|
|
case 'X':
|
|
|
|
|
dirtyload = true;
|
|
|
|
|
break;
|
2001-02-12 23:39:57 +01:00
|
|
|
|
case 'l':
|
|
|
|
|
log_open(argv[++i]);
|
|
|
|
|
break;
|
2001-09-05 21:40:40 +02:00
|
|
|
|
case 'w':
|
|
|
|
|
g_writemap = true;
|
|
|
|
|
break;
|
2001-02-05 17:11:59 +01:00
|
|
|
|
default:
|
|
|
|
|
usage(argv[0], argv[i]);
|
|
|
|
|
}
|
2001-01-25 10:37:55 +01:00
|
|
|
|
}
|
2001-02-05 17:11:59 +01:00
|
|
|
|
return 0;
|
|
|
|
|
}
|
2001-02-03 14:45:35 +01:00
|
|
|
|
|
2002-01-09 09:20:33 +01:00
|
|
|
|
#ifdef BETA_CODE
|
2001-12-10 01:13:39 +01:00
|
|
|
|
extern int xml_writeitems(const char * filename);
|
2002-01-09 09:20:33 +01:00
|
|
|
|
#endif
|
2001-12-10 01:13:39 +01:00
|
|
|
|
|
|
|
|
|
typedef struct lostdata {
|
|
|
|
|
int x, y;
|
|
|
|
|
int prevunit;
|
|
|
|
|
int building;
|
|
|
|
|
int ship;
|
|
|
|
|
} lostdata;
|
|
|
|
|
|
|
|
|
|
static unit * lostunits;
|
|
|
|
|
|
2001-02-05 17:11:59 +01:00
|
|
|
|
int
|
|
|
|
|
main(int argc, char *argv[])
|
|
|
|
|
{
|
|
|
|
|
int i;
|
|
|
|
|
char zText[MAX_PATH];
|
|
|
|
|
|
2001-12-30 12:27:58 +01:00
|
|
|
|
updatelog = fopen("update.log", "w");
|
2001-02-12 23:39:57 +01:00
|
|
|
|
log_open("eressea.log");
|
2001-02-05 17:11:59 +01:00
|
|
|
|
printf("\n%s PBEM host\n"
|
|
|
|
|
"Copyright (C) 1996-2001 C.Schlittchen, K.Zedel, E.Rehling, H.Peters.\n\n"
|
|
|
|
|
"Compilation: " __DATE__ " at " __TIME__ "\nVersion: %f\n\n", global.gamename, version());
|
|
|
|
|
|
|
|
|
|
setlocale(LC_ALL, "");
|
2001-12-10 01:13:39 +01:00
|
|
|
|
setlocale(LC_NUMERIC, "C");
|
2001-02-05 17:11:59 +01:00
|
|
|
|
#ifdef LOCALE_CHECK
|
|
|
|
|
if (!locale_check()) {
|
- Neue Messages fertig
Messages werden jetzt in einem anderen Meta-Format (message* of
message_type*) gespeichert, das man in beliebige Formate (CR oder NR)
rendern kann. crmessage.c und nrmessage.c sind die render-engines dafür.
Die Messagetypen werden in res/{de,en}/messages.xml gesammelt, ultimativ
kann das aber durchaus eine einzelne Datei sein. Die ist derzeit nicht
wirklich xml (Umlaute drin, keine Definitionsdatei), aber gut lesbar.
- make_message
Diese Funktion ersetzt new_message, und ist etwas einfacher in der Syntax:
make_message("dumb_mistake", "unit region command", u, r, cmd) erzeugt
eine neue Nachricht, die dann einfach mit add_message wie bisher an die
Nachrichtenliste gehängt werden kann.
TODO: Messages könnte man durchaus reference-counten, und in mehrere Listen
einfügen, solang sie a) mehrfachverwendet (Kampf!) und b) vom Betrachter
unabhängig sind. Das spart einigen Speicher.
- CR Version erhöht.
Weil die MESSAGETYPES Blocks anders sind als früher
- OFFENSIVE_DELAY
Verbietet Einheiten, deren Partei eine Reigon niht bewachen, den
Angriff in der Region, wenn sie sich in der Runde zuvor bewegt haben.
Status der letzten Runde wird in neuem Attribut at_moved gespeichert.
- SHORT_ATTACKS
ein define, das angibt ob Kämpfen grundsätzlich keine lange Aktion ist.
- XML Parser
xml.[hc] enthält einen XML-Parser, dem man ein plugin mit callbacks
übergibt, die nach dem Parsen eines tokens aufgerufen werden.
2001-04-12 19:21:57 +02:00
|
|
|
|
log_error(("The current locale is not suitable for international Eressea.\n"));
|
2001-02-05 17:11:59 +01:00
|
|
|
|
return -1;
|
|
|
|
|
}
|
2001-02-03 14:45:35 +01:00
|
|
|
|
#endif
|
2001-01-25 10:37:55 +01:00
|
|
|
|
#if MALLOCDBG
|
2001-02-05 17:11:59 +01:00
|
|
|
|
init_malloc_debug();
|
2001-01-25 10:37:55 +01:00
|
|
|
|
#endif
|
|
|
|
|
|
2001-02-05 17:11:59 +01:00
|
|
|
|
if ((i=read_args(argc, argv))!=0) return i;
|
2001-01-25 10:37:55 +01:00
|
|
|
|
|
2001-02-05 17:11:59 +01:00
|
|
|
|
printf(
|
|
|
|
|
"version %d.%d\n"
|
|
|
|
|
"turn %d.\n"
|
|
|
|
|
"orders %s.\n",
|
|
|
|
|
global.data_version / 10, global.data_version % 10, turn, orders);
|
2001-01-25 10:37:55 +01:00
|
|
|
|
|
2001-02-05 17:11:59 +01:00
|
|
|
|
strcat(strcpy(zText, resourcepath()), "/timestrings");
|
|
|
|
|
if ((i=read_datenames(zText))!=0) return i;
|
2001-01-25 10:37:55 +01:00
|
|
|
|
|
2001-02-05 17:11:59 +01:00
|
|
|
|
kernel_init();
|
|
|
|
|
game_init();
|
2002-01-09 09:20:33 +01:00
|
|
|
|
#if defined(BETA_CODE) && 0
|
2002-01-31 23:18:00 +01:00
|
|
|
|
xml_writeships();
|
|
|
|
|
/* xml_writeitems("items.xml"); */
|
2001-12-10 01:13:39 +01:00
|
|
|
|
return 0;
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
if (insertfaction) {
|
|
|
|
|
faction * lostf;
|
|
|
|
|
unit *ulost, **ulostp = &lostunits;
|
|
|
|
|
faction **fp = &factions;
|
|
|
|
|
region **rp = ®ions;
|
|
|
|
|
|
|
|
|
|
if ((i=readgame(false))!=0) return i;
|
2002-01-05 17:14:38 +01:00
|
|
|
|
|
2001-12-10 01:13:39 +01:00
|
|
|
|
lostf = findfaction(insertfaction);
|
|
|
|
|
lostf->lastorders = turn;
|
|
|
|
|
lostf->allies = NULL;
|
|
|
|
|
lostf->groups = NULL;
|
|
|
|
|
|
|
|
|
|
free(used_faction_ids);
|
|
|
|
|
while (*rp) {
|
|
|
|
|
building *b, *b2;
|
|
|
|
|
ship *s, *s2;
|
|
|
|
|
region *r = *rp;
|
|
|
|
|
int prevunit = 0;
|
|
|
|
|
unit ** up = &r->units;
|
|
|
|
|
while(*up) {
|
|
|
|
|
unit * u = *up;
|
|
|
|
|
if (u->faction != lostf) {
|
|
|
|
|
*up = u->next;
|
|
|
|
|
prevunit = u->no;
|
|
|
|
|
stripunit(u);
|
|
|
|
|
uunhash(u);
|
|
|
|
|
free(u);
|
|
|
|
|
} else {
|
|
|
|
|
lostdata * ld = calloc(sizeof(lostdata), 1);
|
|
|
|
|
ld->x = r->x;
|
|
|
|
|
ld->y = r->y;
|
|
|
|
|
ld->ship = u->ship?u->ship->no:0;
|
|
|
|
|
ld->building = u->building?u->building->no:0;
|
|
|
|
|
ld->prevunit = prevunit;
|
|
|
|
|
u->building = (building*)ld; /* hack */
|
|
|
|
|
u->ship = NULL;
|
|
|
|
|
u->region = NULL;
|
|
|
|
|
u->items = i_new(i_silver, 10);
|
|
|
|
|
prevunit = u->no;
|
|
|
|
|
*ulostp = u;
|
|
|
|
|
ulostp = &u->next;
|
|
|
|
|
up = &u->next;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
for (b = r->buildings; b; b = b2) {
|
|
|
|
|
bunhash(b);
|
|
|
|
|
free(b->name);
|
|
|
|
|
free(b->display);
|
|
|
|
|
b2 = b->next;
|
|
|
|
|
free(b);
|
|
|
|
|
}
|
|
|
|
|
for (s = r->ships; s; s = s2) {
|
|
|
|
|
sunhash(s);
|
|
|
|
|
free(s->name);
|
|
|
|
|
free(s->display);
|
|
|
|
|
s2 = s->next;
|
|
|
|
|
free(s);
|
|
|
|
|
}
|
|
|
|
|
*rp = r->next;
|
|
|
|
|
free_region(r);
|
|
|
|
|
}
|
|
|
|
|
while (*fp) {
|
|
|
|
|
faction * f = *fp;
|
|
|
|
|
if (f!=lostf) {
|
|
|
|
|
stripfaction(f);
|
|
|
|
|
*fp = f->next;
|
|
|
|
|
free(f);
|
|
|
|
|
} else {
|
|
|
|
|
fp = &f->next;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
while (planes) {
|
|
|
|
|
plane * pl = planes;
|
|
|
|
|
planes = planes->next;
|
|
|
|
|
free(pl);
|
|
|
|
|
}
|
|
|
|
|
free_borders();
|
|
|
|
|
|
|
|
|
|
++turn;
|
|
|
|
|
if ((i=readgame(false))!=0) return i;
|
|
|
|
|
|
|
|
|
|
ulost=lostunits;
|
|
|
|
|
while (ulost) {
|
|
|
|
|
unit * u = ulost;
|
|
|
|
|
lostdata * ld = (lostdata*)u->building;
|
|
|
|
|
region * r = findregion(ld->x, ld->y);
|
|
|
|
|
ulost = u->next;
|
|
|
|
|
|
|
|
|
|
u->items = NULL;
|
|
|
|
|
if (r) {
|
|
|
|
|
unit ** up = &r->units;
|
|
|
|
|
u->region = r;
|
|
|
|
|
if (ld->prevunit) {
|
|
|
|
|
while (*up && (*up)->no!=ld->prevunit) up = &(*up)->next;
|
|
|
|
|
if (*up) up=&(*up)->next;
|
|
|
|
|
}
|
|
|
|
|
u->next = *up;
|
|
|
|
|
*up = u;
|
|
|
|
|
if (ld->building) {
|
|
|
|
|
building * b = r->buildings;
|
|
|
|
|
while (b && b->no!=ld->building) b = b->next;
|
|
|
|
|
if (b) u->building = b;
|
|
|
|
|
}
|
|
|
|
|
if (ld->ship) {
|
|
|
|
|
ship * s = r->ships;
|
|
|
|
|
while (s && s->no!=ld->ship) s = s->next;
|
|
|
|
|
if (s) u->ship = s;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (!nowrite) {
|
|
|
|
|
char ztext[64];
|
|
|
|
|
sprintf(ztext, "%s/%d.fix", datapath(), turn);
|
|
|
|
|
writegame(ztext, 0);
|
|
|
|
|
}
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
2001-02-05 17:11:59 +01:00
|
|
|
|
if ((i=readgame(false))!=0) return i;
|
2002-01-20 15:00:07 +01:00
|
|
|
|
#ifdef BETA_CODE
|
2002-01-09 09:20:33 +01:00
|
|
|
|
if (dungeonstyles) {
|
|
|
|
|
struct dungeon * d = dungeonstyles;
|
|
|
|
|
struct region * r = make_dungeon(d);
|
|
|
|
|
make_dungeongate(findregion(0, 0), r, d);
|
|
|
|
|
}
|
2002-01-20 15:00:07 +01:00
|
|
|
|
#endif
|
2001-12-10 01:13:39 +01:00
|
|
|
|
writepasswd();
|
|
|
|
|
if (g_killeiswald) {
|
|
|
|
|
region * r = findregion(0, 25);
|
|
|
|
|
if (r) {
|
|
|
|
|
/* mach sie alle zur schnecke... */
|
|
|
|
|
unit * u;
|
|
|
|
|
terraform(r, T_OCEAN);
|
|
|
|
|
for (u=r->units;u;u=u->next) scale_number(u, 1);
|
|
|
|
|
}
|
|
|
|
|
}
|
2002-01-01 21:51:18 +01:00
|
|
|
|
if (g_writemap) return crwritemap();
|
2002-01-01 22:37:59 +01:00
|
|
|
|
/* {
|
|
|
|
|
* faction * monster = findfaction(MONSTER_FACTION);
|
|
|
|
|
* display_item(monster, monster->units, it_find("mistletoe"));
|
|
|
|
|
* }
|
|
|
|
|
* */
|
2001-02-05 17:11:59 +01:00
|
|
|
|
if ((i=processturn(orders))!=0) return i;
|
2001-01-25 10:37:55 +01:00
|
|
|
|
|
2001-12-10 01:13:39 +01:00
|
|
|
|
#ifdef CLEANUP_CODE
|
|
|
|
|
game_done();
|
|
|
|
|
#endif
|
2001-02-05 17:11:59 +01:00
|
|
|
|
kernel_done();
|
2001-02-12 23:39:57 +01:00
|
|
|
|
log_close();
|
2001-12-30 12:27:58 +01:00
|
|
|
|
fclose(updatelog);
|
2001-01-25 10:37:55 +01:00
|
|
|
|
return 0;
|
|
|
|
|
}
|