forked from github/server
* Bugfix Dämonen (siehe mail)
* FL_GUARD ist obsolet. * SPELLPOINTS an mehr Stellen entfernt
This commit is contained in:
parent
0faa820456
commit
8c002d7f21
16 changed files with 85 additions and 249 deletions
|
@ -240,8 +240,6 @@ expandorders(region * r, request * requests)
|
||||||
}
|
}
|
||||||
/* ------------------------------------------------------------- */
|
/* ------------------------------------------------------------- */
|
||||||
|
|
||||||
#if SKILLPOINTS == 0
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
change_level(unit * u, skill_t sk, int bylevel)
|
change_level(unit * u, skill_t sk, int bylevel)
|
||||||
{
|
{
|
||||||
|
@ -250,7 +248,6 @@ change_level(unit * u, skill_t sk, int bylevel)
|
||||||
if (sv==0) sv = add_skill(u, sk);
|
if (sv==0) sv = add_skill(u, sk);
|
||||||
sk_set(sv, sv->level+bylevel);
|
sk_set(sv, sv->level+bylevel);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
expandrecruit(region * r, request * recruitorders)
|
expandrecruit(region * r, request * recruitorders)
|
||||||
|
@ -1502,7 +1499,7 @@ allocate_resource(unit * u, const resource_type * rtype, int want)
|
||||||
{
|
{
|
||||||
for (u2 = r->units; u2; u2 = u2->next ) {
|
for (u2 = r->units; u2; u2 = u2->next ) {
|
||||||
if (getguard(u) & GUARD_MINING
|
if (getguard(u) & GUARD_MINING
|
||||||
&& !fval(u2, FL_ISNEW)
|
&& !fval(u2, UFL_ISNEW)
|
||||||
&& u2->number
|
&& u2->number
|
||||||
&& !ucontact(u2, u)
|
&& !ucontact(u2, u)
|
||||||
&& !allied(u2, u->faction, HELP_GUARD))
|
&& !allied(u2, u->faction, HELP_GUARD))
|
||||||
|
|
|
@ -82,7 +82,7 @@ static FILE * dragonlog;
|
||||||
static boolean
|
static boolean
|
||||||
is_waiting(const unit * u)
|
is_waiting(const unit * u)
|
||||||
{
|
{
|
||||||
if (fval(u, FL_ISNEW)) return true;
|
if (fval(u, UFL_ISNEW)) return true;
|
||||||
if (strncasecmp(u->lastorder, "WARTEN", 6) == 0) return true;
|
if (strncasecmp(u->lastorder, "WARTEN", 6) == 0) return true;
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
|
@ -976,7 +976,7 @@ plan_monsters(void)
|
||||||
if (tr != r) is_moving = true;
|
if (tr != r) is_moving = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(fval(u, FL_ISNEW)) && r->terrain != T_OCEAN) { /* Monster bewachen immer */
|
if (!(fval(u, UFL_ISNEW)) && r->terrain != T_OCEAN) { /* Monster bewachen immer */
|
||||||
strlist *S;
|
strlist *S;
|
||||||
S = makestrlist(locale_string(u->faction->locale, keywords[K_GUARD]));
|
S = makestrlist(locale_string(u->faction->locale, keywords[K_GUARD]));
|
||||||
addlist(&u->orders, S);
|
addlist(&u->orders, S);
|
||||||
|
|
|
@ -294,12 +294,8 @@ find_manual(region * r, unit * u)
|
||||||
addmessage(r, u->faction, buf, MSG_EVENT, ML_IMPORTANT);
|
addmessage(r, u->faction, buf, MSG_EVENT, ML_IMPORTANT);
|
||||||
|
|
||||||
if (improve_all(u->faction, skill, 3) == 0) {
|
if (improve_all(u->faction, skill, 3) == 0) {
|
||||||
#if SKILLPOINTS
|
|
||||||
change_skill(u, skill, 270);
|
|
||||||
#else
|
|
||||||
int i;
|
int i;
|
||||||
for (i=0;i!=9;++i) learn_skill(u, skill, 1.0);
|
for (i=0;i!=9;++i) learn_skill(u, skill, 1.0);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -317,7 +313,7 @@ get_unit(region * r, unit * u)
|
||||||
newunit = createunit(r, u->faction, rand() % 20 + 3, u->faction->race);
|
newunit = createunit(r, u->faction, rand() % 20 + 3, u->faction->race);
|
||||||
set_string(&newunit->name, "Dorfbewohner");
|
set_string(&newunit->name, "Dorfbewohner");
|
||||||
set_money(newunit, (rand() % 26 + 10) * newunit->number);
|
set_money(newunit, (rand() % 26 + 10) * newunit->number);
|
||||||
fset(newunit, FL_ISNEW);
|
fset(newunit, UFL_ISNEW);
|
||||||
if (fval(u, FL_PARTEITARNUNG)) fset(newunit, FL_PARTEITARNUNG);
|
if (fval(u, FL_PARTEITARNUNG)) fset(newunit, FL_PARTEITARNUNG);
|
||||||
switch (rand() % 4) {
|
switch (rand() % 4) {
|
||||||
case 0:
|
case 0:
|
||||||
|
@ -472,7 +468,7 @@ get_allies(region * r, unit * u)
|
||||||
newunit->irace = u->irace;
|
newunit->irace = u->irace;
|
||||||
}
|
}
|
||||||
if (fval(u, FL_PARTEITARNUNG)) fset(newunit, FL_PARTEITARNUNG);
|
if (fval(u, FL_PARTEITARNUNG)) fset(newunit, FL_PARTEITARNUNG);
|
||||||
fset(u, FL_ISNEW);
|
fset(u, UFL_ISNEW);
|
||||||
|
|
||||||
sprintf(buf, "Plötzlich stolper%c %s über einige %s. Nach kurzem "
|
sprintf(buf, "Plötzlich stolper%c %s über einige %s. Nach kurzem "
|
||||||
"Zögern entschließen sich die %s, sich Deiner Partei anzuschließen.",
|
"Zögern entschließen sich die %s, sich Deiner Partei anzuschließen.",
|
||||||
|
@ -1448,7 +1444,7 @@ randomevents(void)
|
||||||
for (u=r->units; u; u=u->next) {
|
for (u=r->units; u; u=u->next) {
|
||||||
if (u->faction->no != MONSTER_FACTION
|
if (u->faction->no != MONSTER_FACTION
|
||||||
&& (u->race->flags & RCF_DESERT)) {
|
&& (u->race->flags & RCF_DESERT)) {
|
||||||
if (fval(u, FL_ISNEW)) continue;
|
if (fval(u, UFL_ISNEW)) continue;
|
||||||
if (rand()%100 < 5) {
|
if (rand()%100 < 5) {
|
||||||
ADDMSG(&u->faction->msgs, msg_message("desertion",
|
ADDMSG(&u->faction->msgs, msg_message("desertion",
|
||||||
"unit region", u, r));
|
"unit region", u, r));
|
||||||
|
|
|
@ -424,12 +424,8 @@ teach(region * r, unit * u)
|
||||||
|
|
||||||
}
|
}
|
||||||
if (academy) {
|
if (academy) {
|
||||||
#if SKILLPOINTS
|
|
||||||
change_skill(u, sk, academy / 30);
|
|
||||||
#else
|
|
||||||
academy = academy/30;
|
academy = academy/30;
|
||||||
learn_skill(u, sk, academy/30.0/TEACHNUMBER);
|
learn_skill(u, sk, academy/30.0/TEACHNUMBER);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* ------------------------------------------------------------- */
|
/* ------------------------------------------------------------- */
|
||||||
|
|
|
@ -3804,9 +3804,11 @@ int
|
||||||
damage_unit(unit *u, const char *dam, boolean armor, boolean magic)
|
damage_unit(unit *u, const char *dam, boolean armor, boolean magic)
|
||||||
{
|
{
|
||||||
int *hp = malloc(u->number * sizeof(int));
|
int *hp = malloc(u->number * sizeof(int));
|
||||||
int h = u->hp/u->number;
|
int h;
|
||||||
int i, dead = 0, hp_rem = 0, heiltrank;
|
int i, dead = 0, hp_rem = 0, heiltrank;
|
||||||
|
|
||||||
|
if (u->number==0) return 0;
|
||||||
|
h = u->hp/u->number;
|
||||||
/* HP verteilen */
|
/* HP verteilen */
|
||||||
for (i=0; i<u->number; i++) hp[i] = h;
|
for (i=0; i<u->number; i++) hp[i] = h;
|
||||||
h = u->hp - (u->number * h);
|
h = u->hp - (u->number * h);
|
||||||
|
|
|
@ -693,7 +693,7 @@ scale_number (unit * u, int n)
|
||||||
}
|
}
|
||||||
for (sk = 0; sk < MAXSKILLS; sk++) {
|
for (sk = 0; sk < MAXSKILLS; sk++) {
|
||||||
if (n==0 || u->number == 0) {
|
if (n==0 || u->number == 0) {
|
||||||
set_level(u, sk, 0);
|
remove_skill(u, sk);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1382,7 +1382,7 @@ getunit(const region * r, const faction * f)
|
||||||
if (n < 0) return 0;
|
if (n < 0) return 0;
|
||||||
|
|
||||||
for (u2 = r->units; u2; u2 = u2->next) {
|
for (u2 = r->units; u2; u2 = u2->next) {
|
||||||
if (u2->no == n && !fval(u2, FL_ISNEW)) {
|
if (u2->no == n && !fval(u2, UFL_ISNEW)) {
|
||||||
return u2;
|
return u2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2512,7 +2512,7 @@ make_undead_unit(region * r, faction * f, int n, const struct race * rc)
|
||||||
u = createunit(r, f, n, rc);
|
u = createunit(r, f, n, rc);
|
||||||
set_string(&u->lastorder, "");
|
set_string(&u->lastorder, "");
|
||||||
name_unit(u);
|
name_unit(u);
|
||||||
fset(u, FL_ISNEW);
|
fset(u, UFL_ISNEW);
|
||||||
return u;
|
return u;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2991,13 +2991,8 @@ int
|
||||||
produceexp(struct unit * u, skill_t sk, int n)
|
produceexp(struct unit * u, skill_t sk, int n)
|
||||||
{
|
{
|
||||||
if (n==0 || !playerrace(u->race)) return 0;
|
if (n==0 || !playerrace(u->race)) return 0;
|
||||||
#if SKILLPOINTS
|
|
||||||
change_skill(u, sk, PRODUCEEXP * n);
|
|
||||||
return 1;
|
|
||||||
#else
|
|
||||||
learn_skill(u, sk, PRODUCEEXP/30.0);
|
learn_skill(u, sk, PRODUCEEXP/30.0);
|
||||||
return 0;
|
return 0;
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
boolean
|
boolean
|
||||||
|
|
|
@ -845,8 +845,8 @@ typedef struct strlist {
|
||||||
|
|
||||||
extern int max_unique_id;
|
extern int max_unique_id;
|
||||||
|
|
||||||
#define FL_GUARD (1<<0) /* 1 */
|
#define UFL_DEBUG (1<<0)
|
||||||
#define FL_ISNEW (1<<1) /* 2 */
|
#define UFL_ISNEW (1<<1) /* 2 */
|
||||||
#define FL_LONGACTION (1<<2) /* 4 */
|
#define FL_LONGACTION (1<<2) /* 4 */
|
||||||
#define FL_OWNER (1<<3) /* 8 */
|
#define FL_OWNER (1<<3) /* 8 */
|
||||||
#define FL_PARTEITARNUNG (1<<4) /* 16 */
|
#define FL_PARTEITARNUNG (1<<4) /* 16 */
|
||||||
|
|
|
@ -120,7 +120,7 @@ addplayer(region *r, const char *email, const struct race * frace, const locale
|
||||||
|
|
||||||
u = createunit(r, f, 1, f->race);
|
u = createunit(r, f, 1, f->race);
|
||||||
give_starting_equipment(r, u);
|
give_starting_equipment(r, u);
|
||||||
fset(u, FL_ISNEW);
|
fset(u, UFL_ISNEW);
|
||||||
if (old_race(f->race) == RC_DAEMON) {
|
if (old_race(f->race) == RC_DAEMON) {
|
||||||
race_t urc;
|
race_t urc;
|
||||||
do
|
do
|
||||||
|
|
|
@ -1669,10 +1669,10 @@ readunit(FILE * F)
|
||||||
guard(u, GUARD_NONE);
|
guard(u, GUARD_NONE);
|
||||||
}
|
}
|
||||||
} else
|
} else
|
||||||
u->flags = ri(F);
|
u->flags = ri(F) & ~UFL_DEBUG;
|
||||||
if (global.data_version < GUARD_VERSION) {
|
if (global.data_version < GUARD_VERSION) {
|
||||||
#if RELEASE_VERSION < GUARDFIX_VERSION
|
#if RELEASE_VERSION < GUARDFIX_VERSION
|
||||||
if (fval(u, FL_GUARD)) guard(u, GUARD_ALL);
|
if (fval(u, 1)) guard(u, GUARD_ALL);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
/* Kurze persistente Befehle einlesen */
|
/* Kurze persistente Befehle einlesen */
|
||||||
|
|
|
@ -257,53 +257,6 @@ level(int days)
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if !SKILLPOINTS
|
|
||||||
|
|
||||||
/*
|
|
||||||
#define MAXLEVEL 32
|
|
||||||
static struct {
|
|
||||||
int permutations;
|
|
||||||
int * chances;
|
|
||||||
} upgrade[MAXLEVEL];
|
|
||||||
|
|
||||||
static double
|
|
||||||
fak(int n)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
double f=1;
|
|
||||||
for (i=2;i<n;++i) f=f*i;
|
|
||||||
return f;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
sk_set(skill * sv, int level)
|
|
||||||
{
|
|
||||||
double i;
|
|
||||||
int weeks;
|
|
||||||
int multi=1+(level/16);
|
|
||||||
if (upgrade[level].permutations==0) {
|
|
||||||
int m;
|
|
||||||
int ctr = 1;
|
|
||||||
int n = level * 2 / multi;
|
|
||||||
upgrade[level].permutations = 1 << n;
|
|
||||||
if (n>0) upgrade[level].chances = malloc(sizeof(double)*n);
|
|
||||||
for (m=0;m!=n;++m) {
|
|
||||||
upgrade[level].chances[m] = (int)(fak(n)/(fak(m)*fak(n-m)));
|
|
||||||
ctr += upgrade[level].chances[m];
|
|
||||||
}
|
|
||||||
assert(ctr==upgrade[level].permutations);
|
|
||||||
}
|
|
||||||
i = rand() % upgrade[level].permutations;
|
|
||||||
for (weeks=0;weeks!=level*2/multi;++weeks) {
|
|
||||||
if (i<=upgrade[level].chances[weeks]) break;
|
|
||||||
else i-=upgrade[level].chances[weeks];
|
|
||||||
}
|
|
||||||
weeks*=multi;
|
|
||||||
sv->weeks = (unsigned char)(weeks+1);
|
|
||||||
sv->level = (unsigned char)level;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
void
|
void
|
||||||
sk_set(skill * sv, int level)
|
sk_set(skill * sv, int level)
|
||||||
{
|
{
|
||||||
|
@ -354,4 +307,3 @@ skill_compare(const skill * sk, const skill * sc)
|
||||||
if (sk->weeks > sc->weeks) return -1;
|
if (sk->weeks > sc->weeks) return -1;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
|
@ -23,15 +23,10 @@ extern signed char skill_bonus(struct unit * u, struct region * r);
|
||||||
#define SMF_RIDING (1<<2) /* Bonus für berittene - an der rasse*/
|
#define SMF_RIDING (1<<2) /* Bonus für berittene - an der rasse*/
|
||||||
|
|
||||||
typedef struct skill {
|
typedef struct skill {
|
||||||
#if SKILLPOINTS
|
|
||||||
skill_t id;
|
|
||||||
int value;
|
|
||||||
#else
|
|
||||||
unsigned char id;
|
unsigned char id;
|
||||||
unsigned char level;
|
unsigned char level;
|
||||||
unsigned char weeks;
|
unsigned char weeks;
|
||||||
unsigned char old;
|
unsigned char old;
|
||||||
#endif
|
|
||||||
} skill;
|
} skill;
|
||||||
|
|
||||||
typedef struct skillmod_data {
|
typedef struct skillmod_data {
|
||||||
|
@ -54,16 +49,12 @@ extern skill_t sk_find(const char * name);
|
||||||
extern int level_days(int level);
|
extern int level_days(int level);
|
||||||
extern int level(int days);
|
extern int level(int days);
|
||||||
|
|
||||||
#if SKILLPOINTS
|
|
||||||
# define skill_level(level) level_days(level)
|
|
||||||
#else
|
|
||||||
#define skill_level(level) (level)
|
#define skill_level(level) (level)
|
||||||
extern void reduce_skill(struct unit *u, skill * sv, int change);
|
extern void reduce_skill(struct unit *u, skill * sv, int change);
|
||||||
extern int skill_weeks(int level);
|
extern int skill_weeks(int level);
|
||||||
extern int skill_compare(const skill * sk, const skill * sc);
|
extern int skill_compare(const skill * sk, const skill * sc);
|
||||||
|
|
||||||
extern void sk_set(skill * sv, int level);
|
extern void sk_set(skill * sv, int level);
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -2266,7 +2266,7 @@ sp_ironkeeper(castorder *co)
|
||||||
|
|
||||||
/*keeper->age = cast_level + 2;*/
|
/*keeper->age = cast_level + 2;*/
|
||||||
guard(keeper, GUARD_MINING);
|
guard(keeper, GUARD_MINING);
|
||||||
fset(keeper, FL_ISNEW);
|
fset(keeper, UFL_ISNEW);
|
||||||
keeper->status = ST_AVOID; /* kaempft nicht */
|
keeper->status = ST_AVOID; /* kaempft nicht */
|
||||||
/* Parteitarnen, damit man nicht sofort weiß, wer dahinter steckt */
|
/* Parteitarnen, damit man nicht sofort weiß, wer dahinter steckt */
|
||||||
fset(keeper, FL_PARTEITARNUNG);
|
fset(keeper, FL_PARTEITARNUNG);
|
||||||
|
|
|
@ -51,6 +51,8 @@
|
||||||
|
|
||||||
#define FIND_FOREIGN_TEMP
|
#define FIND_FOREIGN_TEMP
|
||||||
|
|
||||||
|
|
||||||
|
int demonfix = 0;
|
||||||
/* ------------------------------------------------------------- */
|
/* ------------------------------------------------------------- */
|
||||||
|
|
||||||
const unit u_peasants = { NULL, NULL, NULL, NULL, NULL, 2, "die Bauern" };
|
const unit u_peasants = { NULL, NULL, NULL, NULL, NULL, 2, "die Bauern" };
|
||||||
|
@ -679,6 +681,8 @@ transfermen(unit * u, unit * u2, int n)
|
||||||
skill_t sk;
|
skill_t sk;
|
||||||
assert(u2->number+n>0);
|
assert(u2->number+n>0);
|
||||||
|
|
||||||
|
if (demonfix && u2->race==new_race[RC_DAEMON]) fset(u2, UFL_DEBUG);
|
||||||
|
|
||||||
for (sk=0; sk!=MAXSKILLS; ++sk) {
|
for (sk=0; sk!=MAXSKILLS; ++sk) {
|
||||||
double dlevel = 0.0;
|
double dlevel = 0.0;
|
||||||
int weeks, level;
|
int weeks, level;
|
||||||
|
|
|
@ -520,11 +520,7 @@ gm_skill(const char * str, void * data, const char * cmd)
|
||||||
mistake(u, cmd, "Unzureichende Rechte für diesen Befehl.\n", 0);
|
mistake(u, cmd, "Unzureichende Rechte für diesen Befehl.\n", 0);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
#if SKILLPOINTS
|
|
||||||
set_skill(to, skill, num*to->number);
|
|
||||||
#else
|
|
||||||
set_level(to, skill, num);
|
set_level(to, skill, num);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -52,15 +52,16 @@
|
||||||
|
|
||||||
/* kernel includes */
|
/* kernel includes */
|
||||||
#include <building.h>
|
#include <building.h>
|
||||||
#include <unit.h>
|
#include <creport.h>
|
||||||
#include <message.h>
|
|
||||||
#include <teleport.h>
|
|
||||||
#include <faction.h>
|
#include <faction.h>
|
||||||
|
#include <message.h>
|
||||||
#include <plane.h>
|
#include <plane.h>
|
||||||
#include <race.h>
|
#include <race.h>
|
||||||
#include <reports.h>
|
#include <skill.h>
|
||||||
#include <creport.h>
|
#include <teleport.h>
|
||||||
|
#include <unit.h>
|
||||||
#include <region.h>
|
#include <region.h>
|
||||||
|
#include <reports.h>
|
||||||
#include <resources.h>
|
#include <resources.h>
|
||||||
#include <save.h>
|
#include <save.h>
|
||||||
#include <ship.h>
|
#include <ship.h>
|
||||||
|
@ -98,9 +99,6 @@ extern boolean nobattle;
|
||||||
extern boolean nobattledebug;
|
extern boolean nobattledebug;
|
||||||
extern boolean dirtyload;
|
extern boolean dirtyload;
|
||||||
|
|
||||||
static boolean printpotions;
|
|
||||||
static int insertfaction;
|
|
||||||
|
|
||||||
extern void debug_messagetypes(FILE * out);
|
extern void debug_messagetypes(FILE * out);
|
||||||
extern void free_region(region * r);
|
extern void free_region(region * r);
|
||||||
extern void render_init(void);
|
extern void render_init(void);
|
||||||
|
@ -140,20 +138,6 @@ crwritemap(void)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
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)));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
game_init(void)
|
game_init(void)
|
||||||
{
|
{
|
||||||
|
@ -197,11 +181,6 @@ game_init(void)
|
||||||
abort();
|
abort();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (printpotions) {
|
|
||||||
FILE * F = fopen("recipes.txt", "w");
|
|
||||||
print_potions(F);
|
|
||||||
fclose(F);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -455,6 +434,8 @@ usage(const char * prog, const char * arg)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern int demonfix;
|
||||||
|
|
||||||
static int
|
static int
|
||||||
read_args(int argc, char **argv)
|
read_args(int argc, char **argv)
|
||||||
{
|
{
|
||||||
|
@ -489,7 +470,7 @@ read_args(int argc, char **argv)
|
||||||
g_reportdir = argv[++i];
|
g_reportdir = argv[++i];
|
||||||
break;
|
break;
|
||||||
case 'D': /* DEBUG */
|
case 'D': /* DEBUG */
|
||||||
printpotions = true;
|
demonfix = atoi(argv[++i]);
|
||||||
break;
|
break;
|
||||||
case 'd':
|
case 'd':
|
||||||
g_datadir = argv[++i];
|
g_datadir = argv[++i];
|
||||||
|
@ -503,9 +484,6 @@ read_args(int argc, char **argv)
|
||||||
case 't':
|
case 't':
|
||||||
turn = atoi(argv[++i]);
|
turn = atoi(argv[++i]);
|
||||||
break;
|
break;
|
||||||
case 'i':
|
|
||||||
insertfaction = atoi36(argv[++i]);
|
|
||||||
break;
|
|
||||||
case 'f':
|
case 'f':
|
||||||
firstx = atoi(argv[++i]);
|
firstx = atoi(argv[++i]);
|
||||||
firsty = atoi(argv[++i]);
|
firsty = atoi(argv[++i]);
|
||||||
|
@ -593,124 +571,6 @@ main(int argc, char *argv[])
|
||||||
return 0;
|
return 0;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (insertfaction) {
|
|
||||||
faction * lostf;
|
|
||||||
unit *ulost, **ulostp = &lostunits;
|
|
||||||
faction **fp = &factions;
|
|
||||||
region **rp = ®ions;
|
|
||||||
|
|
||||||
if ((i=readgame(false))!=0) return i;
|
|
||||||
|
|
||||||
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;
|
|
||||||
}
|
|
||||||
if ((i=readgame(false))!=0) return i;
|
if ((i=readgame(false))!=0) return i;
|
||||||
#ifdef BETA_CODE
|
#ifdef BETA_CODE
|
||||||
if (dungeonstyles) {
|
if (dungeonstyles) {
|
||||||
|
@ -730,13 +590,60 @@ main(int argc, char *argv[])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (g_writemap) return crwritemap();
|
if (g_writemap) return crwritemap();
|
||||||
/* {
|
|
||||||
* faction * monster = findfaction(MONSTER_FACTION);
|
if (demonfix==2) {
|
||||||
* display_item(monster, monster->units, it_find("mistletoe"));
|
FILE * F = fopen("demons.fix", "r");
|
||||||
* }
|
for (;;) {
|
||||||
* */
|
int x, y, id, fno, size, age, number;
|
||||||
|
unit * u;
|
||||||
|
if (fscanf(F, "%d %d %d %d %d %d %d", &id, &age, &fno, &x, &y, &size, &number)<=0) break;
|
||||||
|
u = findunit(id);
|
||||||
|
if (u==NULL || u->faction->no!=fno) {
|
||||||
|
region * r = findregion(x, y);
|
||||||
|
if (r) for (u=r->units;u;u=u->next) if (u->number==number && u->age==age && u->faction->no==fno) break;
|
||||||
|
}
|
||||||
|
if (!u) {
|
||||||
|
log_error(("could not find unit %s and fix it!\n", itoa36(id)));
|
||||||
|
}
|
||||||
|
else u->skill_size = 0;
|
||||||
|
while (size--) {
|
||||||
|
int sk, value, weeks;
|
||||||
|
if (fscanf(F, "%d %d %d", &sk, &value, &weeks)<=0) break;
|
||||||
|
if (u) {
|
||||||
|
skill * sv = add_skill(u, (skill_t)sk);
|
||||||
|
sv->level = (unsigned char)value;
|
||||||
|
sv->weeks = (unsigned char)weeks;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
log_error((" %s[%u] : %u/%u\n", skillname((skill_t)sk, default_locale), sk, value, weeks));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fclose(F);
|
||||||
|
}
|
||||||
|
|
||||||
if ((i=processturn(orders))!=0) return i;
|
if ((i=processturn(orders))!=0) return i;
|
||||||
|
|
||||||
|
if (demonfix==1) {
|
||||||
|
region * r;
|
||||||
|
FILE * F = fopen("demons.fix", "w");
|
||||||
|
for (r=regions;r;r=r->next) {
|
||||||
|
unit * u;
|
||||||
|
for (u=r->units;u;u=u->next) {
|
||||||
|
if (u->number && fval(u, UFL_DEBUG)) {
|
||||||
|
skill * sv;
|
||||||
|
fprintf(F, "%d %d %d %d %d %d %d\n", u->no, u->age, u->faction->no, r->x, r->y, u->skill_size, u->number);
|
||||||
|
for (sv=u->skills;sv!=u->skills+u->skill_size;++sv) {
|
||||||
|
fprintf(F, "%d %d %d\n", sv->id, sv->level, sv->weeks);
|
||||||
|
}
|
||||||
|
fputc('\n', F);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fclose(F);
|
||||||
|
exit(0);
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef CLEANUP_CODE
|
#ifdef CLEANUP_CODE
|
||||||
game_done();
|
game_done();
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -873,7 +873,7 @@ mapper_spunit(dbllist ** SP, unit * u, int indent)
|
||||||
|
|
||||||
sncat(buf, " (", BUFSIZE); icat(u->hp/u->number); sncat(buf, " HP)", BUFSIZE);
|
sncat(buf, " (", BUFSIZE); icat(u->hp/u->number); sncat(buf, " HP)", BUFSIZE);
|
||||||
|
|
||||||
if (fval(u, FL_GUARD))
|
if (getguard(u, UFL_GUARD))
|
||||||
sncat(buf, ", bewacht die Region", BUFSIZE);
|
sncat(buf, ", bewacht die Region", BUFSIZE);
|
||||||
|
|
||||||
if (usiege(u)) {
|
if (usiege(u)) {
|
||||||
|
|
Loading…
Reference in a new issue