1 | #! perl |
1 | #! perl # MANDATORY |
2 | |
2 | |
3 | use POSIX (); |
3 | use POSIX (); |
4 | |
4 | |
5 | # miscellaneous commands |
5 | # miscellaneous commands |
6 | |
6 | |
… | |
… | |
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 |
|
|
90 | }; |
|
|
91 | |
|
|
92 | cf::register_command seen => sub { |
|
|
93 | my ($pl, $args) = @_; |
|
|
94 | |
|
|
95 | if (my ($login) = $args =~ /(\S+)/) { |
|
|
96 | if ($login eq $pl->name) { |
|
|
97 | $pl->message ("Very funny, $login. Ha. Ha.", cf::NDI_UNIQUE); |
|
|
98 | } elsif (cf::player::find_active $login) { |
|
|
99 | $pl->message ("$login is right here on this server!", cf::NDI_UNIQUE); |
|
|
100 | } elsif (cf::player::exists $login |
|
|
101 | and stat cf::player::path $login) { |
|
|
102 | my $time = (stat _)[9]; |
|
|
103 | |
|
|
104 | $pl->message ("$login was last seen here " |
|
|
105 | . (POSIX::strftime "%Y-%m-%d %H:%M:%S +0000", gmtime $time) |
|
|
106 | . " which was " . (int +(time - $time) / 3600) . " hours ago.", cf::NDI_UNIQUE); |
|
|
107 | } else { |
|
|
108 | $pl->message ("No player named $login is known to me.", cf::NDI_UNIQUE); |
|
|
109 | } |
|
|
110 | } else { |
|
|
111 | $pl->message ("Usage: seen <player>", cf::NDI_UNIQUE); |
89 | 1 |
112 | } |
90 | }; |
113 | }; |
91 | |
114 | |
92 | cf::register_command body => sub { |
115 | cf::register_command body => sub { |
93 | my ($ob) = @_; |
116 | my ($ob) = @_; |
94 | |
117 | |
… | |
… | |
116 | }; |
139 | }; |
117 | |
140 | |
118 | cf::register_command mark => sub { |
141 | cf::register_command mark => sub { |
119 | my ($pl, $arg) = @_; |
142 | my ($pl, $arg) = @_; |
120 | |
143 | |
121 | unless (length $arg) { |
144 | if (length $arg) { |
|
|
145 | my $ob = $pl->find_best_object_match ($arg); |
|
|
146 | |
|
|
147 | return $pl->reply (undef, "Could not find an object that matches $arg") |
|
|
148 | unless $ob; |
|
|
149 | |
|
|
150 | $pl->contr->mark ($ob); |
|
|
151 | $pl->reply (undef, (sprintf "Marked item %s", $ob->name, $ob->title)); |
|
|
152 | } else { |
122 | my $ob = $pl->find_marked_object; |
153 | my $ob = $pl->find_marked_object; |
123 | |
154 | |
124 | $pl->reply (undef, $ob |
155 | $pl->reply (undef, $ob |
125 | ? (sprintf "%s %s * is marked.", $ob->name, $ob->title) |
156 | ? (sprintf "%s %s * is marked.", $ob->name, $ob->title) |
126 | : "You have no marked object."); |
157 | : "You have no marked object."); |
127 | } else { |
|
|
128 | my $ob = $pl->find_best_object_match ($arg); |
|
|
129 | |
|
|
130 | return $pl->reply (undef, "Could not find an object that matches $arg") |
|
|
131 | unless $ob; |
|
|
132 | |
|
|
133 | $pl->contr->mark ($ob); |
|
|
134 | $pl->reply (undef, (sprintf "Marked item %s", $ob->name, $ob->title)); |
|
|
135 | } |
|
|
136 | |
|
|
137 | 1 |
158 | } |
138 | }; |
|
|
139 | |
|
|
140 | cf::register_command who => sub { |
|
|
141 | my ($ob, $arg) = @_; |
|
|
142 | |
|
|
143 | $ob->speed_left ($ob->speed_left - 0.25); |
|
|
144 | |
|
|
145 | $ob->reply (undef, (join "\n", who_listing $ob->may ("extended_who")), cf::NDI_UNIQUE | cf::NDI_DK_ORANGE); |
|
|
146 | |
159 | |
147 | 1 |
160 | 1 |
148 | }; |
161 | }; |
149 | |
162 | |
150 | for my $cmd ("run", "fire") { |
163 | for my $cmd ("run", "fire") { |
151 | my $oncmd = "${cmd}_on"; |
164 | my $oncmd = "${cmd}_on"; |
152 | cf::register_command $cmd => sub { |
165 | cf::register_command $cmd => sub { |
153 | my ($ob, $arg) = @_; |
166 | my ($ob, $arg) = @_; |
154 | |
167 | |
155 | return $ob->reply (undef, "Can't $cmd into a non adjacent square.") |
168 | $ob->reply (undef, "Can't $cmd into a non adjacent square.") |
156 | if $arg < 0 or $arg >= 9; |
169 | if $arg < 0 or $arg >= 9; |
157 | |
170 | |
158 | $ob->contr->$oncmd (1); |
171 | $ob->contr->$oncmd (1); |
159 | $ob->move ($arg); |
172 | $ob->move_player ($arg); |
160 | |
173 | |
161 | 1 |
174 | 1 |
162 | }; |
175 | }; |
163 | |
176 | |
164 | cf::register_command "${cmd}_stop" => sub { |
177 | cf::register_command "${cmd}_stop" => sub { |
165 | my ($ob) = @_; |
178 | my ($ob) = @_; |
166 | |
179 | |
167 | $ob->contr->$oncmd (0); |
180 | $ob->contr->$oncmd (0); |
168 | |
181 | |
… | |
… | |
257 | $ob->reply (undef, $ob->contr->braced ? "You are braced." : "Not braced."); |
270 | $ob->reply (undef, $ob->contr->braced ? "You are braced." : "Not braced."); |
258 | |
271 | |
259 | 1 |
272 | 1 |
260 | }; |
273 | }; |
261 | |
274 | |
|
|
275 | cf::register_command 'output-rate' => sub { |
|
|
276 | my ($ob, $arg) = @_; |
|
|
277 | |
|
|
278 | return $ob->reply (undef, sprintf "Output rate is presently %dbps.", $ob->contr->ns->max_rate / $cf::TICK) |
|
|
279 | unless $arg > 0; |
|
|
280 | |
|
|
281 | # minimum is 2k/s |
|
|
282 | $ob->contr->ns->max_rate ((List::Util::max 2048, $arg) * $cf::TICK); |
|
|
283 | $ob->reply (undef, sprintf "Output rate now set to %dbps.", $ob->contr->ns->max_rate / $cf::TICK); |
|
|
284 | |
|
|
285 | 1 |
|
|
286 | }; |
|
|
287 | |
262 | cf::register_command 'output-count' => sub { |
288 | cf::register_command 'output-count' => sub { |
263 | my ($ob, $arg) = @_; |
289 | my ($ob, $arg) = @_; |
264 | |
290 | |
265 | 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) |
266 | unless $arg > 0; |
292 | unless $arg > 0; |
267 | |
293 | |
|
|
294 | $arg = 4 if $arg < 4; |
|
|
295 | |
268 | $ob->contr->outputs_count ($arg); |
296 | $ob->contr->outputs_count ($arg); |
269 | $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); |
270 | |
298 | |
271 | 1 |
299 | 1 |
272 | }; |
300 | }; |
273 | |
301 | |
274 | cf::register_command 'output-sync' => sub { |
302 | cf::register_command 'output-sync' => sub { |
275 | my ($ob, $arg) = @_; |
303 | my ($ob, $arg) = @_; |
276 | |
304 | |
277 | return $ob->reply (undef, "Output sync time is presently " . $ob->contr->outputs_sync) |
305 | return $ob->reply (undef, sprintf "Output sync time is presently %.1fs", $ob->contr->outputs_sync * $cf::TICK) |
278 | unless $arg > 0; |
306 | unless length $arg; |
279 | |
307 | |
|
|
308 | $arg = 0.5 if $arg < 0.5; |
|
|
309 | |
280 | $ob->contr->outputs_sync ($arg); |
310 | $ob->contr->outputs_sync ($arg / $cf::TICK); |
281 | $ob->reply (undef, "Output sync time now set to " . $ob->contr->outputs_sync); |
311 | $ob->reply (undef, sprintf "Output sync time now set to %.1fs", $ob->contr->outputs_sync * $cf::TICK); |
282 | |
312 | |
283 | 1 |
313 | 1 |
284 | }; |
314 | }; |
285 | |
315 | |
286 | # XXX: This has a bug. After one sets his wimpy level to 0 and resets it to |
316 | # XXX: This has a bug. After one sets his wimpy level to 0 and resets it to |