OSDN Git Service

[Refactor] #37353 バリアント名称とバージョン定義を core.h へ移動.
[hengband/hengband.git] / src / quest.c
index 5feb725..ffa270b 100644 (file)
@@ -1,6 +1,7 @@
 #include "angband.h"
 #include "util.h"
 
+#include "core.h"
 #include "floor.h"
 #include "floor-save.h"
 #include "floor-events.h"
@@ -8,7 +9,17 @@
 #include "quest.h"
 #include "monsterrace-hook.h"
 #include "monster.h"
-
+#include "player-status.h"
+#include "artifact.h"
+#include "feature.h"
+#include "world.h"
+#include "cmd-dump.h"
+
+quest_type *quest; /*!< Quest info */
+QUEST_IDX max_q_idx; /*!< Maximum number of quests */
+char quest_text[10][80]; /*!< Quest text */
+int quest_text_line; /*!< Current line of the quest text */
+int leaving_quest = 0;
 
 /*!
  * @brief クエスト突入時のメッセージテーブル / Array of places to find an inscription
@@ -502,3 +513,41 @@ void leave_tower_check(void)
                }
        }
 }
+
+
+/*!
+ * @brief クエスト入り口にプレイヤーが乗った際の処理 / Do building commands
+ * @return なし
+ */
+void do_cmd_quest(void)
+{
+       if (p_ptr->wild_mode) return;
+
+       take_turn(p_ptr, 100);
+
+       if (!cave_have_flag_bold(p_ptr->y, p_ptr->x, FF_QUEST_ENTER))
+       {
+               msg_print(_("ここにはクエストの入口はない。", "You see no quest level here."));
+               return;
+       }
+       else
+       {
+               msg_print(_("ここにはクエストへの入口があります。", "There is an entry of a quest."));
+               if (!get_check(_("クエストに入りますか?", "Do you enter? "))) return;
+               if ((p_ptr->pseikaku == SEIKAKU_COMBAT) || (p_ptr->inventory_list[INVEN_BOW].name1 == ART_CRIMSON))
+                       msg_print(_("『とにかく入ってみようぜぇ。』", ""));
+               else if (p_ptr->pseikaku == SEIKAKU_CHARGEMAN) msg_print("『全滅してやるぞ!』");
+
+               /* Player enters a new quest */
+               p_ptr->oldpy = 0;
+               p_ptr->oldpx = 0;
+
+               leave_quest_check();
+
+               if (quest[p_ptr->inside_quest].type != QUEST_TYPE_RANDOM) current_floor_ptr->dun_level = 1;
+               p_ptr->inside_quest = current_floor_ptr->grid_array[p_ptr->y][p_ptr->x].special;
+
+               p_ptr->leaving = TRUE;
+       }
+}
+