diff options
author | zelgadis <zelgadis@c06c8d41-db1a-0410-9941-cceddc491573> | 2008-12-13 01:00:01 +0000 |
---|---|---|
committer | zelgadis <zelgadis@c06c8d41-db1a-0410-9941-cceddc491573> | 2008-12-13 01:00:01 +0000 |
commit | 42d0d63ae25d7ec3e5ded02ae77489cc5e8371f9 (patch) | |
tree | dfa131b93bdbc36c38bc31adb71d717ce44a659b /crawl-ref/source/mon-util.cc | |
parent | 43d6d67d143b01bacbf10dad61f460c7446db1fb (diff) | |
download | crawl-ref-42d0d63ae25d7ec3e5ded02ae77489cc5e8371f9.tar.gz crawl-ref-42d0d63ae25d7ec3e5ded02ae77489cc5e8371f9.zip |
Breaks savefile compatibility.
Allow Shadow Creatures spell (along with anything that uses create_monster(),
mons_place(), place_monster() or pick_random_monster()) to work in portal
vaults; only fixed ziggurats to use it. Must be done by manually calling
dgn.set_random_mon_list(); can't automatically set it from MONS since the
actual frequency of the monster specified that way is controlled by the number
of 1/2/3/etc symbols that are in the map combined with symbol shufflings and
substitutions. Can add an RMONS keyword to handle it if needed.
Limitations: can only use level id or monster type + base type. Monster number
(specific number of hydra heads), colour, items, band, and patrolling are all
discarded/ignored. This can be improved if it's too limiting.
New per-level env.properties CrawlHashTable stores the information.
env.properties can be used to store new per-level data without breaking
savefile compatibility (though changing the handling of old data in
env.properties can still break compatibility).
Random monster spawn rate is now controlled by the per-level
env.spawn_random_rate (though the default rates are all the same as before), in
case any weird portal vaults want to turn on random monster spawning. Could
also be used to alter the random spawn rate for places like Vault:8
Prevented Shadow Creatues from working in the Temple.
git-svn-id: https://crawl-ref.svn.sourceforge.net/svnroot/crawl-ref/trunk@7816 c06c8d41-db1a-0410-9941-cceddc491573
Diffstat (limited to 'crawl-ref/source/mon-util.cc')
-rw-r--r-- | crawl-ref/source/mon-util.cc | 29 |
1 files changed, 28 insertions, 1 deletions
diff --git a/crawl-ref/source/mon-util.cc b/crawl-ref/source/mon-util.cc index 38be768b2f..f0e7e8ea33 100644 --- a/crawl-ref/source/mon-util.cc +++ b/crawl-ref/source/mon-util.cc @@ -2105,7 +2105,34 @@ std::string mons_type_name(int type, description_level_type desc ) } } - result += get_monster_data(type)->name; + switch(type) + { + case RANDOM_MONSTER: + result += "random monster"; + return (result); + case RANDOM_DRACONIAN: + result += "random draconian"; + return (result); + case RANDOM_BASE_DRACONIAN: + result += "random base draconian"; + return (result); + case RANDOM_NONBASE_DRACONIAN: + result += "random nonbase draconian"; + return (result); + case WANDERING_MONSTER: + result += "wandering monster"; + return (result); + } + + const monsterentry *me = get_monster_data(type); + ASSERT(me != NULL); + if (me == NULL) + { + result += make_stringf("invalid type %d", type); + return (result); + } + + result += me->name; // Vowel fix: Change 'a orc' to 'an orc'. if (result.length() >= 3 |