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.3 by root, Sun Dec 17 14:46:45 2006 UTC vs.
Revision 1.10 by root, Mon Jan 1 17:50:26 2007 UTC

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) {
50 my $ns = $pl->ns or next;
50 my $ob = $pl->ob; 51 my $ob = $pl->ob;
51 52
52 next unless $ob->map 53 next unless $ob->map
53 && ($privileged || !$pl->hidden); 54 && ($privileged || !$pl->hidden);
54 55
55 $numwiz++ if $ob->flag (cf::FLAG_WIZ); 56 $numwiz++ if $ob->flag (cf::FLAG_WIZ);
56 $numafk++ if $ob->flag (cf::FLAG_AFK); 57 $numafk++ if $ns->afk;
57 58
58 push @pl, $pl; 59 push @pl, $pl;
59 } 60 }
60 61
61 ( 62 (
62 "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)",
63 ( 64 (
64 map { 65 map {
65 my ($pl, $ob) = ($_, $_->ob); 66 my ($pl, $ob, $ns) = ($_, $_->ob, $_->ns);
66 67
67 "* " . $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)
68 . ($pl->peaceful ? " [peaceful]" : " [HOSTILE]") 69 . ($pl->peaceful ? " [peaceful]" : " [HOSTILE]")
69 . ($ob->flag (cf::FLAG_AFK) ? " [AFK]" : "") 70 . ($ns->afk ? " [AFK]" : "")
70 . ($ob->flag (cf::FLAG_WIZ) ? " [WIZ]" : "") 71 . ($ob->flag (cf::FLAG_WIZ) ? " [WIZ]" : "")
71 . " [" . $pl->socket->version . "]" 72 . " [" . $pl->ns->version . "]"
72 . " [" . ($pl->peaceful || $privileged ? $ob->map->path : $ob->map->region ? $ob->map->region->name : "the unknown") . "]" 73 . " [" . ($pl->peaceful || $privileged ? $ob->map->{path}->visible_name : $ob->map->region ? $ob->map->region->name : "the unknown") . "]"
73 . (sprintf " [rtt %.3fs]", $pl->socket->rtt * 1e-6) 74 . (sprintf " [rtt %.3fs]", $pl->ns->rtt * 1e-6)
74 . ($privileged ? " " . $pl->socket->host : "") 75 . ($privileged ? " " . $pl->ns->host : "")
75 } sort { (lc $a->ob->name) cmp (lc $b->ob->name) } @pl 76 } sort { (lc $a->ob->name) cmp (lc $b->ob->name) } @pl
76 ), 77 ),
77 eval { "* IRC: " . join ", ", ext::schmorp_irc::users }, 78 eval { "* IRC: " . join ", ", ext::schmorp_irc::users },
78 ) 79 )
79} 80}
122 $ob->reply (undef, "server started $startup, uptime ${runtime}\d"); 123 $ob->reply (undef, "server started $startup, uptime ${runtime}\d");
123 124
124 1 125 1
125}; 126};
126 127
128my %IN_MEMORY = (
129 cf::MAP_IN_MEMORY => "I",
130 cf::MAP_SWAPPED => "S",
131 cf::MAP_LOADING => "L",
132);
133
134cf::register_command maps => sub {
135 my ($ob, $arg) = @_;
136
137 no re 'eval'; $arg = qr<$arg>;
138
139 my $format = "%2s %1s %3s %5s %-60.60s\n";
140
141 my $msg = sprintf $format, "Pl", "I", "Svd", "Reset", "Name";
142
143 for (sort keys %cf::MAP) {
144 my $map = $cf::MAP{$_}
145 or next;
146
147 next unless $map->path =~ $arg;
148
149 my $svd = int $cf::RUNTIME - $map->{last_save};
150 $svd = "++" if $svd > 99;
151
152 $msg .= sprintf $format,
153 (scalar $map->players),
154 $IN_MEMORY{$map->in_memory} || "?",
155 $svd,
156 (int $map->reset_at - $cf::RUNTIME),
157 $map->{path}->visible_name;
158 }
159
160 $ob->reply (undef, $msg);
161
162 1
163};
164

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines