Complete OBJ localization in actions2.c

This commit is contained in:
Eric S. Raymond 2017-06-07 08:48:12 -04:00
parent df83a345a2
commit f01cb89a76
3 changed files with 25 additions and 25 deletions

View file

@ -161,7 +161,7 @@ L8010: if(game.atloc[game.loc] == 0 || game.link[game.atloc[game.loc]] != 0 || A
/* Transitive carry/drop are in separate file. */ /* Transitive carry/drop are in separate file. */
L9010: return(carry()); L9010: return(carry(OBJ));
L9020: return(discard(OBJ, false)); L9020: return(discard(OBJ, false));
/* SAY. Echo WD2 (or WD1 if no WD2 (SAY WHAT?, etc.).) Magic words override. */ /* SAY. Echo WD2 (or WD1 if no WD2 (SAY WHAT?, etc.).) Magic words override. */

View file

@ -5,44 +5,44 @@
* take one without the other). Liquids also special, since they depend on * take one without the other). Liquids also special, since they depend on
* status of bottle. Also various side effects, etc. */ * status of bottle. Also various side effects, etc. */
int carry(void) { int carry(long obj) {
if(TOTING(OBJ)) return(2011); if(TOTING(obj)) return(2011);
SPK=25; SPK=25;
if(OBJ == PLANT && game.prop[PLANT] <= 0)SPK=115; if(obj == PLANT && game.prop[PLANT] <= 0)SPK=115;
if(OBJ == BEAR && game.prop[BEAR] == 1)SPK=169; if(obj == BEAR && game.prop[BEAR] == 1)SPK=169;
if(OBJ == CHAIN && game.prop[BEAR] != 0)SPK=170; if(obj == CHAIN && game.prop[BEAR] != 0)SPK=170;
if(OBJ == URN)SPK=215; if(obj == URN)SPK=215;
if(OBJ == CAVITY)SPK=217; if(obj == CAVITY)SPK=217;
if(OBJ == BLOOD)SPK=239; if(obj == BLOOD)SPK=239;
if(OBJ == RUG && game.prop[RUG] == 2)SPK=222; if(obj == RUG && game.prop[RUG] == 2)SPK=222;
if(OBJ == SIGN)SPK=196; if(obj == SIGN)SPK=196;
if(OBJ != MESSAG) goto L9011; if(obj != MESSAG) goto L9011;
SPK=190; SPK=190;
DSTROY(MESSAG); DSTROY(MESSAG);
L9011: if(game.fixed[OBJ] != 0) return(2011); L9011: if(game.fixed[obj] != 0) return(2011);
if(OBJ != WATER && OBJ != OIL) goto L9017; if(obj != WATER && obj != OIL) goto L9017;
K=OBJ; K=obj;
OBJ=BOTTLE; obj=BOTTLE;
if(HERE(BOTTLE) && LIQ(0) == K) goto L9017; if(HERE(BOTTLE) && LIQ(0) == K) goto L9017;
if(TOTING(BOTTLE) && game.prop[BOTTLE] == 1) return(fill(OBJ)); if(TOTING(BOTTLE) && game.prop[BOTTLE] == 1) return(fill(obj));
if(game.prop[BOTTLE] != 1)SPK=105; if(game.prop[BOTTLE] != 1)SPK=105;
if(!TOTING(BOTTLE))SPK=104; if(!TOTING(BOTTLE))SPK=104;
return(2011); return(2011);
L9017: SPK=92; L9017: SPK=92;
if(game.holdng >= 7) return(2011); if(game.holdng >= 7) return(2011);
if(OBJ != BIRD || game.prop[BIRD] == 1 || -1-game.prop[BIRD] == 1) goto L9014; if(obj != BIRD || game.prop[BIRD] == 1 || -1-game.prop[BIRD] == 1) goto L9014;
if(game.prop[BIRD] == 2) goto L9015; if(game.prop[BIRD] == 2) goto L9015;
if(!TOTING(CAGE))SPK=27; if(!TOTING(CAGE))SPK=27;
if(TOTING(ROD))SPK=26; if(TOTING(ROD))SPK=26;
if(SPK/2 == 13) return(2011); if(SPK/2 == 13) return(2011);
game.prop[BIRD]=1; game.prop[BIRD]=1;
L9014: if((OBJ == BIRD || OBJ == CAGE) && (game.prop[BIRD] == 1 || -1-game.prop[BIRD] == L9014: if((obj == BIRD || obj == CAGE) && (game.prop[BIRD] == 1 || -1-game.prop[BIRD] ==
1))CARRY(BIRD+CAGE-OBJ,game.loc); 1))CARRY(BIRD+CAGE-obj,game.loc);
CARRY(OBJ,game.loc); CARRY(obj,game.loc);
K=LIQ(0); K=LIQ(0);
if(OBJ == BOTTLE && K != 0)game.place[K]= -1; if(obj == BOTTLE && K != 0)game.place[K]= -1;
if(!GSTONE(OBJ) || game.prop[OBJ] == 0) return(2009); if(!GSTONE(obj) || game.prop[obj] == 0) return(2009);
game.prop[OBJ]=0; game.prop[obj]=0;
game.prop[CAVITY]=1; game.prop[CAVITY]=1;
return(2009); return(2009);

View file

@ -38,7 +38,7 @@
#define OUTSID(LOC) ((LOC) <= 8 || FOREST(LOC) || (LOC) == PLAC[SAPPH] || (LOC) == 180 || (LOC) == 182) #define OUTSID(LOC) ((LOC) <= 8 || FOREST(LOC) || (LOC) == PLAC[SAPPH] || (LOC) == 180 || (LOC) == 182)
#define INDEEP(LOC) ((LOC) >= 15 && !OUTSID(LOC) && (LOC) != 179) #define INDEEP(LOC) ((LOC) >= 15 && !OUTSID(LOC) && (LOC) != 179)
extern int carry(void), discard(long, bool), attack(FILE *, long), throw(FILE *, long obj), feed(long), fill(long); extern int carry(long), discard(long, bool), attack(FILE *, long), throw(FILE *, long obj), feed(long), fill(long);
void score(long); void score(long);