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

Comparing deliantra/server/ext/commands.ext (file contents):
Revision 1.55 by root, Fri Jul 20 14:13:58 2007 UTC vs.
Revision 1.63 by root, Sun Oct 7 15:52:05 2007 UTC

1#! perl # mandatory depends=irc 1#! perl # mandatory depends=irc
2 2
3use POSIX (); 3use POSIX ();
4 4
5# miscellaneous commands 5# miscellaneous commands
6
7sub rename_to($$$) {
8 my ($ob, $from, $to) = @_;
9
10 $to =~ /^[a-zA-Z0-9.,=#\/%$!^ ]*$/
11 or return $ob->message ("rename: name must consist only of letters, digits, spaces and a few other things.");
12
13 127 >= length $to
14 or return $ob->message ("rename: new name must be <= 127 characters.");
15
16 my $item;
17
18 if (length $from) {
19 $item = $ob->find_best_object_match ($from)
20 or return $ob->message ("rename: could not find a matching item to rename.");
21 } else {
22 $item = $ob->find_marked_object
23 or return $ob->message ("rename: no from name and no marked item found to rename.");
24 }
25
26 $item->custom_name (length $to ? $to : undef);
27
28 if (length $to) {
29 $item->custom_name ($to);
30 $ob->message ("Your " . $item->base_name . " will now be called $to.");
31 } else {
32 $item->custom_name (undef);
33 $ob->message ("You stop calling your " . $item->base_name . " with weird names.");
34 }
35
36 $ob->esrv_update_item (cf::UPD_NAME, $item);
37
38 1
39}
40 6
41sub who_listing(;$$) { 7sub who_listing(;$$) {
42 my ($privileged, $select) = @_; 8 my ($privileged, $select) = @_;
43 9
44 my ($numwiz, $numafk) = (0, 0); 10 my ($numwiz, $numafk) = (0, 0);
68 . ($pl->peaceful ? " [peaceful]" : " [HOSTILE]") 34 . ($pl->peaceful ? " [peaceful]" : " [HOSTILE]")
69 . ($ns->afk ? " [AFK]" : "") 35 . ($ns->afk ? " [AFK]" : "")
70 . ($ob->flag (cf::FLAG_WIZ) ? " [WIZ]" : "") 36 . ($ob->flag (cf::FLAG_WIZ) ? " [WIZ]" : "")
71 . " [" . $pl->ns->version . "]" 37 . " [" . $pl->ns->version . "]"
72 . " [" . ($pl->peaceful || $privileged ? $ob->map->visible_name : $ob->region->name) . "]" 38 . " [" . ($pl->peaceful || $privileged ? $ob->map->visible_name : $ob->region->name) . "]"
73 . (sprintf " [rtt %.3fs]", $pl->ns->rtt * 1e-6) 39 . (sprintf " [rtt %.3fs]", $pl->ns->tcpi_rtt * 1e-6)
74 . ($privileged ? " " . $pl->ns->host : "") 40 . ($privileged ? " " . $pl->ns->host : "")
75 } sort { (lc $a->ob->name) cmp (lc $b->ob->name) } @pl 41 } sort { (lc $a->ob->name) cmp (lc $b->ob->name) } @pl
76 ), 42 ),
77 eval { "* IRC: " . join ", ", ext::irc::users }, 43 eval { "* IRC: " . join ", ", ext::irc::users },
78 ) 44 )
81cf::register_command who => sub { 47cf::register_command who => sub {
82 my ($ob, $arg) = @_; 48 my ($ob, $arg) = @_;
83 49
84 $ob->speed_left ($ob->speed_left - 4); 50 $ob->speed_left ($ob->speed_left - 4);
85 51
86 $ob->reply (undef, (join "\n", who_listing $ob->may ("extended_who"), $arg), cf::NDI_UNIQUE | cf::NDI_DK_ORANGE); 52 my $CHANNEL = {
53 id => "who",
54 title => "Players",
55 reply => undef,
56 tooltip => "Shows players who are currently online",
57 };
87 58
88 1 59 $ob->send_msg ($CHANNEL => (join "\n\n", who_listing $ob->may ("extended_who"), $arg), cf::NDI_DK_ORANGE | cf::NDI_REPLY | cf::NDI_CLEAR | cf::NDI_DEF);
89}; 60};
90 61
91cf::register_command seen => sub { 62cf::register_command seen => sub {
92 my ($pl, $args) = @_; 63 my ($pl, $args) = @_;
93 64
94 if (my ($login) = $args =~ /(\S+)/) { 65 if (my ($login) = $args =~ /(\S+)/) {
95 if ($login eq $pl->name) { 66 if ($login eq $pl->name) {
96 $pl->message ("Very funny, $login. Ha. Ha.", cf::NDI_UNIQUE); 67 $pl->message ("Very funny, $login. Ha. Ha.", cf::NDI_REPLY);
97 } elsif (cf::player::find_active $login) { 68 } elsif (cf::player::find_active $login) {
98 $pl->message ("$login is right here on this server!", cf::NDI_UNIQUE); 69 $pl->message ("$login is right here on this server!", cf::NDI_REPLY);
99 } elsif (cf::player::exists $login 70 } elsif (cf::player::exists $login
100 and stat cf::player::path $login) { 71 and stat cf::player::path $login) {
101 my $time = (stat _)[9]; 72 my $time = (stat _)[9];
102 73
103 $pl->message ("$login was last seen here " 74 $pl->message ("$login was last seen here "
104 . (POSIX::strftime "%Y-%m-%d %H:%M:%S +0000", gmtime $time) 75 . (POSIX::strftime "%Y-%m-%d %H:%M:%S +0000", gmtime $time)
105 . " which was " . (int +(time - $time) / 3600) . " hours ago.", cf::NDI_UNIQUE); 76 . " which was " . (int +(time - $time) / 3600) . " hours ago.", cf::NDI_REPLY);
106 } else { 77 } else {
107 $pl->message ("No player named $login is known to me.", cf::NDI_UNIQUE); 78 $pl->message ("No player named $login is known to me.", cf::NDI_REPLY);
108 } 79 }
109 } else { 80 } else {
110 $pl->message ("Usage: seen <player>", cf::NDI_UNIQUE); 81 $pl->message ("Usage: seen <player>", cf::NDI_REPLY);
111 } 82 }
112}; 83};
113 84
114cf::register_command body => sub { 85cf::register_command body => sub {
115 my ($ob) = @_; 86 my ($ob) = @_;
132 $reply .= "You are not allowed to wear armor\n\n" 103 $reply .= "You are not allowed to wear armor\n\n"
133 unless $ob->flag (cf::FLAG_USE_ARMOUR); 104 unless $ob->flag (cf::FLAG_USE_ARMOUR);
134 $reply .= "You are not allowed to use weapons\n\n" 105 $reply .= "You are not allowed to use weapons\n\n"
135 unless $ob->flag (cf::FLAG_USE_WEAPON); 106 unless $ob->flag (cf::FLAG_USE_WEAPON);
136 107
137 $ob->reply (undef, $reply); 108 my $CHANNEL = {
109 id => "body",
110 title => "Body Parts",
111 reply => undef,
112 tooltip => "Shows which body parts you posess and are available",
113 };
138 114
139 1 115 $ob->send_msg ($CHANNEL => $reply, cf::NDI_REPLY);
140}; 116};
141 117
142cf::register_command mark => sub { 118cf::register_command mark => sub {
143 my ($pl, $arg) = @_; 119 my ($pl, $arg) = @_;
144 120
155 131
156 $pl->reply (undef, $ob 132 $pl->reply (undef, $ob
157 ? (sprintf "%s %s * is marked.", $ob->name, $ob->title) 133 ? (sprintf "%s %s * is marked.", $ob->name, $ob->title)
158 : "You have no marked object."); 134 : "You have no marked object.");
159 } 135 }
160
161 1
162}; 136};
163 137
164for my $cmd ("run", "fire") { 138for my $cmd ("run", "fire") {
165 my $oncmd = "${cmd}_on"; 139 my $oncmd = "${cmd}_on";
166 cf::register_command $cmd => sub { 140 cf::register_command $cmd => sub {
169 $ob->reply (undef, "Can't $cmd into a non adjacent square.") 143 $ob->reply (undef, "Can't $cmd into a non adjacent square.")
170 if $arg < 0 or $arg >= 9; 144 if $arg < 0 or $arg >= 9;
171 145
172 $ob->contr->$oncmd (1); 146 $ob->contr->$oncmd (1);
173 $ob->move_player ($arg); 147 $ob->move_player ($arg);
174
175 1
176 }; 148 };
177 149
178 cf::register_command "${cmd}_stop" => sub { 150 cf::register_command "${cmd}_stop" => sub {
179 my ($ob) = @_; 151 my ($ob) = @_;
180 152
181 $ob->contr->$oncmd (0); 153 $ob->contr->$oncmd (0);
182
183 1
184 }; 154 };
185} 155}
186 156
157our $MAPINFO_CHANNEL = {
158 id => "mapinfo",
159 title => "Map Info",
160 reply => undef,
161 tooltip => "Information about the map",
162};
163
187cf::register_command mapinfo => sub { 164cf::register_command mapinfo => sub {
188 my ($ob) = @_; 165 my ($ob) = @_;
189 166
190 $ob = $ob->contr->observe; 167 my $observe = $ob->contr->observe;
191 168
192 my $map = $ob->map 169 my $map = $observe->map
193 or return; 170 or return;
171
194 $ob->reply (undef, (sprintf "%s (%s) %s", $map->name, $map->path, $ob->region->longname)); 172 my $msg = sprintf "%s (%s) %s", $map->name, $map->path, $observe->region->longname;
195 $ob->reply (undef, (sprintf "players: %d difficulty: %d size: %d start: %dx%d timeout: %d", 173 $msg .= sprintf "\n\nplayers: %d difficulty: %d size: %d start: %dx%d timeout: %d",
196 (scalar $map->players), $map->difficulty, $map->width, $map->height, $map->enter_x, $map->enter_y, $map->timeout)) 174 (scalar $map->players), $map->difficulty, $map->width, $map->height, $map->enter_x, $map->enter_y, $map->timeout
197 if $ob->flag (cf::FLAG_WIZ); 175 if $ob->flag (cf::FLAG_WIZ);
198 $ob->reply (undef, $map->msg);
199 176
200 1 177 $ob->send_msg ($MAPINFO_CHANNEL => $msg, cf::NDI_REPLY | cf::NDI_CLEAR);
201}; 178};
202 179
203cf::register_command whereami => sub { 180cf::register_command whereami => sub {
204 my ($ob) = @_; 181 my ($ob) = @_;
205 182
206 my $reg = $ob->contr->observe->region; 183 my $reg = $ob->contr->observe->region;
207 $ob->reply (undef, (sprintf "You are %s.\n%s", $reg->longname, $reg->msg)); 184 $ob->send_msg ($MAPINFO_CHANNEL => (sprintf "You are %s.\n%s", $reg->longname, $reg->msg), cf::NDI_REPLY | cf::NDI_CLEAR);
185};
208 186
187cf::register_command whereabouts => sub {
188 my ($ob, $arg) = @_;
189
190 my %count;
191
192 for my $pl (cf::player::list) {
193 ++$count{$pl->ob->region->longname};
209 1 194 }
195
196 my $msg = "In the world currently there are:\n\n"
197 . join "", map "$count{$_} player(s) $_\n\n", sort keys %count;
198
199 $ob->send_msg ($MAPINFO_CHANNEL => $msg, cf::NDI_REPLY | cf::NDI_CLEAR);
200};
201
202cf::register_command hiscore => sub {
203 my ($ob, $arg) = @_;
204
205 my $url = $cf::CFG{hiscore_url};
206 $ob->send_msg (log => "See $url", cf::NDI_REPLY);
210}; 207};
211 208
212sub _set_mode($$$@) { 209sub _set_mode($$$@) {
213 my ($name, $ob, $arg, $slot, @choices) = @_; 210 my ($name, $ob, $arg, $slot, @choices) = @_;
214 211
226 223
227cf::register_command applymode => sub { 224cf::register_command applymode => sub {
228 my ($ob, $arg) = @_; 225 my ($ob, $arg) = @_;
229 226
230 _set_mode "applymode", $ob, $arg, unapply => qw(nochoice never always); 227 _set_mode "applymode", $ob, $arg, unapply => qw(nochoice never always);
231
232 1
233}; 228};
234 229
235cf::register_command petmode => sub { 230cf::register_command petmode => sub {
236 my ($ob, $arg) = @_; 231 my ($ob, $arg) = @_;
237 232
238 _set_mode "petmode", $ob, $arg, petmode => qw(normal sad defend arena); 233 _set_mode "petmode", $ob, $arg, petmode => qw(normal sad defend arena);
239
240 1
241}; 234};
242 235
243cf::register_command usekeys => sub { 236cf::register_command usekeys => sub {
244 my ($ob, $arg) = @_; 237 my ($ob, $arg) = @_;
245 238
246 _set_mode "usekeys", $ob, $arg, usekeys => qw(inventory keyrings containers); 239 _set_mode "usekeys", $ob, $arg, usekeys => qw(inventory keyrings containers);
247
248 1
249}; 240};
250 241
251cf::register_command hintmode => sub { 242cf::register_command hintmode => sub {
252 my ($ob, $arg) = @_; 243 my ($ob, $arg) = @_;
253 244
254 _set_mode "hintmode", $ob, $arg, hintmode => qw(show mark hide); 245 _set_mode "hintmode", $ob, $arg, hintmode => qw(show mark hide);
255
256 1
257}; 246};
258 247
259cf::register_command afk => sub { 248cf::register_command afk => sub {
260 my ($ob, $arg) = @_; 249 my ($ob, $arg) = @_;
261 250
262 $ob->contr->ns->afk ($ob->contr->ns->afk ? 0 : 1); 251 $ob->contr->ns->afk ($ob->contr->ns->afk ? 0 : 1);
263 $ob->reply (undef, $ob->contr->ns->afk ? "You are now AFK" : "You are no longer AFK"); 252 $ob->reply (undef, $ob->contr->ns->afk ? "You are now AFK" : "You are no longer AFK");
264
265 1
266}; 253};
267 254
268cf::register_command sound => sub { 255cf::register_command sound => sub {
269 my ($ob, $arg) = @_; 256 my ($ob, $arg) = @_;
270 257
271 $ob->contr->ns->sound ($ob->contr->ns->sound ? 0 : 1); 258 $ob->contr->ns->sound ($ob->contr->ns->sound ? 0 : 1);
272 $ob->reply (undef, $ob->contr->ns->sound ? "The sounds are enabled." : "Silence is golden..."); 259 $ob->reply (undef, $ob->contr->ns->sound ? "The sounds are enabled." : "Silence is golden...");
273
274 1
275}; 260};
276 261
277cf::register_command brace => sub { 262cf::register_command brace => sub {
278 my ($ob, $arg) = @_; 263 my ($ob, $arg) = @_;
279 264
280 $ob->contr->braced ($ob->contr->braced ? 0 : 1); 265 $ob->contr->braced ($ob->contr->braced ? 0 : 1);
281 $ob->reply (undef, $ob->contr->braced ? "You are braced." : "Not braced."); 266 $ob->reply (undef, $ob->contr->braced ? "You are braced." : "Not braced.");
282
283 1
284}; 267};
285 268
286cf::register_command 'output-rate' => sub { 269cf::register_command 'output-rate' => sub {
287 my ($ob, $arg) = @_; 270 my ($ob, $arg) = @_;
288 271
289 return $ob->reply (undef, sprintf "Output rate is presently %dbps.", $ob->contr->ns->max_rate / $cf::TICK) 272 return $ob->reply (undef, sprintf "Output rate is presently %dbps.", $ob->contr->ns->max_rate / $cf::TICK)
290 unless $arg > 0; 273 unless $arg > 0;
291 274
292 # minimum is 5k/s 275 # minimum is 5k/s
276 # maximum is 100k/s, this should be configurable
293 $ob->contr->ns->max_rate ((List::Util::max 5000, $arg) * $cf::TICK); 277 $ob->contr->ns->max_rate ((List::Util::max 5000, List::Util::min 100000, $arg) * $cf::TICK);
294 $ob->reply (undef, sprintf "Output rate now set to %dbps.", $ob->contr->ns->max_rate / $cf::TICK); 278 $ob->reply (undef, sprintf "Output rate now set to %dbps.", $ob->contr->ns->max_rate / $cf::TICK);
295
296 1
297}; 279};
298 280
299cf::register_command 'output-count' => sub { 281cf::register_command 'output-count' => sub {
300 my ($ob, $arg) = @_; 282 my ($ob, $arg) = @_;
301 283
304 286
305 $arg = 4 if $arg < 4; 287 $arg = 4 if $arg < 4;
306 288
307 $ob->contr->outputs_count ($arg); 289 $ob->contr->outputs_count ($arg);
308 $ob->reply (undef, "Output count now set to " . $ob->contr->outputs_count); 290 $ob->reply (undef, "Output count now set to " . $ob->contr->outputs_count);
309
310 1
311}; 291};
312 292
313cf::register_command 'output-sync' => sub { 293cf::register_command 'output-sync' => sub {
314 my ($ob, $arg) = @_; 294 my ($ob, $arg) = @_;
315 295
318 298
319 $arg = 0.5 if $arg < 0.5; 299 $arg = 0.5 if $arg < 0.5;
320 300
321 $ob->contr->outputs_sync ($arg / $cf::TICK); 301 $ob->contr->outputs_sync ($arg / $cf::TICK);
322 $ob->reply (undef, sprintf "Output sync time now set to %.1fs", $ob->contr->outputs_sync * $cf::TICK); 302 $ob->reply (undef, sprintf "Output sync time now set to %.1fs", $ob->contr->outputs_sync * $cf::TICK);
323
324 1
325}; 303};
326 304
327# XXX: This has a bug. After one sets his wimpy level to 0 and resets it to 305# XXX: This has a bug. After one sets his wimpy level to 0 and resets it to
328# some other level (which may also be 0), this does not get echoed, 306# some other level (which may also be 0), this does not get echoed,
329# but it does get set. 307# but it does get set.
336 314
337 return $ob->run_away ($arg) && $ob->reply (undef, "Your new wimpy level is $arg.") 315 return $ob->run_away ($arg) && $ob->reply (undef, "Your new wimpy level is $arg.")
338 if $arg =~ /^\d+$/ and $arg <= 100; 316 if $arg =~ /^\d+$/ and $arg <= 100;
339 317
340 $ob->reply (undef, "Incorrect parameters for wimpy: $arg"); 318 $ob->reply (undef, "Incorrect parameters for wimpy: $arg");
341
342 1
343}; 319};
344 320
345cf::register_command peaceful => sub { 321cf::register_command peaceful => sub {
346 my ($ob, $arg) = @_; 322 my ($ob, $arg) = @_;
347 323
350 ." if you want to become hostile or in temple of Valriel" 326 ." if you want to become hostile or in temple of Valriel"
351 ." if you want to become peaceful again."); 327 ." if you want to become peaceful again.");
352 328
353 #$ob->contr->peaceful ($ob->contr->peaceful ? 0 : 1); 329 #$ob->contr->peaceful ($ob->contr->peaceful ? 0 : 1);
354 #$ob->reply (undef, $ob->contr->peaceful ? "You will attack other players." : "You will not attack other players."); 330 #$ob->reply (undef, $ob->contr->peaceful ? "You will attack other players." : "You will not attack other players.");
331};
355 332
333sub rename_to($$$) {
334 my ($ob, $from, $to) = @_;
335
336 $to =~ /^[a-zA-Z0-9.,=#\/%$!^ ]*$/
337 or return $ob->message ("rename: name must consist only of letters, digits, spaces and a few other things.");
338
339 127 >= length $to
340 or return $ob->message ("rename: new name must be <= 127 characters.");
341
342 my $item;
343
344 if (length $from) {
345 $item = $ob->find_best_object_match ($from)
346 or return $ob->message ("rename: could not find a matching item to rename.");
347 } else {
348 $item = $ob->find_marked_object
349 or return $ob->message ("rename: no from name and no marked item found to rename.");
350 }
351
352 $item->custom_name (length $to ? $to : undef);
353
354 if (length $to) {
355 $item->custom_name ($to);
356 $ob->message ("Your " . $item->base_name . " will now be called $to.");
357 } else {
358 $item->custom_name (undef);
359 $ob->message ("You stop calling your " . $item->base_name . " with weird names.");
360 }
361
362 $ob->esrv_update_item (cf::UPD_NAME, $item);
363
356 1 364 1
357}; 365}
358 366
359cf::register_command rename => sub { 367cf::register_command rename => sub {
360 my ($ob, $arg) = @_; 368 my ($ob, $arg) = @_;
361 369
362 $ob->speed_left ($ob->speed_left - 0.25); 370 $ob->speed_left ($ob->speed_left - 0.25);
376 # does not unquote $1 or $3 384 # does not unquote $1 or $3
377 rename_to $ob, $2||$1, $4||$3; 385 rename_to $ob, $2||$1, $4||$3;
378 } else { 386 } else {
379 $ob->reply (undef, 'Syntax error. Rename usage: rename ["oldname"] to "newname"'); 387 $ob->reply (undef, 'Syntax error. Rename usage: rename ["oldname"] to "newname"');
380 } 388 }
381
382 1
383}; 389};
384 390
385cf::register_command uptime => sub { 391cf::register_command uptime => sub {
386 my ($ob, $arg) = @_; 392 my ($ob, $arg) = @_;
387 393
388 my $startup = POSIX::strftime "%Y-%m-%d %H:%M:%S %Z", localtime $cf::UPTIME; 394 my $startup = POSIX::strftime "%Y-%m-%d %H:%M:%S %Z", localtime $cf::UPTIME;
389 my $runtime = sprintf "%.1f", (time - $cf::UPTIME) / 86400; 395 my $runtime = sprintf "%.1f", (time - $cf::UPTIME) / 86400;
390 $ob->reply (undef, "server started $startup, uptime ${runtime}\d"); 396 $ob->send_msg (log => "server started $startup, uptime ${runtime}\d", cf::NDI_REPLY);
391
392 1
393}; 397};
394 398
395my %IN_MEMORY = ( 399my %IN_MEMORY = (
396 cf::MAP_IN_MEMORY => "I", 400 cf::MAP_IN_MEMORY => "I",
397 cf::MAP_SWAPPED => "S", 401 cf::MAP_SWAPPED => "S",
403 407
404 no re 'eval'; $arg = qr<$arg>; 408 no re 'eval'; $arg = qr<$arg>;
405 409
406 my $format = "%2s %1s %3s %5s %.60s\n"; 410 my $format = "%2s %1s %3s %5s %.60s\n";
407 411
408 $ob->reply (undef, (sprintf $format, "Pl", "I", "Svd", "Reset", "Name"), cf::NDI_BLACK | cf::NDI_UNIQUE); 412 $ob->send_msg ($MAPINFO_CHANNEL => (sprintf $format, "Pl", "I", "Svd", "Reset", "Name"), cf::NDI_REPLY | cf::NDI_CLEAR);
409 413
410 for (sort keys %cf::MAP) { 414 for (sort keys %cf::MAP) {
411 my $map = $cf::MAP{$_} 415 my $map = $cf::MAP{$_}
412 or next; 416 or next;
413 417
415 next if $map->{deny_list}; 419 next if $map->{deny_list};
416 420
417 my $svd = int $cf::RUNTIME - $map->{last_save}; 421 my $svd = int $cf::RUNTIME - $map->{last_save};
418 $svd = "++" if $svd > 99; 422 $svd = "++" if $svd > 99;
419 423
420 $ob->reply (undef, 424 $ob->send_msg ($MAPINFO_CHANNEL =>
421 (sprintf $format, 425 (sprintf $format,
422 (scalar $map->players), 426 (scalar $map->players),
423 $IN_MEMORY{$map->in_memory} || "?", 427 $IN_MEMORY{$map->in_memory} || "?",
424 $svd, 428 $svd,
425 (int $map->reset_at - $cf::RUNTIME), 429 (int $map->reset_at - $cf::RUNTIME),
426 $map->visible_name), 430 $map->visible_name)
427 cf::NDI_BLACK | cf::NDI_UNIQUE); 431 );
428 }
429
430 1 432 }
431}; 433};
432 434

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines