NAME
    `IO::Async::Loop::Ppoll' - use `IO::Async' with `ppoll(2)'

SYNOPSIS
     use IO::Async::Loop::Ppoll;

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

     $loop->add( ... );

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

     $loop->loop_forever();

DESCRIPTION
    This subclass of `IO::Async::Loop::Poll' uses an `IO::Ppoll' object
    instead of a `IO::Poll' to perform read-ready and write-ready tests so
    that they can be mixed with signal handling.

    The `ppoll()' system call atomically switches the process's signal mask,
    performs a wait exactly as `poll()' would, then switches it back. This
    allows a process to block the signals it cares about, but switch in an
    empty signal mask during the poll, allowing it to handle file IO and
    signals concurrently.

CONSTRUCTOR
  $loop = IO::Async::Loop::Ppoll->new( %args )
    This function returns a new instance of a `IO::Async::Loop::Ppoll'
    object. It takes the following named arguments:

    `poll'  The `IO::Ppoll' object to use for notification. Optional; if a
            value is not given, a new `IO::Ppoll' object will be
            constructed.

METHODS
    As this is a subclass of IO::Async::Loop::Poll, all of its methods are
    inherited. Expect where noted below, all of the class's methods behave
    identically to `IO::Async::Loop::Poll'.

  $count = $loop->loop_once( $timeout )
    This method calls the `poll()' method on the stored `IO::Ppoll' object,
    passing in the value of `$timeout', and processes the results of that
    call. It returns the total number of `IO::Async::Notifier' callbacks
    invoked, or `undef' if the underlying `poll()' method returned an error.
    If the `poll()' was interrupted by a signal, then 0 is returned instead.

SEE ALSO
    *   IO::Ppoll - Object interface to Linux's `ppoll()' call

    *   IO::Async::Loop::Poll - a set using an `IO::Poll' object

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