1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-01-11 18:00:34 +00:00

Add Orb error messages for Phasing and Vaulting

This commit is contained in:
Jesse Ruderman 2021-08-09 04:26:56 -07:00
parent 8d98193e70
commit dbb6488557

View File

@ -1282,6 +1282,9 @@ EX eItem targetRangedOrb(cell *c, orbAction a) {
#define CHKV(b, v) ((b) ? true : (v, false)) #define CHKV(b, v) ((b) ? true : (v, false))
#define CHK(b, s) CHKV(b, orb_error_messages.push_back(s)) #define CHK(b, s) CHKV(b, orb_error_messages.push_back(s))
bool wouldkill_there = false;
bool wouldkill_here = false;
// (0-) strong wind // (0-) strong wind
if(items[itStrongWind] if(items[itStrongWind]
&& CHK(c->cpdist == 2 && cwt.at == whirlwind::jumpFromWhereTo(c, true), XLAT("Strong wind can only take you to a specific place!"))) { && CHK(c->cpdist == 2 && cwt.at == whirlwind::jumpFromWhereTo(c, true), XLAT("Strong wind can only take you to a specific place!"))) {
@ -1337,8 +1340,6 @@ EX eItem targetRangedOrb(cell *c, orbAction a) {
CHK(!nowhereToBlow, isBlowableMonster(c->monst) ? XLAT("Nowhere to blow %the1!", c->monst) : XLAT("Nowhere to blow %the1!", c->wall)); CHK(!nowhereToBlow, isBlowableMonster(c->monst) ? XLAT("Nowhere to blow %the1!", c->monst) : XLAT("Nowhere to blow %the1!", c->wall));
} }
int jumpstate = 0;
// nature // nature
if(items[itOrbNature] if(items[itOrbNature]
&& CHK(numplayers() == 1, XLAT("Cannot be used in multiplayer")) && CHK(numplayers() == 1, XLAT("Cannot be used in multiplayer"))
@ -1350,11 +1351,11 @@ EX eItem targetRangedOrb(cell *c, orbAction a) {
if(c->monst ? ( if(c->monst ? (
CHK(canAttack(cf, moFriendlyIvy, c, c->monst, 0), XLAT("Cannot attack there!")) && CHK(canAttack(cf, moFriendlyIvy, c, c->monst, 0), XLAT("Cannot attack there!")) &&
CHKV(!monstersnear(cwt.at, moPlayer), jumpstate = 99) CHKV(!monstersnear(cwt.at, moPlayer), wouldkill_here = true)
) : ( ) : (
CHK(passable(c, cf, P_ISPLAYER | P_MONSTER), XLAT("Cannot grow there!")) && CHK(passable(c, cf, P_ISPLAYER | P_MONSTER), XLAT("Cannot grow there!")) &&
CHK(!strictlyAgainstGravity(c, cf, false, MF_IVY), XLAT("Cannot grow against gravity!")) && CHK(!strictlyAgainstGravity(c, cf, false, MF_IVY), XLAT("Cannot grow against gravity!")) &&
CHKV(!monstersnear(cwt.at, moPlayer), jumpstate = 99)) CHKV(!monstersnear(cwt.at, moPlayer), wouldkill_here = true))
) )
dirs.push_back(d); dirs.push_back(d);
} }
@ -1373,10 +1374,18 @@ EX eItem targetRangedOrb(cell *c, orbAction a) {
if(!shmup::on && items[itOrbDash] && c->cpdist == 2) { if(!shmup::on && items[itOrbDash] && c->cpdist == 2) {
int i = items[itOrbAether]; int i = items[itOrbAether];
if(i) items[itOrbAether] = i-1; if(i) items[itOrbAether] = i-1;
jumpstate = 10 + check_vault(cwt.at, c, P_ISPLAYER, jumpthru); int vaultstate = check_vault(cwt.at, c, P_ISPLAYER, jumpthru);
items[itOrbAether] = i; items[itOrbAether] = i;
if(jumpstate == 16) { if(vaultstate == 0) orb_error_messages.push_back(XLAT("ERROR: No common neighbor to vault through!"));
if(vaultstate == 1) orb_error_messages.push_back(XLAT("Can only vault in a roughly straight line!"));
if(vaultstate == 2) orb_error_messages.push_back(XLAT("Nothing to vault over!"));
if(vaultstate == 3) orb_error_messages.push_back(XLAT("Cannot pass through %the1 while vaulting!", jumpthru->wall));
if(vaultstate == 4 && c->monst) orb_error_messages.push_back(XLAT("Cannot vault onto %the1!", c->monst));
if(vaultstate == 4 && !c->monst) orb_error_messages.push_back(XLAT("Cannot vault to %the1!", c->wall));
if(vaultstate == 5) orb_error_messages.push_back(XLAT("Cannot attack %the1 while vaulting!", jumpthru->monst));
if(vaultstate == 6) {
changes.init(isCheck(a)); changes.init(isCheck(a));
int k = tkills(); int k = tkills();
eMonster m = jumpthru->monst; eMonster m = jumpthru->monst;
@ -1398,20 +1407,35 @@ EX eItem targetRangedOrb(cell *c, orbAction a) {
if(m) if(m)
attackMonster(jumpthru, AF_NORMAL | AF_MSG, moPlayer); attackMonster(jumpthru, AF_NORMAL | AF_MSG, moPlayer);
k = tkills() - k; k = tkills() - k;
if(jumpTo(a, c, itOrbDash, k, m)) jumpstate = 17; if(jumpTo(a, c, itOrbDash, k, m)) vaultstate = 7;
if(jumpstate == 17) return itOrbDash; else wouldkill_there = true;
if(vaultstate == 7) return itOrbDash;
} }
} }
if(items[itOrbFrog] && c->cpdist == 2) { if(items[itOrbFrog] && c->cpdist == 2) {
int i = items[itOrbAether]; int i = items[itOrbAether];
if(i) items[itOrbAether] = i-1; if(i) items[itOrbAether] = i-1;
jumpstate = check_jump(cwt.at, c, P_ISPLAYER, jumpthru); int frogstate = check_jump(cwt.at, c, P_ISPLAYER, jumpthru);
items[itOrbAether] = i; items[itOrbAether] = i;
if(jumpstate == 3) { if(frogstate == 1 && jumpthru && jumpthru->monst) {
orb_error_messages.push_back(XLAT("Cannot jump through %the1!", jumpthru->monst));
}
else if(frogstate == 1 && jumpthru) {
orb_error_messages.push_back(XLAT("Cannot jump through %the1!", jumpthru->wall));
}
else if(frogstate == 2 && c->monst) {
orb_error_messages.push_back(XLAT("Cannot jump onto %the1!", c->monst));
}
else if(frogstate == 2 && c->wall) {
orb_error_messages.push_back(XLAT("Cannot jump on %the1!", c->wall));
}
if(frogstate == 3) {
changes.init(isCheck(a)); changes.init(isCheck(a));
if(jumpTo(a, c, itOrbFrog)) jumpstate = 4; if(jumpTo(a, c, itOrbFrog)) frogstate = 4;
if(jumpstate == 4) return itOrbFrog; else wouldkill_there = true;
if(frogstate == 4) return itOrbFrog;
} }
} }
@ -1419,14 +1443,25 @@ EX eItem targetRangedOrb(cell *c, orbAction a) {
if(shmup::on) shmup::pushmonsters(); if(shmup::on) shmup::pushmonsters();
int i = items[itOrbAether]; int i = items[itOrbAether];
if(i) items[itOrbAether] = i-1; if(i) items[itOrbAether] = i-1;
jumpstate = 20 + check_phase(cwt.at, c, P_ISPLAYER, jumpthru); int phasestate = check_phase(cwt.at, c, P_ISPLAYER, jumpthru);
items[itOrbAether] = i; items[itOrbAether] = i;
if(jumpstate == 23) { if(phasestate == 1 && c->monst) {
orb_error_messages.push_back(XLAT("Cannot phase onto %the1!", c->monst));
}
else if(phasestate == 1) {
orb_error_messages.push_back(XLAT("Cannot phase to %the1!", c->wall));
}
else if(phasestate == 2) {
orb_error_messages.push_back(XLAT("Nothing to phase through!"));
}
if(phasestate == 3) {
changes.init(isCheck(a)); changes.init(isCheck(a));
if(jumpTo(a, c, itOrbPhasing)) jumpstate = 24; if(jumpTo(a, c, itOrbPhasing)) phasestate = 4;
else wouldkill_there = true;
} }
if(shmup::on) shmup::popmonsters(); if(shmup::on) shmup::popmonsters();
if(jumpstate == 24) return itOrbPhasing; if(phasestate == 4) return itOrbPhasing;
} }
// (1) switch with an illusion // (1) switch with an illusion
@ -1541,21 +1576,9 @@ EX eItem targetRangedOrb(cell *c, orbAction a) {
for(string s: orb_error_messages) addMessage(s); for(string s: orb_error_messages) addMessage(s);
if(jumpstate == 1 && jumpthru && jumpthru->monst) { if(wouldkill_there)
addMessage(XLAT("Cannot jump through %the1!", jumpthru->monst));
}
else if(jumpstate == 1 && jumpthru) {
addMessage(XLAT("Cannot jump through %the1!", jumpthru->wall));
}
else if(jumpstate == 2 && c->monst) {
addMessage(XLAT("Cannot jump on %the1!", c->monst));
}
else if(jumpstate == 2 && c->wall) {
addMessage(XLAT("Cannot jump on %the1!", c->wall));
}
else if(jumpstate == 3)
wouldkill("%The1 would get you there!"); wouldkill("%The1 would get you there!");
else if(jumpstate == 99) if(wouldkill_here)
wouldkill("%The1 would get you if you grew there!"); wouldkill("%The1 would get you if you grew there!");
#undef CHK #undef CHK