… | |
… | |
38 | 1 |
38 | 1 |
39 | } |
39 | } |
40 | |
40 | |
41 | sub ext::schmorp_irc::users; # HACK: TODO: replace by signal |
41 | sub ext::schmorp_irc::users; # HACK: TODO: replace by signal |
42 | |
42 | |
43 | sub who_listing(;$) { |
43 | sub who_listing(;$$) { |
44 | my ($privileged) = @_; |
44 | my ($privileged, $select) = @_; |
45 | |
45 | |
46 | my ($numwiz, $numafk) = (0, 0); |
46 | my ($numwiz, $numafk) = (0, 0); |
47 | my @pl; |
47 | my @pl; |
48 | |
48 | |
49 | foreach my $pl (cf::player::list) { |
49 | foreach my $pl (cf::player::list) { |
… | |
… | |
59 | push @pl, $pl; |
59 | push @pl, $pl; |
60 | } |
60 | } |
61 | |
61 | |
62 | ( |
62 | ( |
63 | "Total Players in The World. (" . (scalar @pl) . ") -- WIZ($numwiz) AFK($numafk) BOT(0)", |
63 | "Total Players in The World. (" . (scalar @pl) . ") -- WIZ($numwiz) AFK($numafk) BOT(0)", |
64 | ( |
64 | (grep /$select/, |
65 | map { |
65 | map { |
66 | my ($pl, $ob, $ns) = ($_, $_->ob, $_->ns); |
66 | my ($pl, $ob, $ns) = ($_, $_->ob, $_->ns); |
67 | |
67 | |
68 | "* " . $ob->name . "/" . $ob->level . " " . (length $pl->own_title ? $pl->own_title : "the " . $pl->title) |
68 | "* " . $ob->name . "/" . $ob->level . " " . (length $pl->own_title ? $pl->own_title : "the " . $pl->title) |
69 | . ($pl->peaceful ? " [peaceful]" : " [HOSTILE]") |
69 | . ($pl->peaceful ? " [peaceful]" : " [HOSTILE]") |
70 | . ($ns->afk ? " [AFK]" : "") |
70 | . ($ns->afk ? " [AFK]" : "") |
71 | . ($ob->flag (cf::FLAG_WIZ) ? " [WIZ]" : "") |
71 | . ($ob->flag (cf::FLAG_WIZ) ? " [WIZ]" : "") |
72 | . " [" . $pl->ns->version . "]" |
72 | . " [" . $pl->ns->version . "]" |
73 | . " [" . ($pl->peaceful || $privileged ? $ob->map->visible_name : $ob->region->name) . "]" |
73 | . " [" . ($pl->peaceful || $privileged ? $ob->map->visible_name : $ob->region->name) . "]" |
74 | . (sprintf " [rtt %.3fs]", $pl->ns->rtt * 1e-6) |
74 | . (sprintf " [rtt %.3fs]", $pl->ns->rtt * 1e-6) |
75 | . ($privileged ? " " . $pl->ns->host : "") |
75 | . ($privileged ? " " . $pl->ns->host : "") |
76 | } sort { (lc $a->ob->name) cmp (lc $b->ob->name) } @pl |
76 | } sort { (lc $a->ob->name) cmp (lc $b->ob->name) } @pl |
77 | ), |
77 | ), |
78 | eval { "* IRC: " . join ", ", ext::schmorp_irc::users }, |
78 | eval { "* IRC: " . join ", ", ext::schmorp_irc::users }, |
79 | ) |
79 | ) |
80 | } |
80 | } |
81 | |
81 | |
82 | cf::register_command who => sub { |
82 | cf::register_command who => sub { |
83 | my ($ob, $arg) = @_; |
83 | my ($ob, $arg) = @_; |
84 | |
84 | |
85 | $ob->speed_left ($ob->speed_left - 0.25); |
85 | $ob->speed_left ($ob->speed_left - 4); |
86 | |
86 | |
87 | $ob->reply (undef, (join "\n", who_listing $ob->may ("extended_who")), cf::NDI_UNIQUE | cf::NDI_DK_ORANGE); |
87 | $ob->reply (undef, (join "\n", who_listing $ob->may ("extended_who"), $arg), cf::NDI_UNIQUE | cf::NDI_DK_ORANGE); |
88 | |
88 | |
89 | 1 |
89 | 1 |
90 | }; |
90 | }; |
91 | |
91 | |
92 | cf::register_command seen => sub { |
92 | cf::register_command seen => sub { |
… | |
… | |
289 | my ($ob, $arg) = @_; |
289 | my ($ob, $arg) = @_; |
290 | |
290 | |
291 | return $ob->reply (undef, "Output count is presently " . $ob->contr->outputs_count) |
291 | return $ob->reply (undef, "Output count is presently " . $ob->contr->outputs_count) |
292 | unless $arg > 0; |
292 | unless $arg > 0; |
293 | |
293 | |
|
|
294 | $arg = 4 if $arg < 4; |
|
|
295 | |
294 | $ob->contr->outputs_count ($arg); |
296 | $ob->contr->outputs_count ($arg); |
295 | $ob->reply (undef, "Output count now set to " . $ob->contr->outputs_count); |
297 | $ob->reply (undef, "Output count now set to " . $ob->contr->outputs_count); |
296 | |
298 | |
297 | 1 |
299 | 1 |
298 | }; |
300 | }; |
… | |
… | |
300 | cf::register_command 'output-sync' => sub { |
302 | cf::register_command 'output-sync' => sub { |
301 | my ($ob, $arg) = @_; |
303 | my ($ob, $arg) = @_; |
302 | |
304 | |
303 | return $ob->reply (undef, sprintf "Output sync time is presently %.1fs", $ob->contr->outputs_sync * $cf::TICK) |
305 | return $ob->reply (undef, sprintf "Output sync time is presently %.1fs", $ob->contr->outputs_sync * $cf::TICK) |
304 | unless length $arg; |
306 | unless length $arg; |
|
|
307 | |
|
|
308 | $arg = 0.5 if $arg < 0.5; |
305 | |
309 | |
306 | $ob->contr->outputs_sync ($arg / $cf::TICK); |
310 | $ob->contr->outputs_sync ($arg / $cf::TICK); |
307 | $ob->reply (undef, sprintf "Output sync time now set to %.1fs", $ob->contr->outputs_sync * $cf::TICK); |
311 | $ob->reply (undef, sprintf "Output sync time now set to %.1fs", $ob->contr->outputs_sync * $cf::TICK); |
308 | |
312 | |
309 | 1 |
313 | 1 |