1 | |
1 | |
2 | /* |
2 | /* |
3 | * static char *rcs_treasure_c = |
3 | * static char *rcs_treasure_c = |
4 | * "$Id: treasure.c,v 1.3.2.1 2006/08/10 16:53:34 elmex Exp $"; |
4 | * "$Id: treasure.c,v 1.3.2.2 2006/08/10 19:09:02 elmex Exp $"; |
5 | */ |
5 | */ |
6 | |
6 | |
7 | /* |
7 | /* |
8 | CrossFire, A Multiplayer game for X-windows |
8 | CrossFire, A Multiplayer game for X-windows |
9 | |
9 | |
… | |
… | |
331 | |
331 | |
332 | |
332 | |
333 | if((int)t->chance >= 100 || (RANDOM()%100 + 1) < (int) t->chance) { |
333 | if((int)t->chance >= 100 || (RANDOM()%100 + 1) < (int) t->chance) { |
334 | if (t->name) { |
334 | if (t->name) { |
335 | if (strcmp(t->name,"NONE") && difficulty>=t->magic) |
335 | if (strcmp(t->name,"NONE") && difficulty>=t->magic) |
|
|
336 | { |
336 | create_treasure(find_treasurelist(t->name), op, flag, difficulty, tries); |
337 | create_treasure(find_treasurelist(t->name), op, flag, difficulty, tries); |
|
|
338 | } |
337 | } |
339 | } |
338 | else { |
340 | else { |
339 | if(t->item->clone.invisible != 0 || ! (flag & GT_INVISIBLE)) { |
341 | if(t->item->clone.invisible != 0 || ! (flag & GT_INVISIBLE)) { |
340 | tmp=arch_to_object(t->item); |
342 | tmp=arch_to_object(t->item); |
341 | if(t->nrof&&tmp->nrof<=1) |
343 | if(t->nrof&&tmp->nrof<=1) |
… | |
… | |
485 | * |
487 | * |
486 | * elmex Wed Aug 9 17:44:59 CEST 2006: |
488 | * elmex Wed Aug 9 17:44:59 CEST 2006: |
487 | * Removed multiplicator, too many high-level items were generated on low-difficulty maps. |
489 | * Removed multiplicator, too many high-level items were generated on low-difficulty maps. |
488 | */ |
490 | */ |
489 | |
491 | |
490 | int level_for_item(const object *op, int difficulty) |
492 | int level_for_item (const object *op, int difficulty) |
491 | { |
493 | { |
492 | int mult = 0, olevel = 0; |
494 | int mult = 0, olevel = 0; |
493 | |
495 | |
494 | if (!op->inv) |
496 | if (!op->inv) |
495 | { |
497 | { |
… | |
… | |
520 | */ |
522 | */ |
521 | |
523 | |
522 | int magic_from_difficulty(int difficulty) |
524 | int magic_from_difficulty(int difficulty) |
523 | { |
525 | { |
524 | int percent = 0, magic = 0; |
526 | int percent = 0, magic = 0; |
525 | int scaled_diff = ((double) difficulty / settings.max_level) * 31; |
527 | int scaled_diff = ((double) difficulty / settings.max_level) * DIFFLEVELS; |
526 | |
528 | |
527 | scaled_diff--; |
529 | scaled_diff--; |
528 | |
530 | |
529 | if(scaled_diff < 0) |
531 | if(scaled_diff < 0) |
530 | scaled_diff = 0; |
532 | scaled_diff = 0; |
… | |
… | |
760 | * value. |
762 | * value. |
761 | * GT_MINIMAL: Does minimal processing on the object - just enough to make it |
763 | * GT_MINIMAL: Does minimal processing on the object - just enough to make it |
762 | * a working object - don't change magic, value, etc, but set it material |
764 | * a working object - don't change magic, value, etc, but set it material |
763 | * type as appropriate, for objects that need spell objects, set those, etc |
765 | * type as appropriate, for objects that need spell objects, set those, etc |
764 | */ |
766 | */ |
|
|
767 | |
765 | void fix_generated_item (object *op, object *creator, int difficulty, |
768 | void fix_generated_item (object * op, object * creator, int difficulty, |
766 | int max_magic, int flags) |
769 | int max_magic, int flags) |
767 | { |
770 | { |
768 | int was_magic = op->magic, num_enchantments=0, save_item_power; |
771 | int was_magic = op->magic, num_enchantments = 0, save_item_power = 0; |
769 | |
772 | |
770 | if(!creator||creator->type==op->type) creator=op; /*safety & to prevent polymorphed |
773 | if (!creator || creator->type == op->type) |
771 | * objects giving attributes */ |
774 | creator = op; /*safety & to prevent polymorphed objects giving attributes */ |
772 | |
775 | |
773 | /* If we make an artifact, this information will be destroyed */ |
776 | /* If we make an artifact, this information will be destroyed */ |
774 | save_item_power = op->item_power; |
777 | save_item_power = op->item_power; |
775 | op->item_power = 0; |
778 | op->item_power = 0; |
776 | |
779 | |
777 | if (op->randomitems && op->type != SPELL) { |
780 | if (op->randomitems && op->type != SPELL) |
|
|
781 | { |
778 | create_treasure(op->randomitems, op,flags ,difficulty, 0); |
782 | create_treasure (op->randomitems, op, flags, difficulty, 0); |
779 | if (!op->inv) LOG(llevDebug,"fix_generated_item: Unable to generate treasure for %s\n", |
783 | if (!op->inv) |
780 | op->name); |
784 | LOG (llevDebug, |
|
|
785 | "fix_generated_item: Unable to generate treasure for %s\n", |
|
|
786 | op->name); |
|
|
787 | |
781 | /* So the treasure doesn't get created again */ |
788 | /* So the treasure doesn't get created again */ |
782 | op->randomitems = NULL; |
789 | op->randomitems = NULL; |
783 | } |
790 | } |
784 | |
791 | |
785 | if (difficulty<1) difficulty=1; |
792 | if (difficulty < 1) |
|
|
793 | difficulty = 1; |
|
|
794 | |
786 | if (!(flags & GT_MINIMAL)) { |
795 | if (!(flags & GT_MINIMAL)) |
|
|
796 | { |
787 | if (op->arch == crown_arch) { |
797 | if (op->arch == crown_arch) |
|
|
798 | { |
788 | set_magic(difficulty>25?30:difficulty+5, op, max_magic, flags); |
799 | set_magic (difficulty, op, max_magic, flags); |
789 | num_enchantments = calc_item_power(op, 1); |
800 | num_enchantments = calc_item_power (op, 1); |
790 | generate_artifact(op,difficulty); |
801 | generate_artifact (op, difficulty); |
791 | } else { |
802 | } |
|
|
803 | else |
|
|
804 | { |
792 | if(!op->magic && max_magic) |
805 | if (!op->magic && max_magic) |
793 | set_magic(difficulty,op,max_magic, flags); |
806 | set_magic (difficulty, op, max_magic, flags); |
|
|
807 | |
794 | num_enchantments = calc_item_power(op, 1); |
808 | num_enchantments = calc_item_power (op, 1); |
|
|
809 | |
795 | if ((!was_magic && !(RANDOM()%CHANCE_FOR_ARTIFACT)) || op->type == HORN || |
810 | if ((!was_magic && !(RANDOM () % CHANCE_FOR_ARTIFACT)) |
796 | difficulty >= 999 ) |
811 | || op->type == HORN) |
797 | generate_artifact(op, difficulty); |
812 | generate_artifact (op, difficulty); |
798 | } |
813 | } |
799 | |
814 | |
800 | /* Object was made an artifact. Calculate its item_power rating. |
815 | /* Object was made an artifact. Calculate its item_power rating. |
801 | * the item_power in the object is what the artfiact adds. |
816 | * the item_power in the object is what the artfiact adds. |
802 | */ |
817 | */ |
803 | if (op->title) { |
818 | if (op->title) |
|
|
819 | { |
804 | /* if save_item_power is set, then most likely we started with an |
820 | /* if save_item_power is set, then most likely we started with an |
805 | * artifact and have added new abilities to it - this is rare, but |
821 | * artifact and have added new abilities to it - this is rare, but |
806 | * but I have seen things like 'strange rings of fire'. So just figure |
822 | * but I have seen things like 'strange rings of fire'. So just figure |
807 | * out the power from the base power plus what this one adds. Note |
823 | * out the power from the base power plus what this one adds. Note |
808 | * that since item_power is not quite linear, this actually ends up |
824 | * that since item_power is not quite linear, this actually ends up |
809 | * being somewhat of a bonus |
825 | * being somewhat of a bonus |
810 | */ |
826 | */ |
811 | if (save_item_power) { |
827 | if (save_item_power) |
|
|
828 | op->item_power = |
812 | op->item_power = save_item_power + get_power_from_ench(op->item_power); |
829 | save_item_power + get_power_from_ench (op->item_power); |
813 | } else { |
830 | else |
|
|
831 | op->item_power = |
814 | op->item_power = get_power_from_ench(op->item_power + num_enchantments); |
832 | get_power_from_ench (op->item_power + num_enchantments); |
815 | } |
833 | } |
816 | } else if (save_item_power) { |
834 | else if (save_item_power) |
|
|
835 | { |
817 | /* restore the item_power field to the object if we haven't changed it. |
836 | /* restore the item_power field to the object if we haven't changed it. |
818 | * we don't care about num_enchantments - that will basically just |
837 | * we don't care about num_enchantments - that will basically just |
819 | * have calculated some value from the base attributes of the archetype. |
838 | * have calculated some value from the base attributes of the archetype. |
820 | */ |
839 | */ |
821 | op->item_power = save_item_power; |
840 | op->item_power = save_item_power; |
822 | } |
841 | } |
823 | } |
842 | } |
824 | |
843 | |
825 | /* materialtype modifications. Note we allow this on artifacts. */ |
844 | /* materialtype modifications. Note we allow this on artifacts. */ |
826 | |
|
|
827 | set_materialname(op, difficulty, NULL); |
845 | set_materialname (op, difficulty, NULL); |
828 | |
846 | |
829 | if (flags & GT_MINIMAL) { |
847 | if (flags & GT_MINIMAL) |
|
|
848 | { |
830 | if (op->type == POTION) |
849 | if (op->type == POTION) |
831 | /* Handle healing and magic power potions */ |
850 | /* Handle healing and magic power potions */ |
832 | if (op->stats.sp && !op->randomitems) { |
851 | if (op->stats.sp && !op->randomitems) |
833 | object *tmp; |
852 | { |
|
|
853 | object *tmp; |
834 | |
854 | |
835 | tmp = get_archetype(spell_mapping[op->stats.sp]); |
855 | tmp = get_archetype (spell_mapping[op->stats.sp]); |
836 | insert_ob_in_ob(tmp, op); |
856 | insert_ob_in_ob (tmp, op); |
837 | op->stats.sp=0; |
857 | op->stats.sp = 0; |
|
|
858 | } |
838 | } |
859 | } |
839 | } |
|
|
840 | else if (!op->title) /* Only modify object if not special */ |
860 | else if (!op->title) /* Only modify object if not special */ |
841 | switch(op->type) { |
861 | switch (op->type) |
|
|
862 | { |
842 | case WEAPON: |
863 | case WEAPON: |
843 | case ARMOUR: |
864 | case ARMOUR: |
844 | case SHIELD: |
865 | case SHIELD: |
845 | case HELMET: |
866 | case HELMET: |
846 | case CLOAK: |
867 | case CLOAK: |
847 | if (QUERY_FLAG(op, FLAG_CURSED) && !(RANDOM()%4)) |
868 | if (QUERY_FLAG (op, FLAG_CURSED) && !(RANDOM () % 4)) |
848 | set_ring_bonus(op, -DICE2); |
869 | set_ring_bonus (op, -DICE2); |
849 | break; |
870 | break; |
850 | |
871 | |
851 | case BRACERS: |
872 | case BRACERS: |
852 | if (!(RANDOM()%(QUERY_FLAG(op, FLAG_CURSED)?5:20))) { |
873 | if (!(RANDOM () % (QUERY_FLAG (op, FLAG_CURSED) ? 5 : 20))) |
|
|
874 | { |
853 | set_ring_bonus(op,QUERY_FLAG(op, FLAG_CURSED)?-DICE2:DICE2); |
875 | set_ring_bonus (op, QUERY_FLAG (op, FLAG_CURSED) ? -DICE2 : DICE2); |
854 | if (!QUERY_FLAG(op, FLAG_CURSED)) |
876 | if (!QUERY_FLAG (op, FLAG_CURSED)) |
855 | op->value*=3; |
877 | op->value *= 3; |
856 | } |
878 | } |
857 | break; |
879 | break; |
858 | |
880 | |
859 | case POTION: { |
881 | case POTION: |
|
|
882 | { |
860 | int too_many_tries=0,is_special=0; |
883 | int too_many_tries = 0, is_special = 0; |
861 | |
884 | |
862 | /* Handle healing and magic power potions */ |
885 | /* Handle healing and magic power potions */ |
863 | if (op->stats.sp && !op->randomitems) { |
886 | if (op->stats.sp && !op->randomitems) |
864 | object *tmp; |
887 | { |
|
|
888 | object *tmp; |
865 | |
889 | |
866 | tmp = get_archetype(spell_mapping[op->stats.sp]); |
890 | tmp = get_archetype (spell_mapping[op->stats.sp]); |
867 | insert_ob_in_ob(tmp, op); |
891 | insert_ob_in_ob (tmp, op); |
868 | op->stats.sp=0; |
892 | op->stats.sp = 0; |
869 | } |
893 | } |
870 | |
894 | |
871 | while(!(is_special=special_potion(op)) && !op->inv) { |
895 | while (!(is_special = special_potion (op)) && !op->inv) |
|
|
896 | { |
872 | generate_artifact(op,difficulty); |
897 | generate_artifact (op, difficulty); |
873 | if(too_many_tries++ > 10) break; |
898 | if (too_many_tries++ > 10) |
874 | } |
899 | break; |
|
|
900 | } |
|
|
901 | |
875 | /* don't want to change value for healing/magic power potions, |
902 | /* don't want to change value for healing/magic power potions, |
876 | * since the value set on those is already correct. |
903 | * since the value set on those is already correct. |
877 | */ |
904 | */ |
878 | if (op->inv && op->randomitems) { |
905 | if (op->inv && op->randomitems) |
|
|
906 | { |
879 | /* value multiplier is same as for scrolls */ |
907 | /* value multiplier is same as for scrolls */ |
880 | op->value=(op->value*op->inv->value); |
908 | op->value = (op->value * op->inv->value); |
881 | op->level = op->inv->level/2+ RANDOM()%difficulty + RANDOM()%difficulty; |
909 | op->level = |
882 | } else { |
910 | op->inv->level / 2 + RANDOM () % difficulty |
|
|
911 | + RANDOM () % difficulty; |
|
|
912 | } |
|
|
913 | else |
|
|
914 | { |
883 | FREE_AND_COPY(op->name, "potion"); |
915 | FREE_AND_COPY (op->name, "potion"); |
884 | FREE_AND_COPY(op->name_pl, "potions"); |
916 | FREE_AND_COPY (op->name_pl, "potions"); |
885 | } |
917 | } |
886 | if ( ! (flags & GT_ONLY_GOOD) && RANDOM() % 2) |
918 | if (!(flags & GT_ONLY_GOOD) && RANDOM () % 2) |
887 | SET_FLAG(op, FLAG_CURSED); |
919 | SET_FLAG (op, FLAG_CURSED); |
888 | break; |
920 | break; |
889 | } |
921 | } |
890 | |
922 | |
891 | case AMULET: |
923 | case AMULET: |
892 | if(op->arch==amulet_arch) |
924 | if (op->arch == amulet_arch) |
893 | op->value*=5; /* Since it's not just decoration */ |
925 | op->value *= 5; /* Since it's not just decoration */ |
894 | |
926 | |
895 | case RING: |
927 | case RING: |
896 | if(op->arch==NULL) { |
928 | if (op->arch == NULL) |
|
|
929 | { |
897 | remove_ob(op); |
930 | remove_ob (op); |
898 | free_object(op); |
931 | free_object (op); |
899 | op=NULL; |
932 | op = NULL; |
900 | break; |
933 | break; |
901 | } |
934 | } |
|
|
935 | |
902 | if(op->arch!=ring_arch&&op->arch!=amulet_arch) /* It's a special artifact!*/ |
936 | if (op->arch != ring_arch && op->arch != amulet_arch) /* It's a special artifact! */ |
903 | break; |
937 | break; |
904 | |
938 | |
905 | if ( ! (flags & GT_ONLY_GOOD) && ! (RANDOM() % 3)) |
939 | if (!(flags & GT_ONLY_GOOD) && !(RANDOM () % 3)) |
906 | SET_FLAG(op, FLAG_CURSED); |
940 | SET_FLAG (op, FLAG_CURSED); |
|
|
941 | |
907 | set_ring_bonus(op,QUERY_FLAG(op, FLAG_CURSED)?-DICE2:DICE2); |
942 | set_ring_bonus (op, QUERY_FLAG (op, FLAG_CURSED) ? -DICE2 : DICE2); |
|
|
943 | |
908 | if(op->type!=RING) /* Amulets have only one ability */ |
944 | if (op->type != RING) /* Amulets have only one ability */ |
909 | break; |
945 | break; |
910 | if(!(RANDOM()%4)) { |
946 | |
911 | int d=(RANDOM()%2 || QUERY_FLAG(op, FLAG_CURSED))?-DICE2:DICE2; |
947 | if (!(RANDOM () % 4)) |
912 | if(d>0) |
948 | { |
913 | op->value*=3; |
949 | int d = (RANDOM () % 2 |
|
|
950 | || QUERY_FLAG (op, FLAG_CURSED)) ? -DICE2 : DICE2; |
|
|
951 | |
|
|
952 | if (d > 0) |
|
|
953 | op->value *= 3; |
|
|
954 | |
914 | set_ring_bonus(op,d); |
955 | set_ring_bonus (op, d); |
915 | if(!(RANDOM()%4)) { |
956 | |
916 | int d=(RANDOM()%3 || QUERY_FLAG(op, FLAG_CURSED))?-DICE2:DICE2; |
957 | if (!(RANDOM () % 4)) |
917 | if(d>0) |
958 | { |
918 | op->value*=5; |
959 | int d = (RANDOM () % 3 |
919 | set_ring_bonus(op,d); |
960 | || QUERY_FLAG (op, FLAG_CURSED)) ? -DICE2 : DICE2; |
920 | } |
961 | if (d > 0) |
921 | } |
962 | op->value *= 5; |
|
|
963 | set_ring_bonus (op, d); |
|
|
964 | } |
|
|
965 | } |
|
|
966 | |
922 | if(GET_ANIM_ID(op)) |
967 | if (GET_ANIM_ID (op)) |
923 | SET_ANIMATION(op, RANDOM()%((int) NUM_ANIMATIONS(op))); |
968 | SET_ANIMATION (op, RANDOM () % ((int) NUM_ANIMATIONS (op))); |
924 | break; |
|
|
925 | |
969 | |
|
|
970 | break; |
|
|
971 | |
926 | case BOOK: |
972 | case BOOK: |
927 | /* Is it an empty book?, if yes lets make a special |
973 | /* Is it an empty book?, if yes lets make a special |
928 | * msg for it, and tailor its properties based on the |
974 | * msg for it, and tailor its properties based on the |
929 | * creator and/or map level we found it on. |
975 | * creator and/or map level we found it on. |
930 | */ |
976 | */ |
931 | if(!op->msg&&RANDOM()%10) { |
977 | if (!op->msg && RANDOM () % 10) |
|
|
978 | { |
932 | /* set the book level properly */ |
979 | /* set the book level properly */ |
933 | if(creator->level==0 || QUERY_FLAG(creator,FLAG_ALIVE)) { |
980 | if (creator->level == 0 || QUERY_FLAG (creator, FLAG_ALIVE)) |
934 | if(op->map&&op->map->difficulty) |
981 | { |
935 | op->level=RANDOM()%(op->map->difficulty)+RANDOM()%10+1; |
982 | if (op->map && op->map->difficulty) |
936 | else |
983 | op->level = |
937 | op->level=RANDOM()%20+1; |
984 | RANDOM () % (op->map->difficulty) + RANDOM () % 10 + 1; |
938 | } else |
985 | else |
|
|
986 | op->level = RANDOM () % 20 + 1; |
|
|
987 | } |
|
|
988 | else |
939 | op->level=RANDOM()%creator->level; |
989 | op->level = RANDOM () % creator->level; |
940 | |
990 | |
941 | tailor_readable_ob(op,(creator&&creator->stats.sp)?creator->stats.sp:-1); |
991 | tailor_readable_ob (op, |
|
|
992 | (creator |
|
|
993 | && creator->stats.sp) ? creator->stats. |
|
|
994 | sp : -1); |
942 | /* books w/ info are worth more! */ |
995 | /* books w/ info are worth more! */ |
943 | op->value*=((op->level>10?op->level:(op->level+1)/2)*((strlen(op->msg)/250)+1)); |
996 | op->value *= |
|
|
997 | ((op->level > |
|
|
998 | 10 ? op->level : (op->level + |
|
|
999 | 1) / 2) * ((strlen (op->msg) / 250) + 1)); |
944 | /* creator related stuff */ |
1000 | /* creator related stuff */ |
945 | |
1001 | |
946 | /* for library, chained books. Note that some monsters have no_pick |
1002 | /* for library, chained books. Note that some monsters have no_pick |
947 | * set - we don't want to set no pick in that case. |
1003 | * set - we don't want to set no pick in that case. |
948 | */ |
1004 | */ |
949 | if(QUERY_FLAG(creator,FLAG_NO_PICK) && |
1005 | if (QUERY_FLAG (creator, FLAG_NO_PICK) && |
950 | !QUERY_FLAG(creator, FLAG_MONSTER)) |
1006 | !QUERY_FLAG (creator, FLAG_MONSTER)) |
951 | SET_FLAG(op,FLAG_NO_PICK); |
1007 | SET_FLAG (op, FLAG_NO_PICK); |
952 | if(creator->slaying&&!op->slaying) /* for check_inv floors */ |
1008 | if (creator->slaying && !op->slaying) /* for check_inv floors */ |
953 | op->slaying = add_string(creator->slaying); |
1009 | op->slaying = add_string (creator->slaying); |
954 | |
1010 | |
955 | /* add exp so reading it gives xp (once)*/ |
1011 | /* add exp so reading it gives xp (once) */ |
956 | op->stats.exp = op->value>10000?op->value/5:op->value/10; |
1012 | op->stats.exp = |
957 | } |
1013 | op->value > 10000 ? op->value / 5 : op->value / 10; |
958 | break; |
1014 | } |
|
|
1015 | break; |
959 | |
1016 | |
960 | case SPELLBOOK: |
1017 | case SPELLBOOK: |
961 | op->value=op->value* op->inv->value; |
|
|
962 | /* add exp so learning gives xp */ |
|
|
963 | op->level = op->inv->level; |
|
|
964 | op->stats.exp = op->value; |
|
|
965 | break; |
|
|
966 | |
|
|
967 | case WAND: |
|
|
968 | /* nrof in the treasure list is number of charges, |
|
|
969 | * not number of wands. So copy that into food (charges), |
|
|
970 | * and reset nrof. |
|
|
971 | */ |
|
|
972 | op->stats.food=op->inv->nrof; |
|
|
973 | op->nrof=1; |
|
|
974 | /* If the spell changes by level, choose a random level |
|
|
975 | * for it, and adjust price. If the spell doesn't |
|
|
976 | * change by level, just set the wand to the level of |
|
|
977 | * the spell, and value calculation is simpler. |
|
|
978 | */ |
|
|
979 | if (op->inv->duration_modifier || op->inv->dam_modifier || |
|
|
980 | op->inv->range_modifier) { |
|
|
981 | op->level = level_for_item(op, difficulty); |
|
|
982 | op->value= op->value* op->inv->value * (op->level +50)/ |
|
|
983 | (op->inv->level + 50); |
|
|
984 | } |
|
|
985 | else { |
|
|
986 | op->level = op->inv->level; |
|
|
987 | op->value = op->value * op->inv->value; |
1018 | op->value = op->value * op->inv->value; |
988 | } |
1019 | /* add exp so learning gives xp */ |
989 | break; |
1020 | op->level = op->inv->level; |
|
|
1021 | op->stats.exp = op->value; |
|
|
1022 | break; |
990 | |
1023 | |
|
|
1024 | case WAND: |
|
|
1025 | /* nrof in the treasure list is number of charges, |
|
|
1026 | * not number of wands. So copy that into food (charges), |
|
|
1027 | * and reset nrof. |
|
|
1028 | */ |
|
|
1029 | op->stats.food = op->inv->nrof; |
|
|
1030 | op->nrof = 1; |
|
|
1031 | /* If the spell changes by level, choose a random level |
|
|
1032 | * for it, and adjust price. If the spell doesn't |
|
|
1033 | * change by level, just set the wand to the level of |
|
|
1034 | * the spell, and value calculation is simpler. |
|
|
1035 | */ |
|
|
1036 | if (op->inv->duration_modifier || op->inv->dam_modifier || |
|
|
1037 | op->inv->range_modifier) |
|
|
1038 | { |
|
|
1039 | op->level = level_for_item (op, difficulty); |
|
|
1040 | op->value = op->value * op->inv->value * (op->level + 50) / |
|
|
1041 | (op->inv->level + 50); |
|
|
1042 | } |
|
|
1043 | else |
|
|
1044 | { |
|
|
1045 | op->level = op->inv->level; |
|
|
1046 | op->value = op->value * op->inv->value; |
|
|
1047 | } |
|
|
1048 | break; |
|
|
1049 | |
991 | case ROD: |
1050 | case ROD: |
992 | op->level = level_for_item(op, difficulty); |
1051 | op->level = level_for_item (op, difficulty); |
993 | /* Add 50 to both level an divisor to keep prices a little more |
1052 | /* Add 50 to both level an divisor to keep prices a little more |
994 | * reasonable. Otherwise, a high level version of a low level |
1053 | * reasonable. Otherwise, a high level version of a low level |
995 | * spell can be worth tons a money (eg, level 20 rod, level 2 spell = |
1054 | * spell can be worth tons a money (eg, level 20 rod, level 2 spell = |
996 | * 10 time multiplier). This way, the value are a bit more reasonable. |
1055 | * 10 time multiplier). This way, the value are a bit more reasonable. |
997 | */ |
1056 | */ |
|
|
1057 | op->value = |
998 | op->value= op->value * op->inv->value * (op->level +50) / (op->inv->level + 50); |
1058 | op->value * op->inv->value * (op->level + 50) / (op->inv->level + |
|
|
1059 | 50); |
999 | /* maxhp is used to denote how many 'charges' the rod holds before */ |
1060 | /* maxhp is used to denote how many 'charges' the rod holds before */ |
1000 | if (op->stats.maxhp) |
1061 | if (op->stats.maxhp) |
1001 | op->stats.maxhp *= MAX(op->inv->stats.sp, op->inv->stats.grace); |
1062 | op->stats.maxhp *= MAX (op->inv->stats.sp, op->inv->stats.grace); |
1002 | else |
1063 | else |
1003 | op->stats.maxhp = 2 * MAX(op->inv->stats.sp, op->inv->stats.grace); |
1064 | op->stats.maxhp = 2 * MAX (op->inv->stats.sp, op->inv->stats.grace); |
1004 | |
1065 | |
1005 | op->stats.hp = op->stats.maxhp; |
1066 | op->stats.hp = op->stats.maxhp; |
1006 | break; |
1067 | break; |
1007 | |
1068 | |
1008 | case SCROLL: |
1069 | case SCROLL: |
1009 | op->level = level_for_item(op, difficulty); |
1070 | op->level = level_for_item (op, difficulty); |
1010 | op->value= op->value * op->inv->value * (op->level +50) / (op->inv->level + 50); |
1071 | op->value = |
|
|
1072 | op->value * op->inv->value |
|
|
1073 | * (op->level + 50) / (op->inv->level + 50); |
|
|
1074 | |
1011 | /* add exp so reading them properly gives xp */ |
1075 | /* add exp so reading them properly gives xp */ |
1012 | op->stats.exp = op->value/5; |
1076 | op->stats.exp = op->value / 5; |
1013 | op->nrof = op->inv->nrof; |
1077 | op->nrof = op->inv->nrof; |
1014 | break; |
1078 | break; |
1015 | |
1079 | |
1016 | case RUNE: |
1080 | case RUNE: |
1017 | trap_adjust(op,difficulty); |
1081 | trap_adjust (op, difficulty); |
1018 | break; |
1082 | break; |
1019 | |
1083 | |
1020 | case TRAP: |
1084 | case TRAP: |
1021 | trap_adjust(op,difficulty); |
1085 | trap_adjust (op, difficulty); |
1022 | break; |
1086 | break; |
1023 | } /* switch type */ |
1087 | } /* switch type */ |
1024 | |
1088 | |
1025 | if (flags & GT_STARTEQUIP) { |
1089 | if (flags & GT_STARTEQUIP) |
|
|
1090 | { |
1026 | if (op->nrof < 2 && op->type != CONTAINER |
1091 | if (op->nrof < 2 && op->type != CONTAINER |
1027 | && op->type != MONEY && ! QUERY_FLAG (op, FLAG_IS_THROWN)) |
1092 | && op->type != MONEY && !QUERY_FLAG (op, FLAG_IS_THROWN)) |
1028 | SET_FLAG (op, FLAG_STARTEQUIP); |
1093 | SET_FLAG (op, FLAG_STARTEQUIP); |
1029 | else if (op->type != MONEY) |
1094 | else if (op->type != MONEY) |
1030 | op->value = 0; |
1095 | op->value = 0; |
1031 | } |
1096 | } |
1032 | |
1097 | |
1033 | if ( ! (flags & GT_ENVIRONMENT)) |
1098 | if (!(flags & GT_ENVIRONMENT)) |
1034 | fix_flesh_item (op, creator); |
1099 | fix_flesh_item (op, creator); |
1035 | } |
1100 | } |
1036 | |
1101 | |
1037 | /* |
1102 | /* |
1038 | * |
1103 | * |
1039 | * |
1104 | * |