forked from github/server
Bugfix crashbug bei Astraler Wirbel
This commit is contained in:
parent
53d6b4c2b8
commit
7d927094dd
3 changed files with 28 additions and 23 deletions
|
@ -3849,8 +3849,12 @@ eval_direction(struct opstack ** stack, const void * userdata)
|
||||||
{
|
{
|
||||||
const faction * report = (const faction*)userdata;
|
const faction * report = (const faction*)userdata;
|
||||||
int i = opop(stack, int);
|
int i = opop(stack, int);
|
||||||
|
const char * c;
|
||||||
const char * c = LOC(report->locale, directions[i]);
|
if (i>=0) {
|
||||||
|
c = LOC(report->locale, directions[i]);
|
||||||
|
} else {
|
||||||
|
c = LOC(report->locale, "unknown_direction");
|
||||||
|
}
|
||||||
opush(stack, strcpy(balloc(strlen(c)+1), c));
|
opush(stack, strcpy(balloc(strlen(c)+1), c));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -37,20 +37,20 @@ extern "C" {
|
||||||
/* #define MSG_LEVELS -- msg-levels active */
|
/* #define MSG_LEVELS -- msg-levels active */
|
||||||
|
|
||||||
/* basic types used in the eressea "kernel" */
|
/* basic types used in the eressea "kernel" */
|
||||||
typedef unsigned char order_t;
|
typedef short order_t;
|
||||||
typedef char terrain_t;
|
typedef short terrain_t;
|
||||||
typedef char direction_t;
|
typedef short direction_t;
|
||||||
typedef int race_t;
|
typedef short race_t;
|
||||||
typedef int magic_t;
|
typedef short magic_t;
|
||||||
typedef short skill_t;
|
typedef short skill_t;
|
||||||
typedef short typ_t;
|
typedef short typ_t;
|
||||||
typedef int herb_t;
|
typedef short herb_t;
|
||||||
typedef int potion_t;
|
typedef short potion_t;
|
||||||
typedef int luxury_t;
|
typedef short luxury_t;
|
||||||
typedef int weapon_t;
|
typedef short weapon_t;
|
||||||
typedef int item_t;
|
typedef short item_t;
|
||||||
typedef int resource_t;
|
typedef short resource_t;
|
||||||
typedef int spellid_t;
|
typedef short spellid_t;
|
||||||
|
|
||||||
struct plane;
|
struct plane;
|
||||||
struct spell;
|
struct spell;
|
||||||
|
|
|
@ -1058,7 +1058,7 @@ travel(region * first, unit * u, region * next, int flucht)
|
||||||
direction_t dir = reldirection(current, next);
|
direction_t dir = reldirection(current, next);
|
||||||
border * b = get_borders(current, next);
|
border * b = get_borders(current, next);
|
||||||
|
|
||||||
while (b) {
|
while (b!=NULL) {
|
||||||
if (b->type==&bt_wisps) {
|
if (b->type==&bt_wisps) {
|
||||||
wall_data * wd = (wall_data*)b->data;
|
wall_data * wd = (wall_data*)b->data;
|
||||||
if (wd->active) {
|
if (wd->active) {
|
||||||
|
@ -1081,15 +1081,17 @@ travel(region * first, unit * u, region * next, int flucht)
|
||||||
k -= BP_NORMAL;
|
k -= BP_NORMAL;
|
||||||
if (k<0) break;
|
if (k<0) break;
|
||||||
/* r2 -> Zielregion, r3 -> Momentane Region */
|
/* r2 -> Zielregion, r3 -> Momentane Region */
|
||||||
if (move_blocked(u, current, reldirection(current, next))
|
if (dir>=0 && move_blocked(u, current, dir)
|
||||||
|| curse_active(get_curse(current->attribs, fogtrap_ct)))
|
|| curse_active(get_curse(current->attribs, fogtrap_ct)))
|
||||||
{
|
{
|
||||||
ADDMSG(&u->faction->msgs, msg_message("leavefail",
|
ADDMSG(&u->faction->msgs, msg_message("leavefail",
|
||||||
"unit region", u, next));
|
"unit region",
|
||||||
|
u, next));
|
||||||
}
|
}
|
||||||
if (!entrance_allowed(u, next)) {
|
if (!entrance_allowed(u, next)) {
|
||||||
ADDMSG(&u->faction->msgs, msg_message("regionowned",
|
ADDMSG(&u->faction->msgs, msg_message("regionowned",
|
||||||
"unit region target", u, current, next));
|
"unit region target",
|
||||||
|
u, current, next));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if ((wache = bewegung_blockiert_von(u, current)) != (unit *) NULL
|
if ((wache = bewegung_blockiert_von(u, current)) != (unit *) NULL
|
||||||
|
@ -1116,10 +1118,9 @@ travel(region * first, unit * u, region * next, int flucht)
|
||||||
|
|
||||||
if (rterrain(next) == T_OCEAN && !canswim(u)) {
|
if (rterrain(next) == T_OCEAN && !canswim(u)) {
|
||||||
plane *pl = getplane(next);
|
plane *pl = getplane(next);
|
||||||
if(pl && fval(pl, PFL_NOCOORDS)) {
|
if (pl!=NULL && fval(pl, PFL_NOCOORDS)) {
|
||||||
add_message(&u->faction->msgs, new_message(u->faction,
|
add_message(&u->faction->msgs, new_message(u->faction,
|
||||||
"detectoceandir%u:unit%i:direction", u,
|
"detectoceandir%u:unit%i:direction", u, dir));
|
||||||
reldirection(current, next)));
|
|
||||||
} else {
|
} else {
|
||||||
add_message(&u->faction->msgs, new_message(u->faction,
|
add_message(&u->faction->msgs, new_message(u->faction,
|
||||||
"detectocean%u:unit%r:region", u, next));
|
"detectocean%u:unit%r:region", u, next));
|
||||||
|
@ -1131,7 +1132,7 @@ travel(region * first, unit * u, region * next, int flucht)
|
||||||
plane *pl = getplane(next);
|
plane *pl = getplane(next);
|
||||||
if(pl && fval(pl, PFL_NOCOORDS)) {
|
if(pl && fval(pl, PFL_NOCOORDS)) {
|
||||||
add_message(&u->faction->msgs, new_message(u->faction,
|
add_message(&u->faction->msgs, new_message(u->faction,
|
||||||
"detectforbiddendir%u:unit%i:direction", u, reldirection(current, next)));
|
"detectforbiddendir%u:unit%i:direction", u, dir));
|
||||||
} else {
|
} else {
|
||||||
add_message(&u->faction->msgs, new_message(u->faction,
|
add_message(&u->faction->msgs, new_message(u->faction,
|
||||||
"detectforbidden%u:unit%r:region", u, next));
|
"detectforbidden%u:unit%r:region", u, next));
|
||||||
|
|
Loading…
Reference in a new issue