/* File: cmd6.c */
-/* Purpose: Object commands */
-
/*
- * Copyright (c) 1989 James E. Wilson, Robert A. Koeneke
+ * Copyright (c) 1997 Ben Harrison, James E. Wilson, Robert A. Koeneke
*
- * This software may be copied and distributed for educational, research, and
- * not for profit purposes provided that this copyright and statement are
- * included in all such copies.
+ * This software may be copied and distributed for educational, research,
+ * and not for profit purposes provided that this copyright and statement
+ * are included in all such copies. Other copyrights may also apply.
*/
+/* Purpose: Object commands */
+
#include "angband.h"
{
case SV_FOOD_POISON:
{
- if (!(p_ptr->resist_pois || p_ptr->oppose_pois))
+ if (!(p_ptr->resist_pois || IS_OPPOSE_POIS()))
{
if (set_poisoned(p_ptr->poisoned + randint0(10) + 10))
{
}
/* We have tried it */
- object_tried(o_ptr);
+ if (o_ptr->tval == TV_FOOD) object_tried(o_ptr);
/* The player is now aware of the object */
if (ident && !object_aware_p(o_ptr))
#endif
}
- else if (p_ptr->prace == RACE_SKELETON)
+ else if ((prace_is_(RACE_SKELETON) ||
+ prace_is_(RACE_GOLEM) ||
+ prace_is_(RACE_ZOMBIE) ||
+ prace_is_(RACE_SPECTRE)) &&
+ (o_ptr->tval == TV_STAFF || o_ptr->tval == TV_WAND))
{
+ cptr staff;
+
+ if (o_ptr->tval == TV_STAFF &&
+ (item < 0) && (o_ptr->number > 1))
+ {
+#ifdef JP
+ msg_print("¤Þ¤º¤Ï¾ó¤ò½¦¤ï¤Ê¤±¤ì¤Ð¡£");
+#else
+ msg_print("You must first pick up the staffs.");
+#endif
+ return;
+ }
+
+#ifdef JP
+ staff = (o_ptr->tval == TV_STAFF) ? "¾ó" : "ËâË¡ËÀ";
+#else
+ staff = (o_ptr->tval == TV_STAFF) ? "staff" : "wand";
+#endif
+
+ /* "Eat" charges */
+ if (o_ptr->pval == 0)
+ {
+#ifdef JP
+ msg_format("¤³¤Î%s¤Ë¤Ï¤â¤¦ËâÎϤ¬»Ä¤Ã¤Æ¤¤¤Ê¤¤¡£", staff);
+#else
+ msg_format("The %s has no charges left.", staff);
+#endif
+
+ o_ptr->ident |= (IDENT_EMPTY);
+
+ /* Combine / Reorder the pack (later) */
+ p_ptr->notice |= (PN_COMBINE | PN_REORDER);
+ p_ptr->window |= (PW_INVEN);
+
+ return;
+ }
+
+#ifdef JP
+ msg_format("¤¢¤Ê¤¿¤Ï%s¤ÎËâÎϤò¥¨¥Í¥ë¥®¡¼¸»¤È¤·¤ÆµÛ¼ý¤·¤¿¡£", staff);
+#else
+ msg_format("You absorb mana of the %s as your energy.", staff);
+#endif
+
+ /* Use a single charge */
+ o_ptr->pval--;
+
+ /* Eat a charge */
+ set_food(p_ptr->food + 5000);
+
+ /* XXX Hack -- unstack if necessary */
+ if (o_ptr->tval == TV_STAFF &&
+ (item >= 0) && (o_ptr->number > 1))
+ {
+ object_type forge;
+ object_type *q_ptr;
+
+ /* Get local object */
+ q_ptr = &forge;
+
+ /* Obtain a local object */
+ object_copy(q_ptr, o_ptr);
+
+ /* Modify quantity */
+ q_ptr->number = 1;
+
+ /* Restore the charges */
+ o_ptr->pval++;
+
+ /* Unstack the used item */
+ o_ptr->number--;
+ p_ptr->total_weight -= q_ptr->weight;
+ item = inven_carry(q_ptr);
+
+ /* Message */
+#ifdef JP
+ msg_format("¾ó¤ò¤Þ¤È¤á¤Ê¤ª¤·¤¿¡£");
+#else
+ msg_print("You unstack your staff.");
+#endif
+ }
+
+ /* Describe charges in the pack */
+ if (item >= 0)
+ {
+ inven_item_charges(item);
+ }
+
+ /* Describe charges on the floor */
+ else
+ {
+ floor_item_charges(0 - item);
+ }
+
+ /* Don't eat a staff/wand itself */
+ return;
+ }
+ else if ((prace_is_(RACE_DEMON) ||
+ (mimic_info[p_ptr->mimic_form].MIMIC_FLAGS & MIMIC_IS_DEMON)) &&
+ (o_ptr->tval == TV_CORPSE && o_ptr->sval == SV_CORPSE &&
+ strchr("pht", r_info[o_ptr->pval].d_char)))
+ {
+ /* Drain vitality of humanoids */
+ char o_name[MAX_NLEN];
+
+ object_desc(o_name, o_ptr, FALSE, 0);
+
+#ifdef JP
+ msg_format("%s¤Ïdz¤¨¾å¤ê³¥¤Ë¤Ê¤Ã¤¿¡£ÀºÎϤòµÛ¼ý¤·¤¿µ¤¤¬¤¹¤ë¡£", o_name);
+#else
+ msg_format("%^s is burnt to ashes. You absorb its vitality!", o_name);
+#endif
+ (void)set_food(PY_FOOD_MAX - 1);
+ }
+ else if (prace_is_(RACE_SKELETON))
+ {
+#if 0
+ if (o_ptr->tval == TV_SKELETON ||
+ (o_ptr->tval == TV_CORPSE && o_ptr->sval == SV_SKELETON))
+ {
+#ifdef JP
+ msg_print("¤¢¤Ê¤¿¤Ï¹ü¤Ç¼«Ê¬¤ÎÂΤòÊä¤Ã¤¿¡£");
+#else
+ msg_print("Your body absorbs the bone.");
+#endif
+ set_food(p_ptr->food + 5000);
+ }
+ else
+#endif
+
if (!((o_ptr->sval == SV_FOOD_WAYBREAD) ||
(o_ptr->sval < SV_FOOD_BISCUIT)))
{
}
}
- else if ((p_ptr->prace == RACE_GOLEM) ||
- (p_ptr->prace == RACE_ZOMBIE) ||
- (p_ptr->prace == RACE_ENT) ||
- (p_ptr->prace == RACE_DEMON) ||
- (p_ptr->prace == RACE_ANDROID) ||
- (p_ptr->prace == RACE_SPECTRE) ||
+ else if (prace_is_(RACE_GOLEM) ||
+ prace_is_(RACE_ZOMBIE) ||
+ prace_is_(RACE_ENT) ||
+ prace_is_(RACE_DEMON) ||
+ prace_is_(RACE_ANDROID) ||
+ prace_is_(RACE_SPECTRE) ||
(mimic_info[p_ptr->mimic_form].MIMIC_FLAGS & MIMIC_IS_NONLIVING))
{
#ifdef JP
set_food(p_ptr->food + ((o_ptr->pval) / 20));
}
+ else if (o_ptr->tval == TV_FOOD && o_ptr->sval == SV_FOOD_WAYBREAD)
+ {
+ /* Waybread is always fully satisfying. */
+ set_food(MAX(p_ptr->food, PY_FOOD_MAX - 1));
+ }
else
{
+ /* Food can feed the player */
(void)set_food(p_ptr->food + o_ptr->pval);
}
*/
static bool item_tester_hook_eatable(object_type *o_ptr)
{
-/* if ((o_ptr->tval==TV_FOOD) || ((o_ptr->tval==TV_CORPSE) && o_ptr->sval)) return (TRUE); */
- if (o_ptr->tval==TV_FOOD) return (TRUE);
+ if (o_ptr->tval==TV_FOOD) return TRUE;
+
+#if 0
+ if (prace_is_(RACE_SKELETON))
+ {
+ if (o_ptr->tval == TV_SKELETON ||
+ (o_ptr->tval == TV_CORPSE && o_ptr->sval == SV_SKELETON))
+ return TRUE;
+ }
+ else
+#endif
+
+ if (prace_is_(RACE_SKELETON) ||
+ prace_is_(RACE_GOLEM) ||
+ prace_is_(RACE_ZOMBIE) ||
+ prace_is_(RACE_SPECTRE))
+ {
+ if (o_ptr->tval == TV_STAFF || o_ptr->tval == TV_WAND)
+ return TRUE;
+ }
+ else if (prace_is_(RACE_DEMON) ||
+ (mimic_info[p_ptr->mimic_form].MIMIC_FLAGS & MIMIC_IS_DEMON))
+ {
+ if (o_ptr->tval == TV_CORPSE &&
+ o_ptr->sval == SV_CORPSE &&
+ strchr("pht", r_info[o_ptr->pval].d_char))
+ return TRUE;
+ }
/* Assume not */
return (FALSE);
return;
}
- if((p_ptr->pclass == CLASS_BARD) && p_ptr->magic_num1[0])
- {
- stop_singing();
- }
+ if((p_ptr->pclass == CLASS_BARD) && p_ptr->magic_num1[0])
+ {
+ stop_singing();
+ }
/* Get the item (in the pack) */
if (item >= 0)
lev = get_object_level(q_ptr);
/* Analyze the potion */
- switch (q_ptr->sval)
+ if (q_ptr->tval == TV_POTION)
{
+ switch (q_ptr->sval)
+ {
#ifdef JP
- /* °û¤ß¤´¤¿¤¨¤ò¥ª¥ê¥¸¥Ê¥ë¤è¤êºÙ¤«¤¯É½¸½ */
+ /* °û¤ß¤´¤¿¤¨¤ò¥ª¥ê¥¸¥Ê¥ë¤è¤êºÙ¤«¤¯É½¸½ */
case SV_POTION_WATER:
- {
msg_print("¸ý¤ÎÃ椬¤µ¤Ã¤Ñ¤ê¤·¤¿¡£");
msg_print("¤Î¤É¤Î³é¤¤¬¾¯¤·¤ª¤µ¤Þ¤Ã¤¿¡£");
ident = TRUE;
break;
- }
+
case SV_POTION_APPLE_JUICE:
- {
msg_print("´Å¤¯¤Æ¥µ¥Ã¥Ñ¥ê¤È¤·¤Æ¤¤¤Æ¡¢¤È¤Æ¤â¤ª¤¤¤·¤¤¡£");
msg_print("¤Î¤É¤Î³é¤¤¬¾¯¤·¤ª¤µ¤Þ¤Ã¤¿¡£");
ident = TRUE;
break;
- }
+
case SV_POTION_SLIME_MOLD:
- {
msg_print("¤Ê¤ó¤È¤âÉÔµ¤Ì£¤ÊÌ£¤À¡£");
msg_print("¤Î¤É¤Î³é¤¤¬¾¯¤·¤ª¤µ¤Þ¤Ã¤¿¡£");
ident = TRUE;
break;
- }
+
#else
case SV_POTION_WATER:
case SV_POTION_APPLE_JUICE:
case SV_POTION_SLIME_MOLD:
- {
msg_print("You feel less thirsty.");
ident = TRUE;
break;
- }
#endif
-
case SV_POTION_SLOWNESS:
- {
if (set_slow(randint1(25) + 15, FALSE)) ident = TRUE;
break;
- }
case SV_POTION_SALT_WATER:
- {
#ifdef JP
msg_print("¤¦¤§¡ª»×¤ï¤ºÅǤ¤¤Æ¤·¤Þ¤Ã¤¿¡£");
#else
msg_print("The potion makes you vomit!");
#endif
- (void)set_food(PY_FOOD_STARVE - 1);
+ if (!(prace_is_(RACE_GOLEM) ||
+ prace_is_(RACE_ZOMBIE) ||
+ prace_is_(RACE_DEMON) ||
+ prace_is_(RACE_ANDROID) ||
+ prace_is_(RACE_SPECTRE) ||
+ (mimic_info[p_ptr->mimic_form].MIMIC_FLAGS & MIMIC_IS_NONLIVING)))
+ {
+ /* Only living creatures get thirsty */
+ (void)set_food(PY_FOOD_STARVE - 1);
+ }
+
(void)set_poisoned(0);
(void)set_paralyzed(p_ptr->paralyzed + 4);
ident = TRUE;
break;
- }
case SV_POTION_POISON:
- {
- if (!(p_ptr->resist_pois || p_ptr->oppose_pois))
+ if (!(p_ptr->resist_pois || IS_OPPOSE_POIS()))
{
if (set_poisoned(p_ptr->poisoned + randint0(15) + 10))
{
}
}
break;
- }
case SV_POTION_BLINDNESS:
- {
if (!p_ptr->resist_blind)
{
if (set_blind(p_ptr->blind + randint0(100) + 100))
}
}
break;
- }
case SV_POTION_CONFUSION: /* Booze */
- {
if (p_ptr->pclass != CLASS_MONK) chg_virtue(V_HARMONY, -1);
else if (!p_ptr->resist_conf) p_ptr->special_attack |= ATTACK_SUIKEN;
if (!p_ptr->resist_conf)
}
}
break;
- }
case SV_POTION_SLEEP:
- {
if (!p_ptr->free_act)
{
#ifdef JP
- msg_print("¤¢¤Ê¤¿¤Ï̲¤Ã¤Æ¤·¤Þ¤Ã¤¿¡£");
+ msg_print("¤¢¤Ê¤¿¤Ï̲¤Ã¤Æ¤·¤Þ¤Ã¤¿¡£");
#else
- msg_print("You fall asleep.");
+ msg_print("You fall asleep.");
#endif
}
}
break;
- }
case SV_POTION_LOSE_MEMORIES:
- {
if (!p_ptr->hold_life && (p_ptr->exp > 0))
{
#ifdef JP
ident = TRUE;
}
break;
- }
case SV_POTION_RUINATION:
- {
#ifdef JP
msg_print("¿È¤â¿´¤â¼å¤Ã¤Æ¤¤Æ¡¢Àºµ¤¤¬È´¤±¤Æ¤¤¤¯¤è¤¦¤À¡£");
take_hit(DAMAGE_LOSELIFE, damroll(10, 10), "ÇËÌǤÎÌô", -1);
(void)dec_stat(A_INT, 25, TRUE);
ident = TRUE;
break;
- }
case SV_POTION_DEC_STR:
- {
if (do_dec_stat(A_STR)) ident = TRUE;
break;
- }
case SV_POTION_DEC_INT:
- {
if (do_dec_stat(A_INT)) ident = TRUE;
break;
- }
case SV_POTION_DEC_WIS:
- {
if (do_dec_stat(A_WIS)) ident = TRUE;
break;
- }
case SV_POTION_DEC_DEX:
- {
if (do_dec_stat(A_DEX)) ident = TRUE;
break;
- }
case SV_POTION_DEC_CON:
- {
if (do_dec_stat(A_CON)) ident = TRUE;
break;
- }
case SV_POTION_DEC_CHR:
- {
if (do_dec_stat(A_CHR)) ident = TRUE;
break;
- }
case SV_POTION_DETONATIONS:
- {
#ifdef JP
msg_print("ÂΤÎÃæ¤Ç·ã¤·¤¤Çúȯ¤¬µ¯¤¤¿¡ª");
take_hit(DAMAGE_NOESCAPE, damroll(50, 20), "Çúȯ¤ÎÌô", -1);
(void)set_cut(p_ptr->cut + 5000);
ident = TRUE;
break;
- }
case SV_POTION_DEATH:
- {
chg_virtue(V_VITALITY, -1);
chg_virtue(V_UNLIFE, 5);
#ifdef JP
ident = TRUE;
break;
- }
case SV_POTION_INFRAVISION:
- {
if (set_tim_infra(p_ptr->tim_infra + 100 + randint1(100), FALSE))
{
ident = TRUE;
}
break;
- }
case SV_POTION_DETECT_INVIS:
- {
if (set_tim_invis(p_ptr->tim_invis + 12 + randint1(12), FALSE))
{
ident = TRUE;
}
break;
- }
case SV_POTION_SLOW_POISON:
- {
if (set_poisoned(p_ptr->poisoned / 2)) ident = TRUE;
break;
- }
case SV_POTION_CURE_POISON:
- {
if (set_poisoned(0)) ident = TRUE;
break;
- }
case SV_POTION_BOLDNESS:
- {
if (set_afraid(0)) ident = TRUE;
break;
- }
case SV_POTION_SPEED:
- {
if (!p_ptr->fast)
{
if (set_fast(randint1(25) + 15, FALSE)) ident = TRUE;
(void)set_fast(p_ptr->fast + 5, FALSE);
}
break;
- }
case SV_POTION_RESIST_HEAT:
- {
if (set_oppose_fire(p_ptr->oppose_fire + randint1(10) + 10, FALSE))
{
ident = TRUE;
}
break;
- }
case SV_POTION_RESIST_COLD:
- {
if (set_oppose_cold(p_ptr->oppose_cold + randint1(10) + 10, FALSE))
{
ident = TRUE;
}
break;
- }
case SV_POTION_HEROISM:
- {
if (set_afraid(0)) ident = TRUE;
if (set_hero(p_ptr->hero + randint1(25) + 25, FALSE)) ident = TRUE;
if (hp_player(10)) ident = TRUE;
break;
- }
case SV_POTION_BESERK_STRENGTH:
- {
if (set_afraid(0)) ident = TRUE;
if (set_shero(p_ptr->shero + randint1(25) + 25, FALSE)) ident = TRUE;
if (hp_player(30)) ident = TRUE;
break;
- }
case SV_POTION_CURE_LIGHT:
- {
if (hp_player(damroll(2, 8))) ident = TRUE;
if (set_blind(0)) ident = TRUE;
if (set_cut(p_ptr->cut - 10)) ident = TRUE;
if (set_shero(0,TRUE)) ident = TRUE;
break;
- }
case SV_POTION_CURE_SERIOUS:
- {
if (hp_player(damroll(4, 8))) ident = TRUE;
if (set_blind(0)) ident = TRUE;
if (set_confused(0)) ident = TRUE;
if (set_cut((p_ptr->cut / 2) - 50)) ident = TRUE;
if (set_shero(0,TRUE)) ident = TRUE;
break;
- }
case SV_POTION_CURE_CRITICAL:
- {
if (hp_player(damroll(6, 8))) ident = TRUE;
if (set_blind(0)) ident = TRUE;
if (set_confused(0)) ident = TRUE;
if (set_cut(0)) ident = TRUE;
if (set_shero(0,TRUE)) ident = TRUE;
break;
- }
case SV_POTION_HEALING:
- {
if (hp_player(300)) ident = TRUE;
if (set_blind(0)) ident = TRUE;
if (set_confused(0)) ident = TRUE;
if (set_cut(0)) ident = TRUE;
if (set_shero(0,TRUE)) ident = TRUE;
break;
- }
case SV_POTION_STAR_HEALING:
- {
if (hp_player(1200)) ident = TRUE;
if (set_blind(0)) ident = TRUE;
if (set_confused(0)) ident = TRUE;
if (set_cut(0)) ident = TRUE;
if (set_shero(0,TRUE)) ident = TRUE;
break;
- }
case SV_POTION_LIFE:
- {
chg_virtue(V_VITALITY, 1);
chg_virtue(V_UNLIFE, -5);
#ifdef JP
hp_player(5000);
ident = TRUE;
break;
- }
case SV_POTION_RESTORE_MANA:
- {
if (p_ptr->pclass == CLASS_MAGIC_EATER)
{
int i;
}
if (set_shero(0,TRUE)) ident = TRUE;
break;
- }
case SV_POTION_RESTORE_EXP:
- {
if (restore_level()) ident = TRUE;
break;
- }
case SV_POTION_RES_STR:
- {
if (do_res_stat(A_STR)) ident = TRUE;
break;
- }
case SV_POTION_RES_INT:
- {
if (do_res_stat(A_INT)) ident = TRUE;
break;
- }
case SV_POTION_RES_WIS:
- {
if (do_res_stat(A_WIS)) ident = TRUE;
break;
- }
case SV_POTION_RES_DEX:
- {
if (do_res_stat(A_DEX)) ident = TRUE;
break;
- }
case SV_POTION_RES_CON:
- {
if (do_res_stat(A_CON)) ident = TRUE;
break;
- }
case SV_POTION_RES_CHR:
- {
if (do_res_stat(A_CHR)) ident = TRUE;
break;
- }
case SV_POTION_INC_STR:
- {
if (do_inc_stat(A_STR)) ident = TRUE;
break;
- }
case SV_POTION_INC_INT:
- {
if (do_inc_stat(A_INT)) ident = TRUE;
break;
- }
case SV_POTION_INC_WIS:
- {
if (do_inc_stat(A_WIS)) ident = TRUE;
break;
- }
case SV_POTION_INC_DEX:
- {
if (do_inc_stat(A_DEX)) ident = TRUE;
break;
- }
case SV_POTION_INC_CON:
- {
if (do_inc_stat(A_CON)) ident = TRUE;
break;
- }
case SV_POTION_INC_CHR:
- {
if (do_inc_stat(A_CHR)) ident = TRUE;
break;
- }
case SV_POTION_AUGMENTATION:
- {
if (do_inc_stat(A_STR)) ident = TRUE;
if (do_inc_stat(A_INT)) ident = TRUE;
if (do_inc_stat(A_WIS)) ident = TRUE;
if (do_inc_stat(A_CON)) ident = TRUE;
if (do_inc_stat(A_CHR)) ident = TRUE;
break;
- }
case SV_POTION_ENLIGHTENMENT:
- {
#ifdef JP
msg_print("¼«Ê¬¤ÎÃÖ¤«¤ì¤Æ¤¤¤ë¾õ¶·¤¬Ç¾Î¢¤ËÉ⤫¤ó¤Ç¤¤¿...");
#else
chg_virtue(V_KNOWLEDGE, 1);
chg_virtue(V_ENLIGHTEN, 1);
- wiz_lite(FALSE, FALSE);
+ wiz_lite(FALSE);
ident = TRUE;
break;
- }
case SV_POTION_STAR_ENLIGHTENMENT:
- {
#ifdef JP
msg_print("¹¹¤Ê¤ë·¼Ìؤò´¶¤¸¤¿...");
#else
chg_virtue(V_KNOWLEDGE, 1);
chg_virtue(V_ENLIGHTEN, 2);
msg_print(NULL);
- wiz_lite(TRUE, FALSE);
+ wiz_lite(FALSE);
(void)do_inc_stat(A_INT);
(void)do_inc_stat(A_WIS);
(void)detect_traps(DETECT_RAD_DEFAULT, TRUE);
self_knowledge();
ident = TRUE;
break;
- }
case SV_POTION_SELF_KNOWLEDGE:
- {
#ifdef JP
msg_print("¼«Ê¬¼«¿È¤Î¤³¤È¤¬¾¯¤·¤Ïʬ¤«¤Ã¤¿µ¤¤¬¤¹¤ë...");
#else
self_knowledge();
ident = TRUE;
break;
- }
case SV_POTION_EXPERIENCE:
- {
if (p_ptr->prace == RACE_ANDROID) break;
chg_virtue(V_ENLIGHTEN, 1);
if (p_ptr->exp < PY_MAX_EXP)
ident = TRUE;
}
break;
- }
case SV_POTION_RESISTANCE:
- {
(void)set_oppose_acid(p_ptr->oppose_acid + randint1(20) + 20, FALSE);
(void)set_oppose_elec(p_ptr->oppose_elec + randint1(20) + 20, FALSE);
(void)set_oppose_fire(p_ptr->oppose_fire + randint1(20) + 20, FALSE);
(void)set_oppose_pois(p_ptr->oppose_pois + randint1(20) + 20, FALSE);
ident = TRUE;
break;
- }
case SV_POTION_CURING:
- {
if (hp_player(50)) ident = TRUE;
if (set_blind(0)) ident = TRUE;
if (set_poisoned(0)) ident = TRUE;
if (set_cut(0)) ident = TRUE;
if (set_image(0)) ident = TRUE;
break;
- }
case SV_POTION_INVULNERABILITY:
- {
(void)set_invuln(p_ptr->invuln + randint1(4) + 4, FALSE);
ident = TRUE;
break;
- }
case SV_POTION_NEW_LIFE:
- {
do_cmd_rerate(FALSE);
get_max_stats();
p_ptr->update |= PU_BONUS;
}
ident = TRUE;
break;
- }
case SV_POTION_NEO_TSUYOSHI:
- {
(void)set_image(0);
(void)set_tsuyoshi(p_ptr->tsuyoshi + randint1(100) + 100, FALSE);
ident = TRUE;
break;
- }
case SV_POTION_TSUYOSHI:
- {
#ifdef JP
msg_print("¡Ö¥ª¥¯¥ì·»¤µ¤ó¡ª¡×");
#else
}
ident = TRUE;
break;
- }
case SV_POTION_POLYMORPH:
- {
if ((p_ptr->muta1 || p_ptr->muta2 || p_ptr->muta3) && one_in_(23))
{
chg_virtue(V_CHANCE, -5);
}
}
- if (p_ptr->prace == RACE_SKELETON)
+ if (prace_is_(RACE_SKELETON))
{
#ifdef JP
msg_print("±ÕÂΤΰìÉô¤Ï¤¢¤Ê¤¿¤Î¥¢¥´¤òÁÇÄ̤ꤷ¤ÆÍî¤Á¤¿¡ª");
break;
case RACE_GOLEM:
case RACE_ZOMBIE:
- case RACE_ENT:
case RACE_DEMON:
case RACE_SPECTRE:
- case RACE_ANDROID:
set_food(p_ptr->food + ((o_ptr->pval) / 20));
break;
+ case RACE_ANDROID:
+ if (o_ptr->tval == TV_FLASK)
+ {
+#ifdef JP
+ msg_print("¥ª¥¤¥ë¤òÊäµë¤·¤¿¡£");
+#else
+ msg_print("You replenish yourself with the oil.");
+#endif
+ set_food(p_ptr->food + 5000);
+ }
+ else
+ {
+ set_food(p_ptr->food + ((o_ptr->pval) / 20));
+ }
+ break;
+ case RACE_ENT:
+#ifdef JP
+ msg_print("¿åʬ¤ò¼è¤ê¹þ¤ó¤À¡£");
+#else
+ msg_print("You are moistened.");
+#endif
+ set_food(MIN(p_ptr->food + o_ptr->pval + MAX(0, o_ptr->pval * 10) + 2000, PY_FOOD_MAX - 1));
+ break;
default:
(void)set_food(p_ptr->food + o_ptr->pval);
break;
}
+/*
+ * Hook to determine if an object can be quaffed
+ */
+static bool item_tester_hook_quaff(object_type *o_ptr)
+{
+ if (o_ptr->tval == TV_POTION) return TRUE;
+
+ if (prace_is_(RACE_ANDROID))
+ {
+ if (o_ptr->tval == TV_FLASK && o_ptr->sval == SV_FLASK_OIL)
+ return TRUE;
+ }
+
+ return FALSE;
+}
+
+
+/*
+ * Quaff some potion (from the pack or floor)
+ */
void do_cmd_quaff_potion(void)
{
int item;
}
/* Restrict choices to potions */
- item_tester_tval = TV_POTION;
+ item_tester_hook = item_tester_hook_quaff;
/* Get an item */
#ifdef JP
return;
}
- if((p_ptr->pclass == CLASS_BARD) && p_ptr->magic_num1[0])
- {
- stop_singing();
- }
+ if((p_ptr->pclass == CLASS_BARD) && p_ptr->magic_num1[0])
+ {
+ stop_singing();
+ }
/* Not identified yet */
ident = FALSE;
case SV_SCROLL_TELEPORT_LEVEL:
{
- (void)teleport_player_level();
+ (void)teleport_level(0);
ident = TRUE;
break;
}
case SV_SCROLL_IDENTIFY:
{
+ if (!ident_spell(FALSE)) used_up = FALSE;
ident = TRUE;
- if (!ident_spell(FALSE, TRUE)) used_up = FALSE;
break;
}
case SV_SCROLL_STAR_IDENTIFY:
{
+ if (!identify_fully(FALSE)) used_up = FALSE;
ident = TRUE;
- if (!identify_fully(FALSE, TRUE)) used_up = FALSE;
break;
}
case SV_SCROLL_STAR_DESTRUCTION:
{
- if (destroy_area(py, px, 13+randint0(5), TRUE))
+ if (destroy_area(py, px, 13 + randint0(5), FALSE))
ident = TRUE;
else
#ifdef JP
{
fire_ball(GF_FIRE, 0, 666, 4);
/* Note: "Double" damage since it is centered on the player ... */
- if (!(p_ptr->oppose_fire || p_ptr->resist_fire || p_ptr->immune_fire))
+ if (!(IS_OPPOSE_FIRE() || p_ptr->resist_fire || p_ptr->immune_fire))
#ifdef JP
take_hit(DAMAGE_NOESCAPE, 50+randint1(50), "±ê¤Î´¬Êª", -1);
#else
case SV_SCROLL_ICE:
{
fire_ball(GF_ICE, 0, 777, 4);
- if (!(p_ptr->oppose_cold || p_ptr->resist_cold || p_ptr->immune_cold))
+ if (!(IS_OPPOSE_COLD() || p_ptr->resist_cold || p_ptr->immune_cold))
#ifdef JP
take_hit(DAMAGE_NOESCAPE, 100+randint1(100), "ɹ¤Î´¬Êª", -1);
#else
msg_print(NULL);
msg_print("°Å°Ç¤ÎÃæ¤Ë·Ò¤®¤È¤á¤ë¡£¡×");
#else
- msg_print("'One Ring to rule them all, ");
+ msg_print("'One Ring to rule them all, ");
msg_print(NULL);
msg_print("One Ring to find them, ");
msg_print(NULL);
floor_item_describe(0 - item);
floor_item_optimize(0 - item);
}
-
- /* Delayed optimization */
- optimize_inventry_auto_destroy();
}
case SV_STAFF_IDENTIFY:
{
- if (!ident_spell(FALSE, TRUE)) *use_charge = FALSE;
+ if (!ident_spell(FALSE)) *use_charge = FALSE;
ident = TRUE;
break;
}
}
for (k = 0; k < num; k++)
{
- attempts = 1000;
+ attempts = 1000;
- while(attempts--)
+ while (attempts--)
{
scatter(&y, &x, py, px, 4, 0);
if (!cave_floor_bold(y, x)) continue;
- if ((y != py) || (x != px)) break;
+ if (!player_bold(y, x)) break;
}
project(0, 0, y, x, damroll(6 + p_ptr->lev / 8, 10), GF_LITE_WEAK,
case SV_STAFF_DESTRUCTION:
{
- if (destroy_area(py, px, 13+randint0(5), TRUE))
+ if (destroy_area(py, px, 13 + randint0(5), FALSE))
ident = TRUE;
break;
msg_print("Mighty magics rend your enemies!");
#endif
project(0, 5, py, px,
- (randint1(200) + 300) * 2, GF_MANA, PROJECT_KILL | PROJECT_ITEM | PROJECT_GRID | PROJECT_NO_REF, -1);
+ (randint1(200) + 300) * 2, GF_MANA, PROJECT_KILL | PROJECT_ITEM | PROJECT_GRID, -1);
if ((p_ptr->pclass != CLASS_MAGE) && (p_ptr->pclass != CLASS_HIGH_MAGE) && (p_ptr->pclass != CLASS_SORCERER) && (p_ptr->pclass != CLASS_MAGIC_EATER) && (p_ptr->pclass != CLASS_BLUE_MAGE))
{
#ifdef JP
break;
}
+
+ case SV_STAFF_NOTHING:
+ {
+#ifdef JP
+ msg_print("²¿¤âµ¯¤é¤Ê¤«¤Ã¤¿¡£");
+#else
+ msg_print("Nothing happen.");
+#endif
+ if (prace_is_(RACE_SKELETON) || prace_is_(RACE_GOLEM) ||
+ prace_is_(RACE_ZOMBIE) || prace_is_(RACE_SPECTRE))
+#ifdef JP
+ msg_print("¤â¤Ã¤¿¤¤¤Ê¤¤»ö¤ò¤·¤¿¤è¤¦¤Êµ¤¤¬¤¹¤ë¡£¿©¤Ùʪ¤ÏÂçÀڤˤ·¤Ê¤¯¤Æ¤Ï¡£");
+#else
+ msg_print("What a waste. It's your food!");
+#endif
+ break;
+ }
}
return ident;
}
/* Combine / Reorder the pack (later) */
p_ptr->notice |= (PN_COMBINE | PN_REORDER);
- p_ptr->window |= (PW_INVEN);
+ p_ptr->window |= (PW_INVEN);
return;
}
{
floor_item_charges(0 - item);
}
-
- /* Delayed optimization */
- optimize_inventry_auto_destroy();
}
/* Combine / Reorder the pack (later) */
p_ptr->notice |= (PN_COMBINE | PN_REORDER);
- p_ptr->window |= (PW_INVEN);
+ p_ptr->window |= (PW_INVEN);
return;
}
{
int ident = FALSE;
+ /* Unused */
+ (void)magic;
+
/* Analyze the rod */
switch (sval)
{
case SV_ROD_DETECT_TRAP:
{
- if (detect_traps(DETECT_RAD_DEFAULT, dir ? TRUE : FALSE)) ident = TRUE;
+ if (detect_traps(DETECT_RAD_DEFAULT, (bool)(dir ? FALSE : TRUE))) ident = TRUE;
break;
}
case SV_ROD_IDENTIFY:
{
+ if (!ident_spell(FALSE)) *use_charge = FALSE;
ident = TRUE;
- if (!ident_spell(FALSE, FALSE)) *use_charge = FALSE;
break;
}
static void do_cmd_zap_rod_aux(int item)
{
int ident, chance, lev, fail;
- int dir = 0;
+ int dir = 0;
object_type *o_ptr;
bool success;
monster_race *r_ptr1 = &r_info[m_ptr1->r_idx];
monster_race *r_ptr2 = &r_info[m_ptr2->r_idx];
+ /* Unused */
+ (void)v;
+
if (m_ptr1->nickname && !m_ptr2->nickname) return TRUE;
if (m_ptr2->nickname && !m_ptr1->nickname) return FALSE;
chg_virtue(V_KNOWLEDGE, 1);
chg_virtue(V_ENLIGHTEN, 1);
- wiz_lite(FALSE, FALSE);
+ wiz_lite(FALSE);
#ifdef JP
msg_print("¤½¤ÎÊõÀФϤ¢¤Ê¤¿¤ÎÂÎÎϤòÃ¥¤Ã¤¿...");
take_hit(DAMAGE_LOSELIFE, damroll(3,8), "¿³È½¤ÎÊõÀÐ", -1);
for (k = 0; k < num; k++)
{
- attempts = 1000;
+ attempts = 1000;
- while(attempts--)
+ while (attempts--)
{
scatter(&y, &x, py, px, 4, 0);
if (!cave_floor_bold(y, x)) continue;
- if ((y != py) || (x != px)) break;
+ if (!player_bold(y, x)) break;
}
project(0, 3, y, x, 150, GF_ELEC,
msg_print("Your quarterstaff glows yellow...");
#endif
- if (!ident_spell(FALSE, FALSE)) return;
+ if (!ident_spell(FALSE)) return;
o_ptr->timeout = 10;
break;
}
detect_all(DETECT_RAD_DEFAULT);
probing();
- identify_fully(FALSE, TRUE);
- o_ptr->timeout = 1000;
+ identify_fully(FALSE);
+ o_ptr->timeout = 100;
break;
}
{
int num = 1;
int i;
- int flg = PROJECT_STOP | PROJECT_GRID | PROJECT_ITEM | PROJECT_KILL | PROJECT_NO_REF;
+ int flg = PROJECT_STOP | PROJECT_GRID | PROJECT_ITEM | PROJECT_KILL;
int tx, ty;
#ifdef JP
msg_print("¤»¤Ã¤«¤¯¤À¤«¤é¡Ø¥¯¥ê¥à¥¾¥ó¡Ù¤ò¤Ö¤Ã¤Ñ¤Ê¤¹¤¼¡ª");
o_ptr->timeout = 15;
break;
}
- case ART_PALANTIR:
- {
- monster_type *m_ptr;
- monster_race *r_ptr;
- int i;
+ case ART_PALANTIR:
+ {
+ monster_type *m_ptr;
+ monster_race *r_ptr;
+ int i;
#ifdef JP
- msg_print("´ñ̯¤Ê¾ì½ê¤¬Æ¬¤ÎÃæ¤ËÉ⤫¤ó¤À¡¥¡¥¡¥");
+ msg_print("´ñ̯¤Ê¾ì½ê¤¬Æ¬¤ÎÃæ¤ËÉ⤫¤ó¤À¡¥¡¥¡¥");
#else
- msg_print("Some strange places show up in your mind. And you see ...");
+ msg_print("Some strange places show up in your mind. And you see ...");
#endif
- /* Process the monsters (backwards) */
- for (i = m_max - 1; i >= 1; i--)
- {
- /* Access the monster */
- m_ptr = &m_list[i];
+ /* Process the monsters (backwards) */
+ for (i = m_max - 1; i >= 1; i--)
+ {
+ /* Access the monster */
+ m_ptr = &m_list[i];
- /* Ignore "dead" monsters */
- if (!m_ptr->r_idx) continue;
+ /* Ignore "dead" monsters */
+ if (!m_ptr->r_idx) continue;
- r_ptr = &r_info[m_ptr->r_idx];
+ r_ptr = &r_info[m_ptr->r_idx];
- if(r_ptr->flags1 & RF1_UNIQUE)
- {
+ if(r_ptr->flags1 & RF1_UNIQUE)
+ {
#ifdef JP
msg_format("%s¡¥ ",r_name + r_ptr->name);
#else
- msg_format("%s. ",r_name + r_ptr->name);
+ msg_format("%s. ",r_name + r_ptr->name);
#endif
- }
- }
- o_ptr->timeout = 200;
- break;
- }
+ }
+ }
+ o_ptr->timeout = 200;
+ break;
+ }
case ART_STONE_LORE:
{
#else
msg_print("The stone reveals hidden mysteries...");
#endif
- if (!ident_spell(FALSE, FALSE)) return;
+ if (!ident_spell(FALSE)) return;
if (mp_ptr->spell_book)
{
o_ptr->timeout = randint0(120) + 120;
break;
}
- case ART_HURIN:
+ case ART_HURIN:
{
(void)set_fast(randint1(50) + 50, FALSE);
hp_player(10);
(void)set_image(0);
o_ptr->timeout = 100;
- break;
+ break;
}
case ART_BOLISHOI:
(void)charm_animal(dir, p_ptr->lev);
o_ptr->timeout = 200;
- break;
+ break;
}
case ART_ARUNRUTH:
o_ptr->timeout = randint0(150) + 150;
break;
}
+ case ART_HELL:
+ {
+#ifdef JP
+ msg_print("¼óÎؤ¬¿¼¤¤°Ç¤Ëʤ¤ï¤ì¤¿...");
+#else
+ msg_print("Your collar harness is coverd in pitch-darkness...");
+#endif
+ if (!get_aim_dir(&dir)) return;
+ fire_ball(GF_DARK, dir, 250, 4);
+ o_ptr->timeout = randint0(150) + 150;
+ break;
+ }
+ case ART_SACRED_KNIGHTS:
+ {
+#ifdef JP
+ msg_print("¼ó¾þ¤ê¤¬¿¿¼Â¤ò¾È¤é¤·½Ð¤¹...");
+#else
+ msg_print("Your amulet exhibits the truth...");
+#endif
+ if (remove_all_curse())
+ {
+#ifdef JP
+ msg_print("狼¤Ë¸«¼é¤é¤ì¤Æ¤¤¤ë¤è¤¦¤Êµ¤¤¬¤¹¤ë¡£");
+#else
+ msg_print("You feel as if someone is watching over you.");
+#endif
+ }
+ (void)probing();
+ break;
+ }
+ case ART_CHARMED:
+ {
+#ifdef JP
+ msg_print("¥Ú¥ó¥À¥ó¥È¤¬ÀÄÇò¤¯¸÷¤Ã¤¿¡¥¡¥¡¥");
+#else
+ msg_print("Your pendant glows pale...");
+#endif
+ if (p_ptr->pclass == CLASS_MAGIC_EATER)
+ {
+ int i;
+ for (i = 0; i < EATER_EXT*2; i++)
+ {
+ p_ptr->magic_num1[i] += (p_ptr->magic_num2[i] < 10) ? EATER_CHARGE * 3 : p_ptr->magic_num2[i]*EATER_CHARGE/3;
+ if (p_ptr->magic_num1[i] > p_ptr->magic_num2[i]*EATER_CHARGE) p_ptr->magic_num1[i] = p_ptr->magic_num2[i]*EATER_CHARGE;
+ }
+ for (; i < EATER_EXT*3; i++)
+ {
+ int k_idx = lookup_kind(TV_ROD, i-EATER_EXT*2);
+ p_ptr->magic_num1[i] -= ((p_ptr->magic_num2[i] < 10) ? EATER_ROD_CHARGE*3 : p_ptr->magic_num2[i]*EATER_ROD_CHARGE/3)*k_info[k_idx].pval;
+ if (p_ptr->magic_num1[i] < 0) p_ptr->magic_num1[i] = 0;
+ }
+#ifdef JP
+ msg_print("Ƭ¤¬¥Ï¥Ã¥¥ê¤È¤·¤¿¡£");
+#else
+ msg_print("Your feel your head clear.");
+#endif
+ p_ptr->window |= (PW_PLAYER);
+ }
+ else if (p_ptr->csp < p_ptr->msp)
+ {
+ p_ptr->csp = p_ptr->msp;
+ p_ptr->csp_frac = 0;
+#ifdef JP
+ msg_print("Ƭ¤¬¥Ï¥Ã¥¥ê¤È¤·¤¿¡£");
+#else
+ msg_print("Your feel your head clear.");
+#endif
+
+ p_ptr->redraw |= (PR_MANA);
+ p_ptr->window |= (PW_PLAYER);
+ p_ptr->window |= (PW_SPELL);
+ }
+ o_ptr->timeout = 777;
+ break;
+ }
}
/* Window stuff */
return;
}
- else if ((o_ptr->tval > TV_CAPTURE) && (o_ptr->xtra3))
- {
- switch (o_ptr->xtra3-1)
- {
- case ESSENCE_TMP_RES_ACID:
- (void)set_oppose_acid(randint1(20) + 20, FALSE);
- o_ptr->timeout = randint0(50) + 50;
- return;
+ if (item_tester_hook_smith(o_ptr))
+ {
+ switch (o_ptr->xtra3-1)
+ {
+ case ESSENCE_TMP_RES_ACID:
+ (void)set_oppose_acid(randint1(20) + 20, FALSE);
+ o_ptr->timeout = randint0(50) + 50;
+ return;
- case ESSENCE_TMP_RES_ELEC:
- (void)set_oppose_elec(randint1(20) + 20, FALSE);
- o_ptr->timeout = randint0(50) + 50;
- return;
+ case ESSENCE_TMP_RES_ELEC:
+ (void)set_oppose_elec(randint1(20) + 20, FALSE);
+ o_ptr->timeout = randint0(50) + 50;
+ return;
- case ESSENCE_TMP_RES_FIRE:
- (void)set_oppose_fire(randint1(20) + 20, FALSE);
- o_ptr->timeout = randint0(50) + 50;
- return;
+ case ESSENCE_TMP_RES_FIRE:
+ (void)set_oppose_fire(randint1(20) + 20, FALSE);
+ o_ptr->timeout = randint0(50) + 50;
+ return;
- case ESSENCE_TMP_RES_COLD:
- (void)set_oppose_cold(randint1(20) + 20, FALSE);
- o_ptr->timeout = randint0(50) + 50;
- return;
+ case ESSENCE_TMP_RES_COLD:
+ (void)set_oppose_cold(randint1(20) + 20, FALSE);
+ o_ptr->timeout = randint0(50) + 50;
+ return;
- case TR_IMPACT:
- earthquake(py, px, 5);
- o_ptr->timeout = 100 + randint1(100);
-
- /* Window stuff */
- p_ptr->window |= (PW_INVEN | PW_EQUIP);
+ case TR_IMPACT:
+ earthquake(py, px, 5);
+ o_ptr->timeout = 100 + randint1(100);
+
+ /* Window stuff */
+ p_ptr->window |= (PW_INVEN | PW_EQUIP);
- /* Done */
- return;
- }
- }
+ /* Done */
+ return;
+ }
+ }
- else if (o_ptr->name2 == EGO_TRUMP)
+ if (o_ptr->name2 == EGO_TRUMP)
{
teleport_player(100);
o_ptr->timeout = 50 + randint1(50);
}
- else if (o_ptr->name2 == EGO_LITE_ILLUMINATION)
+ if (o_ptr->name2 == EGO_LITE_ILLUMINATION)
{
if (!o_ptr->xtra4 && ((o_ptr->sval == SV_LITE_TORCH) || (o_ptr->sval == SV_LITE_LANTERN)))
{
}
- else if (o_ptr->name2 == EGO_EARTHQUAKES)
+ if (o_ptr->name2 == EGO_EARTHQUAKES)
{
earthquake(py, px, 5);
o_ptr->timeout = 100 + randint1(100);
}
- else if (o_ptr->name2 == EGO_JUMP)
+ if (o_ptr->name2 == EGO_JUMP)
{
teleport_player(10);
o_ptr->timeout = 10 + randint1(10);
/* Hack -- Dragon Scale Mail can be activated as well */
- else if (o_ptr->tval == TV_DRAG_ARMOR)
+ if (o_ptr->tval == TV_DRAG_ARMOR)
{
/* Get a direction for breathing (or abort) */
if (!get_aim_dir(&dir)) return;
chance = randint0(5);
#ifdef JP
msg_format("¤¢¤Ê¤¿¤Ï%s¤Î¥Ö¥ì¥¹¤òÅǤ¤¤¿¡£",
- ((chance == 1) ? "°ðºÊ" :
- ((chance == 2) ? "Î䵤" :
- ((chance == 3) ? "»À" :
- ((chance == 4) ? "ÆÇ¥¬¥¹" : "²Ð±ê")))));
+ ((chance == 1) ? "°ðºÊ" :
+ ((chance == 2) ? "Î䵤" :
+ ((chance == 3) ? "»À" :
+ ((chance == 4) ? "ÆÇ¥¬¥¹" : "²Ð±ê")))));
#else
msg_format("You breathe %s.",
- ((chance == 1) ? "lightning" :
- ((chance == 2) ? "frost" :
- ((chance == 3) ? "acid" :
- ((chance == 4) ? "poison gas" : "fire")))));
+ ((chance == 1) ? "lightning" :
+ ((chance == 2) ? "frost" :
+ ((chance == 3) ? "acid" :
+ ((chance == 4) ? "poison gas" : "fire")))));
#endif
fire_ball(((chance == 1) ? GF_ELEC :
- ((chance == 2) ? GF_COLD :
- ((chance == 3) ? GF_ACID :
- ((chance == 4) ? GF_POIS : GF_FIRE)))),
- dir, 250, -2);
+ ((chance == 2) ? GF_COLD :
+ ((chance == 3) ? GF_ACID :
+ ((chance == 4) ? GF_POIS : GF_FIRE)))),
+ dir, 250, -2);
o_ptr->timeout = randint0(200) + 200;
break;
}
chance = randint0(2);
#ifdef JP
msg_format("¤¢¤Ê¤¿¤Ï%s¤Î¥Ö¥ì¥¹¤òÅǤ¤¤¿¡£",
- ((chance == 1 ? "¥«¥ª¥¹" : "Îô²½")));
+ ((chance == 1 ? "¥«¥ª¥¹" : "Îô²½")));
#else
msg_format("You breathe %s.",
- ((chance == 1 ? "chaos" : "disenchantment")));
+ ((chance == 1 ? "chaos" : "disenchantment")));
#endif
fire_ball((chance == 1 ? GF_CHAOS : GF_DISENCHANT),
- dir, 220, -2);
+ dir, 220, -2);
o_ptr->timeout = randint0(200) + 200;
break;
}
chance = randint0(2);
#ifdef JP
msg_format("¤¢¤Ê¤¿¤Ï%s¤Î¥Ö¥ì¥¹¤òÅǤ¤¤¿¡£",
- ((chance == 1 ? "¹ì²»" : "ÇËÊÒ")));
+ ((chance == 1 ? "¹ì²»" : "ÇËÊÒ")));
#else
msg_format("You breathe %s.",
- ((chance == 1 ? "sound" : "shards")));
+ ((chance == 1 ? "sound" : "shards")));
#endif
fire_ball((chance == 1 ? GF_SOUND : GF_SHARDS),
- dir, 230, -2);
+ dir, 230, -2);
o_ptr->timeout = randint0(200) + 200;
break;
}
chance = randint0(4);
#ifdef JP
msg_format("¤¢¤Ê¤¿¤Ï%s¤Î¥Ö¥ì¥¹¤òÅǤ¤¤¿",
- ((chance == 1) ? "¥«¥ª¥¹" :
- ((chance == 2) ? "Îô²½" :
- ((chance == 3) ? "¹ì²»" : "ÇËÊÒ"))));
+ ((chance == 1) ? "¥«¥ª¥¹" :
+ ((chance == 2) ? "Îô²½" :
+ ((chance == 3) ? "¹ì²»" : "ÇËÊÒ"))));
#else
msg_format("You breathe %s.",
- ((chance == 1) ? "chaos" :
- ((chance == 2) ? "disenchantment" :
- ((chance == 3) ? "sound" : "shards"))));
+ ((chance == 1) ? "chaos" :
+ ((chance == 2) ? "disenchantment" :
+ ((chance == 3) ? "sound" : "shards"))));
#endif
fire_ball(((chance == 1) ? GF_CHAOS :
- ((chance == 2) ? GF_DISENCHANT :
- ((chance == 3) ? GF_SOUND : GF_SHARDS))),
- dir, 250, -2);
+ ((chance == 2) ? GF_DISENCHANT :
+ ((chance == 3) ? GF_SOUND : GF_SHARDS))),
+ dir, 250, -2);
o_ptr->timeout = randint0(200) + 200;
break;
}
chance = randint0(2);
#ifdef JP
msg_format("¤¢¤Ê¤¿¤Ï%s¤Î¥Ö¥ì¥¹¤òÅǤ¤¤¿¡£",
- ((chance == 0 ? "Á®¸÷" : "°Å¹õ")));
+ ((chance == 0 ? "Á®¸÷" : "°Å¹õ")));
#else
msg_format("You breathe %s.",
- ((chance == 0 ? "light" : "darkness")));
+ ((chance == 0 ? "light" : "darkness")));
#endif
fire_ball((chance == 0 ? GF_LITE : GF_DARK), dir, 200, -2);
switch (o_ptr->name2)
{
case EGO_AMU_IDENT:
- if (!ident_spell(FALSE, FALSE)) return;
+ if (!ident_spell(FALSE)) return;
o_ptr->timeout = 10;
break;
case EGO_AMU_CHARM:
for (i = 0; i < max_pet; i++)
{
pet_ctr = who[i];
- teleport_to_player(pet_ctr, 100);
+ teleport_monster_to(pet_ctr, py, px, 100);
}
/* Free the "who" array */
}
}
-static bool select_magic_eater(bool only_browse)
+static int select_magic_eater(bool only_browse)
{
int ext=0;
char choice;
- bool flag, redraw, request_list;
+ bool flag, request_list;
int tval = 0;
int ask = TRUE, i = 0;
char out_val[160];
/* Nothing chosen yet */
flag = FALSE;
- /* No redraw yet */
- redraw = FALSE;
-
/* Build a prompt */
#ifdef JP
(void) strnfmt(out_val, 78, "('*'¤Ç°ìÍ÷, ESC¤ÇÃæÃÇ) ¤É¤ÎËâÎϤò»È¤¤¤Þ¤¹¤«¡©");
/* Save the screen */
screen_save();
- request_list = always_show_list;
+ request_list = always_show_list;
/* Get a spell from the user */
- while (!flag)
- {
+ while (!flag)
+ {
/* Show the list */
if (request_list || use_menu)
{
}
}
- if(!get_com(out_val, &choice, FALSE)) break;
+ if (!get_com(out_val, &choice, FALSE)) break;
if (use_menu && choice != ' ')
{
- switch(choice)
+ switch (choice)
{
case '0':
{
screen_load();
- return (FALSE);
- break;
+ return 0;
}
case '8':
Term_erase(7, 21, 255);
Term_erase(7, 20, 255);
- roff_to_buf(k_text + k_info[lookup_kind(tval, i)].text, 62, temp);
+ roff_to_buf(k_text + k_info[lookup_kind(tval, i)].text, 62, temp, sizeof(temp));
for (j = 0, line = 21; temp[j]; j += 1 + strlen(&temp[j]))
{
prt(&temp[j], line, 10);
*/
void do_cmd_magic_eater(bool only_browse)
{
- int item, dir, chance, level, k_idx, tval, sval;
+ int item, chance, level, k_idx, tval, sval;
bool use_charge = TRUE;
/* Not when confused */
}
else
{
+ int dir = 0;
+
if (tval == TV_ROD)
{
if ((sval >= SV_ROD_MIN_DIRECTION) && (sval != SV_ROD_HAVOC) && (sval != SV_ROD_AGGRAVATE) && (sval != SV_ROD_PESTICIDE))
{
staff_effect(sval, &use_charge, TRUE, TRUE);
if (!use_charge) return;
-
- /* Delayed optimization */
- optimize_inventry_auto_destroy();
}
if (randint1(100) < chance)
chg_virtue(V_CHANCE,1);