--- deliantra/server/ext/dmcommands.ext 2007/03/01 20:20:05 1.16 +++ deliantra/server/ext/dmcommands.ext 2007/09/19 21:56:30 1.23 @@ -1,7 +1,30 @@ -#! perl +#! perl # mandatory # wizard commands +cf::register_command shutdown => sub { + my ($ob, $arg) = @_; + return $ob->reply (undef, "Sorry, you can't shutdown the server.") + unless $ob->flag (cf::FLAG_WIZ); + + my $name = $ob->name; + cf::cleanup ("dm '$name' initiated shutdown" . ($arg ? " with reason: $arg" : "."), 0); + + 1 +}; + +cf::register_command kick => sub { + my ($ob, $arg) = @_; + return unless $ob->flag (cf::FLAG_WIZ); + + my $other = cf::player::find_active $arg + or return 0; + $other->kick ($ob); + $ob->reply (undef, "$arg is kicked out of the game.", cf::NDI_UNIQUE | cf::NDI_ALL | cf::NDI_RED); + + 1 +}; + cf::register_command goto => sub { my ($ob, $arg) = @_; @@ -20,6 +43,8 @@ return unless $ob->may ("command_teleport"); cf::async { + $Coro::current->{desc} = "teleport $arg"; + my $other = cf::player::find $arg or return $ob->reply (undef, "$arg: no such player."); @@ -70,7 +95,7 @@ return unless $ob->may ("command_wizlook"); - $ob->clear_los; + $ob->contr->clear_los; $ob->reply (undef, "You can temporarily see through walls."); @@ -88,6 +113,7 @@ $_->enter_link for @pl; cf::async { my $name = $map->visible_name; + $Coro::current->{desc} = "reset $name"; $map->reset; $_->leave_link for @pl; @@ -98,7 +124,18 @@ 1 }; -for my $command (qw(summon arrest kick banish)) { +cf::register_command observe => sub { + my ($ob, $arg) = @_; + + return unless $ob->may ("command_observe"); + + my $other = cf::player::find_active $arg; + $ob->contr->set_observe ($other ? $other->ob : undef); + + 1 +}; + +for my $command (qw(summon arrest banish)) { my $method = "command_$command"; cf::register_command $command => sub {