ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/server/ext/bonus.ext
(Generate patch)

Comparing deliantra/server/ext/bonus.ext (file contents):
Revision 1.5 by elmex, Tue Feb 6 09:36:01 2007 UTC vs.
Revision 1.9 by root, Tue May 4 21:45:42 2010 UTC

1#!perl 1#! perl
2
2use List::Util qw/min/; 3use List::Util qw/min/;
3 4
4my $WC_BASE_VALUE = 15 * 5000; # 15r 5my $WC_BASE_VALUE = 15 * 5000; # 15r
5my $AC_BASE_VALUE = 40 * 5000; # 40r 6my $AC_BASE_VALUE = 40 * 5000; # 40r
6my $DAM_BASE_VALUE = 200; # 4p 7my $DAM_BASE_VALUE = 200; # 4p
9my $MAX_LEVEL = cf::settings->max_level; 10my $MAX_LEVEL = cf::settings->max_level;
10 11
11# maximum values of additions at $MAX_LEVEL difficulty 12# maximum values of additions at $MAX_LEVEL difficulty
12my $MAX_ADD_WC = 10; 13my $MAX_ADD_WC = 10;
13my $MAX_ADD_AC = 5; # weapons should rather give wc than ac 14my $MAX_ADD_AC = 5; # weapons should rather give wc than ac
14my $MAX_ADD_DAM = 60; 15my $MAX_ADD_DAM = 45;
15my $MAX_ADD_MAGIC = 5; 16my $MAX_ADD_MAGIC = 5;
16 17
17# TODO: should become part of some stdlib 18# TODO: should become part of some stdlib
18sub rand_range($$) { 19sub rand_range($$) {
19 $_[0] + ($_[1] - $_[0]) * rand 20 $_[0] + ($_[1] - $_[0]) * rand
20} 21}
21 22
22sub determine_weapon_value { 23sub determine_weapon_value {
23 my ($weapon) = @_; 24 my ($weapon) = @_;
24 25
25 my $clone = $weapon->arch->clone; 26 my $arch = $weapon->arch;
26 my $value = $clone->value; 27 my $value = $arch->value;
27 28
28 my $wc_diff = $weapon->stats->wc - $clone->stats->wc; 29 my $wc_diff = $weapon->stats->wc - $arch->stats->wc;
29 my $ac_diff = $weapon->stats->ac - $clone->stats->ac; 30 my $ac_diff = $weapon->stats->ac - $arch->stats->ac;
30 my $dam_diff = $weapon->stats->dam - $clone->stats->dam; 31 my $dam_diff = $weapon->stats->dam - $arch->stats->dam;
31 32
32 my $magic_diff = $weapon->magic - $clone->magic; 33 my $magic_diff = $weapon->magic - $arch->magic;
33 34
34 if ($wc_diff > 0) { $value += $WC_BASE_VALUE * 1.5 * $wc_diff * rand_range .5, 1 } 35 if ($wc_diff > 0) { $value += $WC_BASE_VALUE * 1.5 * $wc_diff * rand_range .5, 1 }
35 if ($ac_diff > 0) { $value += $AC_BASE_VALUE * 1.5 * $ac_diff * rand_range .5, 1 } 36 if ($ac_diff > 0) { $value += $AC_BASE_VALUE * 1.5 * $ac_diff * rand_range .5, 1 }
36 if ($dam_diff > 0) { $value += $DAM_BASE_VALUE * ($dam_diff ** 2.2) * rand_range .7, 1 } 37 if ($dam_diff > 0) { $value += $DAM_BASE_VALUE * ($dam_diff ** 2.4) * rand_range .7, 1 }
37 if ($magic_diff > 0) { $value += $MAGIC_BASE_VALUE * 1.5 * $magic_diff * rand_range .5, 1 } 38 if ($magic_diff > 0) { $value += $MAGIC_BASE_VALUE * 1.5 * $magic_diff * rand_range .5, 1 }
38 39
39 #warn sprintf "WC DIFF: %3d, %3d, %3d, %3d | %10d = %10.3f r\n", 40 #warn sprintf "WC DIFF: %3d, %3d, %3d, %3d | %10d = %10.3f r\n",
40 # $dam_diff, $wc_diff, $ac_diff, $magic_diff, $value, $value / 5000 41 # $dam_diff, $wc_diff, $ac_diff, $magic_diff, $value, $value / 5000
41 # if $cf::CFG{ext_bonus_debug}; 42 # if $cf::CFG{ext_bonus_debug};
59 determine_weapon_value $item; 60 determine_weapon_value $item;
60 61
61 cf::override; 62 cf::override;
62 }, 63 },
63); 64);
65

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines