2003-11-10 00:36:11 +01:00
|
|
|
|
/* vi: set ts=2:
|
|
|
|
|
*
|
|
|
|
|
*
|
2003-12-14 11:10:30 +01:00
|
|
|
|
* Eressea PB(E)M host Copyright (C) 1998-2003
|
2003-11-10 00:36:11 +01:00
|
|
|
|
* 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
|
|
|
|
|
|
2003-12-14 11:10:30 +01:00
|
|
|
|
/* config includes */
|
2003-11-10 00:36:11 +01:00
|
|
|
|
#include <config.h>
|
|
|
|
|
#include <eressea.h>
|
|
|
|
|
|
|
|
|
|
#include "korrektur.h"
|
|
|
|
|
|
|
|
|
|
/* initialization - TODO: init in separate module */
|
|
|
|
|
#include <attributes/attributes.h>
|
2003-12-14 11:10:30 +01:00
|
|
|
|
#include <spells/spells.h>
|
2003-11-10 00:36:11 +01:00
|
|
|
|
#include <triggers/triggers.h>
|
|
|
|
|
#include <items/items.h>
|
|
|
|
|
|
|
|
|
|
/* modules includes */
|
2003-12-14 11:10:30 +01:00
|
|
|
|
#ifdef DUNGEON_MODULE
|
2003-11-10 00:36:11 +01:00
|
|
|
|
#include <modules/dungeon.h>
|
2003-12-14 11:10:30 +01:00
|
|
|
|
#endif
|
2003-11-10 00:36:11 +01:00
|
|
|
|
#include <modules/score.h>
|
2003-12-14 11:10:30 +01:00
|
|
|
|
#include <modules/xmas.h>
|
2003-11-10 00:36:11 +01:00
|
|
|
|
#include <modules/gmcmd.h>
|
2003-12-14 11:10:30 +01:00
|
|
|
|
#include <modules/infocmd.h>
|
|
|
|
|
#ifdef MUSEUM_MODULE
|
|
|
|
|
#include <modules/museum.h>
|
|
|
|
|
#endif
|
2004-02-21 23:25:00 +01:00
|
|
|
|
#ifdef WORMHOLE_MODULE
|
|
|
|
|
#include <modules/wormhole.h>
|
|
|
|
|
#endif
|
2003-12-14 11:10:30 +01:00
|
|
|
|
#ifdef ARENA_MODULE
|
|
|
|
|
#include <modules/arena.h>
|
2003-11-10 00:36:11 +01:00
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
/* gamecode includes */
|
|
|
|
|
#include <economy.h>
|
|
|
|
|
#include <goodies.h>
|
|
|
|
|
#include <laws.h>
|
|
|
|
|
|
|
|
|
|
/* kernel includes */
|
|
|
|
|
#include <building.h>
|
2003-12-14 11:10:30 +01:00
|
|
|
|
#include <creport.h>
|
2003-11-10 00:36:11 +01:00
|
|
|
|
#include <faction.h>
|
|
|
|
|
#include <message.h>
|
|
|
|
|
#include <plane.h>
|
|
|
|
|
#include <race.h>
|
|
|
|
|
#include <skill.h>
|
|
|
|
|
#include <teleport.h>
|
|
|
|
|
#include <unit.h>
|
|
|
|
|
#include <region.h>
|
|
|
|
|
#include <reports.h>
|
|
|
|
|
#include <resources.h>
|
|
|
|
|
#include <save.h>
|
|
|
|
|
#include <ship.h>
|
|
|
|
|
#include <border.h>
|
|
|
|
|
#include <region.h>
|
|
|
|
|
#include <item.h>
|
|
|
|
|
|
|
|
|
|
/* util includes */
|
2003-12-15 23:59:15 +01:00
|
|
|
|
#include <util/rand.h>
|
|
|
|
|
#include <util/log.h>
|
|
|
|
|
#include <util/sql.h>
|
|
|
|
|
#include <util/base36.h>
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
|
|
|
|
/* lua includes */
|
|
|
|
|
#include "lua/bindings.h"
|
|
|
|
|
#include <lua.hpp>
|
|
|
|
|
#include <luabind/luabind.hpp>
|
|
|
|
|
|
|
|
|
|
/* libc includes */
|
|
|
|
|
#include <cstdio>
|
|
|
|
|
#include <cstdlib>
|
|
|
|
|
#include <cctype>
|
|
|
|
|
#include <cstring>
|
|
|
|
|
#include <ctime>
|
|
|
|
|
#include <clocale>
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
** global variables we are importing from other modules
|
|
|
|
|
**/
|
|
|
|
|
extern "C" {
|
2003-12-14 11:10:30 +01:00
|
|
|
|
extern char * g_reportdir;
|
|
|
|
|
extern char * g_datadir;
|
|
|
|
|
extern char * g_basedir;
|
|
|
|
|
extern char * g_resourcedir;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
extern item_type * i_silver;
|
|
|
|
|
|
|
|
|
|
extern boolean nonr;
|
|
|
|
|
extern boolean nocr;
|
|
|
|
|
extern boolean noreports;
|
|
|
|
|
extern boolean nomer;
|
|
|
|
|
extern boolean nomsg;
|
|
|
|
|
extern boolean nobattle;
|
2003-12-14 11:10:30 +01:00
|
|
|
|
extern boolean nomonsters;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
extern boolean nobattledebug;
|
|
|
|
|
extern boolean dirtyload;
|
|
|
|
|
|
2003-12-14 11:10:30 +01:00
|
|
|
|
extern int demonfix;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
extern int loadplane;
|
|
|
|
|
|
|
|
|
|
extern void debug_messagetypes(FILE * out);
|
|
|
|
|
extern void free_region(region * r);
|
|
|
|
|
extern void render_init(void);
|
|
|
|
|
extern void free_borders(void);
|
2003-12-14 11:10:30 +01:00
|
|
|
|
extern boolean opt_cr_absolute_coords;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
2003-12-14 11:10:30 +01:00
|
|
|
|
#ifdef FUZZY_BASE36
|
|
|
|
|
extern int fuzzy_hits;
|
|
|
|
|
#endif /* FUZZY_BASE36 */
|
|
|
|
|
}
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
|
|
|
|
/**
|
2003-12-14 11:10:30 +01:00
|
|
|
|
** global variables that we are exporting
|
2003-11-10 00:36:11 +01:00
|
|
|
|
**/
|
|
|
|
|
static char * orders = NULL;
|
|
|
|
|
static int nowrite = 0;
|
|
|
|
|
static boolean g_writemap = false;
|
2003-12-14 11:10:30 +01:00
|
|
|
|
static boolean opt_reportonly = false;
|
2003-12-14 17:34:00 +01:00
|
|
|
|
static const char * luafile = "default.lua";
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
|
|
|
|
struct settings global = {
|
|
|
|
|
"Eressea", /* gamename */
|
|
|
|
|
"eressea", /* resourcepath */
|
|
|
|
|
1000, /* maxunits */
|
|
|
|
|
};
|
|
|
|
|
|
magicskillboost
-- implementiert. Kann nur einmal pro Partei verwendet werden, und nur von einem Magier. Müssen wir erklären.
Amulett des wahren Sehens und Ring der Unsichtbarkeit geben lediglich einen Bonus auf Wahrnehmung (+2) und Tarnung (+4).
-- das define war nicht aktiviert
Halblinge haben Armbrustschiessen +0 (statt +1).
-- spearates Rassenfile für WDW
Es gibt spezielle Regeln für Allianzen, und der HELFE und KONTAKTIERE Befehl sind eingeschränkt. Konkret kann kein HELP_FIGHT HELP_GUARD HELP_FSTEALTH HELP_MONEY gegeben werden (die anderen sind erlaubt).
-- mit #defeine ALLIES_ONLY definiert
Jede Allianz kann bis zu 15 Magier und 15 Alchemisten haben. Jede einzelne Partei der Allianz kann dabei nicht mehr als 15/Anzahl_Parteien (aufgerundet) Magier bzw. Alchemisten haben, und die Gesamtsumme darf 15 nicht übersteigen.
-- mit #define ALLIANCE_LIMITS gemacht.
Die Startgeschenke (Personen, Silber, ...) werden pro Allianz, nicht pro Spieler verteilt. Größere Allianzen bekommen also weniger pro Spieler.
-- Nochmal geändert: Die Allianzen kriegen jede 168 Personen zum Start, weil sich das gut aufteilen lässt. Das wird auf 28 Einheiten pro Partei gesplittet, jede Einheit hat eines der Talente, außer der Starteinheit, die hat den magicskillboost. Einige Skills kommen öfter vor als andere, das ist nicht einfach vermeidbar. Sollte aber auch wurscht sein, es geht primär darum, lehren zu können.
Es gibt ein Einheitenlimit von 1000 Einheiten pro Allianz.
-- die Regel sparen wir uns einfach mal.
2003-12-14 22:45:47 +01:00
|
|
|
|
#if 0
|
2003-11-10 00:36:11 +01: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);
|
2003-12-14 11:10:30 +01:00
|
|
|
|
fprintf(F, "\"%s\";Name\n\"%s\";Terrain\n", rname(r, default_locale), LOC(default_locale, terrain[rterrain(r)].name));
|
2003-11-10 00:36:11 +01:00
|
|
|
|
}
|
|
|
|
|
fclose(F);
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
magicskillboost
-- implementiert. Kann nur einmal pro Partei verwendet werden, und nur von einem Magier. Müssen wir erklären.
Amulett des wahren Sehens und Ring der Unsichtbarkeit geben lediglich einen Bonus auf Wahrnehmung (+2) und Tarnung (+4).
-- das define war nicht aktiviert
Halblinge haben Armbrustschiessen +0 (statt +1).
-- spearates Rassenfile für WDW
Es gibt spezielle Regeln für Allianzen, und der HELFE und KONTAKTIERE Befehl sind eingeschränkt. Konkret kann kein HELP_FIGHT HELP_GUARD HELP_FSTEALTH HELP_MONEY gegeben werden (die anderen sind erlaubt).
-- mit #defeine ALLIES_ONLY definiert
Jede Allianz kann bis zu 15 Magier und 15 Alchemisten haben. Jede einzelne Partei der Allianz kann dabei nicht mehr als 15/Anzahl_Parteien (aufgerundet) Magier bzw. Alchemisten haben, und die Gesamtsumme darf 15 nicht übersteigen.
-- mit #define ALLIANCE_LIMITS gemacht.
Die Startgeschenke (Personen, Silber, ...) werden pro Allianz, nicht pro Spieler verteilt. Größere Allianzen bekommen also weniger pro Spieler.
-- Nochmal geändert: Die Allianzen kriegen jede 168 Personen zum Start, weil sich das gut aufteilen lässt. Das wird auf 28 Einheiten pro Partei gesplittet, jede Einheit hat eines der Talente, außer der Starteinheit, die hat den magicskillboost. Einige Skills kommen öfter vor als andere, das ist nicht einfach vermeidbar. Sollte aber auch wurscht sein, es geht primär darum, lehren zu können.
Es gibt ein Einheitenlimit von 1000 Einheiten pro Allianz.
-- die Regel sparen wir uns einfach mal.
2003-12-14 22:45:47 +01:00
|
|
|
|
#endif
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
game_init(void)
|
|
|
|
|
{
|
|
|
|
|
init_triggers();
|
2003-12-14 11:10:30 +01:00
|
|
|
|
init_xmas();
|
2003-11-10 00:36:11 +01:00
|
|
|
|
report_init();
|
|
|
|
|
creport_init();
|
|
|
|
|
|
|
|
|
|
debug_language("locales.log");
|
|
|
|
|
register_races();
|
|
|
|
|
register_resources();
|
|
|
|
|
register_buildings();
|
|
|
|
|
register_ships();
|
|
|
|
|
register_items();
|
|
|
|
|
register_spells();
|
2003-12-14 11:10:30 +01:00
|
|
|
|
#ifdef DUNGEON_MODULE
|
|
|
|
|
register_dungeon();
|
2003-11-10 00:36:11 +01:00
|
|
|
|
#endif
|
|
|
|
|
|
2004-01-18 21:29:47 +01:00
|
|
|
|
init_data(xmlfile);
|
2003-11-10 00:36:11 +01:00
|
|
|
|
init_locales();
|
|
|
|
|
|
|
|
|
|
init_attributes();
|
|
|
|
|
init_resources();
|
|
|
|
|
init_items();
|
|
|
|
|
init_economy();
|
2003-12-14 11:10:30 +01:00
|
|
|
|
#if NEW_RESOURCEGROWTH
|
2003-11-10 00:36:11 +01:00
|
|
|
|
init_rawmaterials();
|
2003-12-14 11:10:30 +01:00
|
|
|
|
#endif
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
|
|
|
|
init_gmcmd();
|
|
|
|
|
init_info();
|
|
|
|
|
init_conversion();
|
|
|
|
|
|
2003-12-14 11:10:30 +01:00
|
|
|
|
#ifdef MUSEUM_MODULE
|
|
|
|
|
register_museum();
|
|
|
|
|
#endif
|
|
|
|
|
#ifdef ARENA_MODULE
|
|
|
|
|
register_arena();
|
|
|
|
|
#endif
|
2004-02-21 23:25:00 +01:00
|
|
|
|
#ifdef WORMHOLE_MODULE
|
|
|
|
|
register_wormholes();
|
|
|
|
|
#endif
|
|
|
|
|
|
2003-11-10 00:36:11 +01:00
|
|
|
|
#ifdef REMOVE_THIS
|
|
|
|
|
render_init();
|
|
|
|
|
{
|
|
|
|
|
FILE * F = fopen("messagetypes.txt", "w");
|
|
|
|
|
debug_messagetypes(F);
|
|
|
|
|
fclose(F);
|
|
|
|
|
abort();
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
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
|
|
|
|
|
}
|
|
|
|
|
|
2003-12-14 11:10:30 +01:00
|
|
|
|
#ifdef SHORTPWDS
|
|
|
|
|
static void
|
|
|
|
|
readshortpwds()
|
|
|
|
|
{
|
|
|
|
|
FILE * F;
|
|
|
|
|
char zText[MAX_PATH];
|
|
|
|
|
sprintf(zText, "%s/%s.%u", basepath(), "shortpwds", turn);
|
|
|
|
|
|
|
|
|
|
F = fopen(zText, "r");
|
|
|
|
|
if (F==NULL) {
|
|
|
|
|
log_error(("could not open password file %s", zText));
|
|
|
|
|
} else {
|
|
|
|
|
while (!feof(F)) {
|
|
|
|
|
faction * f;
|
|
|
|
|
char passwd[16], faction[5], email[64];
|
|
|
|
|
fscanf(F, "%s %s %s\n", faction, passwd, email);
|
|
|
|
|
f = findfaction(atoi36(faction));
|
|
|
|
|
if (f!=NULL) {
|
|
|
|
|
shortpwd * pwd = (shortpwd*)malloc(sizeof(shortpwd));
|
|
|
|
|
pwd->email = strdup(email);
|
|
|
|
|
pwd->pwd = strdup(passwd);
|
|
|
|
|
pwd->used = false;
|
|
|
|
|
pwd->next = f->shortpwds;
|
|
|
|
|
f->shortpwds = pwd;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
fclose(F);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
2003-12-14 17:34:00 +01:00
|
|
|
|
lua_State *
|
2003-11-10 00:36:11 +01:00
|
|
|
|
lua_init(void)
|
|
|
|
|
{
|
2003-12-14 17:34:00 +01:00
|
|
|
|
lua_State * luaState = lua_open();
|
2003-11-10 00:36:11 +01:00
|
|
|
|
luaopen_base(luaState);
|
magicskillboost
-- implementiert. Kann nur einmal pro Partei verwendet werden, und nur von einem Magier. Müssen wir erklären.
Amulett des wahren Sehens und Ring der Unsichtbarkeit geben lediglich einen Bonus auf Wahrnehmung (+2) und Tarnung (+4).
-- das define war nicht aktiviert
Halblinge haben Armbrustschiessen +0 (statt +1).
-- spearates Rassenfile für WDW
Es gibt spezielle Regeln für Allianzen, und der HELFE und KONTAKTIERE Befehl sind eingeschränkt. Konkret kann kein HELP_FIGHT HELP_GUARD HELP_FSTEALTH HELP_MONEY gegeben werden (die anderen sind erlaubt).
-- mit #defeine ALLIES_ONLY definiert
Jede Allianz kann bis zu 15 Magier und 15 Alchemisten haben. Jede einzelne Partei der Allianz kann dabei nicht mehr als 15/Anzahl_Parteien (aufgerundet) Magier bzw. Alchemisten haben, und die Gesamtsumme darf 15 nicht übersteigen.
-- mit #define ALLIANCE_LIMITS gemacht.
Die Startgeschenke (Personen, Silber, ...) werden pro Allianz, nicht pro Spieler verteilt. Größere Allianzen bekommen also weniger pro Spieler.
-- Nochmal geändert: Die Allianzen kriegen jede 168 Personen zum Start, weil sich das gut aufteilen lässt. Das wird auf 28 Einheiten pro Partei gesplittet, jede Einheit hat eines der Talente, außer der Starteinheit, die hat den magicskillboost. Einige Skills kommen öfter vor als andere, das ist nicht einfach vermeidbar. Sollte aber auch wurscht sein, es geht primär darum, lehren zu können.
Es gibt ein Einheitenlimit von 1000 Einheiten pro Allianz.
-- die Regel sparen wir uns einfach mal.
2003-12-14 22:45:47 +01:00
|
|
|
|
luaopen_math(luaState);
|
|
|
|
|
luaopen_string(luaState);
|
|
|
|
|
luaopen_io(luaState);
|
2003-11-10 00:36:11 +01:00
|
|
|
|
luabind::open(luaState);
|
2003-12-14 11:10:30 +01:00
|
|
|
|
bind_eressea(luaState);
|
2004-01-04 23:29:33 +01:00
|
|
|
|
#ifdef ALLIANCES
|
2003-12-14 11:10:30 +01:00
|
|
|
|
bind_alliance(luaState);
|
2004-01-04 23:29:33 +01:00
|
|
|
|
#endif
|
2003-11-10 00:36:11 +01:00
|
|
|
|
bind_region(luaState);
|
2003-12-14 11:10:30 +01:00
|
|
|
|
bind_faction(luaState);
|
2003-11-10 00:36:11 +01:00
|
|
|
|
bind_unit(luaState);
|
|
|
|
|
bind_ship(luaState);
|
|
|
|
|
bind_building(luaState);
|
2003-12-14 17:34:00 +01:00
|
|
|
|
return luaState;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
}
|
|
|
|
|
|
2003-12-14 17:34:00 +01:00
|
|
|
|
void
|
|
|
|
|
lua_done(lua_State * luaState)
|
2003-11-10 00:36:11 +01:00
|
|
|
|
{
|
|
|
|
|
lua_close(luaState);
|
|
|
|
|
}
|
|
|
|
|
|
2003-12-14 20:17:59 +01:00
|
|
|
|
static void
|
|
|
|
|
update_subscriptions(void)
|
|
|
|
|
{
|
|
|
|
|
FILE * F;
|
|
|
|
|
char zText[MAX_PATH];
|
|
|
|
|
faction * f;
|
|
|
|
|
strcat(strcpy(zText, basepath()), "/subscriptions");
|
|
|
|
|
F = fopen(zText, "r");
|
|
|
|
|
if (F==NULL) {
|
|
|
|
|
log_error(("could not open %s.\n", zText));
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
for (;;) {
|
|
|
|
|
char zFaction[5];
|
|
|
|
|
int subscription, fno;
|
|
|
|
|
if (fscanf(F, "%d %s", &subscription, zFaction)<=0) break;
|
|
|
|
|
fno = atoi36(zFaction);
|
|
|
|
|
f = findfaction(fno);
|
|
|
|
|
if (f!=NULL) {
|
|
|
|
|
f->subscription=subscription;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
fclose(F);
|
|
|
|
|
|
|
|
|
|
sprintf(zText, "subscriptions.%u", turn);
|
|
|
|
|
F = fopen(zText, "w");
|
|
|
|
|
for (f=factions;f!=NULL;f=f->next) {
|
|
|
|
|
fprintf(F, "%s:%u:%s:%s:%s:%u:\n",
|
|
|
|
|
itoa36(f->no), f->subscription, f->email, f->override,
|
|
|
|
|
dbrace(f->race), f->lastorders);
|
|
|
|
|
}
|
|
|
|
|
fclose(F);
|
|
|
|
|
}
|
|
|
|
|
|
2003-12-14 17:34:00 +01:00
|
|
|
|
int
|
|
|
|
|
process_orders()
|
2003-11-10 00:36:11 +01:00
|
|
|
|
{
|
2003-12-14 11:10:30 +01:00
|
|
|
|
struct summary * begin, * end;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
2003-12-14 11:10:30 +01:00
|
|
|
|
#ifdef SHORTPWDS
|
|
|
|
|
readshortpwds("passwords");
|
|
|
|
|
#endif
|
2003-11-10 00:36:11 +01:00
|
|
|
|
begin = make_summary(false);
|
|
|
|
|
printf(" - Korrekturen Runde %d\n", turn);
|
|
|
|
|
korrektur();
|
|
|
|
|
turn++;
|
|
|
|
|
puts(" - entferne Texte der letzten Runde");
|
|
|
|
|
getgarbage();
|
|
|
|
|
puts(" - Nehme Korrekturen am Datenbestand vor");
|
|
|
|
|
#if BENCHMARK
|
|
|
|
|
exit(0);
|
|
|
|
|
#endif
|
|
|
|
|
processorders();
|
|
|
|
|
score();
|
|
|
|
|
#ifdef WACH_WAFF
|
|
|
|
|
remove_unequipped_guarded();
|
|
|
|
|
#endif
|
|
|
|
|
korrektur_end();
|
2003-12-14 17:34:00 +01:00
|
|
|
|
|
|
|
|
|
end = make_summary(true);
|
|
|
|
|
report_summary(end, begin, false);
|
|
|
|
|
report_summary(end, begin, true);
|
|
|
|
|
free(end);
|
|
|
|
|
free(begin);
|
|
|
|
|
|
|
|
|
|
update_subscriptions();
|
|
|
|
|
return 0;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#ifdef CLEANUP_CODE
|
|
|
|
|
static void
|
|
|
|
|
game_done(void)
|
|
|
|
|
{
|
|
|
|
|
/* 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;
|
|
|
|
|
free_region(r);
|
|
|
|
|
}
|
|
|
|
|
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
|
|
|
|
|
creport_cleanup();
|
|
|
|
|
report_cleanup();
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
2003-12-14 11:10:30 +01:00
|
|
|
|
#include "magic.h"
|
|
|
|
|
|
|
|
|
|
#ifdef MALLOCDBG
|
|
|
|
|
void
|
2003-11-10 00:36:11 +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)
|
2003-12-14 11:10:30 +01:00
|
|
|
|
# elif MALLOCDBG == 3
|
|
|
|
|
# define CHECKON() _CrtSetDbgFlag(_CrtSetDbgFlag(_CRTDBG_REPORT_FLAG) & 0)
|
2003-11-10 00:36:11 +01:00
|
|
|
|
# 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
|
|
|
|
|
|
|
|
|
|
static int
|
|
|
|
|
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"
|
|
|
|
|
"-l logfile : specify an alternative logfile\n"
|
2003-12-14 11:10:30 +01:00
|
|
|
|
"-R : erstellt nur die Reports neu\n"
|
2003-11-10 00:36:11 +01:00
|
|
|
|
"--nomsg : keine Messages (RAM sparen)\n"
|
|
|
|
|
"--nobattle : keine K<>mpfe\n"
|
2003-12-14 11:10:30 +01:00
|
|
|
|
"--nomonsters : keine monster KI\n"
|
2003-11-10 00:36:11 +01:00
|
|
|
|
"--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"
|
2003-12-14 11:10:30 +01:00
|
|
|
|
"--crabsolute : absolute Koordinaten im CR\n"
|
2003-11-10 00:36:11 +01:00
|
|
|
|
"--help : help\n", prog);
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
2003-12-14 17:34:00 +01:00
|
|
|
|
static void
|
|
|
|
|
setLuaString(lua_State * luaState, const char * name, const char * value)
|
|
|
|
|
{
|
|
|
|
|
luabind::object globals = luabind::get_globals(luaState);
|
|
|
|
|
globals[name] = value;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
setLuaNumber(lua_State * luaState, const char * name, double value)
|
|
|
|
|
{
|
|
|
|
|
luabind::object globals = luabind::get_globals(luaState);
|
|
|
|
|
globals[name] = value;
|
|
|
|
|
}
|
|
|
|
|
|
2003-11-10 00:36:11 +01:00
|
|
|
|
static int
|
2003-12-14 17:34:00 +01:00
|
|
|
|
read_args(int argc, char **argv, lua_State * luaState)
|
2003-11-10 00:36:11 +01:00
|
|
|
|
{
|
|
|
|
|
int i;
|
2003-12-14 17:34:00 +01:00
|
|
|
|
char * c;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
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]+2, "nocr")==0) nocr = true;
|
|
|
|
|
else if (strcmp(argv[i]+2, "nosave")==0) nowrite = true;
|
|
|
|
|
else if (strcmp(argv[i]+2, "noreports")==0) {
|
|
|
|
|
noreports = true;
|
|
|
|
|
nocr = true;
|
|
|
|
|
nocr = true;
|
|
|
|
|
}
|
|
|
|
|
else if (strcmp(argv[i]+2, "xml")==0) xmlfile = argv[++i];
|
|
|
|
|
else if (strcmp(argv[i]+2, "dirtyload")==0) dirtyload = true;
|
|
|
|
|
else if (strcmp(argv[i]+2, "nonr")==0) nonr = true;
|
|
|
|
|
else if (strcmp(argv[i]+2, "nomsg")==0) nomsg = true;
|
|
|
|
|
else if (strcmp(argv[i]+2, "nobattle")==0) nobattle = true;
|
2003-12-14 11:10:30 +01:00
|
|
|
|
else if (strcmp(argv[i]+2, "nomonsters")==0) nomonsters = true;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
else if (strcmp(argv[i]+2, "nodebug")==0) nobattledebug = true;
|
2003-12-14 11:10:30 +01:00
|
|
|
|
else if (strcmp(argv[i]+2, "crabsolute")==0) opt_cr_absolute_coords = true;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
else if (strcmp(argv[i]+2, "help")==0)
|
|
|
|
|
return usage(argv[0], NULL);
|
|
|
|
|
else
|
|
|
|
|
return usage(argv[0], argv[i]);
|
|
|
|
|
} else switch(argv[i][1]) {
|
|
|
|
|
case 'o':
|
|
|
|
|
g_reportdir = argv[++i];
|
|
|
|
|
break;
|
2003-12-14 17:34:00 +01:00
|
|
|
|
case 'e':
|
|
|
|
|
luafile = argv[++i];
|
|
|
|
|
break;
|
2003-12-14 11:10:30 +01:00
|
|
|
|
case 'D': /* DEBUG */
|
|
|
|
|
demonfix = atoi(argv[++i]);
|
|
|
|
|
break;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
case 'd':
|
|
|
|
|
g_datadir = argv[++i];
|
|
|
|
|
break;
|
|
|
|
|
case 'r':
|
|
|
|
|
g_resourcedir = argv[++i];
|
|
|
|
|
break;
|
|
|
|
|
case 'b':
|
|
|
|
|
g_basedir = argv[++i];
|
|
|
|
|
break;
|
2003-12-14 11:10:30 +01:00
|
|
|
|
case 'i':
|
|
|
|
|
xmlfile = argv[++i];
|
|
|
|
|
break;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
case 't':
|
|
|
|
|
turn = atoi(argv[++i]);
|
|
|
|
|
break;
|
|
|
|
|
case 'f':
|
|
|
|
|
firstx = atoi(argv[++i]);
|
|
|
|
|
firsty = atoi(argv[++i]);
|
|
|
|
|
break;
|
|
|
|
|
case 'q':
|
|
|
|
|
quiet = 1;
|
|
|
|
|
break;
|
|
|
|
|
case 'v':
|
2003-12-14 17:34:00 +01:00
|
|
|
|
if (i<argc) {
|
|
|
|
|
orders = argv[++i];
|
|
|
|
|
} else {
|
|
|
|
|
return usage(argv[0], argv[i]);
|
|
|
|
|
}
|
2003-11-10 00:36:11 +01:00
|
|
|
|
break;
|
|
|
|
|
case 'p':
|
|
|
|
|
loadplane = atoi(argv[++i]);
|
|
|
|
|
break;
|
|
|
|
|
case 'x':
|
|
|
|
|
maxregions = atoi(argv[++i]);
|
|
|
|
|
maxregions = (maxregions*81+80) / 81;
|
|
|
|
|
break;
|
|
|
|
|
case 'X':
|
|
|
|
|
dirtyload = true;
|
|
|
|
|
break;
|
2003-12-14 17:34:00 +01:00
|
|
|
|
case 's':
|
|
|
|
|
c = argv[++i];
|
|
|
|
|
while (*c && (*c!='=')) ++c;
|
|
|
|
|
if (*c) {
|
|
|
|
|
*c++ = 0;
|
|
|
|
|
setLuaString(luaState, argv[i], c);
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case 'n':
|
|
|
|
|
c = argv[++i];
|
|
|
|
|
while (*c && (*c!='=')) ++c;
|
|
|
|
|
if (*c) {
|
|
|
|
|
*c++ = 0;
|
|
|
|
|
setLuaNumber(luaState, argv[i], atof(c));
|
|
|
|
|
}
|
|
|
|
|
break;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
case 'l':
|
|
|
|
|
log_open(argv[++i]);
|
|
|
|
|
break;
|
|
|
|
|
case 'w':
|
|
|
|
|
g_writemap = true;
|
|
|
|
|
break;
|
2003-12-14 11:10:30 +01:00
|
|
|
|
case 'R':
|
|
|
|
|
opt_reportonly = true;
|
|
|
|
|
break;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
default:
|
|
|
|
|
usage(argv[0], argv[i]);
|
|
|
|
|
}
|
|
|
|
|
}
|
2003-12-15 23:59:15 +01:00
|
|
|
|
|
|
|
|
|
/* add some more variables to the lua globals */
|
|
|
|
|
setLuaString(luaState, "datapath", datapath());
|
|
|
|
|
setLuaString(luaState, "basepath", basepath());
|
|
|
|
|
setLuaString(luaState, "reportpath", reportpath());
|
|
|
|
|
setLuaString(luaState, "resourcepath", resourcepath());
|
|
|
|
|
setLuaString(luaState, "orderfile", orders);
|
|
|
|
|
|
|
|
|
|
return 0;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
}
|
|
|
|
|
|
2003-12-14 11:10:30 +01:00
|
|
|
|
#ifdef BETA_CODE
|
|
|
|
|
extern int xml_writeitems(const char * filename);
|
|
|
|
|
extern int xml_writeships(void);
|
|
|
|
|
extern int xml_writebuildings(void);
|
|
|
|
|
#endif
|
|
|
|
|
|
2003-11-10 00:36:11 +01:00
|
|
|
|
typedef struct lostdata {
|
|
|
|
|
int x, y;
|
|
|
|
|
int prevunit;
|
|
|
|
|
int building;
|
|
|
|
|
int ship;
|
|
|
|
|
} lostdata;
|
|
|
|
|
|
|
|
|
|
int
|
|
|
|
|
main(int argc, char *argv[])
|
|
|
|
|
{
|
2003-12-14 11:10:30 +01:00
|
|
|
|
int i;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
char zText[MAX_PATH];
|
|
|
|
|
|
2003-12-14 11:10:30 +01:00
|
|
|
|
sqlpatch = true;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
updatelog = fopen("update.log", "w");
|
|
|
|
|
log_open("eressea.log");
|
|
|
|
|
printf("\n%s PBEM host\n"
|
2003-12-14 20:17:59 +01:00
|
|
|
|
"Copyright (C) 1996-2003 C. Schlittchen, K. Zedel, E. Rehling, H. Peters.\n\n"
|
2003-11-10 00:36:11 +01:00
|
|
|
|
"Compilation: " __DATE__ " at " __TIME__ "\nVersion: %f\n\n", global.gamename, version());
|
|
|
|
|
|
|
|
|
|
setlocale(LC_ALL, "");
|
|
|
|
|
setlocale(LC_NUMERIC, "C");
|
|
|
|
|
#ifdef LOCALE_CHECK
|
|
|
|
|
if (!locale_check()) {
|
|
|
|
|
log_error(("The current locale is not suitable for international Eressea.\n"));
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
2003-12-14 11:10:30 +01:00
|
|
|
|
#ifdef MALLOCDBG
|
2003-11-10 00:36:11 +01:00
|
|
|
|
init_malloc_debug();
|
|
|
|
|
#endif
|
|
|
|
|
|
2003-12-14 17:34:00 +01:00
|
|
|
|
lua_State * luaState = lua_init();
|
|
|
|
|
if ((i=read_args(argc, argv, luaState))!=0) return i;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
|
|
|
|
strcat(strcpy(zText, resourcepath()), "/timestrings");
|
|
|
|
|
if ((i=read_datenames(zText))!=0) return i;
|
|
|
|
|
|
|
|
|
|
kernel_init();
|
|
|
|
|
game_init();
|
|
|
|
|
|
2003-12-14 17:34:00 +01:00
|
|
|
|
// run the main script
|
|
|
|
|
lua_dofile(luaState, luafile);
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
|
|
|
|
#ifdef CLEANUP_CODE
|
|
|
|
|
game_done();
|
|
|
|
|
#endif
|
|
|
|
|
kernel_done();
|
2003-12-14 17:34:00 +01:00
|
|
|
|
lua_done(luaState);
|
2003-11-10 00:36:11 +01:00
|
|
|
|
log_close();
|
|
|
|
|
fclose(updatelog);
|
|
|
|
|
return 0;
|
|
|
|
|
}
|