diff options
author | Manoj Srivastava <srivasta@debian.org> | 2016-01-27 12:43:59 -0800 |
---|---|---|
committer | Manoj Srivastava <srivasta@debian.org> | 2016-01-27 12:50:09 -0800 |
commit | 76fce162659078323fcd5e54b3195dae371faca2 (patch) | |
tree | c1d93d415b96238aae3c54eb83cb0815af2e4bca /src/q_spider.cc | |
parent | b4456969cd02d75c599a5b86b225c0774697e85d (diff) | |
parent | 4aa1a39402c3908e9e8b6eb3fd4e2183d5e5c52e (diff) |
Merge branch 'development' into upstream
Signed-off-by: Manoj Srivastava <srivasta@debian.org>
# Conflicts:
# src/.gitignore
# src/maid-x11.c
# src/quest.pkg
Diffstat (limited to 'src/q_spider.cc')
-rw-r--r-- | src/q_spider.cc | 127 |
1 files changed, 127 insertions, 0 deletions
diff --git a/src/q_spider.cc b/src/q_spider.cc new file mode 100644 index 00000000..07531b96 --- /dev/null +++ b/src/q_spider.cc @@ -0,0 +1,127 @@ +#include "q_spider.hpp" + +#include "cave.hpp" +#include "gods.hpp" +#include "hook_quest_finish_in.hpp" +#include "hooks.hpp" +#include "init1.hpp" +#include "monster2.hpp" +#include "monster_type.hpp" +#include "object2.hpp" +#include "object_type.hpp" +#include "player_type.hpp" +#include "tables.hpp" +#include "util.hpp" +#include "variable.hpp" + +#define cquest (quest[QUEST_SPIDER]) + +static bool_ quest_spider_gen_hook(void *, void *, void *) +{ + int x, y; + int xstart = 2; + int ystart = 2; + + if (p_ptr->inside_quest != QUEST_SPIDER) return FALSE; + + /* Start with perm walls */ + for (y = 0; y < cur_hgt; y++) + { + for (x = 0; x < cur_wid; x++) + { + cave_set_feat(y, x, FEAT_PERM_SOLID); + } + } + dun_level = quest[p_ptr->inside_quest].level; + + /* Set the correct monster hook */ + set_mon_num_hook(); + + /* Prepare allocation table */ + get_mon_num_prep(); + + init_flags = INIT_CREATE_DUNGEON; + process_dungeon_file("spiders.map", &ystart, &xstart, cur_hgt, cur_wid, TRUE, TRUE); + + return TRUE; +} + +static bool_ quest_spider_death_hook(void *, void *, void *) +{ + int i, mcnt = 0; + + if (p_ptr->inside_quest != QUEST_SPIDER) return FALSE; + + for (i = m_max - 1; i >= 1; i--) + { + /* Access the monster */ + monster_type *m_ptr = &m_list[i]; + + /* Ignore "dead" monsters */ + if (!m_ptr->r_idx) continue; + + if (m_ptr->status <= MSTATUS_ENEMY) mcnt++; + } + + if (mcnt <= 1) + { + cmsg_print(TERM_YELLOW, "The forest is now safer, thanks to you."); + + /* Yavanna LOVES saving forests */ + if (p_ptr->pgod == GOD_YAVANNA) + { + cmsg_print(TERM_L_GREEN, "You feel the gentle touch of Yavanna, as she smiles at you."); + inc_piety(GOD_YAVANNA, 6000); + } + + cquest.status = QUEST_STATUS_COMPLETED; + + del_hook_new(HOOK_MONSTER_DEATH, quest_spider_death_hook); + process_hooks_restart = TRUE; + + return (FALSE); + } + + return (FALSE); +} + +static bool_ quest_spider_finish_hook(void *, void *in_, void *) +{ + struct hook_quest_finish_in *in = static_cast<struct hook_quest_finish_in *>(in_); + object_type forge, *q_ptr; + s32b q_idx = in->q_idx; + + if (q_idx != QUEST_SPIDER) return FALSE; + + c_put_str(TERM_YELLOW, "All of us praise your mighty deed in driving back the", 8, 0); + c_put_str(TERM_YELLOW, "menace. Take this as a reward.", 9, 0); + + q_ptr = &forge; + object_prep(q_ptr, lookup_kind(TV_POTION, SV_POTION_AUGMENTATION)); + q_ptr->number = 1; + q_ptr->found = OBJ_FOUND_REWARD; + object_aware(q_ptr); + object_known(q_ptr); + q_ptr->ident |= IDENT_STOREB; + (void)inven_carry(q_ptr, FALSE); + + /* Continue the plot */ + *(quest[q_idx].plot) = QUEST_POISON; + quest[*(quest[q_idx].plot)].init(*(quest[q_idx].plot)); + + del_hook_new(HOOK_QUEST_FINISH, quest_spider_finish_hook); + process_hooks_restart = TRUE; + + return TRUE; +} + +bool_ quest_spider_init_hook(int q_idx) +{ + if ((cquest.status >= QUEST_STATUS_TAKEN) && (cquest.status < QUEST_STATUS_FINISHED)) + { + add_hook_new(HOOK_MONSTER_DEATH, quest_spider_death_hook, "spider_death", NULL); + add_hook_new(HOOK_GEN_QUEST, quest_spider_gen_hook, "spider_gen", NULL); + add_hook_new(HOOK_QUEST_FINISH, quest_spider_finish_hook, "spider_finish", NULL); + } + return (FALSE); +} |