… | |
… | |
87 | use Async::Interrupt (); |
87 | use Async::Interrupt (); |
88 | |
88 | |
89 | use base 'EV::Loop'; |
89 | use base 'EV::Loop'; |
90 | |
90 | |
91 | BEGIN { |
91 | BEGIN { |
92 | our $VERSION = '0.02'; |
92 | our $VERSION = '0.04'; |
93 | |
93 | |
94 | require XSLoader; |
94 | require XSLoader; |
95 | XSLoader::load ("EV::Loop::Async", $VERSION); |
95 | XSLoader::load ("EV::Loop::Async", $VERSION); |
96 | } |
96 | } |
97 | |
97 | |
… | |
… | |
186 | my ($class, $flags, @asy) = @_; |
186 | my ($class, $flags, @asy) = @_; |
187 | |
187 | |
188 | my $self = bless $class->SUPER::new ($flags), $class; |
188 | my $self = bless $class->SUPER::new ($flags), $class; |
189 | my ($c_func, $c_arg) = _c_func $self; |
189 | my ($c_func, $c_arg) = _c_func $self; |
190 | my $asy = new Async::Interrupt @asy, c_cb => [$c_func, $c_arg]; |
190 | my $asy = new Async::Interrupt @asy, c_cb => [$c_func, $c_arg]; |
191 | $self->_attach ($asy, $asy->signal_func); |
191 | _attach $self, $asy, $asy->signal_func; |
192 | |
192 | |
193 | $self |
193 | $self |
194 | } |
194 | } |
195 | |
195 | |
196 | =item $loop->notify |
196 | =item $loop->notify |
… | |
… | |
256 | file descriptors. To improve latency and performance, you can ask |
256 | file descriptors. To improve latency and performance, you can ask |
257 | C<EV::Loop::Async> to loop an additional number of times in the foreground |
257 | C<EV::Loop::Async> to loop an additional number of times in the foreground |
258 | after invoking the callbacks, effectively doing the polling in the |
258 | after invoking the callbacks, effectively doing the polling in the |
259 | foreground. |
259 | foreground. |
260 | |
260 | |
261 | The default is C<0>, meaning thatno foreground polling will be done. A |
261 | The default is C<0>, meaning that no foreground polling will be done. A |
262 | value of C<1> means that, after handling the pending events, it will call |
262 | value of C<1> means that, after handling the pending events, it will call |
263 | C<< $loop->loop (EV::LOOP_NONBLOCK) >> and handle the resulting events, if |
263 | C<< $loop->loop (EV::LOOP_NONBLOCK) >> and handle the resulting events, if |
264 | any. A value of C<2> means that this will be iterated twice. |
264 | any. A value of C<2> means that this will be iterated twice. |
265 | |
265 | |
266 | When a foreground event poll does not yield any new events, then no |
266 | When a foreground event poll does not yield any new events, then no |
267 | further iterations will be made, so this is only a I<maximum> value of |
267 | further iterations will be made, so this is only a I<maximum> value of |
268 | additional loop runs. |
268 | additional loop runs. |
269 | |
269 | |
|
|
270 | Take also note of the standard EV C<set_io_collect_interval> |
|
|
271 | functionality, which can achieve a similar, but different, effect - YMMV. |
|
|
272 | |
270 | =back |
273 | =back |
271 | |
274 | |
272 | =head1 SEE ALSO |
275 | =head1 SEE ALSO |
273 | |
276 | |
274 | L<EV>, L<Async::Interrupt>. |
277 | L<EV>, L<Async::Interrupt>. |