… | |
… | |
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 | # ext::map_scheduler::loadall & # debugging only! |
|
|
35 | while (EV::TIMEOUT & Coro::EV::timed_io_once \$fh, EV::READ, 1) { Coro::Debug::command "ps" } & |
|
|
36 | ({cf::mallinfo}) |
35 | EOF |
37 | EOF |
36 | print $fh "\n> "; |
38 | print $fh "\n> "; |
37 | |
39 | |
38 | my $iow; $iow = EV::io $fh, EV::READ, sub { |
40 | my $iow; $iow = EV::io $fh, EV::READ, sub { |
39 | if (defined (my $cmd = <$fh>)) { |
41 | if (defined (my $cmd = <$fh>)) { |
… | |
… | |
48 | } else { |
50 | } else { |
49 | my $sub = sub { |
51 | my $sub = sub { |
50 | package cf; |
52 | package cf; |
51 | select $fh; |
53 | select $fh; |
52 | |
54 | |
53 | # compile first, the execute, as Coro does not support switching in eval string |
55 | # compile first, then execute, as Coro does not support switching in eval string |
54 | my $cb = eval "sub { $cmd \n}"; |
56 | my $cb = eval "sub { $cmd \n}"; |
55 | |
57 | |
56 | my $t1 = Time::HiRes::time; |
58 | my $t1 = Time::HiRes::time; |
57 | my @res = $@ ? () : eval { $cb->() }; |
59 | my @res = $@ ? () : eval { $cb->() }; |
58 | my $t2 = Time::HiRes::time; |
60 | my $t2 = Time::HiRes::time; |