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

Comparing deliantra/server/ext/jeweler.ext (file contents):
Revision 1.2 by root, Thu Dec 21 22:41:34 2006 UTC vs.
Revision 1.27 by root, Sun May 30 19:51:28 2010 UTC

1#! perl 1#! perl
2 2
3use Data::Dumper; 3use strict;
4
4use Jeweler; 5use Jeweler;
5use List::Util qw/max min sum/; 6use List::Util qw/max min sum/;
6use strict;
7 7
8sub ingred_alias { 8sub ingred_alias {
9 my ($ing) = @_; 9 my ($ing) = @_;
10 10
11 my %aliases = ( 11 my %aliases = (
14 wis => 'wisdom', 14 wis => 'wisdom',
15 int => 'intelligence', 15 int => 'intelligence',
16 dex => 'dexterity', 16 dex => 'dexterity',
17 con => 'constitution', 17 con => 'constitution',
18 str => 'strength', 18 str => 'strength',
19 gem => 'diamond',
19 ); 20 );
20 21
21 if ($ing =~ m/resist_(\S+)/) { 22 if ($ing =~ m/resist_(\S+)/) {
22 my $a = $aliases{lc $1} || $1; 23 my $a = $aliases{lc $1} || $1;
23 "something for '". lc ($a). "' resistance"; 24 "something for '". lc ($a). "' resistance";
28 29
29 } elsif ($ing =~ m/spec_(\S+)/) { 30 } elsif ($ing =~ m/spec_(\S+)/) {
30 my $a = $aliases{lc $1} || $1; 31 my $a = $aliases{lc $1} || $1;
31 "something for the ". lc ($a). "' special"; 32 "something for the ". lc ($a). "' special";
32 33
34 } elsif ($aliases{$ing}) {
35 $aliases{$ing}
36
33 } else { 37 } else {
34 $ing 38 $ing
35 } 39 }
36} 40}
37 41
38my $DEBUG = 1; 42my $DEBUG = 1;
39 43
40sub merge { 44sub merge {
41 my ($chdl, $sk, $pl, $do_analyze) = @_; 45 my ($chdl, $sk, $pl, $do_analyze) = @_;
42 46
43 my $ingred = $chdl->extract_jeweler_ingredients; 47 my $ingred = get_ingred ($pl, $chdl) || return;
48
44 my @ring = $ingred->get_ring; 49 my @ring = $ingred->get_ring;
45 my @rings = map { Jeweler::Object->new (object => $_) } @ring; 50 my @rings = map { Jeweler::Object->new (object => $_) } @ring;
46 51
47 @rings >= 2 52 @rings >= 2
48 or return $pl->reply (undef, "You slap yourself, you forgot to put at least 2 jewels in!"); 53 or return $pl->message ("You slap yourself, you forgot to put at least 2 jewels in!");
54
55 my $input_level = 0;
56 my $value;
57 for (@rings) {
58 $input_level = max ($_->power_to_level, $input_level);
59 $value += $_->{hash}->{value};
60 }
49 61
50 my $ring = shift @rings; 62 my $ring = shift @rings;
51 $ring->improve_by_ring (@rings); 63 $ring->improve_by_ring (@rings);
52 64
53 if ($do_analyze) { 65 if ($do_analyze) {
54 $pl->reply (undef, "You want to make a " . $ring->to_string . ": " . $ring->analyze ($sk, $pl)); 66 $pl->message ("You want to make a " . $ring->to_string . ": " . $ring->analyze ($sk, $pl, $input_level));
55 $ring->wiz_analyze ($pl) 67 $ring->wiz_analyze ($pl)
56 if $pl->flag (cf::FLAG_WIZ); 68 if $pl->flag (cf::FLAG_WIZ);
57 return; 69 return;
58 } 70 }
59 71
60 make_ring ($chdl, $ingred, $ring, $sk, $pl); 72 make_ring ($chdl, $ingred, $ring, $value, $sk, $pl, $input_level);
61} 73}
62 74
63sub make_ring { 75sub make_ring {
64 my ($chdl, $ingred, $ring, $sk, $pl) = @_; 76 my ($chdl, $ingred, $ring, $value, $sk, $pl, $input_level) = @_;
65 77
66 if (!$pl->flag (cf::FLAG_WIZ)) { 78 if (!$pl->flag (cf::FLAG_WIZ)) {
67 $ingred->remove ('rings'); 79 $ingred->remove ('rings');
68 $ingred->remove ('ammys'); 80 $ingred->remove ('ammys');
69 } 81 }
70 82
71 my $ch = $ring->get_chance_perc ($sk); 83 my $ch = $ring->get_chance_perc ($sk);
72 my $succ = 0; 84 my $succ = 0;
73 my $r = cf::random_roll (0, 100, $pl, cf::PREFER_HIGH); 85 my $r = cf::random_roll (0, 100, $pl, cf::PREFER_LOW);
86
87 my $make_status;
88 my $exp;
89
74 if ($r <= $ch or $pl->flag (cf::FLAG_WIZ)) { 90 if ($r <= $ch or $pl->flag (cf::FLAG_WIZ)) {
75 my $lvl = max ($ring->power_to_level, 1); 91 $exp = $ring->projected_exp ($input_level);
76 my $exp = (cf::level_to_min_exp ($lvl) - cf::level_to_min_exp ($lvl - 1)) / 100; 92
77 $pl->change_exp ($exp, "jeweler", cf::SK_EXP_SKILL_ONLY); 93 $pl->change_exp ($exp, "jeweler", cf::SK_EXP_SKILL_ONLY);
78 $pl->message ("You succeed and get $exp experience."); 94 $pl->message (
95 "You succeed and get " . (int $exp) . " experience points.");
96 $make_status = "succeeded";
97
98 $ring->set_value ($value);
99
79 } else { 100 } else {
80 $pl->message ("You fail!"); 101 $pl->message ("You fail!");
81 $ring->negate; 102 $ring->negate;
103 $make_status = "fail";
104 $exp = 0;
105 }
106
107 my $ring_ob = $ring->to_object;
108
109 $ring_ob->kv_set (ext_jeweler_maker => $pl->name);
110
111 { # some audit info calculation
112 my $sklvl = cf::exp_to_level ($sk->stats->exp);
113
114 my $make_info = sprintf
115 "JEWELER AUDIT: '%s' made '%s' (%s) (sk lvl %d, ring lvl %d, got %d exp): %s",
116 $pl->name, $ring->to_string, $ring_ob->uuid, $sklvl,
117 $ring->power_to_level, $exp, $make_status;
118
119 cf::debug "$make_info\n"
120 if $make_status eq 'succeeded';
121 }
122
123 $chdl->put ($ring_ob);
124}
125
126sub get_ingred {
127 my ($pl, $chdl) = @_;
128 my $ingred = eval { $chdl->extract_jeweler_ingredients };
129 if ($@ =~ /cursed/) {
130 $pl->message ("There are cursed items in the workbench, take them out before you do anything.").
131 return
132 } elsif ($@ =~ /unidentified/) {
133 $pl->message ("There are unidentified items in the workbench, identify them before you do anything.").
134 return
135 } elsif ($@) {
136 cf::error "error in jeweler ingredient extraction: $@";
137 return;
138 }
139 $ingred;
140}
141
142cf::object::attachment check_ring_drop_on =>
143 on_drop_on => sub {
144 my ($self, $obj, $who) = @_;
145 my $cfg = $self->{check_ring_drop_on};
146 if ($obj->type == cf::RING
147 && !$obj->flag (cf::FLAG_CURSED)
148 && !$obj->flag (cf::FLAG_DAMNED)
149 ) {
150 my $ringo = Jeweler::Object->new (object => $obj);
151 for (grep { /^resist_/ } keys %$cfg) {
152 if (/^resist_(\S+)$/) {
153 if ($ringo->has_resist ($1)) {
154 $self->map->trigger (
155 $cfg->{connection},
156 $cfg->{state}
157 );
158 $obj->decrease (1);
159 cf::override;
160 }
161 }
162 }
163 }
82 } 164 };
83 $chdl->put ($ring->to_object);
84}
85 165
86cf::object->attach ( 166cf::object->attach (
87 type => cf::SKILL, 167 type => cf::SKILL,
88 subtype => cf::SK_JEWELER, 168 subtype => cf::SK_JEWELER,
89 on_use_skill => sub { 169 on_use_skill => sub {
111 191
112 } elsif ($msg =~ m/^\s*make\s*$/i) { 192 } elsif ($msg =~ m/^\s*make\s*$/i) {
113 $pl->message ("You can make: " . (join ', ', keys %{Jeweler::getcfg ('conversions') || {}})); 193 $pl->message ("You can make: " . (join ', ', keys %{Jeweler::getcfg ('conversions') || {}}));
114 194
115 } elsif ($msg =~ m/^\s*make\s+(\S+)\s*$/i) { 195 } elsif ($msg =~ m/^\s*make\s+(\S+)\s*$/i) {
116 my $ingred = $chdl->extract_jeweler_ingredients; 196 my $ingred = get_ingred ($pl, $chdl) || return;
117 197
118 unless ($Jeweler::CFG->{conversions}->{lc $1}) { 198 unless ($Jeweler::CFG->{conversions}->{lc $1}) {
119 $pl->message ("You don't know how to make '$1', is does such a thing even exist?"); 199 $pl->message ("You don't know how to make '$1', is does such a thing even exist?");
120 return 200 return
121 } 201 }
122 202
123 Jeweler::simple_converter ($player, $ingred, $chdl, $1); 203 Jeweler::simple_converter (
204 $player, $ingred, $chdl, $1,
205 cf::exp_to_level ($sk->stats->exp));
124 206
125 } elsif ($msg =~ m/^\s*merge\s*analy[sz]e\s*$/i) { 207 } elsif ($msg =~ m/^\s*merge\s*analy[sz]e\s*$/i) {
126 merge ($chdl, $sk, $pl, 1); 208 merge ($chdl, $sk, $pl, 1);
127 209
128 } elsif ($msg =~ m/^\s*merge\s*$/i) { 210 } elsif ($msg =~ m/^\s*merge\s*$/i) {
129 merge ($chdl, $sk, $pl, 0); 211 merge ($chdl, $sk, $pl, 0);
130 212
131 } else { 213 } else {
132 my $ingred = $chdl->extract_jeweler_ingredients; 214 my $ingred = get_ingred ($pl, $chdl) || return;
215
133 my $plan = $ingred->get_plan; 216 my $plan = $ingred->get_plan;
134 217
135 if ($plan) { 218 if ($plan) {
136 my @ring = $ingred->get_ring; 219 my @ring = $ingred->get_ring;
137 220
221 if (!@ring) {
222 # actually the algorithm cant
223 $pl->message ("You slap yourself, you forgot the jewelery!");
224 return;
225
138 if ((@ring > 1) || ($ring[0]->nrof > 1)) { 226 } elsif ((@ring > 1) || (grep { $_->nrof > 1 } @ring)) {
139 # actually the algorithm cant handle more than one improvement at a time 227 # actually the algorithm cant handle more than one improvement at a time
140 $pl->message ("You can't manage to improve more than one thing at a time!"); 228 $pl->message ("You can't manage to improve more than one thing at a time!");
141 return; 229 return;
142
143 } elsif (@ring < 1) {
144 # actually the algorithm cant
145 $pl->message ("You slap yourself, you forgot the jewelery!");
146 return;
147
148 } else { 230 } else {
149 my $ringo = Jeweler::Object->new (object => $ring[0]); 231 my $ringo = Jeweler::Object->new (object => $ring[0]);
150 my $iring = $ingred->improve_ring_by_plan ($plan, $ringo); 232 my $iring = $ingred->improve_ring_by_plan ($plan, $ringo);
151 my $c1 = $ringo->calc_costs; 233 my $c1 = $ringo->calc_costs;
152 my $c2 = $iring->calc_costs; 234 my $c2 = $iring->calc_costs;
235 my $value = $iring->calc_value_from_cost ($c2);
236
237 if ((not defined $c1) || (not defined $c2)) {
238 $pl->message ("The jewel has or will become a resistancy above 99%,\n"
239 ."that is completly impossible to make!");
240 return;
241 }
153 242
154 my %keys; 243 my %keys;
155 my %cdiff; 244 my %cdiff;
156 for (keys %$c1, keys %$c2) { $keys{$_} = 1 } 245 for (keys %$c1, keys %$c2) { $keys{$_} = 1 }
157 for (keys %keys) { $cdiff{$_} = $c2->{$_} - $c1->{$_} } 246 for (keys %keys) { $cdiff{$_} = $c2->{$_} - $c1->{$_}; }
158 247
159 unless (grep { $_ > 0 } values %cdiff) { 248 unless ($iring->is_better_than ($ringo)) {
160 $pl->message ("This plan doesn't improve anything, you find yourself puzzled about what you missed..."); 249 $pl->message ("This plan doesn't improve anything, you find yourself puzzled about what you missed...");
161 return; 250 return;
162 } 251 }
163 252
164 my $remcosts = $ingred->check_costs (\%cdiff); 253 my $remcosts = $ingred->check_costs (\%cdiff);
175 } 264 }
176 } else { 265 } else {
177 if (!$pl->flag (cf::FLAG_WIZ)) { 266 if (!$pl->flag (cf::FLAG_WIZ)) {
178 $ingred->check_costs (\%cdiff, 1); 267 $ingred->check_costs (\%cdiff, 1);
179 } 268 }
180 make_ring ($chdl, $ingred, $iring, $sk, $pl); 269 make_ring ($chdl, $ingred, $iring, $value, $sk, $pl);
181 } 270 }
182 } 271 }
183 } else { 272 } else {
184 $pl->message ("You've got no idea what you are planning to do!"); 273 $pl->message ("You've got no idea what you are planning to do!");
185 } 274 }
186 } 275 }
187 }; 276 };
188 $@ and warn "ERROR: $@\n"; 277 $@ and cf::error "$@\n";
189 } 278 }
190); 279);
191 280
192Jeweler::read_config (cf::datadir . '/jeweler.yaml'); 281Jeweler::load_config;
282

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines