/*!
- @file dungeon.c
- @brief Angbandゲームエンジン / Angband game engine
- @date 2013/12/31
- @author
- Copyright (c) 1989 James E. Wilson, Robert A. Koeneke\n
- This software may be copied and distributed for educational, research, and\n
- not for profit purposes provided that this copyright and statement are\n
- included in all such copies.\n
- 2013 Deskull rearranged comment for Doxygen.
+ @file dungeon.c
+ @brief Angbandゲームエンジン / Angband game engine
+ @date 2013/12/31
+ @author
+ Copyright (c) 1989 James E. Wilson, Robert A. Koeneke\n
+ This software may be copied and distributed for educational, research, and\n
+ not for profit purposes provided that this copyright and statement are\n
+ included in all such copies.\n
+ 2013 Deskull rearranged comment for Doxygen.
*/
#include "angband.h"
{
switch (feel)
{
- case FEEL_TERRIBLE:
- {
- feel = FEEL_SPECIAL;
- break;
- }
- case FEEL_WORTHLESS:
- {
- feel = FEEL_EXCELLENT;
- break;
- }
- case FEEL_CURSED:
- {
- if (heavy)
- feel = randint0(3) ? FEEL_GOOD : FEEL_AVERAGE;
- else
- feel = FEEL_UNCURSED;
- break;
- }
- case FEEL_AVERAGE:
- {
- feel = randint0(2) ? FEEL_CURSED : FEEL_GOOD;
- break;
- }
- case FEEL_GOOD:
- {
- if (heavy)
- feel = randint0(3) ? FEEL_CURSED : FEEL_AVERAGE;
- else
- feel = FEEL_CURSED;
- break;
- }
- case FEEL_EXCELLENT:
- {
- feel = FEEL_WORTHLESS;
- break;
- }
- case FEEL_SPECIAL:
- {
- feel = FEEL_TERRIBLE;
- break;
- }
+ case FEEL_TERRIBLE:
+ {
+ feel = FEEL_SPECIAL;
+ break;
+ }
+ case FEEL_WORTHLESS:
+ {
+ feel = FEEL_EXCELLENT;
+ break;
+ }
+ case FEEL_CURSED:
+ {
+ if (heavy)
+ feel = randint0(3) ? FEEL_GOOD : FEEL_AVERAGE;
+ else
+ feel = FEEL_UNCURSED;
+ break;
+ }
+ case FEEL_AVERAGE:
+ {
+ feel = randint0(2) ? FEEL_CURSED : FEEL_GOOD;
+ break;
+ }
+ case FEEL_GOOD:
+ {
+ if (heavy)
+ feel = randint0(3) ? FEEL_CURSED : FEEL_AVERAGE;
+ else
+ feel = FEEL_CURSED;
+ break;
+ }
+ case FEEL_EXCELLENT:
+ {
+ feel = FEEL_WORTHLESS;
+ break;
+ }
+ case FEEL_SPECIAL:
+ {
+ feel = FEEL_TERRIBLE;
+ break;
+ }
}
}
{
#ifdef JP
msg_format("%s%s(%c)は%sという感じがする...",
- describe_use(creature_ptr, slot),o_name, index_to_label(slot),game_inscriptions[feel]);
+ describe_use(creature_ptr, slot), o_name, index_to_label(slot), game_inscriptions[feel]);
#else
msg_format("You feel the %s (%c) you are %s %s %s...",
- o_name, index_to_label(slot), describe_use(slot),
- ((o_ptr->number == 1) ? "is" : "are"),
- game_inscriptions[feel]);
+ o_name, index_to_label(slot), describe_use(creature_ptr, slot),
+ ((o_ptr->number == 1) ? "is" : "are"),
+ game_inscriptions[feel]);
#endif
}
{
#ifdef JP
msg_format("ザックの中の%s(%c)は%sという感じがする...",
- o_name, index_to_label(slot),game_inscriptions[feel]);
+ o_name, index_to_label(slot), game_inscriptions[feel]);
#else
msg_format("You feel the %s (%c) in your pack %s %s...",
- o_name, index_to_label(slot),
- ((o_ptr->number == 1) ? "is" : "are"),
- game_inscriptions[feel]);
+ o_name, index_to_label(slot),
+ ((o_ptr->number == 1) ? "is" : "are"),
+ game_inscriptions[feel]);
#endif
}
/* Analyze the class */
switch (creature_ptr->pclass)
{
- case CLASS_WARRIOR:
- case CLASS_ARCHER:
- case CLASS_SAMURAI:
- case CLASS_CAVALRY:
- {
- /* Good sensing */
- if (0 != randint0(9000L / (plev * plev + 40))) return;
+ case CLASS_WARRIOR:
+ case CLASS_ARCHER:
+ case CLASS_SAMURAI:
+ case CLASS_CAVALRY:
+ {
+ /* Good sensing */
+ if (0 != randint0(9000L / (plev * plev + 40))) return;
- /* Heavy sensing */
- heavy = TRUE;
+ /* Heavy sensing */
+ heavy = TRUE;
- break;
- }
+ break;
+ }
- case CLASS_SMITH:
- {
- /* Good sensing */
- if (0 != randint0(6000L / (plev * plev + 50))) return;
+ case CLASS_SMITH:
+ {
+ /* Good sensing */
+ if (0 != randint0(6000L / (plev * plev + 50))) return;
- /* Heavy sensing */
- heavy = TRUE;
+ /* Heavy sensing */
+ heavy = TRUE;
- break;
- }
+ break;
+ }
- case CLASS_MAGE:
- case CLASS_HIGH_MAGE:
- case CLASS_SORCERER:
- case CLASS_MAGIC_EATER:
- {
- /* Very bad (light) sensing */
- if (0 != randint0(240000L / (plev + 5))) return;
+ case CLASS_MAGE:
+ case CLASS_HIGH_MAGE:
+ case CLASS_SORCERER:
+ case CLASS_MAGIC_EATER:
+ {
+ /* Very bad (light) sensing */
+ if (0 != randint0(240000L / (plev + 5))) return;
- break;
- }
+ break;
+ }
- case CLASS_PRIEST:
- case CLASS_BARD:
- {
- /* Good (light) sensing */
- if (0 != randint0(10000L / (plev * plev + 40))) return;
+ case CLASS_PRIEST:
+ case CLASS_BARD:
+ {
+ /* Good (light) sensing */
+ if (0 != randint0(10000L / (plev * plev + 40))) return;
- break;
- }
+ break;
+ }
- case CLASS_ROGUE:
- case CLASS_NINJA:
- {
- /* Okay sensing */
- if (0 != randint0(20000L / (plev * plev + 40))) return;
+ case CLASS_ROGUE:
+ case CLASS_NINJA:
+ {
+ /* Okay sensing */
+ if (0 != randint0(20000L / (plev * plev + 40))) return;
- /* Heavy sensing */
- heavy = TRUE;
+ /* Heavy sensing */
+ heavy = TRUE;
- break;
- }
+ break;
+ }
- case CLASS_RANGER:
- {
- /* Bad sensing */
- if (0 != randint0(95000L / (plev * plev + 40))) return;
+ case CLASS_RANGER:
+ {
+ /* Bad sensing */
+ if (0 != randint0(95000L / (plev * plev + 40))) return;
- /* Changed! */
- heavy = TRUE;
+ /* Changed! */
+ heavy = TRUE;
- break;
- }
+ break;
+ }
- case CLASS_PALADIN:
- case CLASS_SNIPER:
- {
- /* Bad sensing */
- if (0 != randint0(77777L / (plev * plev + 40))) return;
+ case CLASS_PALADIN:
+ case CLASS_SNIPER:
+ {
+ /* Bad sensing */
+ if (0 != randint0(77777L / (plev * plev + 40))) return;
- /* Heavy sensing */
- heavy = TRUE;
+ /* Heavy sensing */
+ heavy = TRUE;
- break;
- }
+ break;
+ }
- case CLASS_WARRIOR_MAGE:
- case CLASS_RED_MAGE:
- {
- /* Bad sensing */
- if (0 != randint0(75000L / (plev * plev + 40))) return;
+ case CLASS_WARRIOR_MAGE:
+ case CLASS_RED_MAGE:
+ {
+ /* Bad sensing */
+ if (0 != randint0(75000L / (plev * plev + 40))) return;
- break;
- }
+ break;
+ }
- case CLASS_MINDCRAFTER:
- case CLASS_IMITATOR:
- case CLASS_BLUE_MAGE:
- case CLASS_MIRROR_MASTER:
- {
- /* Bad sensing */
- if (0 != randint0(55000L / (plev * plev + 40))) return;
+ case CLASS_MINDCRAFTER:
+ case CLASS_IMITATOR:
+ case CLASS_BLUE_MAGE:
+ case CLASS_MIRROR_MASTER:
+ {
+ /* Bad sensing */
+ if (0 != randint0(55000L / (plev * plev + 40))) return;
- break;
- }
+ break;
+ }
- case CLASS_CHAOS_WARRIOR:
- {
- /* Bad sensing */
- if (0 != randint0(80000L / (plev * plev + 40))) return;
+ case CLASS_CHAOS_WARRIOR:
+ {
+ /* Bad sensing */
+ if (0 != randint0(80000L / (plev * plev + 40))) return;
- /* Changed! */
- heavy = TRUE;
+ /* Changed! */
+ heavy = TRUE;
- break;
- }
+ break;
+ }
- case CLASS_MONK:
- case CLASS_FORCETRAINER:
- {
- /* Okay sensing */
- if (0 != randint0(20000L / (plev * plev + 40))) return;
+ case CLASS_MONK:
+ case CLASS_FORCETRAINER:
+ {
+ /* Okay sensing */
+ if (0 != randint0(20000L / (plev * plev + 40))) return;
- break;
- }
+ break;
+ }
- case CLASS_TOURIST:
- {
- /* Good sensing */
- if (0 != randint0(20000L / ((plev+50)*(plev+50)))) return;
+ case CLASS_TOURIST:
+ {
+ /* Good sensing */
+ if (0 != randint0(20000L / ((plev + 50)*(plev + 50)))) return;
- /* Heavy sensing */
- heavy = TRUE;
+ /* Heavy sensing */
+ heavy = TRUE;
- break;
- }
+ break;
+ }
- case CLASS_BEASTMASTER:
- {
- /* Bad sensing */
- if (0 != randint0(65000L / (plev * plev + 40))) return;
+ case CLASS_BEASTMASTER:
+ {
+ /* Bad sensing */
+ if (0 != randint0(65000L / (plev * plev + 40))) return;
- break;
- }
- case CLASS_BERSERKER:
- {
- /* Heavy sensing */
- heavy = TRUE;
+ break;
+ }
+ case CLASS_BERSERKER:
+ {
+ /* Heavy sensing */
+ heavy = TRUE;
- break;
- }
+ break;
+ }
}
if (compare_virtue(creature_ptr, V_KNOWLEDGE, 100, VIRTUE_LARGE)) heavy = TRUE;
/* Valid "tval" codes */
switch (o_ptr->tval)
{
- case TV_SHOT:
- case TV_ARROW:
- case TV_BOLT:
- case TV_BOW:
- case TV_DIGGING:
- case TV_HAFTED:
- case TV_POLEARM:
- case TV_SWORD:
- case TV_BOOTS:
- case TV_GLOVES:
- case TV_HELM:
- case TV_CROWN:
- case TV_SHIELD:
- case TV_CLOAK:
- case TV_SOFT_ARMOR:
- case TV_HARD_ARMOR:
- case TV_DRAG_ARMOR:
- case TV_CARD:
- {
- okay = TRUE;
- break;
- }
+ case TV_SHOT:
+ case TV_ARROW:
+ case TV_BOLT:
+ case TV_BOW:
+ case TV_DIGGING:
+ case TV_HAFTED:
+ case TV_POLEARM:
+ case TV_SWORD:
+ case TV_BOOTS:
+ case TV_GLOVES:
+ case TV_HELM:
+ case TV_CROWN:
+ case TV_SHIELD:
+ case TV_CLOAK:
+ case TV_SOFT_ARMOR:
+ case TV_HARD_ARMOR:
+ case TV_DRAG_ARMOR:
+ case TV_CARD:
+ {
+ okay = TRUE;
+ break;
+ }
}
/* Skip non-sense machines */
/* Analyze the class */
switch (creature_ptr->pclass)
{
- case CLASS_WARRIOR:
- case CLASS_ARCHER:
- case CLASS_SAMURAI:
- case CLASS_CAVALRY:
- case CLASS_BERSERKER:
- case CLASS_SNIPER:
- {
- return;
- }
+ case CLASS_WARRIOR:
+ case CLASS_ARCHER:
+ case CLASS_SAMURAI:
+ case CLASS_CAVALRY:
+ case CLASS_BERSERKER:
+ case CLASS_SNIPER:
+ {
+ return;
+ }
- case CLASS_SMITH:
- case CLASS_PALADIN:
- case CLASS_CHAOS_WARRIOR:
- case CLASS_IMITATOR:
- case CLASS_BEASTMASTER:
- case CLASS_NINJA:
- {
- /* Very bad (light) sensing */
- if (0 != randint0(240000L / (plev + 5))) return;
+ case CLASS_SMITH:
+ case CLASS_PALADIN:
+ case CLASS_CHAOS_WARRIOR:
+ case CLASS_IMITATOR:
+ case CLASS_BEASTMASTER:
+ case CLASS_NINJA:
+ {
+ /* Very bad (light) sensing */
+ if (0 != randint0(240000L / (plev + 5))) return;
- break;
- }
+ break;
+ }
- case CLASS_RANGER:
- case CLASS_WARRIOR_MAGE:
- case CLASS_RED_MAGE:
- case CLASS_MONK:
- {
- /* Bad sensing */
- if (0 != randint0(95000L / (plev * plev + 40))) return;
+ case CLASS_RANGER:
+ case CLASS_WARRIOR_MAGE:
+ case CLASS_RED_MAGE:
+ case CLASS_MONK:
+ {
+ /* Bad sensing */
+ if (0 != randint0(95000L / (plev * plev + 40))) return;
- break;
- }
+ break;
+ }
- case CLASS_PRIEST:
- case CLASS_BARD:
- case CLASS_ROGUE:
- case CLASS_FORCETRAINER:
- case CLASS_MINDCRAFTER:
- {
- /* Good sensing */
- if (0 != randint0(20000L / (plev * plev + 40))) return;
+ case CLASS_PRIEST:
+ case CLASS_BARD:
+ case CLASS_ROGUE:
+ case CLASS_FORCETRAINER:
+ case CLASS_MINDCRAFTER:
+ {
+ /* Good sensing */
+ if (0 != randint0(20000L / (plev * plev + 40))) return;
- break;
- }
+ break;
+ }
- case CLASS_MAGE:
- case CLASS_HIGH_MAGE:
- case CLASS_SORCERER:
- case CLASS_MAGIC_EATER:
- case CLASS_MIRROR_MASTER:
- case CLASS_BLUE_MAGE:
- {
- /* Good sensing */
- if (0 != randint0(9000L / (plev * plev + 40))) return;
+ case CLASS_MAGE:
+ case CLASS_HIGH_MAGE:
+ case CLASS_SORCERER:
+ case CLASS_MAGIC_EATER:
+ case CLASS_MIRROR_MASTER:
+ case CLASS_BLUE_MAGE:
+ {
+ /* Good sensing */
+ if (0 != randint0(9000L / (plev * plev + 40))) return;
- break;
- }
+ break;
+ }
- case CLASS_TOURIST:
- {
- /* Good sensing */
- if (0 != randint0(20000L / ((plev+50)*(plev+50)))) return;
+ case CLASS_TOURIST:
+ {
+ /* Good sensing */
+ if (0 != randint0(20000L / ((plev + 50)*(plev + 50)))) return;
- break;
- }
+ break;
+ }
}
/*** Sense everything ***/
/* Valid "tval" codes */
switch (o_ptr->tval)
{
- case TV_RING:
- case TV_AMULET:
- case TV_LITE:
- case TV_FIGURINE:
- {
- okay = TRUE;
- break;
- }
+ case TV_RING:
+ case TV_AMULET:
+ case TV_LITE:
+ case TV_FIGURINE:
+ {
+ okay = TRUE;
+ break;
+ }
}
/* Skip non-sense machines */
leave_quest_check(creature_ptr);
- if (record_stair) exe_write_diary(creature_ptr, NIKKI_PAT_TELE, 0, NULL);
+ if (record_stair) exe_write_diary(creature_ptr, DIARY_PAT_TELE, 0, NULL);
creature_ptr->current_floor_ptr->inside_quest = 0;
free_turn(creature_ptr);
if (!pattern_tile(creature_ptr->y, creature_ptr->x)) return FALSE;
if ((PRACE_IS_(creature_ptr, RACE_AMBERITE)) &&
- (creature_ptr->cut > 0) && one_in_(10))
+ (creature_ptr->cut > 0) && one_in_(10))
{
wreck_the_pattern(creature_ptr);
}
(void)restore_level(creature_ptr);
(void)cure_critical_wounds(creature_ptr, 1000);
- cave_set_feat(floor_ptr, creature_ptr->y, creature_ptr->x, feat_pattern_old);
+ cave_set_feat(creature_ptr, creature_ptr->y, creature_ptr->x, feat_pattern_old);
msg_print(_("「パターン」のこの部分は他の部分より強力でないようだ。", "This section of the Pattern looks less powerful."));
/*
int dev = 30;
int mult = (dev + adj_mag_mana[creature_ptr->stat_ind[A_INT]]); /* x1 to x2 speed bonus for recharging */
- for (i = 0; i < EATER_EXT*2; i++)
+ for (i = 0; i < EATER_EXT * 2; i++)
{
if (!creature_ptr->magic_num2[i]) continue;
if (creature_ptr->magic_num1[i] == ((long)creature_ptr->magic_num2[i] << 16)) continue;
}
wild_regen = 20;
}
- for (i = EATER_EXT*2; i < EATER_EXT*3; i++)
+ for (i = EATER_EXT * 2; i < EATER_EXT * 3; i++)
{
if (!creature_ptr->magic_num1[i]) continue;
if (!creature_ptr->magic_num2[i]) continue;
/* Decrease remaining period for charging */
- new_mana = (regen_amount * mult * ((long)creature_ptr->magic_num2[i] + 10) * EATER_ROD_CHARGE)
- / (dev * 16 * PY_REGEN_NORMAL);
+ new_mana = (regen_amount * mult * ((long)creature_ptr->magic_num2[i] + 10) * EATER_ROD_CHARGE)
+ / (dev * 16 * PY_REGEN_NORMAL);
creature_ptr->magic_num1[i] -= new_mana;
/* Check minimum remaining period for charging */
/*!
* @brief 100ゲームターン毎のモンスターのHP自然回復処理 / Regenerate the monsters (once per 100 game turns)
+ * @param player_ptr プレーヤーへの参照ポインタ
* @return なし
* @note Should probably be done during monster turns.
*/
-static void regen_monsters(void)
+static void regenerate_monsters(player_type *player_ptr)
{
- int i, frac;
-
-
- /* Regenerate everyone */
- for (i = 1; i < p_ptr->current_floor_ptr->m_max; i++)
+ for (int i = 1; i < player_ptr->current_floor_ptr->m_max; i++)
{
/* Check the i'th monster */
- monster_type *m_ptr = &p_ptr->current_floor_ptr->m_list[i];
+ monster_type *m_ptr = &player_ptr->current_floor_ptr->m_list[i];
monster_race *r_ptr = &r_info[m_ptr->r_idx];
if (!monster_is_valid(m_ptr)) continue;
if (m_ptr->hp < m_ptr->maxhp)
{
/* Hack -- Base regeneration */
- frac = m_ptr->maxhp / 100;
+ int frac = m_ptr->maxhp / 100;
/* Hack -- Minimal regeneration rate */
if (!frac) if (one_in_(2)) frac = 1;
if (m_ptr->hp > m_ptr->maxhp) m_ptr->hp = m_ptr->maxhp;
/* Redraw (later) if needed */
- if (p_ptr->health_who == i) p_ptr->redraw |= (PR_HEALTH);
- if (p_ptr->riding == i) p_ptr->redraw |= (PR_UHEALTH);
+ if (player_ptr->health_who == i) player_ptr->redraw |= (PR_HEALTH);
+ if (player_ptr->riding == i) player_ptr->redraw |= (PR_UHEALTH);
}
}
}
/*!
* @brief 30ゲームターン毎のボール中モンスターのHP自然回復処理 / Regenerate the captured monsters (once per 30 game turns)
+ * @param creature_ptr プレーヤーへの参照ポインタ
* @return なし
* @note Should probably be done during monster turns.
*/
-static void regen_captured_monsters(void)
+static void regenerate_captured_monsters(player_type *creature_ptr)
{
int i, frac;
bool heal = FALSE;
for (i = 0; i < INVEN_TOTAL; i++)
{
monster_race *r_ptr;
- object_type *o_ptr = &p_ptr->inventory_list[i];
+ object_type *o_ptr = &creature_ptr->inventory_list[i];
if (!o_ptr->k_idx) continue;
if (o_ptr->tval != TV_CAPTURE) continue;
if (heal)
{
/* Combine pack */
- p_ptr->update |= (PU_COMBINE);
- p_ptr->window |= (PW_INVEN);
- p_ptr->window |= (PW_EQUIP);
+ creature_ptr->update |= (PU_COMBINE);
+ creature_ptr->window |= (PW_INVEN);
+ creature_ptr->window |= (PW_EQUIP);
wild_regen = 20;
}
}
/*!
* @brief 寿命つき光源の警告メッセージ処理
+ * @param creature_ptr プレーヤーへの参照ポインタ
* @param o_ptr 現在光源として使っているオブジェクトの構造体参照ポインタ
* @return なし
*/
else if (o_ptr->name2 == EGO_LITE_LONG)
{
if ((o_ptr->xtra4 < 50) && (!(o_ptr->xtra4 % 5))
- && (current_world_ptr->game_turn % (TURNS_PER_TICK*2)))
+ && (current_world_ptr->game_turn % (TURNS_PER_TICK * 2)))
{
if (disturb_minor) disturb(creature_ptr, FALSE, TRUE);
msg_print(_("明かりが微かになってきている。", "Your light is growing faint."));
else if ((o_ptr->xtra4 < 100) && (!(o_ptr->xtra4 % 10)))
{
if (disturb_minor) disturb(creature_ptr, FALSE, TRUE);
- msg_print(_("明かりが微かになってきている。", "Your light is growing faint."));
+ msg_print(_("明かりが微かになってきている。", "Your light is growing faint."));
}
}
* @param o_ptr 対象オブジェクトの構造体参照ポインタ
* @return なし
*/
-static void recharged_notice(object_type *o_ptr)
+static void recharged_notice(player_type *owner_ptr, object_type *o_ptr)
{
GAME_TEXT o_name[MAX_NLEN];
msg_format("Your %s is recharged.", o_name);
#endif
- disturb(p_ptr, FALSE, FALSE);
+ disturb(owner_ptr, FALSE, FALSE);
/* Done. */
return;
}
if (caster_ptr->spell_exp[spell] < SPELL_EXP_BEGINNER)
caster_ptr->spell_exp[spell] += 5;
- else if(caster_ptr->spell_exp[spell] < SPELL_EXP_SKILLED)
- { if (one_in_(2) && (caster_ptr->current_floor_ptr->dun_level > 4) && ((caster_ptr->current_floor_ptr->dun_level + 10) > caster_ptr->lev)) caster_ptr->spell_exp[spell] += 1; }
- else if(caster_ptr->spell_exp[spell] < SPELL_EXP_EXPERT)
- { if (one_in_(5) && ((caster_ptr->current_floor_ptr->dun_level + 5) > caster_ptr->lev) && ((caster_ptr->current_floor_ptr->dun_level + 5) > s_ptr->slevel)) caster_ptr->spell_exp[spell] += 1; }
- else if(caster_ptr->spell_exp[spell] < SPELL_EXP_MASTER)
- { if (one_in_(5) && ((caster_ptr->current_floor_ptr->dun_level + 5) > caster_ptr->lev) && (caster_ptr->current_floor_ptr->dun_level > s_ptr->slevel)) caster_ptr->spell_exp[spell] += 1; }
+ else if (caster_ptr->spell_exp[spell] < SPELL_EXP_SKILLED)
+ {
+ if (one_in_(2) && (caster_ptr->current_floor_ptr->dun_level > 4) && ((caster_ptr->current_floor_ptr->dun_level + 10) > caster_ptr->lev)) caster_ptr->spell_exp[spell] += 1;
+ }
+ else if (caster_ptr->spell_exp[spell] < SPELL_EXP_EXPERT)
+ {
+ if (one_in_(5) && ((caster_ptr->current_floor_ptr->dun_level + 5) > caster_ptr->lev) && ((caster_ptr->current_floor_ptr->dun_level + 5) > s_ptr->slevel)) caster_ptr->spell_exp[spell] += 1;
+ }
+ else if (caster_ptr->spell_exp[spell] < SPELL_EXP_MASTER)
+ {
+ if (one_in_(5) && ((caster_ptr->current_floor_ptr->dun_level + 5) > caster_ptr->lev) && (caster_ptr->current_floor_ptr->dun_level > s_ptr->slevel)) caster_ptr->spell_exp[spell] += 1;
+ }
/* Do any effects of continual song */
exe_spell(caster_ptr, REALM_MUSIC, spell, SPELL_CONT);
* @return 該当の呪いが一つでもあった場合にランダムに選ばれた装備品のオブジェクト構造体参照ポインタを返す。\n
* 呪いがない場合NULLを返す。
*/
-static object_type *choose_cursed_obj_name(BIT_FLAGS flag)
+static object_type *choose_cursed_obj_name(player_type *player_ptr, BIT_FLAGS flag)
{
int i;
- int choices[INVEN_TOTAL-INVEN_RARM];
+ int choices[INVEN_TOTAL - INVEN_RARM];
int number = 0;
/* Paranoia -- Player has no warning-item */
- if (!(p_ptr->cursed & flag)) return NULL;
+ if (!(player_ptr->cursed & flag)) return NULL;
/* Search Inventry */
for (i = INVEN_RARM; i < INVEN_TOTAL; i++)
{
- object_type *o_ptr = &p_ptr->inventory_list[i];
+ object_type *o_ptr = &player_ptr->inventory_list[i];
if (o_ptr->curse_flags & flag)
{
choices[number] = i;
number++;
}
- else if ((flag == TRC_ADD_L_CURSE) ||
- (flag == TRC_ADD_H_CURSE) ||
- (flag == TRC_DRAIN_HP) ||
- (flag == TRC_DRAIN_MANA) ||
- (flag == TRC_CALL_ANIMAL) ||
- (flag == TRC_CALL_DEMON) ||
- (flag == TRC_CALL_DRAGON) ||
- (flag == TRC_CALL_UNDEAD) ||
- (flag == TRC_COWARDICE) ||
- (flag == TRC_LOW_MELEE) ||
- (flag == TRC_LOW_AC) ||
- (flag == TRC_LOW_MAGIC) ||
- (flag == TRC_FAST_DIGEST) ||
- (flag == TRC_SLOW_REGEN) )
+ else if ((flag == TRC_ADD_L_CURSE) ||
+ (flag == TRC_ADD_H_CURSE) ||
+ (flag == TRC_DRAIN_HP) ||
+ (flag == TRC_DRAIN_MANA) ||
+ (flag == TRC_CALL_ANIMAL) ||
+ (flag == TRC_CALL_DEMON) ||
+ (flag == TRC_CALL_DRAGON) ||
+ (flag == TRC_CALL_UNDEAD) ||
+ (flag == TRC_COWARDICE) ||
+ (flag == TRC_LOW_MELEE) ||
+ (flag == TRC_LOW_AC) ||
+ (flag == TRC_LOW_MAGIC) ||
+ (flag == TRC_FAST_DIGEST) ||
+ (flag == TRC_SLOW_REGEN))
{
u32b cf = 0L;
BIT_FLAGS flgs[TR_FLAG_SIZE];
object_flags(o_ptr, flgs);
switch (flag)
{
- case TRC_ADD_L_CURSE : cf = TR_ADD_L_CURSE; break;
- case TRC_ADD_H_CURSE : cf = TR_ADD_H_CURSE; break;
- case TRC_DRAIN_HP : cf = TR_DRAIN_HP; break;
- case TRC_DRAIN_MANA : cf = TR_DRAIN_MANA; break;
- case TRC_CALL_ANIMAL : cf = TR_CALL_ANIMAL; break;
- case TRC_CALL_DEMON : cf = TR_CALL_DEMON; break;
- case TRC_CALL_DRAGON : cf = TR_CALL_DRAGON; break;
- case TRC_CALL_UNDEAD : cf = TR_CALL_UNDEAD; break;
- case TRC_COWARDICE : cf = TR_COWARDICE; break;
- case TRC_LOW_MELEE : cf = TR_LOW_MELEE; break;
- case TRC_LOW_AC : cf = TR_LOW_AC; break;
- case TRC_LOW_MAGIC : cf = TR_LOW_MAGIC; break;
- case TRC_FAST_DIGEST : cf = TR_FAST_DIGEST; break;
- case TRC_SLOW_REGEN : cf = TR_SLOW_REGEN; break;
- default : break;
+ case TRC_ADD_L_CURSE: cf = TR_ADD_L_CURSE; break;
+ case TRC_ADD_H_CURSE: cf = TR_ADD_H_CURSE; break;
+ case TRC_DRAIN_HP: cf = TR_DRAIN_HP; break;
+ case TRC_DRAIN_MANA: cf = TR_DRAIN_MANA; break;
+ case TRC_CALL_ANIMAL: cf = TR_CALL_ANIMAL; break;
+ case TRC_CALL_DEMON: cf = TR_CALL_DEMON; break;
+ case TRC_CALL_DRAGON: cf = TR_CALL_DRAGON; break;
+ case TRC_CALL_UNDEAD: cf = TR_CALL_UNDEAD; break;
+ case TRC_COWARDICE: cf = TR_COWARDICE; break;
+ case TRC_LOW_MELEE: cf = TR_LOW_MELEE; break;
+ case TRC_LOW_AC: cf = TR_LOW_AC; break;
+ case TRC_LOW_MAGIC: cf = TR_LOW_MAGIC; break;
+ case TRC_FAST_DIGEST: cf = TR_FAST_DIGEST; break;
+ case TRC_SLOW_REGEN: cf = TR_SLOW_REGEN; break;
+ default: break;
}
if (have_flag(flgs, cf))
{
}
}
- /* Choice one of them */
- return (&p_ptr->inventory_list[choices[randint0(number)]]);
+ return &player_ptr->inventory_list[choices[randint0(number)]];
}
}
if (creature_ptr->inventory_list[INVEN_LITE].tval && (creature_ptr->inventory_list[INVEN_LITE].name2 != EGO_LITE_DARKNESS) &&
- !creature_ptr->resist_lite)
+ !creature_ptr->resist_lite)
{
object_type *o_ptr = &creature_ptr->inventory_list[INVEN_LITE];
- GAME_TEXT o_name [MAX_NLEN];
- char ouch [MAX_NLEN+40];
+ GAME_TEXT o_name[MAX_NLEN];
+ char ouch[MAX_NLEN + 40];
/* Get an object description */
object_desc(o_name, o_ptr, (OD_OMIT_PREFIX | OD_NAME_ONLY));
if (damage)
{
- if(PRACE_IS_(creature_ptr, RACE_ENT)) damage += damage / 3;
- if(creature_ptr->resist_fire) damage = damage / 3;
- if(is_oppose_fire(creature_ptr)) damage = damage / 3;
- if(creature_ptr->levitation) damage = damage / 5;
+ if (PRACE_IS_(creature_ptr, RACE_ENT)) damage += damage / 3;
+ if (creature_ptr->resist_fire) damage = damage / 3;
+ if (is_oppose_fire(creature_ptr)) damage = damage / 3;
+ if (creature_ptr->levitation) damage = damage / 5;
damage = damage / 100 + (randint0(100) < (damage % 100));
if (creature_ptr->levitation)
{
msg_print(_("熱で火傷した!", "The heat burns you!"));
- take_hit(creature_ptr, DAMAGE_NOESCAPE, damage, format(_("%sの上に浮遊したダメージ", "flying over %s"),
- f_name + f_info[get_feat_mimic(&creature_ptr->current_floor_ptr->grid_array[creature_ptr->y][creature_ptr->x])].name), -1);
+ take_hit(creature_ptr, DAMAGE_NOESCAPE, damage, format(_("%sの上に浮遊したダメージ", "flying over %s"),
+ f_name + f_info[get_feat_mimic(&creature_ptr->current_floor_ptr->grid_array[creature_ptr->y][creature_ptr->x])].name), -1);
}
else
{
}
if (have_flag(f_ptr->flags, FF_WATER) && have_flag(f_ptr->flags, FF_DEEP) &&
- !creature_ptr->levitation && !creature_ptr->can_swim && !creature_ptr->resist_water)
+ !creature_ptr->levitation && !creature_ptr->can_swim && !creature_ptr->resist_water)
{
if (creature_ptr->total_weight > weight_limit(creature_ptr))
{
/* No regeneration while special action */
if ((creature_ptr->action == ACTION_LEARN) ||
- (creature_ptr->action == ACTION_HAYAGAKE) ||
- (creature_ptr->special_defense & KATA_KOUKIJIN))
+ (creature_ptr->action == ACTION_HAYAGAKE) ||
+ (creature_ptr->special_defense & KATA_KOUKIJIN))
{
upkeep_factor += 100;
}
if (creature_ptr->cut > 1000) adjust = 0;
/* Apply some healing */
- (void)set_cut(creature_ptr,creature_ptr->cut - adjust);
+ (void)set_cut(creature_ptr, creature_ptr->cut - adjust);
}
}
/* Decrease life-span */
if (o_ptr->name2 == EGO_LITE_LONG)
{
- if (current_world_ptr->game_turn % (TURNS_PER_TICK*2)) o_ptr->xtra4--;
+ if (current_world_ptr->game_turn % (TURNS_PER_TICK * 2)) o_ptr->xtra4--;
}
else o_ptr->xtra4--;
msg_print(NULL);
if (one_in_(3)) lose_all_info(creature_ptr);
else wiz_dark(creature_ptr);
- (void)teleport_player_aux(creature_ptr,100, TELEPORT_NONMAGICAL | TELEPORT_PASSIVE);
+ (void)teleport_player_aux(creature_ptr, 100, TELEPORT_NONMAGICAL | TELEPORT_PASSIVE);
wiz_dark(creature_ptr);
msg_print(_("あなたは見知らぬ場所で目が醒めた...頭が痛い。", "You wake up somewhere with a sore head..."));
msg_print(_("何も覚えていない。どうやってここに来たかも分からない!", "You can't remember a thing, or how you got here!"));
}
if ((creature_ptr->muta2 & MUT2_PROD_MANA) &&
- !creature_ptr->anti_magic && one_in_(9000))
+ !creature_ptr->anti_magic && one_in_(9000))
{
int dire = 0;
disturb(creature_ptr, FALSE, TRUE);
- msg_print(_("魔法のエネルギーが突然あなたの中に流れ込んできた!エネルギーを解放しなければならない!",
- "Magical energy flows through you! You must release it!"));
+ msg_print(_("魔法のエネルギーが突然あなたの中に流れ込んできた!エネルギーを解放しなければならない!",
+ "Magical energy flows through you! You must release it!"));
flush();
msg_print(NULL);
if (pet) mode |= PM_FORCE_PET;
else mode |= (PM_ALLOW_UNIQUE | PM_NO_PET);
- if (summon_specific((pet ? -1 : 0), creature_ptr->y, creature_ptr->x, creature_ptr->current_floor_ptr->dun_level, SUMMON_DEMON, mode))
+ if (summon_specific(creature_ptr, (pet ? -1 : 0), creature_ptr->y, creature_ptr->x, creature_ptr->current_floor_ptr->dun_level, SUMMON_DEMON, mode))
{
msg_print(_("あなたはデーモンを引き寄せた!", "You have attracted a demon!"));
disturb(creature_ptr, FALSE, TRUE);
do
{
n = randint0(MAX_STORES);
- }
- while ((n == STORE_HOME) || (n == STORE_MUSEUM));
+ } while ((n == STORE_HOME) || (n == STORE_MUSEUM));
msg_print(_("店の主人が丘に向かって走っている!", "You see one of the shopkeepers running for the hills!"));
- store_shuffle(n);
+ store_shuffle(creature_ptr, n);
}
msg_print(NULL);
}
if (pet) mode |= PM_FORCE_PET;
else mode |= (PM_ALLOW_UNIQUE | PM_NO_PET);
- if (summon_specific((pet ? -1 : 0), creature_ptr->y, creature_ptr->x, creature_ptr->current_floor_ptr->dun_level, SUMMON_ANIMAL, mode))
+ if (summon_specific(creature_ptr, (pet ? -1 : 0), creature_ptr->y, creature_ptr->x, creature_ptr->current_floor_ptr->dun_level, SUMMON_ANIMAL, mode))
{
msg_print(_("動物を引き寄せた!", "You have attracted an animal!"));
disturb(creature_ptr, FALSE, TRUE);
if (pet) mode |= PM_FORCE_PET;
else mode |= (PM_ALLOW_UNIQUE | PM_NO_PET);
- if (summon_specific((pet ? -1 : 0), creature_ptr->y, creature_ptr->x, creature_ptr->current_floor_ptr->dun_level, SUMMON_DRAGON, mode))
+ if (summon_specific(creature_ptr, (pet ? -1 : 0), creature_ptr->y, creature_ptr->x, creature_ptr->current_floor_ptr->dun_level, SUMMON_DRAGON, mode))
{
msg_print(_("ドラゴンを引き寄せた!", "You have attracted a dragon!"));
disturb(creature_ptr, FALSE, TRUE);
}
else
{
- msg_format(_("%sに{.}(ピリオド)と銘を刻むと発動を抑制できます。",
- "You can inscribe {.} on your %s to disable random teleportation. "), o_name);
+ msg_format(_("%sに{.}(ピリオド)と銘を刻むと発動を抑制できます。",
+ "You can inscribe {.} on your %s to disable random teleportation. "), o_name);
disturb(creature_ptr, TRUE, TRUE);
}
}
BIT_FLAGS new_curse;
object_type *o_ptr;
- o_ptr = choose_cursed_obj_name(TRC_ADD_L_CURSE);
+ o_ptr = choose_cursed_obj_name(creature_ptr, TRC_ADD_L_CURSE);
new_curse = get_curse(0, o_ptr);
if (!(o_ptr->curse_flags & new_curse))
BIT_FLAGS new_curse;
object_type *o_ptr;
- o_ptr = choose_cursed_obj_name(TRC_ADD_H_CURSE);
+ o_ptr = choose_cursed_obj_name(creature_ptr, TRC_ADD_H_CURSE);
new_curse = get_curse(1, o_ptr);
if (!(o_ptr->curse_flags & new_curse))
/* Call animal */
if ((creature_ptr->cursed & TRC_CALL_ANIMAL) && one_in_(2500))
{
- if (summon_specific(0, creature_ptr->y, creature_ptr->x, creature_ptr->current_floor_ptr->dun_level, SUMMON_ANIMAL, (PM_ALLOW_GROUP | PM_ALLOW_UNIQUE | PM_NO_PET)))
+ if (summon_specific(creature_ptr, 0, creature_ptr->y, creature_ptr->x, creature_ptr->current_floor_ptr->dun_level, SUMMON_ANIMAL, (PM_ALLOW_GROUP | PM_ALLOW_UNIQUE | PM_NO_PET)))
{
GAME_TEXT o_name[MAX_NLEN];
- object_desc(o_name, choose_cursed_obj_name(TRC_CALL_ANIMAL), (OD_OMIT_PREFIX | OD_NAME_ONLY));
+ object_desc(o_name, choose_cursed_obj_name(creature_ptr, TRC_CALL_ANIMAL), (OD_OMIT_PREFIX | OD_NAME_ONLY));
msg_format(_("%sが動物を引き寄せた!", "Your %s has attracted an animal!"), o_name);
disturb(creature_ptr, FALSE, TRUE);
}
/* Call demon */
if ((creature_ptr->cursed & TRC_CALL_DEMON) && one_in_(1111))
{
- if (summon_specific(0, creature_ptr->y, creature_ptr->x, creature_ptr->current_floor_ptr->dun_level, SUMMON_DEMON, (PM_ALLOW_GROUP | PM_ALLOW_UNIQUE | PM_NO_PET)))
+ if (summon_specific(creature_ptr, 0, creature_ptr->y, creature_ptr->x, creature_ptr->current_floor_ptr->dun_level, SUMMON_DEMON, (PM_ALLOW_GROUP | PM_ALLOW_UNIQUE | PM_NO_PET)))
{
GAME_TEXT o_name[MAX_NLEN];
- object_desc(o_name, choose_cursed_obj_name(TRC_CALL_DEMON), (OD_OMIT_PREFIX | OD_NAME_ONLY));
+ object_desc(o_name, choose_cursed_obj_name(creature_ptr, TRC_CALL_DEMON), (OD_OMIT_PREFIX | OD_NAME_ONLY));
msg_format(_("%sが悪魔を引き寄せた!", "Your %s has attracted a demon!"), o_name);
disturb(creature_ptr, FALSE, TRUE);
}
/* Call dragon */
if ((creature_ptr->cursed & TRC_CALL_DRAGON) && one_in_(800))
{
- if (summon_specific(0, creature_ptr->y, creature_ptr->x, creature_ptr->current_floor_ptr->dun_level, SUMMON_DRAGON,
- (PM_ALLOW_GROUP | PM_ALLOW_UNIQUE | PM_NO_PET)))
+ if (summon_specific(creature_ptr, 0, creature_ptr->y, creature_ptr->x, creature_ptr->current_floor_ptr->dun_level, SUMMON_DRAGON,
+ (PM_ALLOW_GROUP | PM_ALLOW_UNIQUE | PM_NO_PET)))
{
GAME_TEXT o_name[MAX_NLEN];
- object_desc(o_name, choose_cursed_obj_name(TRC_CALL_DRAGON), (OD_OMIT_PREFIX | OD_NAME_ONLY));
+ object_desc(o_name, choose_cursed_obj_name(creature_ptr, TRC_CALL_DRAGON), (OD_OMIT_PREFIX | OD_NAME_ONLY));
msg_format(_("%sがドラゴンを引き寄せた!", "Your %s has attracted an dragon!"), o_name);
disturb(creature_ptr, FALSE, TRUE);
}
/* Call undead */
if ((creature_ptr->cursed & TRC_CALL_UNDEAD) && one_in_(1111))
{
- if (summon_specific(0, creature_ptr->y, creature_ptr->x, creature_ptr->current_floor_ptr->dun_level, SUMMON_UNDEAD,
- (PM_ALLOW_GROUP | PM_ALLOW_UNIQUE | PM_NO_PET)))
+ if (summon_specific(creature_ptr, 0, creature_ptr->y, creature_ptr->x, creature_ptr->current_floor_ptr->dun_level, SUMMON_UNDEAD,
+ (PM_ALLOW_GROUP | PM_ALLOW_UNIQUE | PM_NO_PET)))
{
GAME_TEXT o_name[MAX_NLEN];
- object_desc(o_name, choose_cursed_obj_name(TRC_CALL_UNDEAD), (OD_OMIT_PREFIX | OD_NAME_ONLY));
+ object_desc(o_name, choose_cursed_obj_name(creature_ptr, TRC_CALL_UNDEAD), (OD_OMIT_PREFIX | OD_NAME_ONLY));
msg_format(_("%sが死霊を引き寄せた!", "Your %s has attracted an undead!"), o_name);
disturb(creature_ptr, FALSE, TRUE);
}
{
GAME_TEXT o_name[MAX_NLEN];
- object_desc(o_name, choose_cursed_obj_name(TRC_DRAIN_HP), (OD_OMIT_PREFIX | OD_NAME_ONLY));
+ object_desc(o_name, choose_cursed_obj_name(creature_ptr, TRC_DRAIN_HP), (OD_OMIT_PREFIX | OD_NAME_ONLY));
msg_format(_("%sはあなたの体力を吸収した!", "Your %s drains HP from you!"), o_name);
- take_hit(creature_ptr, DAMAGE_LOSELIFE, MIN(creature_ptr->lev*2, 100), o_name, -1);
+ take_hit(creature_ptr, DAMAGE_LOSELIFE, MIN(creature_ptr->lev * 2, 100), o_name, -1);
}
/* Handle mana draining */
if ((creature_ptr->cursed & TRC_DRAIN_MANA) && creature_ptr->csp && one_in_(666))
{
GAME_TEXT o_name[MAX_NLEN];
- object_desc(o_name, choose_cursed_obj_name(TRC_DRAIN_MANA), (OD_OMIT_PREFIX | OD_NAME_ONLY));
+ object_desc(o_name, choose_cursed_obj_name(creature_ptr, TRC_DRAIN_MANA), (OD_OMIT_PREFIX | OD_NAME_ONLY));
msg_format(_("%sはあなたの魔力を吸収した!", "Your %s drains mana from you!"), o_name);
creature_ptr->csp -= MIN(creature_ptr->lev, 50);
if (creature_ptr->csp < 0)
/* Notice changes */
if (!o_ptr->timeout)
{
- recharged_notice(o_ptr);
+ recharged_notice(creature_ptr, o_ptr);
changed = TRUE;
}
}
/* Notice changes, provide message if object is inscribed. */
if (!(o_ptr->timeout))
{
- recharged_notice(o_ptr);
+ recharged_notice(creature_ptr, o_ptr);
changed = TRUE;
}
if (creature_ptr->dungeon_idx) creature_ptr->recall_dungeon = creature_ptr->dungeon_idx;
if (record_stair)
- exe_write_diary(creature_ptr, NIKKI_RECALL, floor_ptr->dun_level, NULL);
+ exe_write_diary(creature_ptr, DIARY_RECALL, floor_ptr->dun_level, NULL);
floor_ptr->dun_level = 0;
creature_ptr->dungeon_idx = 0;
creature_ptr->dungeon_idx = creature_ptr->recall_dungeon;
if (record_stair)
- exe_write_diary(creature_ptr, NIKKI_RECALL, floor_ptr->dun_level, NULL);
+ exe_write_diary(creature_ptr, DIARY_RECALL, floor_ptr->dun_level, NULL);
/* New depth */
floor_ptr->dun_level = max_dlv[creature_ptr->dungeon_idx];
{
quest_type* const q_ptr = &quest[i];
-
+
if ((q_ptr->type == QUEST_TYPE_RANDOM) &&
- (q_ptr->status == QUEST_STATUS_TAKEN) &&
- (q_ptr->level < floor_ptr->dun_level))
+ (q_ptr->status == QUEST_STATUS_TAKEN) &&
+ (q_ptr->level < floor_ptr->dun_level))
{
q_ptr->status = QUEST_STATUS_FAILED;
q_ptr->complev = (byte)creature_ptr->lev;
const s32b A_DAY = TURNS_PER_TICK * TOWN_DAWN;
s32b prev_turn_in_today = ((current_world_ptr->game_turn - TURNS_PER_TICK) % A_DAY + A_DAY / 4) % A_DAY;
int prev_min = (1440 * prev_turn_in_today / A_DAY) % 60;
-
- extract_day_hour_min(&day, &hour, &min);
+
+ extract_day_hour_min(player_ptr, &day, &hour, &min);
/* Update dungeon feeling, and announce it if changed */
- update_dungeon_feeling(player_ptr, player_ptr->current_floor_ptr);
+ update_dungeon_feeling(player_ptr);
/* 帰還無しモード時のレベルテレポバグ対策 / Fix for level teleport bugs on ironman_downward.*/
+ floor_type *floor_ptr = player_ptr->current_floor_ptr;
if (ironman_downward && (player_ptr->dungeon_idx != DUNGEON_ANGBAND && player_ptr->dungeon_idx != 0))
{
- player_ptr->current_floor_ptr->dun_level = 0;
+ floor_ptr->dun_level = 0;
player_ptr->dungeon_idx = 0;
prepare_change_floor_mode(player_ptr, CFM_FIRST_FLOOR | CFM_RAND_PLACE);
- player_ptr->current_floor_ptr->inside_arena = FALSE;
+ floor_ptr->inside_arena = FALSE;
player_ptr->wild_mode = FALSE;
player_ptr->leaving = TRUE;
}
int number_mon = 0;
/* Count all hostile monsters */
- for (i2 = 0; i2 < player_ptr->current_floor_ptr->width; ++i2)
- for (j2 = 0; j2 < player_ptr->current_floor_ptr->height; j2++)
+ for (i2 = 0; i2 < floor_ptr->width; ++i2)
+ for (j2 = 0; j2 < floor_ptr->height; j2++)
{
- grid_type *g_ptr = &player_ptr->current_floor_ptr->grid_array[j2][i2];
+ grid_type *g_ptr = &floor_ptr->grid_array[j2][i2];
if ((g_ptr->m_idx > 0) && (g_ptr->m_idx != player_ptr->riding))
{
player_ptr->energy_need = 0;
update_gambling_monsters(player_ptr);
}
- else if ((number_mon-1) == 0)
+ else if ((number_mon - 1) == 0)
{
GAME_TEXT m_name[MAX_NLEN];
monster_type *wm_ptr;
- wm_ptr = &player_ptr->current_floor_ptr->m_list[win_m_idx];
+ wm_ptr = &floor_ptr->m_list[win_m_idx];
- monster_desc(m_name, wm_ptr, 0);
+ monster_desc(player_ptr, m_name, wm_ptr, 0);
msg_format(_("%sが勝利した!", "%s is winner!"), m_name);
msg_print(NULL);
- if (win_m_idx == (sel_monster+1))
+ if (win_m_idx == (sel_monster + 1))
{
msg_print(_("おめでとうございます。", "Congratulations."));
msg_format(_("%d$を受け取った。", "You received %d gold."), battle_odds);
player_ptr->energy_need = 0;
update_gambling_monsters(player_ptr);
}
- else if (current_world_ptr->game_turn - player_ptr->current_floor_ptr->generated_turn == 150 * TURNS_PER_TICK)
+ else if (current_world_ptr->game_turn - floor_ptr->generated_turn == 150 * TURNS_PER_TICK)
{
msg_print(_("申し分けありませんが、この勝負は引き分けとさせていただきます。", "This battle have ended in a draw."));
player_ptr->au += kakekin;
do_cmd_save_game(player_ptr, TRUE);
}
- if (player_ptr->current_floor_ptr->monster_noise && !ignore_unview)
+ if (floor_ptr->monster_noise && !ignore_unview)
{
msg_print(_("何かが聞こえた。", "You hear noise."));
}
/*** Handle the wilderness/town (sunshine) ***/
/* While in town/wilderness */
- if (!player_ptr->current_floor_ptr->dun_level && !player_ptr->current_floor_ptr->inside_quest && !player_ptr->phase_out && !player_ptr->current_floor_ptr->inside_arena)
+ if (!floor_ptr->dun_level && !floor_ptr->inside_quest && !player_ptr->phase_out && !floor_ptr->inside_arena)
{
/* Hack -- Daybreak/Nighfall in town */
if (!(current_world_ptr->game_turn % ((TURNS_PER_TICK * TOWN_DAWN) / 2)))
/* Check for dawn */
dawn = (!(current_world_ptr->game_turn % (TURNS_PER_TICK * TOWN_DAWN)));
- if (dawn) day_break(player_ptr->current_floor_ptr);
- else night_falls(player_ptr->current_floor_ptr);
+ if (dawn) day_break(player_ptr);
+ else night_falls(player_ptr);
}
}
/* While in the dungeon (vanilla_town or lite_town mode only) */
- else if ((vanilla_town || (lite_town && !player_ptr->current_floor_ptr->inside_quest && !player_ptr->phase_out && !player_ptr->current_floor_ptr->inside_arena)) && player_ptr->current_floor_ptr->dun_level)
+ else if ((vanilla_town || (lite_town && !floor_ptr->inside_quest && !player_ptr->phase_out && !floor_ptr->inside_arena)) && floor_ptr->dun_level)
{
/*** Shuffle the Storekeepers ***/
do
{
n = randint0(MAX_STORES);
- }
- while ((n == STORE_HOME) || (n == STORE_MUSEUM));
+ } while ((n == STORE_HOME) || (n == STORE_MUSEUM));
/* Check every feature */
for (i = 1; i < max_f_idx; i++)
if (cheat_xtra) msg_format(_("%sの店主をシャッフルします。", "Shuffle a Shopkeeper of %s."), f_name + f_ptr->name);
/* Shuffle it */
- store_shuffle(n);
+ store_shuffle(player_ptr, n);
break;
}
}
}
-
/*** Process the monsters ***/
/* Check for creature generation. */
if (one_in_(d_info[player_ptr->dungeon_idx].max_m_alloc_chance) &&
- !player_ptr->current_floor_ptr->inside_arena && !player_ptr->current_floor_ptr->inside_quest && !player_ptr->phase_out)
+ !floor_ptr->inside_arena && !floor_ptr->inside_quest && !player_ptr->phase_out)
{
/* Make a new monster */
- (void)alloc_monster(MAX_SIGHT + 5, 0);
+ (void)alloc_monster(player_ptr, MAX_SIGHT + 5, 0);
}
/* Hack -- Check for creature regeneration */
- if (!(current_world_ptr->game_turn % (TURNS_PER_TICK * 10)) && !player_ptr->phase_out) regen_monsters();
- if (!(current_world_ptr->game_turn % (TURNS_PER_TICK * 3))) regen_captured_monsters();
+ if (!(current_world_ptr->game_turn % (TURNS_PER_TICK * 10)) && !player_ptr->phase_out) regenerate_monsters(player_ptr);
+ if (!(current_world_ptr->game_turn % (TURNS_PER_TICK * 3))) regenerate_captured_monsters(player_ptr);
if (!player_ptr->leaving)
{
/* Hack -- Process the counters of monsters if needed */
for (i = 0; i < MAX_MTIMED; i++)
{
- if (player_ptr->current_floor_ptr->mproc_max[i] > 0) process_monsters_mtimed(i);
+ if (floor_ptr->mproc_max[i] > 0) process_monsters_mtimed(player_ptr, i);
}
}
-
/* Date changes */
if (!hour && !min)
{
if (min != prev_min)
{
- exe_write_diary(player_ptr, NIKKI_HIGAWARI, 0, NULL);
+ exe_write_diary(player_ptr, DIARY_DIALY, 0, NULL);
determine_daily_bounty(player_ptr, FALSE);
}
}
/*!
* @brief ウィザードモードへの導入処理
* / Verify use of "wizard" mode
+ * @param player_ptr プレーヤーへの参照ポインタ
* @return 実際にウィザードモードへ移行したらTRUEを返す。
*/
-static bool enter_wizard_mode(void)
+static bool enter_wizard_mode(player_type *player_ptr)
{
/* Ask first time */
if (!current_world_ptr->noscore)
return FALSE;
}
- exe_write_diary(p_ptr, NIKKI_BUNSHOU, 0, _("ウィザードモードに突入してスコアを残せなくなった。", "give up recording score to enter wizard mode."));
+ exe_write_diary(player_ptr, DIARY_DESCRIPTION, 0, _("ウィザードモードに突入してスコアを残せなくなった。", "give up recording score to enter wizard mode."));
/* Mark savefile */
current_world_ptr->noscore |= 0x0002;
}
/*!
* @brief デバッグコマンドへの導入処理
* / Verify use of "debug" commands
+ * @param player_ptr プレーヤーへの参照ポインタ
* @return 実際にデバッグコマンドへ移行したらTRUEを返す。
*/
-static bool enter_debug_mode(void)
+static bool enter_debug_mode(player_type *player_ptr)
{
/* Ask first time */
if (!current_world_ptr->noscore)
return FALSE;
}
- exe_write_diary(p_ptr, NIKKI_BUNSHOU, 0, _("デバッグモードに突入してスコアを残せなくなった。", "give up sending score to use debug commands."));
+ exe_write_diary(player_ptr, DIARY_DESCRIPTION, 0, _("デバッグモードに突入してスコアを残せなくなった。", "give up sending score to use debug commands."));
/* Mark savefile */
current_world_ptr->noscore |= 0x0008;
}
switch (command_cmd)
{
/* Ignore */
- case ESCAPE:
- case ' ':
- {
- break;
- }
+ case ESCAPE:
+ case ' ':
+ {
+ break;
+ }
+
+ /* Ignore return */
+ case '\r':
+ case '\n':
+ {
+ break;
+ }
- /* Ignore return */
- case '\r':
- case '\n':
+ /*** Wizard Commands ***/
+ case KTRL('W'):
+ {
+ if (current_world_ptr->wizard)
{
- break;
+ current_world_ptr->wizard = FALSE;
+ msg_print(_("ウィザードモード解除。", "Wizard mode off."));
}
-
- /*** Wizard Commands ***/
- case KTRL('W'):
+ else if (enter_wizard_mode(creature_ptr))
{
- if (current_world_ptr->wizard)
- {
- current_world_ptr->wizard = FALSE;
- msg_print(_("ウィザードモード解除。", "Wizard mode off."));
- }
- else if (enter_wizard_mode())
- {
- current_world_ptr->wizard = TRUE;
- msg_print(_("ウィザードモード突入。", "Wizard mode on."));
- }
- creature_ptr->update |= (PU_MONSTERS);
- creature_ptr->redraw |= (PR_TITLE);
-
- break;
+ current_world_ptr->wizard = TRUE;
+ msg_print(_("ウィザードモード突入。", "Wizard mode on."));
}
+ creature_ptr->update |= (PU_MONSTERS);
+ creature_ptr->redraw |= (PR_TITLE);
+
+ break;
+ }
#ifdef ALLOW_WIZARD
- /* Special "debug" commands */
- case KTRL('A'):
+ /* Special "debug" commands */
+ case KTRL('A'):
+ {
+ if (enter_debug_mode(creature_ptr))
{
- if (enter_debug_mode())
- {
- do_cmd_debug(creature_ptr);
- }
- break;
+ do_cmd_debug(creature_ptr);
}
+ break;
+ }
#endif /* ALLOW_WIZARD */
#ifdef ALLOW_BORG
- /* Special "borg" commands */
- case KTRL('Z'):
+ /* Special "borg" commands */
+ case KTRL('Z'):
+ {
+ if (enter_borg_mode())
{
- if (enter_borg_mode())
- {
- if (!creature_ptr->wild_mode) do_cmd_borg();
- }
- break;
+ if (!creature_ptr->wild_mode) do_cmd_borg();
}
+ break;
+ }
#endif /* ALLOW_BORG */
- /*** Inventory Commands ***/
+ /*** Inventory Commands ***/
- /* Wear/wield equipment */
- case 'w':
- {
- if (!creature_ptr->wild_mode) do_cmd_wield(creature_ptr);
- break;
- }
+ /* Wear/wield equipment */
+ case 'w':
+ {
+ if (!creature_ptr->wild_mode) do_cmd_wield(creature_ptr);
+ break;
+ }
- /* Take off equipment */
- case 't':
- {
- if (!creature_ptr->wild_mode) do_cmd_takeoff(creature_ptr);
- break;
- }
+ /* Take off equipment */
+ case 't':
+ {
+ if (!creature_ptr->wild_mode) do_cmd_takeoff(creature_ptr);
+ break;
+ }
- /* Drop an item */
- case 'd':
- {
- if (!creature_ptr->wild_mode) do_cmd_drop(creature_ptr);
- break;
- }
+ /* Drop an item */
+ case 'd':
+ {
+ if (!creature_ptr->wild_mode) do_cmd_drop(creature_ptr);
+ break;
+ }
- /* Destroy an item */
- case 'k':
- {
- do_cmd_destroy(creature_ptr);
- break;
- }
+ /* Destroy an item */
+ case 'k':
+ {
+ do_cmd_destroy(creature_ptr);
+ break;
+ }
- /* Equipment list */
- case 'e':
- {
- do_cmd_equip(creature_ptr);
- break;
- }
+ /* Equipment list */
+ case 'e':
+ {
+ do_cmd_equip(creature_ptr);
+ break;
+ }
- /* Inventory list */
- case 'i':
- {
- do_cmd_inven(creature_ptr);
- break;
- }
+ /* Inventory list */
+ case 'i':
+ {
+ do_cmd_inven(creature_ptr);
+ break;
+ }
- /*** Various commands ***/
+ /*** Various commands ***/
- /* Identify an object */
- case 'I':
- {
- do_cmd_observe(creature_ptr);
- break;
- }
+ /* Identify an object */
+ case 'I':
+ {
+ do_cmd_observe(creature_ptr);
+ break;
+ }
- case KTRL('I'):
- {
- toggle_inven_equip(creature_ptr);
- break;
- }
+ case KTRL('I'):
+ {
+ toggle_inventory_equipment(creature_ptr);
+ break;
+ }
- /*** Standard "Movement" Commands ***/
+ /*** Standard "Movement" Commands ***/
- /* Alter a grid */
- case '+':
- {
- if (!creature_ptr->wild_mode) do_cmd_alter(creature_ptr);
- break;
- }
+ /* Alter a grid */
+ case '+':
+ {
+ if (!creature_ptr->wild_mode) do_cmd_alter(creature_ptr);
+ break;
+ }
- /* Dig a tunnel */
- case 'T':
- {
- if (!creature_ptr->wild_mode) do_cmd_tunnel(creature_ptr);
- break;
- }
+ /* Dig a tunnel */
+ case 'T':
+ {
+ if (!creature_ptr->wild_mode) do_cmd_tunnel(creature_ptr);
+ break;
+ }
- /* Move (usually pick up things) */
- case ';':
- {
- do_cmd_walk(creature_ptr, FALSE);
- break;
- }
+ /* Move (usually pick up things) */
+ case ';':
+ {
+ do_cmd_walk(creature_ptr, FALSE);
+ break;
+ }
- /* Move (usually do not pick up) */
- case '-':
- {
- do_cmd_walk(creature_ptr, TRUE);
- break;
- }
+ /* Move (usually do not pick up) */
+ case '-':
+ {
+ do_cmd_walk(creature_ptr, TRUE);
+ break;
+ }
- /*** Running, Resting, Searching, Staying */
+ /*** Running, Resting, Searching, Staying */
- /* Begin Running -- Arg is Max Distance */
- case '.':
- {
- if (!creature_ptr->wild_mode) do_cmd_run(creature_ptr);
- break;
- }
+ /* Begin Running -- Arg is Max Distance */
+ case '.':
+ {
+ if (!creature_ptr->wild_mode) do_cmd_run(creature_ptr);
+ break;
+ }
- /* Stay still (usually pick things up) */
- case ',':
- {
- do_cmd_stay(creature_ptr, always_pickup);
- break;
- }
+ /* Stay still (usually pick things up) */
+ case ',':
+ {
+ do_cmd_stay(creature_ptr, always_pickup);
+ break;
+ }
- /* Stay still (usually do not pick up) */
- case 'g':
- {
- do_cmd_stay(creature_ptr, !always_pickup);
- break;
- }
+ /* Stay still (usually do not pick up) */
+ case 'g':
+ {
+ do_cmd_stay(creature_ptr, !always_pickup);
+ break;
+ }
- /* Rest -- Arg is time */
- case 'R':
- {
- do_cmd_rest(creature_ptr);
- break;
- }
+ /* Rest -- Arg is time */
+ case 'R':
+ {
+ do_cmd_rest(creature_ptr);
+ break;
+ }
- /* Search for traps/doors */
- case 's':
- {
- do_cmd_search(creature_ptr);
- break;
- }
+ /* Search for traps/doors */
+ case 's':
+ {
+ do_cmd_search(creature_ptr);
+ break;
+ }
- case 'S':
- {
- if (creature_ptr->action == ACTION_SEARCH) set_action(creature_ptr, ACTION_NONE);
- else set_action(creature_ptr, ACTION_SEARCH);
- break;
- }
+ case 'S':
+ {
+ if (creature_ptr->action == ACTION_SEARCH) set_action(creature_ptr, ACTION_NONE);
+ else set_action(creature_ptr, ACTION_SEARCH);
+ break;
+ }
- /*** Stairs and Doors and Chests and Traps ***/
+ /*** Stairs and Doors and Chests and Traps ***/
- /* Enter store */
- case SPECIAL_KEY_STORE:
- {
- do_cmd_store(creature_ptr);
- break;
- }
+ /* Enter store */
+ case SPECIAL_KEY_STORE:
+ {
+ do_cmd_store(creature_ptr);
+ break;
+ }
- /* Enter building -KMW- */
- case SPECIAL_KEY_BUILDING:
- {
- do_cmd_bldg(creature_ptr);
- break;
- }
+ /* Enter building -KMW- */
+ case SPECIAL_KEY_BUILDING:
+ {
+ do_cmd_bldg(creature_ptr);
+ break;
+ }
- /* Enter quest level -KMW- */
- case SPECIAL_KEY_QUEST:
- {
- do_cmd_quest(creature_ptr);
- break;
- }
+ /* Enter quest level -KMW- */
+ case SPECIAL_KEY_QUEST:
+ {
+ do_cmd_quest(creature_ptr);
+ break;
+ }
- /* Go up staircase */
- case '<':
+ /* Go up staircase */
+ case '<':
+ {
+ if (!creature_ptr->wild_mode && !floor_ptr->dun_level && !floor_ptr->inside_arena && !floor_ptr->inside_quest)
{
- if (!creature_ptr->wild_mode && !floor_ptr->dun_level && !floor_ptr->inside_arena && !floor_ptr->inside_quest)
- {
- if (vanilla_town) break;
-
- if (creature_ptr->ambush_flag)
- {
- msg_print(_("襲撃から逃げるにはマップの端まで移動しなければならない。", "To flee the ambush you have to reach the edge of the map."));
- break;
- }
+ if (vanilla_town) break;
- if (creature_ptr->food < PY_FOOD_WEAK)
- {
- msg_print(_("その前に食事をとらないと。", "You must eat something here."));
- break;
- }
+ if (creature_ptr->ambush_flag)
+ {
+ msg_print(_("襲撃から逃げるにはマップの端まで移動しなければならない。", "To flee the ambush you have to reach the edge of the map."));
+ break;
+ }
- change_wild_mode(creature_ptr, FALSE);
+ if (creature_ptr->food < PY_FOOD_WEAK)
+ {
+ msg_print(_("その前に食事をとらないと。", "You must eat something here."));
+ break;
}
- else
- do_cmd_go_up(creature_ptr);
- break;
- }
- /* Go down staircase */
- case '>':
- {
- if (creature_ptr->wild_mode)
- change_wild_mode(creature_ptr, FALSE);
- else
- do_cmd_go_down(creature_ptr);
- break;
+ change_wild_mode(creature_ptr, FALSE);
}
+ else
+ do_cmd_go_up(creature_ptr);
+ break;
+ }
- /* Open a door or chest */
- case 'o':
- {
- do_cmd_open(creature_ptr);
- break;
- }
+ /* Go down staircase */
+ case '>':
+ {
+ if (creature_ptr->wild_mode)
+ change_wild_mode(creature_ptr, FALSE);
+ else
+ do_cmd_go_down(creature_ptr);
+ break;
+ }
- /* Close a door */
- case 'c':
- {
- do_cmd_close(creature_ptr);
- break;
- }
+ /* Open a door or chest */
+ case 'o':
+ {
+ do_cmd_open(creature_ptr);
+ break;
+ }
- /* Jam a door with spikes */
- case 'j':
- {
- do_cmd_spike(creature_ptr);
- break;
- }
+ /* Close a door */
+ case 'c':
+ {
+ do_cmd_close(creature_ptr);
+ break;
+ }
- /* Bash a door */
- case 'B':
- {
- do_cmd_bash(creature_ptr);
- break;
- }
+ /* Jam a door with spikes */
+ case 'j':
+ {
+ do_cmd_spike(creature_ptr);
+ break;
+ }
- /* Disarm a trap or chest */
- case 'D':
- {
- do_cmd_disarm(creature_ptr);
- break;
- }
+ /* Bash a door */
+ case 'B':
+ {
+ do_cmd_bash(creature_ptr);
+ break;
+ }
+ /* Disarm a trap or chest */
+ case 'D':
+ {
+ do_cmd_disarm(creature_ptr);
+ break;
+ }
- /*** Magic and Prayers ***/
- /* Gain new spells/prayers */
- case 'G':
- {
- if ((creature_ptr->pclass == CLASS_SORCERER) || (creature_ptr->pclass == CLASS_RED_MAGE))
- msg_print(_("呪文を学習する必要はない!", "You don't have to learn spells!"));
- else if (creature_ptr->pclass == CLASS_SAMURAI)
- do_cmd_gain_hissatsu(creature_ptr);
- else if (creature_ptr->pclass == CLASS_MAGIC_EATER)
- import_magic_device(creature_ptr);
- else
- do_cmd_study(creature_ptr);
- break;
- }
+ /*** Magic and Prayers ***/
- /* Browse a book */
- case 'b':
- {
- if ( (creature_ptr->pclass == CLASS_MINDCRAFTER) ||
- (creature_ptr->pclass == CLASS_BERSERKER) ||
- (creature_ptr->pclass == CLASS_NINJA) ||
- (creature_ptr->pclass == CLASS_MIRROR_MASTER)
- ) do_cmd_mind_browse(creature_ptr);
- else if (creature_ptr->pclass == CLASS_SMITH)
- do_cmd_kaji(creature_ptr, TRUE);
- else if (creature_ptr->pclass == CLASS_MAGIC_EATER)
- do_cmd_magic_eater(creature_ptr, TRUE, FALSE);
- else if (creature_ptr->pclass == CLASS_SNIPER)
- do_cmd_snipe_browse(creature_ptr);
- else do_cmd_browse(creature_ptr);
- break;
- }
+ /* Gain new spells/prayers */
+ case 'G':
+ {
+ if ((creature_ptr->pclass == CLASS_SORCERER) || (creature_ptr->pclass == CLASS_RED_MAGE))
+ msg_print(_("呪文を学習する必要はない!", "You don't have to learn spells!"));
+ else if (creature_ptr->pclass == CLASS_SAMURAI)
+ do_cmd_gain_hissatsu(creature_ptr);
+ else if (creature_ptr->pclass == CLASS_MAGIC_EATER)
+ import_magic_device(creature_ptr);
+ else
+ do_cmd_study(creature_ptr);
+ break;
+ }
+
+ /* Browse a book */
+ case 'b':
+ {
+ if ((creature_ptr->pclass == CLASS_MINDCRAFTER) ||
+ (creature_ptr->pclass == CLASS_BERSERKER) ||
+ (creature_ptr->pclass == CLASS_NINJA) ||
+ (creature_ptr->pclass == CLASS_MIRROR_MASTER)
+ ) do_cmd_mind_browse(creature_ptr);
+ else if (creature_ptr->pclass == CLASS_SMITH)
+ do_cmd_kaji(creature_ptr, TRUE);
+ else if (creature_ptr->pclass == CLASS_MAGIC_EATER)
+ do_cmd_magic_eater(creature_ptr, TRUE, FALSE);
+ else if (creature_ptr->pclass == CLASS_SNIPER)
+ do_cmd_snipe_browse(creature_ptr);
+ else do_cmd_browse(creature_ptr);
+ break;
+ }
- /* Cast a spell */
- case 'm':
+ /* Cast a spell */
+ case 'm':
+ {
+ /* -KMW- */
+ if (!creature_ptr->wild_mode)
{
- /* -KMW- */
- if (!creature_ptr->wild_mode)
+ if ((creature_ptr->pclass == CLASS_WARRIOR) || (creature_ptr->pclass == CLASS_ARCHER) || (creature_ptr->pclass == CLASS_CAVALRY))
{
- if ((creature_ptr->pclass == CLASS_WARRIOR) || (creature_ptr->pclass == CLASS_ARCHER) || (creature_ptr->pclass == CLASS_CAVALRY))
- {
- msg_print(_("呪文を唱えられない!", "You cannot cast spells!"));
- }
- else if (floor_ptr->dun_level && (d_info[creature_ptr->dungeon_idx].flags1 & DF1_NO_MAGIC) && (creature_ptr->pclass != CLASS_BERSERKER) && (creature_ptr->pclass != CLASS_SMITH))
- {
- msg_print(_("ダンジョンが魔法を吸収した!", "The dungeon absorbs all attempted magic!"));
- msg_print(NULL);
- }
- else if (creature_ptr->anti_magic && (creature_ptr->pclass != CLASS_BERSERKER) && (creature_ptr->pclass != CLASS_SMITH))
- {
- concptr which_power = _("魔法", "magic");
- if (creature_ptr->pclass == CLASS_MINDCRAFTER)
- which_power = _("超能力", "psionic powers");
- else if (creature_ptr->pclass == CLASS_IMITATOR)
- which_power = _("ものまね", "imitation");
- else if (creature_ptr->pclass == CLASS_SAMURAI)
- which_power = _("必殺剣", "hissatsu");
- else if (creature_ptr->pclass == CLASS_MIRROR_MASTER)
- which_power = _("鏡魔法", "mirror magic");
- else if (creature_ptr->pclass == CLASS_NINJA)
- which_power = _("忍術", "ninjutsu");
- else if (mp_ptr->spell_book == TV_LIFE_BOOK)
- which_power = _("祈り", "prayer");
-
- msg_format(_("反魔法バリアが%sを邪魔した!", "An anti-magic shell disrupts your %s!"), which_power);
- free_turn(creature_ptr);
- }
- else if (creature_ptr->shero && (creature_ptr->pclass != CLASS_BERSERKER))
- {
- msg_format(_("狂戦士化していて頭が回らない!", "You cannot think directly!"));
- free_turn(creature_ptr);
- }
+ msg_print(_("呪文を唱えられない!", "You cannot cast spells!"));
+ }
+ else if (floor_ptr->dun_level && (d_info[creature_ptr->dungeon_idx].flags1 & DF1_NO_MAGIC) && (creature_ptr->pclass != CLASS_BERSERKER) && (creature_ptr->pclass != CLASS_SMITH))
+ {
+ msg_print(_("ダンジョンが魔法を吸収した!", "The dungeon absorbs all attempted magic!"));
+ msg_print(NULL);
+ }
+ else if (creature_ptr->anti_magic && (creature_ptr->pclass != CLASS_BERSERKER) && (creature_ptr->pclass != CLASS_SMITH))
+ {
+ concptr which_power = _("魔法", "magic");
+ if (creature_ptr->pclass == CLASS_MINDCRAFTER)
+ which_power = _("超能力", "psionic powers");
+ else if (creature_ptr->pclass == CLASS_IMITATOR)
+ which_power = _("ものまね", "imitation");
+ else if (creature_ptr->pclass == CLASS_SAMURAI)
+ which_power = _("必殺剣", "hissatsu");
+ else if (creature_ptr->pclass == CLASS_MIRROR_MASTER)
+ which_power = _("鏡魔法", "mirror magic");
+ else if (creature_ptr->pclass == CLASS_NINJA)
+ which_power = _("忍術", "ninjutsu");
+ else if (mp_ptr->spell_book == TV_LIFE_BOOK)
+ which_power = _("祈り", "prayer");
+
+ msg_format(_("反魔法バリアが%sを邪魔した!", "An anti-magic shell disrupts your %s!"), which_power);
+ free_turn(creature_ptr);
+ }
+ else if (creature_ptr->shero && (creature_ptr->pclass != CLASS_BERSERKER))
+ {
+ msg_format(_("狂戦士化していて頭が回らない!", "You cannot think directly!"));
+ free_turn(creature_ptr);
+ }
+ else
+ {
+ if ((creature_ptr->pclass == CLASS_MINDCRAFTER) ||
+ (creature_ptr->pclass == CLASS_BERSERKER) ||
+ (creature_ptr->pclass == CLASS_NINJA) ||
+ (creature_ptr->pclass == CLASS_MIRROR_MASTER)
+ )
+ do_cmd_mind(creature_ptr);
+ else if (creature_ptr->pclass == CLASS_IMITATOR)
+ do_cmd_mane(creature_ptr, FALSE);
+ else if (creature_ptr->pclass == CLASS_MAGIC_EATER)
+ do_cmd_magic_eater(creature_ptr, FALSE, FALSE);
+ else if (creature_ptr->pclass == CLASS_SAMURAI)
+ do_cmd_hissatsu(creature_ptr);
+ else if (creature_ptr->pclass == CLASS_BLUE_MAGE)
+ do_cmd_cast_learned(creature_ptr);
+ else if (creature_ptr->pclass == CLASS_SMITH)
+ do_cmd_kaji(creature_ptr, FALSE);
+ else if (creature_ptr->pclass == CLASS_SNIPER)
+ do_cmd_snipe(creature_ptr);
else
- {
- if ((creature_ptr->pclass == CLASS_MINDCRAFTER) ||
- (creature_ptr->pclass == CLASS_BERSERKER) ||
- (creature_ptr->pclass == CLASS_NINJA) ||
- (creature_ptr->pclass == CLASS_MIRROR_MASTER)
- )
- do_cmd_mind(creature_ptr);
- else if (creature_ptr->pclass == CLASS_IMITATOR)
- do_cmd_mane(creature_ptr, FALSE);
- else if (creature_ptr->pclass == CLASS_MAGIC_EATER)
- do_cmd_magic_eater(creature_ptr, FALSE, FALSE);
- else if (creature_ptr->pclass == CLASS_SAMURAI)
- do_cmd_hissatsu(creature_ptr);
- else if (creature_ptr->pclass == CLASS_BLUE_MAGE)
- do_cmd_cast_learned(creature_ptr);
- else if (creature_ptr->pclass == CLASS_SMITH)
- do_cmd_kaji(creature_ptr, FALSE);
- else if (creature_ptr->pclass == CLASS_SNIPER)
- do_cmd_snipe(creature_ptr);
- else
- do_cmd_cast(creature_ptr);
- }
+ do_cmd_cast(creature_ptr);
}
- break;
}
+ break;
+ }
- /* Issue a pet command */
- case 'p':
- {
- do_cmd_pet(creature_ptr);
- break;
- }
+ /* Issue a pet command */
+ case 'p':
+ {
+ do_cmd_pet(creature_ptr);
+ break;
+ }
- /*** Use various objects ***/
+ /*** Use various objects ***/
- /* Inscribe an object */
- case '{':
- {
- do_cmd_inscribe(creature_ptr);
- break;
- }
+ /* Inscribe an object */
+ case '{':
+ {
+ do_cmd_inscribe(creature_ptr);
+ break;
+ }
- /* Uninscribe an object */
- case '}':
- {
- do_cmd_uninscribe(creature_ptr);
- break;
- }
+ /* Uninscribe an object */
+ case '}':
+ {
+ do_cmd_uninscribe(creature_ptr);
+ break;
+ }
- /* Activate an artifact */
- case 'A':
- {
- do_cmd_activate(creature_ptr);
- break;
- }
+ /* Activate an artifact */
+ case 'A':
+ {
+ do_cmd_activate(creature_ptr);
+ break;
+ }
- /* Eat some food */
- case 'E':
- {
- do_cmd_eat_food(creature_ptr);
- break;
- }
+ /* Eat some food */
+ case 'E':
+ {
+ do_cmd_eat_food(creature_ptr);
+ break;
+ }
- /* Fuel your lantern/torch */
- case 'F':
- {
- do_cmd_refill(creature_ptr);
- break;
- }
+ /* Fuel your lantern/torch */
+ case 'F':
+ {
+ do_cmd_refill(creature_ptr);
+ break;
+ }
- /* Fire an item */
- case 'f':
- {
- do_cmd_fire(creature_ptr, SP_NONE);
- break;
- }
+ /* Fire an item */
+ case 'f':
+ {
+ do_cmd_fire(creature_ptr, SP_NONE);
+ break;
+ }
- /* Throw an item */
- case 'v':
- {
- do_cmd_throw(creature_ptr, 1, FALSE, -1);
- break;
- }
+ /* Throw an item */
+ case 'v':
+ {
+ do_cmd_throw(creature_ptr, 1, FALSE, -1);
+ break;
+ }
- /* Aim a wand */
- case 'a':
- {
- do_cmd_aim_wand(creature_ptr);
- break;
- }
+ /* Aim a wand */
+ case 'a':
+ {
+ do_cmd_aim_wand(creature_ptr);
+ break;
+ }
- /* Zap a rod */
- case 'z':
+ /* Zap a rod */
+ case 'z':
+ {
+ if (use_command && rogue_like_commands)
{
- if (use_command && rogue_like_commands)
- {
- do_cmd_use(creature_ptr);
- }
- else
- {
- do_cmd_zap_rod(creature_ptr);
- }
- break;
+ do_cmd_use(creature_ptr);
}
-
- /* Quaff a potion */
- case 'q':
+ else
{
- do_cmd_quaff_potion(creature_ptr);
- break;
+ do_cmd_zap_rod(creature_ptr);
}
+ break;
+ }
- /* Read a scroll */
- case 'r':
- {
- do_cmd_read_scroll(creature_ptr);
- break;
- }
+ /* Quaff a potion */
+ case 'q':
+ {
+ do_cmd_quaff_potion(creature_ptr);
+ break;
+ }
- /* Use a staff */
- case 'u':
- {
- if (use_command && !rogue_like_commands)
- do_cmd_use(creature_ptr);
- else
- do_cmd_use_staff(creature_ptr);
- break;
- }
+ /* Read a scroll */
+ case 'r':
+ {
+ do_cmd_read_scroll(creature_ptr);
+ break;
+ }
- /* Use racial power */
- case 'U':
- {
- do_cmd_racial_power(creature_ptr);
- break;
- }
+ /* Use a staff */
+ case 'u':
+ {
+ if (use_command && !rogue_like_commands)
+ do_cmd_use(creature_ptr);
+ else
+ do_cmd_use_staff(creature_ptr);
+ break;
+ }
+ /* Use racial power */
+ case 'U':
+ {
+ do_cmd_racial_power(creature_ptr);
+ break;
+ }
- /*** Looking at Things (nearby or on map) ***/
- /* Full dungeon map */
- case 'M':
- {
- do_cmd_view_map();
- break;
- }
+ /*** Looking at Things (nearby or on map) ***/
- /* Locate player on map */
- case 'L':
- {
- do_cmd_locate(creature_ptr);
- break;
- }
+ /* Full dungeon map */
+ case 'M':
+ {
+ do_cmd_view_map(creature_ptr);
+ break;
+ }
- /* Look around */
- case 'l':
- {
- do_cmd_look(creature_ptr);
- break;
- }
+ /* Locate player on map */
+ case 'L':
+ {
+ do_cmd_locate(creature_ptr);
+ break;
+ }
- /* Target monster or location */
- case '*':
- {
- do_cmd_target(creature_ptr);
- break;
- }
+ /* Look around */
+ case 'l':
+ {
+ do_cmd_look(creature_ptr);
+ break;
+ }
+ /* Target monster or location */
+ case '*':
+ {
+ do_cmd_target(creature_ptr);
+ break;
+ }
- /*** Help and Such ***/
- /* Help */
- case '?':
- {
- do_cmd_help(creature_ptr);
- break;
- }
+ /*** Help and Such ***/
- /* Identify symbol */
- case '/':
- {
- do_cmd_query_symbol(creature_ptr);
- break;
- }
+ /* Help */
+ case '?':
+ {
+ do_cmd_help(creature_ptr);
+ break;
+ }
- /* Character description */
- case 'C':
- {
- do_cmd_player_status(creature_ptr);
- break;
- }
+ /* Identify symbol */
+ case '/':
+ {
+ do_cmd_query_symbol(creature_ptr);
+ break;
+ }
+ /* Character description */
+ case 'C':
+ {
+ do_cmd_player_status(creature_ptr);
+ break;
+ }
- /*** System Commands ***/
- /* Hack -- User interface */
- case '!':
- {
- (void)Term_user(0);
- break;
- }
+ /*** System Commands ***/
- /* Single line from a pref file */
- case '"':
- {
- do_cmd_pref(creature_ptr);
- break;
- }
+ /* Hack -- User interface */
+ case '!':
+ {
+ (void)Term_user(0);
+ break;
+ }
- case '$':
- {
- do_cmd_reload_autopick(creature_ptr);
- break;
- }
+ /* Single line from a pref file */
+ case '"':
+ {
+ do_cmd_pref(creature_ptr);
+ break;
+ }
- case '_':
- {
- do_cmd_edit_autopick(creature_ptr);
- break;
- }
+ case '$':
+ {
+ do_cmd_reload_autopick(creature_ptr);
+ break;
+ }
- /* Interact with macros */
- case '@':
- {
- do_cmd_macros(creature_ptr);
- break;
- }
+ case '_':
+ {
+ do_cmd_edit_autopick(creature_ptr);
+ break;
+ }
- /* Interact with visuals */
- case '%':
- {
- do_cmd_visuals(creature_ptr);
- do_cmd_redraw(creature_ptr);
- break;
- }
+ /* Interact with macros */
+ case '@':
+ {
+ do_cmd_macros(creature_ptr);
+ break;
+ }
- /* Interact with colors */
- case '&':
- {
- do_cmd_colors(creature_ptr);
- do_cmd_redraw(creature_ptr);
- break;
- }
+ /* Interact with visuals */
+ case '%':
+ {
+ do_cmd_visuals(creature_ptr);
+ do_cmd_redraw(creature_ptr);
+ break;
+ }
- /* Interact with options */
- case '=':
- {
- do_cmd_options();
- (void)combine_and_reorder_home(STORE_HOME);
- do_cmd_redraw(creature_ptr);
- break;
- }
+ /* Interact with colors */
+ case '&':
+ {
+ do_cmd_colors(creature_ptr);
+ do_cmd_redraw(creature_ptr);
+ break;
+ }
- /*** Misc Commands ***/
+ /* Interact with options */
+ case '=':
+ {
+ do_cmd_options();
+ (void)combine_and_reorder_home(STORE_HOME);
+ do_cmd_redraw(creature_ptr);
+ break;
+ }
- /* Take notes */
- case ':':
- {
- do_cmd_note();
- break;
- }
+ /*** Misc Commands ***/
- /* Version info */
- case 'V':
- {
- do_cmd_version();
- break;
- }
+ /* Take notes */
+ case ':':
+ {
+ do_cmd_note();
+ break;
+ }
- /* Repeat level feeling */
- case KTRL('F'):
- {
- do_cmd_feeling(creature_ptr);
- break;
- }
+ /* Version info */
+ case 'V':
+ {
+ do_cmd_version();
+ break;
+ }
- /* Show previous message */
- case KTRL('O'):
- {
- do_cmd_message_one();
- break;
- }
+ /* Repeat level feeling */
+ case KTRL('F'):
+ {
+ do_cmd_feeling(creature_ptr);
+ break;
+ }
- /* Show previous messages */
- case KTRL('P'):
- {
- do_cmd_messages(old_now_message);
- break;
- }
+ /* Show previous message */
+ case KTRL('O'):
+ {
+ do_cmd_message_one();
+ break;
+ }
- /* Show quest status -KMW- */
- case KTRL('Q'):
- {
- do_cmd_checkquest(creature_ptr);
- break;
- }
+ /* Show previous messages */
+ case KTRL('P'):
+ {
+ do_cmd_messages(old_now_message);
+ break;
+ }
- /* Redraw the screen */
- case KTRL('R'):
- {
- now_message = old_now_message;
- do_cmd_redraw(creature_ptr);
- break;
- }
+ /* Show quest status -KMW- */
+ case KTRL('Q'):
+ {
+ do_cmd_checkquest(creature_ptr);
+ break;
+ }
+
+ /* Redraw the screen */
+ case KTRL('R'):
+ {
+ now_message = old_now_message;
+ do_cmd_redraw(creature_ptr);
+ break;
+ }
#ifndef VERIFY_SAVEFILE
- /* Hack -- Save and don't quit */
- case KTRL('S'):
- {
- do_cmd_save_game(creature_ptr, FALSE);
- break;
- }
+ /* Hack -- Save and don't quit */
+ case KTRL('S'):
+ {
+ do_cmd_save_game(creature_ptr, FALSE);
+ break;
+ }
#endif /* VERIFY_SAVEFILE */
- case KTRL('T'):
- {
- do_cmd_time(creature_ptr);
- break;
- }
+ case KTRL('T'):
+ {
+ do_cmd_time(creature_ptr);
+ break;
+ }
- /* Save and quit */
- case KTRL('X'):
- case SPECIAL_KEY_QUIT:
- {
- do_cmd_save_and_exit(creature_ptr);
- break;
- }
+ /* Save and quit */
+ case KTRL('X'):
+ case SPECIAL_KEY_QUIT:
+ {
+ do_cmd_save_and_exit(creature_ptr);
+ break;
+ }
- /* Quit (commit suicide) */
- case 'Q':
- {
- do_cmd_suicide(creature_ptr);
- break;
- }
+ /* Quit (commit suicide) */
+ case 'Q':
+ {
+ do_cmd_suicide(creature_ptr);
+ break;
+ }
- case '|':
- {
- do_cmd_diary(creature_ptr);
- break;
- }
+ case '|':
+ {
+ do_cmd_diary(creature_ptr);
+ break;
+ }
- /* Check artifacts, uniques, objects */
- case '~':
- {
- do_cmd_knowledge(creature_ptr);
- break;
- }
+ /* Check artifacts, uniques, objects */
+ case '~':
+ {
+ do_cmd_knowledge(creature_ptr);
+ break;
+ }
- /* Load "screen dump" */
- case '(':
- {
- do_cmd_load_screen();
- break;
- }
+ /* Load "screen dump" */
+ case '(':
+ {
+ do_cmd_load_screen();
+ break;
+ }
- /* Save "screen dump" */
- case ')':
- {
- do_cmd_save_screen(creature_ptr);
- break;
- }
+ /* Save "screen dump" */
+ case ')':
+ {
+ do_cmd_save_screen(creature_ptr);
+ break;
+ }
- /* Record/stop "Movie" */
- case ']':
- {
- prepare_movie_hooks();
- break;
- }
+ /* Record/stop "Movie" */
+ case ']':
+ {
+ prepare_movie_hooks();
+ break;
+ }
- /* Make random artifact list */
- case KTRL('V'):
- {
- spoil_random_artifact(creature_ptr, "randifact.txt");
- break;
- }
+ /* Make random artifact list */
+ case KTRL('V'):
+ {
+ spoil_random_artifact(creature_ptr, "randifact.txt");
+ break;
+ }
#ifdef TRAVEL
- case '`':
+ case '`':
+ {
+ if (!creature_ptr->wild_mode) do_cmd_travel(creature_ptr);
+ if (creature_ptr->special_defense & KATA_MUSOU)
{
- if (!creature_ptr->wild_mode) do_cmd_travel(creature_ptr);
- if (creature_ptr->special_defense & KATA_MUSOU)
- {
- set_action(creature_ptr, ACTION_NONE);
- }
- break;
+ set_action(creature_ptr, ACTION_NONE);
}
+ break;
+ }
#endif
- /* Hack -- Unknown command */
- default:
+ /* Hack -- Unknown command */
+ default:
+ {
+ if (flush_failure) flush();
+ if (one_in_(2))
{
- if (flush_failure) flush();
- if (one_in_(2))
- {
- char error_m[1024];
- sound(SOUND_ILLEGAL);
- if (!get_rnd_line(_("error_j.txt", "error.txt"), 0, error_m))
- msg_print(error_m);
- }
- else
- {
- prt(_(" '?' でヘルプが表示されます。", "Type '?' for help."), 0, 0);
- }
-
- break;
+ char error_m[1024];
+ sound(SOUND_ILLEGAL);
+ if (!get_rnd_line(_("error_j.txt", "error.txt"), 0, error_m))
+ msg_print(error_m);
}
+ else
+ {
+ prt(_(" '?' でヘルプが表示されます。", "Type '?' for help."), 0, 0);
+ }
+
+ break;
+ }
}
if (!creature_ptr->energy_use && !now_message)
now_message = old_now_message;
{
creature_ptr->enchant_energy_need -= SPEED_TO_ENERGY(creature_ptr->pspeed);
}
-
+
/* No turn yet */
if (creature_ptr->enchant_energy_need > 0) return;
-
+
while (creature_ptr->enchant_energy_need <= 0)
{
/* Handle the player song */
/* Hex - Handle the hex spells */
if (!load) check_hex(creature_ptr);
if (!load) revenge_spell(creature_ptr);
-
+
/* There is some randomness of needed energy */
creature_ptr->enchant_energy_need += ENERGY_NEED();
}
{
MONRACE_IDX r_idx;
bool success = FALSE;
- get_mon_num_prep(monster_is_fishing_target, NULL);
- r_idx = get_mon_num(creature_ptr->current_floor_ptr->dun_level ? creature_ptr->current_floor_ptr->dun_level : wilderness[creature_ptr->wilderness_y][creature_ptr->wilderness_x].level);
+ get_mon_num_prep(creature_ptr, monster_is_fishing_target, NULL);
+ r_idx = get_mon_num(creature_ptr, creature_ptr->current_floor_ptr->dun_level ? creature_ptr->current_floor_ptr->dun_level : wilderness[creature_ptr->wilderness_y][creature_ptr->wilderness_x].level);
msg_print(NULL);
if (r_idx && one_in_(2))
{
POSITION y, x;
y = creature_ptr->y + ddy[creature_ptr->fishing_dir];
x = creature_ptr->x + ddx[creature_ptr->fishing_dir];
- if (place_monster_aux(0, y, x, r_idx, PM_NO_KAGE))
+ if (place_monster_aux(creature_ptr, 0, y, x, r_idx, PM_NO_KAGE))
{
GAME_TEXT m_name[MAX_NLEN];
- monster_desc(m_name, &creature_ptr->current_floor_ptr->m_list[creature_ptr->current_floor_ptr->grid_array[y][x].m_idx], 0);
+ monster_desc(creature_ptr, m_name, &creature_ptr->current_floor_ptr->m_list[creature_ptr->current_floor_ptr->grid_array[y][x].m_idx], 0);
msg_format(_("%sが釣れた!", "You have a good catch!"), m_name);
success = TRUE;
}
if (creature_ptr->phase_out)
{
- for(m_idx = 1; m_idx < creature_ptr->current_floor_ptr->m_max; m_idx++)
+ for (m_idx = 1; m_idx < creature_ptr->current_floor_ptr->m_max; m_idx++)
{
monster_type *m_ptr = &creature_ptr->current_floor_ptr->m_list[m_idx];
m_ptr->mflag2 |= (MFLAG2_MARK | MFLAG2_SHOW);
update_monster(creature_ptr, m_idx, FALSE);
}
- prt_time();
+
+ print_time(creature_ptr);
}
/* Give the player some energy */
/* No turn yet */
if (creature_ptr->energy_need > 0) return;
- if (!command_rep) prt_time();
+ if (!command_rep) print_time(creature_ptr);
/*** Check for interupts ***/
{
/* Stop resting */
if ((creature_ptr->chp == creature_ptr->mhp) &&
- (creature_ptr->csp >= creature_ptr->msp))
+ (creature_ptr->csp >= creature_ptr->msp))
{
set_action(creature_ptr, ACTION_NONE);
}
{
/* Stop resting */
if ((creature_ptr->chp == creature_ptr->mhp) &&
- (creature_ptr->csp >= creature_ptr->msp) &&
- !creature_ptr->blind && !creature_ptr->confused &&
- !creature_ptr->poisoned && !creature_ptr->afraid &&
- !creature_ptr->stun && !creature_ptr->cut &&
- !creature_ptr->slow && !creature_ptr->paralyzed &&
- !creature_ptr->image && !creature_ptr->word_recall &&
- !creature_ptr->alter_reality)
+ (creature_ptr->csp >= creature_ptr->msp) &&
+ !creature_ptr->blind && !creature_ptr->confused &&
+ !creature_ptr->poisoned && !creature_ptr->afraid &&
+ !creature_ptr->stun && !creature_ptr->cut &&
+ !creature_ptr->slow && !creature_ptr->paralyzed &&
+ !creature_ptr->image && !creature_ptr->word_recall &&
+ !creature_ptr->alter_reality)
{
set_action(creature_ptr, ACTION_NONE);
}
GAME_TEXT m_name[MAX_NLEN];
/* Recover fully */
- (void)set_monster_csleep(creature_ptr->riding, 0);
- monster_desc(m_name, m_ptr, 0);
+ (void)set_monster_csleep(creature_ptr, creature_ptr->riding, 0);
+ monster_desc(creature_ptr, m_name, m_ptr, 0);
msg_format(_("%^sを起こした。", "You have woken %s up."), m_name);
}
if (MON_STUNNED(m_ptr))
{
/* Hack -- Recover from stun */
- if (set_monster_stunned(creature_ptr->riding,
+ if (set_monster_stunned(creature_ptr, creature_ptr->riding,
(randint0(r_ptr->level) < creature_ptr->skill_exp[GINOU_RIDING]) ? 0 : (MON_STUNNED(m_ptr) - 1)))
{
GAME_TEXT m_name[MAX_NLEN];
- monster_desc(m_name, m_ptr, 0);
+ monster_desc(creature_ptr, m_name, m_ptr, 0);
msg_format(_("%^sを朦朧状態から立ち直らせた。", "%^s is no longer stunned."), m_name);
}
}
if (MON_CONFUSED(m_ptr))
{
/* Hack -- Recover from confusion */
- if (set_monster_confused(creature_ptr->riding,
+ if (set_monster_confused(creature_ptr, creature_ptr->riding,
(randint0(r_ptr->level) < creature_ptr->skill_exp[GINOU_RIDING]) ? 0 : (MON_CONFUSED(m_ptr) - 1)))
{
GAME_TEXT m_name[MAX_NLEN];
- monster_desc(m_name, m_ptr, 0);
+ monster_desc(creature_ptr, m_name, m_ptr, 0);
msg_format(_("%^sを混乱状態から立ち直らせた。", "%^s is no longer confused."), m_name);
}
}
if (MON_MONFEAR(m_ptr))
{
/* Hack -- Recover from fear */
- if(set_monster_monfear(creature_ptr->riding,
+ if (set_monster_monfear(creature_ptr, creature_ptr->riding,
(randint0(r_ptr->level) < creature_ptr->skill_exp[GINOU_RIDING]) ? 0 : (MON_MONFEAR(m_ptr) - 1)))
{
GAME_TEXT m_name[MAX_NLEN];
- monster_desc(m_name, m_ptr, 0);
+ monster_desc(creature_ptr, m_name, m_ptr, 0);
msg_format(_("%^sを恐怖から立ち直らせた。", "%^s is no longer afraid."), m_name);
}
}
handle_stuff(creature_ptr);
}
-
+
load = FALSE;
/* Fast */
}
if ((creature_ptr->pclass == CLASS_FORCETRAINER) && P_PTR_KI)
{
- if(P_PTR_KI < 40) P_PTR_KI = 0;
+ if (P_PTR_KI < 40) P_PTR_KI = 0;
else P_PTR_KI -= 40;
creature_ptr->update |= (PU_BONUS);
}
/* Convert the unit (1/2^16) to (1/2^32) */
s64b_LSHIFT(cost, cost_frac, 16);
-
+
if (s64b_cmp(creature_ptr->csp, creature_ptr->csp_frac, cost, cost_frac) < 0)
{
/* Mana run out */
can_save = TRUE;
/* Get a command (normal) */
- request_command(FALSE);
+ request_command(creature_ptr, FALSE);
can_save = FALSE;
/* Process the command */
creature_ptr->redraw |= (PR_STATE);
}
- if (creature_ptr->timewalk && (creature_ptr->energy_need > - 1000))
+ if (creature_ptr->timewalk && (creature_ptr->energy_need > -1000))
{
creature_ptr->redraw |= (PR_MAP);
int quest_num = 0;
/* Set the base level */
- player_ptr->current_floor_ptr->base_level = player_ptr->current_floor_ptr->dun_level;
+ floor_type *floor_ptr = player_ptr->current_floor_ptr;
+ floor_ptr->base_level = floor_ptr->dun_level;
/* Reset various flags */
current_world_ptr->is_loading_now = FALSE;
/* Reset the "command" vars */
command_cmd = 0;
-
-#if 0 /* Don't reset here --- It's used for Arena */
- command_new = 0;
-#endif
-
command_rep = 0;
command_arg = 0;
command_dir = 0;
-
/* Cancel the target */
target_who = 0;
player_ptr->pet_t_m_idx = 0;
player_ptr->riding_t_m_idx = 0;
player_ptr->ambush_flag = FALSE;
- /* Cancel the health bar */
- health_track(0);
+ health_track(player_ptr, 0);
/* Check visual effects */
repair_monsters = TRUE;
disturb(player_ptr, TRUE, TRUE);
/* Get index of current quest (if any) */
- quest_num = quest_number(player_ptr, player_ptr->current_floor_ptr->dun_level);
+ quest_num = quest_number(player_ptr, floor_ptr->dun_level);
/* Inside a quest? */
if (quest_num)
/* Track maximum dungeon level (if not in quest -KMW-) */
- if ((max_dlv[player_ptr->dungeon_idx] < player_ptr->current_floor_ptr->dun_level) && !player_ptr->current_floor_ptr->inside_quest)
+ if ((max_dlv[player_ptr->dungeon_idx] < floor_ptr->dun_level) && !floor_ptr->inside_quest)
{
- max_dlv[player_ptr->dungeon_idx] = player_ptr->current_floor_ptr->dun_level;
- if (record_maxdepth) exe_write_diary(player_ptr, NIKKI_MAXDEAPTH, player_ptr->current_floor_ptr->dun_level, NULL);
+ max_dlv[player_ptr->dungeon_idx] = floor_ptr->dun_level;
+ if (record_maxdepth) exe_write_diary(player_ptr, DIARY_MAXDEAPTH, floor_ptr->dun_level, NULL);
}
(void)calculate_upkeep(player_ptr);
panel_bounds_center();
/* Verify the panel */
- verify_panel();
+ verify_panel(player_ptr);
msg_erase();
Term_fresh();
if (quest_num && (is_fixed_quest_idx(quest_num) &&
- !((quest_num == QUEST_OBERON) || (quest_num == QUEST_SERPENT) ||
- !(quest[quest_num].flags & QUEST_FLAG_PRESET)))) do_cmd_feeling(player_ptr);
+ !((quest_num == QUEST_OBERON) || (quest_num == QUEST_SERPENT) ||
+ !(quest[quest_num].flags & QUEST_FLAG_PRESET)))) do_cmd_feeling(player_ptr);
if (player_ptr->phase_out)
{
if (!player_ptr->playing || player_ptr->is_dead) return;
/* Print quest message if appropriate */
- if (!player_ptr->current_floor_ptr->inside_quest && (player_ptr->dungeon_idx == DUNGEON_ANGBAND))
+ if (!floor_ptr->inside_quest && (player_ptr->dungeon_idx == DUNGEON_ANGBAND))
{
- quest_discovery(random_quest_number(player_ptr, player_ptr->current_floor_ptr->dun_level));
- player_ptr->current_floor_ptr->inside_quest = random_quest_number(player_ptr, player_ptr->current_floor_ptr->dun_level);
+ quest_discovery(random_quest_number(player_ptr, floor_ptr->dun_level));
+ floor_ptr->inside_quest = random_quest_number(player_ptr, floor_ptr->dun_level);
}
- if ((player_ptr->current_floor_ptr->dun_level == d_info[player_ptr->dungeon_idx].maxdepth) && d_info[player_ptr->dungeon_idx].final_guardian)
+ if ((floor_ptr->dun_level == d_info[player_ptr->dungeon_idx].maxdepth) && d_info[player_ptr->dungeon_idx].final_guardian)
{
if (r_info[d_info[player_ptr->dungeon_idx].final_guardian].max_num)
#ifdef JP
msg_format("この階には%sの主である%sが棲んでいる。",
- d_name+d_info[player_ptr->dungeon_idx].name,
- r_name+r_info[d_info[player_ptr->dungeon_idx].final_guardian].name);
+ d_name + d_info[player_ptr->dungeon_idx].name,
+ r_name + r_info[d_info[player_ptr->dungeon_idx].final_guardian].name);
#else
msg_format("%^s lives in this level as the keeper of %s.",
- r_name+r_info[d_info[player_ptr->dungeon_idx].final_guardian].name,
- d_name+d_info[player_ptr->dungeon_idx].name);
+ r_name + r_info[d_info[player_ptr->dungeon_idx].final_guardian].name,
+ d_name + d_info[player_ptr->dungeon_idx].name);
#endif
}
/*** Process this dungeon level ***/
/* Reset the monster generation level */
- player_ptr->current_floor_ptr->monster_level = player_ptr->current_floor_ptr->base_level;
+ floor_ptr->monster_level = floor_ptr->base_level;
/* Reset the object generation level */
- player_ptr->current_floor_ptr->object_level = player_ptr->current_floor_ptr->base_level;
+ floor_ptr->object_level = floor_ptr->base_level;
current_world_ptr->is_loading_now = TRUE;
if (player_ptr->energy_need > 0 && !player_ptr->phase_out &&
- (player_ptr->current_floor_ptr->dun_level || player_ptr->leaving_dungeon || player_ptr->current_floor_ptr->inside_arena))
+ (floor_ptr->dun_level || player_ptr->leaving_dungeon || floor_ptr->inside_arena))
player_ptr->energy_need = 0;
/* Not leaving dungeon */
player_ptr->leaving_dungeon = FALSE;
/* Initialize monster process */
- mproc_init();
+ mproc_init(floor_ptr);
/* Main loop */
while (TRUE)
{
/* Hack -- Compact the monster list occasionally */
- if ((player_ptr->current_floor_ptr->m_cnt + 32 > current_world_ptr->max_m_idx) && !player_ptr->phase_out) compact_monsters(64);
+ if ((floor_ptr->m_cnt + 32 > current_world_ptr->max_m_idx) && !player_ptr->phase_out) compact_monsters(player_ptr, 64);
/* Hack -- Compress the monster list occasionally */
- if ((player_ptr->current_floor_ptr->m_cnt + 32 < player_ptr->current_floor_ptr->m_max) && !player_ptr->phase_out) compact_monsters(0);
+ if ((floor_ptr->m_cnt + 32 < floor_ptr->m_max) && !player_ptr->phase_out) compact_monsters(player_ptr, 0);
/* Hack -- Compact the object list occasionally */
- if (player_ptr->current_floor_ptr->o_cnt + 32 > current_world_ptr->max_o_idx) compact_objects(player_ptr->current_floor_ptr, 64);
+ if (floor_ptr->o_cnt + 32 > current_world_ptr->max_o_idx) compact_objects(player_ptr, 64);
/* Hack -- Compress the object list occasionally */
- if (player_ptr->current_floor_ptr->o_cnt + 32 < player_ptr->current_floor_ptr->o_max) compact_objects(player_ptr->current_floor_ptr, 0);
+ if (floor_ptr->o_cnt + 32 < floor_ptr->o_max) compact_objects(player_ptr, 0);
/* Process the player */
process_player(player_ptr);
else if (player_ptr->wild_mode && !(current_world_ptr->game_turn % ((MAX_HGT + MAX_WID) / 2))) current_world_ptr->dungeon_turn++;
}
- prevent_turn_overflow();
+ prevent_turn_overflow(player_ptr);
/* Handle "leaving" */
if (player_ptr->leaving) break;
process_pref_file(player_ptr, buf);
/* Access the "character" pref file */
- sprintf(buf, "%s.prf", p_ptr->base_name);
+ sprintf(buf, "%s.prf", player_ptr->base_name);
/* Process that file */
process_pref_file(player_ptr, buf);
/* Access the "realm 1" pref file */
- if (p_ptr->realm1 != REALM_NONE)
+ if (player_ptr->realm1 != REALM_NONE)
{
- sprintf(buf, "%s.prf", realm_names[p_ptr->realm1]);
+ sprintf(buf, "%s.prf", realm_names[player_ptr->realm1]);
/* Process that file */
process_pref_file(player_ptr, buf);
}
/* Access the "realm 2" pref file */
- if (p_ptr->realm2 != REALM_NONE)
+ if (player_ptr->realm2 != REALM_NONE)
{
- sprintf(buf, "%s.prf", realm_names[p_ptr->realm2]);
+ sprintf(buf, "%s.prf", realm_names[player_ptr->realm2]);
/* Process that file */
process_pref_file(player_ptr, buf);
if (browsing_movie)
{
- reset_visuals();
+ reset_visuals(player_ptr);
browse_movie();
return;
}
/* No suspending now */
signals_ignore_tstp();
-
+
/* Hack -- Character is now "icky" */
current_world_ptr->character_icky = TRUE;
path_build(buf, sizeof(buf), ANGBAND_DIR_APEX, "scores.raw");
/* Forget the high score fd */
highscore_fd = -1;
-
+
/* Allow suspending now */
signals_handle_tstp();
}
/* Roll new character */
+ floor_type *floor_ptr = player_ptr->current_floor_ptr;
if (new_game)
{
/* The dungeon is not ready */
current_world_ptr->character_dungeon = FALSE;
/* Start in town */
- player_ptr->current_floor_ptr->dun_level = 0;
- player_ptr->current_floor_ptr->inside_quest = 0;
- player_ptr->current_floor_ptr->inside_arena = FALSE;
+ floor_ptr->dun_level = 0;
+ floor_ptr->inside_quest = 0;
+ floor_ptr->inside_arena = FALSE;
player_ptr->phase_out = FALSE;
write_level = TRUE;
/* Roll up a new character */
player_birth(player_ptr);
- counts_write(player_ptr, 2,0);
+ counts_write(player_ptr, 2, 0);
player_ptr->count = 0;
load = FALSE;
- determine_bounty_uniques();
+ determine_bounty_uniques(player_ptr);
determine_daily_bounty(player_ptr, FALSE);
/* Initialize object array */
- wipe_o_list(player_ptr->current_floor_ptr);
+ wipe_o_list(floor_ptr);
}
else
{
write_level = FALSE;
- exe_write_diary(player_ptr, NIKKI_GAMESTART, 1,
- _(" ----ゲーム再開----",
- " ---- Restart Game ----"));
+ exe_write_diary(player_ptr, DIARY_GAMESTART, 1,
+ _(" ----ゲーム再開----",
+ " ---- Restart Game ----"));
-/*
- * 1.0.9 以前はセーブ前に player_ptr->riding = -1 としていたので、再設定が必要だった。
- * もう不要だが、以前のセーブファイルとの互換のために残しておく。
- */
+ /*
+ * 1.0.9 以前はセーブ前に player_ptr->riding = -1 としていたので、再設定が必要だった。
+ * もう不要だが、以前のセーブファイルとの互換のために残しておく。
+ */
if (player_ptr->riding == -1)
{
player_ptr->riding = 0;
- for (i = player_ptr->current_floor_ptr->m_max; i > 0; i--)
+ for (i = floor_ptr->m_max; i > 0; i--)
{
- if (player_bold(player_ptr, player_ptr->current_floor_ptr->m_list[i].fy, player_ptr->current_floor_ptr->m_list[i].fx))
+ if (player_bold(player_ptr, floor_ptr->m_list[i].fy, floor_ptr->m_list[i].fx))
{
player_ptr->riding = i;
break;
record_o_name[0] = '\0';
/* Reset map panel */
- panel_row_min = player_ptr->current_floor_ptr->height;
- panel_col_min = player_ptr->current_floor_ptr->width;
+ panel_row_min = floor_ptr->height;
+ panel_col_min = floor_ptr->width;
/* Sexy gal gets bonus to maximum weapon skill of whip */
if (player_ptr->pseikaku == SEIKAKU_SEXY)
- s_info[player_ptr->pclass].w_max[TV_HAFTED-TV_WEAPON_BEGIN][SV_WHIP] = WEAPON_EXP_MASTER;
+ s_info[player_ptr->pclass].w_max[TV_HAFTED - TV_WEAPON_BEGIN][SV_WHIP] = WEAPON_EXP_MASTER;
/* Fill the arrays of floors and walls in the good proportions */
set_floor_and_wall(player_ptr->dungeon_idx);
/* Hack -- Enter wizard mode */
if (arg_wizard)
{
- if (enter_wizard_mode())
+ if (enter_wizard_mode(player_ptr))
{
current_world_ptr->wizard = TRUE;
init_saved_floors(player_ptr, TRUE);
/* Avoid crash */
- player_ptr->current_floor_ptr->inside_quest = 0;
+ floor_ptr->inside_quest = 0;
/* Avoid crash in update_view() */
player_ptr->y = player_ptr->x = 10;
}
/* Initialize the town-buildings if necessary */
- if (!player_ptr->current_floor_ptr->dun_level && !player_ptr->current_floor_ptr->inside_quest)
+ if (!floor_ptr->dun_level && !floor_ptr->inside_quest)
{
process_dungeon_file(player_ptr, "w_info.txt", 0, 0, current_world_ptr->max_wild_y, current_world_ptr->max_wild_x);
init_flags = INIT_ONLY_BUILDINGS;
{
char buf[80];
sprintf(buf, _("%sに降り立った。", "You are standing in the %s."), map_name(player_ptr));
- exe_write_diary(player_ptr, NIKKI_BUNSHOU, 0, buf);
+ exe_write_diary(player_ptr, DIARY_DESCRIPTION, 0, buf);
}
/* Start game */
player_ptr->playing = TRUE;
/* Reset the visual mappings */
- reset_visuals();
+ reset_visuals(player_ptr);
/* Load the "pref" files */
load_all_pref_files(player_ptr);
monster_type *m_ptr;
MONRACE_IDX pet_r_idx = ((player_ptr->pclass == CLASS_CAVALRY) ? MON_HORSE : MON_YASE_HORSE);
monster_race *r_ptr = &r_info[pet_r_idx];
- place_monster_aux(0, player_ptr->y, player_ptr->x - 1, pet_r_idx,
- (PM_FORCE_PET | PM_NO_KAGE));
- m_ptr = &player_ptr->current_floor_ptr->m_list[hack_m_idx_ii];
+ place_monster_aux(player_ptr, 0, player_ptr->y, player_ptr->x - 1, pet_r_idx,
+ (PM_FORCE_PET | PM_NO_KAGE));
+ m_ptr = &floor_ptr->m_list[hack_m_idx_ii];
m_ptr->mspeed = r_ptr->speed;
- m_ptr->maxhp = r_ptr->hdice*(r_ptr->hside+1)/2;
+ m_ptr->maxhp = r_ptr->hdice*(r_ptr->hside + 1) / 2;
m_ptr->max_maxhp = m_ptr->maxhp;
- m_ptr->hp = r_ptr->hdice*(r_ptr->hside+1)/2;
+ m_ptr->hp = r_ptr->hdice*(r_ptr->hside + 1) / 2;
m_ptr->dealt_damage = 0;
m_ptr->energy_need = ENERGY_NEED() + ENERGY_NEED();
}
/* Cancel the target */
target_who = 0;
- /* Cancel the health bar */
- health_track(0);
+ health_track(player_ptr, 0);
- forget_lite(player_ptr->current_floor_ptr);
- forget_view(player_ptr->current_floor_ptr);
- clear_mon_lite(player_ptr->current_floor_ptr);
+ forget_lite(floor_ptr);
+ forget_view(floor_ptr);
+ clear_mon_lite(floor_ptr);
/* Handle "quit and save" */
if (!player_ptr->playing && !player_ptr->is_dead) break;
- wipe_o_list(player_ptr->current_floor_ptr);
- if (!player_ptr->is_dead) wipe_m_list();
+ wipe_o_list(floor_ptr);
+ if (!player_ptr->is_dead) wipe_monsters_list(player_ptr);
msg_print(NULL);
/* Accidental Death */
if (player_ptr->playing && player_ptr->is_dead)
{
- if (player_ptr->current_floor_ptr->inside_arena)
+ if (floor_ptr->inside_arena)
{
- player_ptr->current_floor_ptr->inside_arena = FALSE;
+ floor_ptr->inside_arena = FALSE;
if (player_ptr->arena_number > MAX_ARENA_MONS)
player_ptr->arena_number++;
else
* @details アンデッド種族は18:00からゲームを開始するので、この修正を予め行う。
* @return 修正をかけた後のゲームターン
*/
-s32b turn_real(s32b hoge)
+s32b turn_real(player_type *player_ptr, s32b hoge)
{
- switch (p_ptr->start_race)
+ switch (player_ptr->start_race)
{
case RACE_VAMPIRE:
case RACE_SKELETON:
/*!
* @brief ターンのオーバーフローに対する対処
+ * @param player_ptr プレーヤーへの参照ポインタ
* @details ターン及びターンを記録する変数をターンの限界の1日前まで巻き戻す.
* @return 修正をかけた後のゲームターン
*/
-void prevent_turn_overflow(void)
+void prevent_turn_overflow(player_type *player_ptr)
{
int rollback_days, i, j;
s32b rollback_turns;
if (current_world_ptr->game_turn > rollback_turns) current_world_ptr->game_turn -= rollback_turns;
else current_world_ptr->game_turn = 1;
- if (p_ptr->current_floor_ptr->generated_turn > rollback_turns) p_ptr->current_floor_ptr->generated_turn -= rollback_turns;
- else p_ptr->current_floor_ptr->generated_turn = 1;
+ floor_type *floor_ptr = player_ptr->current_floor_ptr;
+ if (floor_ptr->generated_turn > rollback_turns) floor_ptr->generated_turn -= rollback_turns;
+ else floor_ptr->generated_turn = 1;
if (current_world_ptr->arena_start_turn > rollback_turns) current_world_ptr->arena_start_turn -= rollback_turns;
else current_world_ptr->arena_start_turn = 1;
- if (p_ptr->feeling_turn > rollback_turns) p_ptr->feeling_turn -= rollback_turns;
- else p_ptr->feeling_turn = 1;
+ if (player_ptr->feeling_turn > rollback_turns) player_ptr->feeling_turn -= rollback_turns;
+ else player_ptr->feeling_turn = 1;
for (i = 1; i < max_towns; i++)
{
show_info(player_ptr);
Term_clear();
- if (check_score())
+ if (check_score(player_ptr))
{
if ((!send_world_score(player_ptr, do_send)))
{
{
display_scores_aux(0, 10, -1, NULL);
}
-#if 0
- /* Dump bones file */
- make_bones();
-#endif
}
/* Still alive */
/*!
* @brief 全更新処理をチェックして処理していく
- * Handle "p_ptr->update" and "p_ptr->redraw" and "p_ptr->window"
+ * Handle "player_ptr->update" and "player_ptr->redraw" and "player_ptr->window"
* @return なし
*/
void handle_stuff(player_type *player_ptr)