… | |
… | |
29 | reload_archetypes & |
29 | reload_archetypes & |
30 | ext::help::reload & |
30 | ext::help::reload & |
31 | ext::books::reload & |
31 | ext::books::reload & |
32 | ext::map_tags::reload & |
32 | ext::map_tags::reload & |
33 | ext::map_world::reload & |
33 | ext::map_world::reload & |
|
|
34 | print JSON::XS->new->pretty->encode({cf::mallinfo}) |
34 | EOF |
35 | EOF |
35 | print $fh "\n> "; |
36 | print $fh "\n> "; |
36 | |
37 | |
37 | Event->io (fd => $fh, poll => 'r', data => 0, cb => sub { |
38 | my $iow; $iow = EV::io $fh, EV::READ, sub { |
38 | if (defined (my $cmd = <$fh>)) { |
39 | if (defined (my $cmd = <$fh>)) { |
39 | $cmd =~ s/\s+$//; |
40 | $cmd =~ s/\s+$//; |
40 | |
41 | |
41 | if ($cmd =~ /^\s*exit\b/i) { |
42 | if ($cmd =~ /^\s*exit\b/i) { |
42 | print $fh "will not exit() server.\n"; |
43 | print $fh "will not exit() server.\n"; |
… | |
… | |
77 | } |
78 | } |
78 | } |
79 | } |
79 | |
80 | |
80 | print $fh "\n> "; |
81 | print $fh "\n> "; |
81 | } else { |
82 | } else { |
82 | $_[0]->w->cancel; |
83 | undef $iow; |
83 | } |
84 | } |
84 | }); |
85 | }; |
85 | } |
86 | } |
|
|
87 | |
|
|
88 | our $LISTENER; |
86 | |
89 | |
87 | # now a shell listening on a tcp-port - let the firewall decide access rights |
90 | # now a shell listening on a tcp-port - let the firewall decide access rights |
88 | if ($cf::CFG{perl_shell}) { |
91 | if ($cf::CFG{perl_shell}) { |
89 | if (my $listen = new IO::Socket::INET LocalAddr => $cf::CFG{perl_shell}, Listen => 1, ReuseAddr => 1) { |
92 | if (my $listen = new IO::Socket::INET LocalAddr => $cf::CFG{perl_shell}, Listen => 1, ReuseAddr => 1, Blocking => 0) { |
90 | Event->io (fd => $listen, poll => 'r', data => cf::WF_AUTOCANCEL, cb => sub { tcp_serve $listen->accept }); |
93 | $LISTENER = EV::io $listen, EV::READ, sub { tcp_serve $listen->accept }; |
91 | } |
94 | } |
92 | } |
95 | } |
93 | |
96 | |
94 | |
97 | |