NAME
    "IO::Async::Loop::AnyEvent" - use "IO::Async" with "AnyEvent"

SYNOPSIS
     use IO::Async::Loop::AnyEvent;

     my $loop = IO::Async::Loop::AnyEvent->new();

     $loop->add( ... );

     $loop->add( IO::Async::Signal->new(
           name => 'HUP',
           on_receipt => sub { ... },
     ) );

     $loop->loop_forever();

DESCRIPTION
    This subclass of IO::Async::Loop uses AnyEvent to perform its work.

CONSTRUCTOR
  $loop = IO::Async::Loop::AnyEvent->new
    This function returns a new instance of a "IO::Async::Loop::AnyEvent"
    object.

BUGS
    *   "watch_idle" and "unwatch_idle" don't work properly against
        "AnyEvent::Impl::IOAsync". At least, the unit tests fail, and some
        scheduled CODErefs never get executed, and sit in the internal queue
        of the inner-nested "IO::Async::Loop" that "AnyEvent::Impl::IOAsync"
        itself constructed. An easy workaround here is simply to pick
        another AnyEvent model, by using the "PERL_ANYEVENT_MODEL"
        environment variable.

        That all said, I am honestly surprised this is the only thing that
        breaks, when "IO::Async" is nested upon "AnyEvent" itself running
        atop another "IO::Async".

    *   The implementation of the "loop_once" method requires the use of an
        undocumented "AnyEvent" method ("one_event" before version 6,
        "_poll" thereafter). This happens to work at the time of writing,
        but as it is undocumented it may be subject to change.

        The "loop_forever" method does not rely on this undocumented method,
        so should be safe from upstream changes. Furthremore, if "AnyEvent"
        rather than "IO::Async" remains ultimately in control of the
        runtime, by waiting on condvars, this should not be problematic.

AUTHOR
    Paul Evans <leonerd@leonerd.org.uk>