mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-10-24 10:27:45 +00:00
Orb of Air now affects boats, statues, thumpers, and barrels
This commit is contained in:
@@ -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;
|
||||||
|
47
orbs.cpp
47
orbs.cpp
@@ -933,8 +933,22 @@ 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));
|
||||||
pushMonster(ct, cf, direction_hint);
|
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);
|
||||||
if(cf->item == itBabyTortoise) {
|
if(cf->item == itBabyTortoise) {
|
||||||
if(ct->item) ct->item = itNone;
|
if(ct->item) ct->item = itNone;
|
||||||
moveItem(cf, ct, true);
|
moveItem(cf, ct, true);
|
||||||
@@ -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(!isCheck(a)) blowoff(c, c2, di);
|
||||||
if(c2 && c2->cpdist > c->cpdist && passable(c2, c, P_BLOW)) {
|
return itOrbAir;
|
||||||
if(!isCheck(a)) blowoff(c, c2, di);
|
|
||||||
return itOrbAir;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
else nowhereToBlow = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// nature
|
// nature
|
||||||
|
Reference in New Issue
Block a user