diff options
author | j-p-e-g <j-p-e-g@c06c8d41-db1a-0410-9941-cceddc491573> | 2009-06-27 17:04:31 +0000 |
---|---|---|
committer | j-p-e-g <j-p-e-g@c06c8d41-db1a-0410-9941-cceddc491573> | 2009-06-27 17:04:31 +0000 |
commit | 1be101fd1fc43a252cdc4debf475edf0c6dba81b (patch) | |
tree | 13e5c780e21268c06bb28c48994f934e906ee62e /crawl-ref/source/transfor.cc | |
parent | 39e1fb93fe8332c69e55c4364d28091a02d52ad5 (diff) | |
download | crawl-ref-1be101fd1fc43a252cdc4debf475edf0c6dba81b.tar.gz crawl-ref-1be101fd1fc43a252cdc4debf475edf0c6dba81b.zip |
Apply patch by Adam Borowski, introducing new unique enchantress Kirke.
This includes a new transformation TRAN_PIG that the player can not end
at will but rather will have to time out. Pigs (or rather hogs) are fast
but cannot use any equipment except amulets, or cast spells.
If the transformation would cause death by stat loss (due to equipment
loss) the player is paralysed instead.
git-svn-id: https://crawl-ref.svn.sourceforge.net/svnroot/crawl-ref/trunk@10061 c06c8d41-db1a-0410-9941-cceddc491573
Diffstat (limited to 'crawl-ref/source/transfor.cc')
-rw-r--r-- | crawl-ref/source/transfor.cc | 43 |
1 files changed, 34 insertions, 9 deletions
diff --git a/crawl-ref/source/transfor.cc b/crawl-ref/source/transfor.cc index 070841ae21..2036d37e0d 100644 --- a/crawl-ref/source/transfor.cc +++ b/crawl-ref/source/transfor.cc @@ -56,9 +56,10 @@ bool transform_allows_wearing_item(const item_def& item, if (item.base_type == OBJ_JEWELLERY) { - // Everything but bats can wear all jewellery; bats can + // Everything but bats can wear all jewellery; bats and pigs can // only wear amulets. - if (transform == TRAN_BAT && !jewellery_is_amulet(item)) + if ((transform == TRAN_BAT || transform == TRAN_PIG) + && !jewellery_is_amulet(item)) rc = false; } else @@ -78,6 +79,7 @@ bool transform_allows_wearing_item(const item_def& item, // Some can't wear anything. case TRAN_DRAGON: case TRAN_BAT: + case TRAN_PIG: rc = false; break; @@ -470,6 +472,8 @@ size_type player::transform_size(int psize) const case TRAN_SPIDER: case TRAN_BAT: return SIZE_TINY; + case TRAN_PIG: + return SIZE_SMALL; case TRAN_ICE_BEAST: return SIZE_LARGE; case TRAN_DRAGON: @@ -530,8 +534,11 @@ bool transform(int pow, transformation_type which_trans, bool force, { if (just_check) return (true); - - mpr("You extend your transformation's duration."); + + if (which_trans==TRAN_PIG) + mpr("You feel you'll be a pig longer."); + else + mpr("You extend your transformation's duration."); you.duration[DUR_TRANSFORMATION] += random2(pow); if (you.duration[DUR_TRANSFORMATION] > 100) @@ -541,7 +548,7 @@ bool transform(int pow, transformation_type which_trans, bool force, } else { - if (!force) + if (!force && which_trans!=TRAN_PIG) mpr("You cannot extend your transformation any further!"); return (false); } @@ -589,7 +596,7 @@ bool transform(int pow, transformation_type which_trans, bool force, std::set<equipment_type> rem_stuff = _init_equipment_removal(which_trans); - if (_check_for_cursed_equipment(rem_stuff, which_trans, force)) + if (_check_for_cursed_equipment(rem_stuff, which_trans, force) && which_trans!=TRAN_PIG) return (_abort_or_fizzle(just_check)); int str = 0, dex = 0, symbol = '@', colour = LIGHTGREY, xhp = 0, dur = 0; @@ -673,14 +680,28 @@ bool transform(int pow, transformation_type which_trans, bool force, msg = "You turn into a bat."; break; + case TRAN_PIG: + tran_name = "pig"; + symbol = 'h'; + colour = RED; + dur = pow; + msg = "You have been turned into a pig!"; + break; + case TRAN_NONE: case NUM_TRANSFORMATIONS: break; } - if (check_transformation_stat_loss(rem_stuff, force, - std::max(-str, 0), std::max(-dex, 0))) - { + if (check_transformation_stat_loss(rem_stuff, force || which_trans == TRAN_PIG, + std::max(-str, 0), std::max(-dex,0))) + { // would have died to stat loss + if (which_trans == TRAN_PIG) + { // no easy way around this! + mpr("A dreadful feeling locks you in place!"); + if (you.duration[DUR_PARALYSIS]<10) + you.duration[DUR_PARALYSIS]=10; + } return (_abort_or_fizzle(just_check)); } @@ -879,6 +900,10 @@ void untransform(bool skip_wielding) you.is_undead = US_ALIVE; break; + case TRAN_PIG: + mpr( "Your transformation has ended.", MSGCH_DURATION ); + break; + default: break; } |