1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-10-26 11:27:39 +00:00

Orb of Air now affects boats, statues, thumpers, and barrels

This commit is contained in:
Zeno Rogue
2019-01-03 03:19:38 +01:00
parent f546bba84a
commit 458b3f5dae
2 changed files with 39 additions and 12 deletions

View File

@@ -31,6 +31,10 @@ bool isWatery(cell *c) {
return c->wall == waCamelotMoat || c->wall == waSea || c->wall == waLake; return c->wall == waCamelotMoat || c->wall == waSea || c->wall == waLake;
} }
bool isBoat(cell *c) {
return among(c->wall, waBoat, waStrandedBoat);
}
bool isChasmy(cell *c) { bool isChasmy(cell *c) {
return c->wall == waChasm || c->wall == waSulphur || c->wall == waSulphurC || c->wall == waBubble || return c->wall == waChasm || c->wall == waSulphur || c->wall == waSulphurC || c->wall == waBubble ||
c->wall == waMercury; c->wall == waMercury;

View File

@@ -933,7 +933,21 @@ void placeIllusion(cell *c) {
void blowoff(cell *cf, cell *ct, int direction_hint) { void blowoff(cell *cf, cell *ct, int direction_hint) {
playSound(ct, "orb-ranged"); playSound(ct, "orb-ranged");
if(cf->monst)
addMessage(XLAT("You blow %the1 away!", cf->monst)); addMessage(XLAT("You blow %the1 away!", cf->monst));
if(cf->wall == waThumperOff) activateActiv(cf, false);
if(isPushable(cf->wall) || cf->wall == waBigStatue)
pushThumper(cf, ct);
else if(isBoat(cf) && !cf->monst) {
bool was_stranded = cf->wall == waStrandedBoat;
bool willbe_stranded = ct->wall == waNone;
if(was_stranded) cf->wall = waBoat;
if(willbe_stranded) ct->wall = waSea;
moveBoat(ct, cf, direction_hint);
if(was_stranded) cf->wall = waNone;
if(willbe_stranded) ct->wall = waStrandedBoat;
}
else
pushMonster(ct, cf, direction_hint); pushMonster(ct, cf, direction_hint);
if(cf->item == itBabyTortoise) { if(cf->item == itBabyTortoise) {
if(ct->item) ct->item = itNone; if(ct->item) ct->item = itNone;
@@ -967,6 +981,17 @@ bool monstersnearO(orbAction a, cell *c, cell *nocount, eMonster who, cell *push
bool isCheck(orbAction a) { return a == roCheck || a == roMultiCheck; } bool isCheck(orbAction a) { return a == roCheck || a == roMultiCheck; }
bool isWeakCheck(orbAction a) { return a == roCheck || a == roMultiCheck || a == roMouse; } bool isWeakCheck(orbAction a) { return a == roCheck || a == roMultiCheck || a == roMouse; }
cell *blowoff_destination(cell *c, int& di) {
int d = 0;
for(; d<c->type; d++) if(c->move(d) && c->move(d)->cpdist < c->cpdist) break;
if(d<c->type) for(int e=d; e<d+c->type; e++) {
int di = e % c->type;
cell *c2 = c->move(di);
if(c2 && c2->cpdist > c->cpdist && passable(c2, c, P_BLOW)) return c2;
}
return NULL;
}
eItem targetRangedOrb(cell *c, orbAction a) { eItem targetRangedOrb(cell *c, orbAction a) {
if(!haveRangedOrb()) { if(!haveRangedOrb()) {
@@ -1027,18 +1052,16 @@ eItem targetRangedOrb(cell *c, orbAction a) {
// (0') air blow // (0') air blow
bool nowhereToBlow = false; bool nowhereToBlow = false;
if(items[itOrbAir] && isBlowableMonster(c->monst)) { if(items[itOrbAir] && (isBlowableMonster(c->monst) || isPushable(c->wall) || c->wall == waBigStatue || isBoat(c))) {
int d = 0; int di = NODIR;
for(; d<c->type; d++) if(c->move(d) && c->move(d)->cpdist < c->cpdist) break; cell *c2 = blowoff_destination(c, di);
if(d<c->type) for(int e=d; e<d+c->type; e++) { if(c2 && isBoat(c) && !isWatery(c2) && c2->wall != waNone) c2 = NULL;
nowhereToBlow = true; if(c2 && c->wall == waBigStatue && !canPushStatueOn(c2)) c2 = NULL;
int di = e % c->type; if(c2) {
cell *c2 = c->move(di);
if(c2 && c2->cpdist > c->cpdist && passable(c2, c, P_BLOW)) {
if(!isCheck(a)) blowoff(c, c2, di); if(!isCheck(a)) blowoff(c, c2, di);
return itOrbAir; return itOrbAir;
} }
} else nowhereToBlow = true;
} }
// nature // nature