Bug 1610 FOLGE SCHIFF und andere lange Befehle

FOLGE SCHIFF ist genau wie FOLGE EINHEIT jetzt ein Halblanger Befehl.
Das ist konsequent und entfernt an einigen Stellen Spezialbehandlungen.
This commit is contained in:
CTD 2014-08-07 18:53:29 +02:00 committed by Enno Rehling
parent f33de38812
commit bf4bda36a2
2 changed files with 53 additions and 44 deletions

View file

@ -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;

View file

@ -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