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.31 by root, Fri Mar 2 14:44:52 2007 UTC vs.
Revision 1.40 by root, Fri Apr 13 05:32:12 2007 UTC

1#! perl 1#! perl # MANDATORY
2 2
3use POSIX (); 3use POSIX ();
4 4
5# miscellaneous commands 5# miscellaneous commands
6 6
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")), cf::NDI_UNIQUE | cf::NDI_DK_ORANGE);
88 88
89 1 89 1
90}; 90};
91 91
92cf::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);
112 }
113};
114
92cf::register_command body => sub { 115cf::register_command body => sub {
93 my ($ob) = @_; 116 my ($ob) = @_;
94 117
95 my @body_locations = ("in your range slot", "on your arm", "on your body", "on your head", 118 my @body_locations = ("in your range slot", "on your arm", "on your body", "on your head",
96 "around your neck", "in your skill slot", "on your finger", "around your shoulders", 119 "around your neck", "in your skill slot", "on your finger", "around your shoulders",
116}; 139};
117 140
118cf::register_command mark => sub { 141cf::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
140cf::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
150for my $cmd ("run", "fire") { 163for 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
275cf::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
262cf::register_command 'output-count' => sub { 288cf::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;
272}; 298};
273 299
274cf::register_command 'output-sync' => sub { 300cf::register_command 'output-sync' => sub {
275 my ($ob, $arg) = @_; 301 my ($ob, $arg) = @_;
276 302
277 return $ob->reply (undef, "Output sync time is presently " . $ob->contr->outputs_sync) 303 return $ob->reply (undef, sprintf "Output sync time is presently %.1fs", $ob->contr->outputs_sync * $cf::TICK)
278 unless $arg > 0; 304 unless length $arg;
279 305
280 $ob->contr->outputs_sync ($arg); 306 $ob->contr->outputs_sync ($arg / $cf::TICK);
281 $ob->reply (undef, "Output sync time now set to " . $ob->contr->outputs_sync); 307 $ob->reply (undef, sprintf "Output sync time now set to %.1fs", $ob->contr->outputs_sync * $cf::TICK);
282 308
283 1 309 1
284}; 310};
285 311
286# XXX: This has a bug. After one sets his wimpy level to 0 and resets it to 312# XXX: This has a bug. After one sets his wimpy level to 0 and resets it to

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines