forked from github/server
Merge pull request #24 from CTD1/Bug-1610
Bug 1610 FOLGE SCHIFF und andere lange Befehle
This commit is contained in:
commit
13ba2b8362
2 changed files with 53 additions and 44 deletions
|
@ -2396,15 +2396,12 @@ static int hunt(unit * u, order * ord)
|
||||||
return 0;
|
return 0;
|
||||||
} else if (!u->ship) {
|
} else if (!u->ship) {
|
||||||
cmistake(u, ord, 144, MSG_MOVE);
|
cmistake(u, ord, 144, MSG_MOVE);
|
||||||
fset(u, UFL_LONGACTION | UFL_NOTMOVING); /* FOLGE SCHIFF ist immer lang */
|
|
||||||
return 0;
|
return 0;
|
||||||
} else if (u!=ship_owner(u->ship)) {
|
} else if (u!=ship_owner(u->ship)) {
|
||||||
cmistake(u, ord, 146, MSG_MOVE);
|
cmistake(u, ord, 146, MSG_MOVE);
|
||||||
fset(u, UFL_LONGACTION | UFL_NOTMOVING); /* FOLGE SCHIFF ist immer lang */
|
|
||||||
return 0;
|
return 0;
|
||||||
} else if (!can_move(u)) {
|
} else if (!can_move(u)) {
|
||||||
cmistake(u, ord, 55, MSG_MOVE);
|
cmistake(u, ord, 55, MSG_MOVE);
|
||||||
fset(u, UFL_LONGACTION | UFL_NOTMOVING); /* FOLGE SCHIFF ist immer lang */
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2412,7 +2409,6 @@ static int hunt(unit * u, order * ord)
|
||||||
|
|
||||||
if (id <= 0) {
|
if (id <= 0) {
|
||||||
cmistake(u, ord, 20, MSG_MOVE);
|
cmistake(u, ord, 20, MSG_MOVE);
|
||||||
fset(u, UFL_LONGACTION | UFL_NOTMOVING); /* FOLGE SCHIFF ist immer lang */
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2423,7 +2419,6 @@ static int hunt(unit * u, order * ord)
|
||||||
if (sh == NULL || sh->region != rc) {
|
if (sh == NULL || sh->region != rc) {
|
||||||
cmistake(u, ord, 20, MSG_MOVE);
|
cmistake(u, ord, 20, MSG_MOVE);
|
||||||
}
|
}
|
||||||
fset(u, UFL_LONGACTION | UFL_NOTMOVING); /* FOLGE SCHIFF ist immer lang */
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2523,7 +2518,7 @@ static void move_hunters(void)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!fval(u, UFL_NOTMOVING) && !LongHunger(u) && hunt(u, ord)) {
|
if (!fval(u, UFL_LONGACTION) && !LongHunger(u) && hunt(u, ord)) {
|
||||||
up = &r->units;
|
up = &r->units;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -2663,7 +2658,6 @@ void movement(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Overrides long orders with a FOLLOW order if the target is moving.
|
/** Overrides long orders with a FOLLOW order if the target is moving.
|
||||||
* FOLLOW SHIP is a long order, and doesn't need to be treated in here.
|
|
||||||
* BUGS: http://bugs.eressea.de/view.php?id=1444 (A folgt B folgt C)
|
* BUGS: http://bugs.eressea.de/view.php?id=1444 (A folgt B folgt C)
|
||||||
*/
|
*/
|
||||||
void follow_unit(unit * u)
|
void follow_unit(unit * u)
|
||||||
|
@ -2671,6 +2665,8 @@ void follow_unit(unit * u)
|
||||||
region *r = u->region;
|
region *r = u->region;
|
||||||
attrib *a = NULL;
|
attrib *a = NULL;
|
||||||
order *ord;
|
order *ord;
|
||||||
|
unit *u2 = NULL;
|
||||||
|
int followship = false;
|
||||||
|
|
||||||
if (fval(u, UFL_NOTMOVING) || LongHunger(u))
|
if (fval(u, UFL_NOTMOVING) || LongHunger(u))
|
||||||
return;
|
return;
|
||||||
|
@ -2681,8 +2677,10 @@ void follow_unit(unit * u)
|
||||||
if (getkeyword(ord) == K_FOLLOW) {
|
if (getkeyword(ord) == K_FOLLOW) {
|
||||||
init_tokens(ord);
|
init_tokens(ord);
|
||||||
skip_token();
|
skip_token();
|
||||||
if (getparam(lang) == P_UNIT) {
|
int id;
|
||||||
int id = read_unitid(u->faction, r);
|
param_t p = getparam(lang);
|
||||||
|
if (p == P_UNIT) {
|
||||||
|
id = read_unitid(u->faction, r);
|
||||||
|
|
||||||
if (a != NULL) {
|
if (a != NULL) {
|
||||||
a = a_find(u->attribs, &at_follow);
|
a = a_find(u->attribs, &at_follow);
|
||||||
|
@ -2700,31 +2698,70 @@ void follow_unit(unit * u)
|
||||||
a = NULL;
|
a = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (p == P_SHIP) {
|
||||||
|
id = getshipid();
|
||||||
|
if (id <= 0) {
|
||||||
|
/* cmistake(u, ord, 20, MSG_MOVE); */
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
ship *sh = findship(id);
|
||||||
|
if (sh == NULL || (sh->region != r && hunted_dir(r->attribs, id) == NODIRECTION)) {
|
||||||
|
cmistake(u, ord, 20, MSG_MOVE);
|
||||||
|
}
|
||||||
|
else if (!u->ship) {
|
||||||
|
/* cmistake(u, ord, 144, MSG_MOVE); */
|
||||||
|
}
|
||||||
|
else if (u != ship_owner(u->ship)) {
|
||||||
|
/* cmistake(u, ord, 146, MSG_MOVE); */
|
||||||
|
}
|
||||||
|
else if (!can_move(u)) {
|
||||||
|
/* cmistake(u, ord, 55, MSG_MOVE); */
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
u2 = ship_owner(sh);
|
||||||
|
followship = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (a && !fval(u, UFL_MOVED | UFL_NOTMOVING)) {
|
if ((a || followship )&& !fval(u, UFL_MOVED | UFL_NOTMOVING)) {
|
||||||
unit *u2 = a->data.v;
|
if (!followship) {
|
||||||
|
u2 = a->data.v;
|
||||||
|
}
|
||||||
bool follow = false;
|
bool follow = false;
|
||||||
|
|
||||||
if (!u2 || u2->region != r || !cansee(u->faction, r, u2, 0)) {
|
if (!u2 || (u2->region != r || !cansee(u->faction, r, u2, 0)) && !followship) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (getkeyword(u2->thisorder)) {
|
switch (getkeyword(u2->thisorder)) {
|
||||||
case K_MOVE:
|
case K_MOVE:
|
||||||
case K_ROUTE:
|
case K_ROUTE:
|
||||||
case K_DRIVE:
|
|
||||||
follow = true;
|
follow = true;
|
||||||
break;
|
break;
|
||||||
|
case K_DRIVE:
|
||||||
|
if (!followship) {
|
||||||
|
follow = true;
|
||||||
|
}
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
for (ord = u2->orders; ord; ord = ord->next) {
|
for (ord = u2->orders; ord; ord = ord->next) {
|
||||||
switch (getkeyword(ord)) {
|
switch (getkeyword(ord)) {
|
||||||
case K_FOLLOW:
|
case K_FOLLOW:
|
||||||
case K_PIRACY:
|
|
||||||
follow = true;
|
follow = true;
|
||||||
break;
|
break;
|
||||||
|
case K_PIRACY:
|
||||||
|
if (followship) {
|
||||||
|
follow = true;
|
||||||
|
}
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
|
if (followship && u2->region != r) {
|
||||||
|
follow = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -406,16 +406,6 @@ bool is_repeated(const order * ord)
|
||||||
result = 1;
|
result = 1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case K_FOLLOW:
|
|
||||||
/* FOLLOW is only a long order if we are following a ship. */
|
|
||||||
parser_pushstate();
|
|
||||||
init_tokens(ord);
|
|
||||||
skip_token();
|
|
||||||
s = getstrtoken();
|
|
||||||
result = isparam(s, lang, P_SHIP);
|
|
||||||
parser_popstate();
|
|
||||||
break;
|
|
||||||
|
|
||||||
case K_MAKE:
|
case K_MAKE:
|
||||||
/* Falls wir MACHE TEMP haben, ignorieren wir es. Alle anderen
|
/* Falls wir MACHE TEMP haben, ignorieren wir es. Alle anderen
|
||||||
* Arten von MACHE zaehlen aber als neue defaults und werden
|
* Arten von MACHE zaehlen aber als neue defaults und werden
|
||||||
|
@ -469,15 +459,6 @@ bool is_exclusive(const order * ord)
|
||||||
result = 1;
|
result = 1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case K_FOLLOW:
|
|
||||||
/* FOLLOW is only a long order if we are following a ship. */
|
|
||||||
parser_pushstate();
|
|
||||||
init_tokens(ord);
|
|
||||||
skip_token();
|
|
||||||
result = isparam(getstrtoken(), lang, P_SHIP);
|
|
||||||
parser_popstate();
|
|
||||||
break;
|
|
||||||
|
|
||||||
case K_MAKE:
|
case K_MAKE:
|
||||||
/* Falls wir MACHE TEMP haben, ignorieren wir es. Alle anderen
|
/* Falls wir MACHE TEMP haben, ignorieren wir es. Alle anderen
|
||||||
* Arten von MACHE zaehlen aber als neue defaults und werden
|
* Arten von MACHE zaehlen aber als neue defaults und werden
|
||||||
|
@ -532,15 +513,6 @@ bool is_long(const order * ord)
|
||||||
case K_PLANT:
|
case K_PLANT:
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
case K_FOLLOW:
|
|
||||||
/* FOLLOW is only a long order if we are following a ship. */
|
|
||||||
parser_pushstate();
|
|
||||||
init_tokens(ord);
|
|
||||||
skip_token();
|
|
||||||
result = isparam(getstrtoken(), lang, P_SHIP);
|
|
||||||
parser_popstate();
|
|
||||||
break;
|
|
||||||
|
|
||||||
case K_MAKE:
|
case K_MAKE:
|
||||||
/* Falls wir MACHE TEMP haben, ignorieren wir es. Alle anderen
|
/* Falls wir MACHE TEMP haben, ignorieren wir es. Alle anderen
|
||||||
* Arten von MACHE zaehlen aber als neue defaults und werden
|
* Arten von MACHE zaehlen aber als neue defaults und werden
|
||||||
|
|
Loading…
Reference in a new issue