… | |
… | |
6 | use IO::AIO; |
6 | use IO::AIO; |
7 | |
7 | |
8 | BEGIN { |
8 | BEGIN { |
9 | use XSLoader; |
9 | use XSLoader; |
10 | |
10 | |
11 | $VERSION = '1.1'; |
11 | $VERSION = '1.3'; |
12 | |
12 | |
13 | XSLoader::load "Gtk2::CV", $VERSION; |
13 | XSLoader::load "Gtk2::CV", $VERSION; |
14 | } |
14 | } |
15 | |
15 | |
16 | my $aio_source; |
16 | my $aio_source; |
17 | |
17 | |
|
|
18 | IO::AIO::min_parallel 32; |
|
|
19 | |
18 | # we use a low priority to give GUI interactions as high a priority |
20 | # we use a low priority watcher to give GUI interactions as high a priority |
19 | # as possible. |
21 | # as possible. |
20 | sub enable_aio { |
22 | sub enable_aio { |
21 | $aio_source ||= |
23 | $aio_source ||= |
22 | add_watch Glib::IO IO::AIO::poll_fileno, |
24 | add_watch Glib::IO IO::AIO::poll_fileno, |
23 | in => sub { IO::AIO::poll_cb; 1 }, |
25 | in => sub { |
24 | undef, |
26 | eval { IO::AIO::poll_some 64 }; |
|
|
27 | warn $@ if $q;#d# |
|
|
28 | 1 |
|
|
29 | }, |
|
|
30 | undef, |
25 | &Glib::G_PRIORITY_LOW; |
31 | &Glib::G_PRIORITY_LOW; |
26 | } |
32 | } |
27 | |
33 | |
28 | sub disable_aio { |
34 | sub disable_aio { |
29 | remove Glib::Source $aio_source if $aio_source; |
35 | remove Glib::Source $aio_source if $aio_source; |
30 | undef $aio_source; |
36 | undef $aio_source; |
31 | } |
37 | } |
32 | |
38 | |
33 | enable_aio; |
39 | enable_aio; |
34 | IO::AIO::max_outstanding 128; |
|
|
35 | |
40 | |
36 | sub find_rcfile($) { |
41 | sub find_rcfile($) { |
37 | my $path; |
42 | my $path; |
38 | |
43 | |
39 | for (@INC) { |
44 | for (@INC) { |