NAME

Net::Curl::Simple::Async - perform Net::Curl requests asynchronously

SYNOPSIS

use Net::Curl::Simple;
use Net::Curl::Simple::Async;

# this does not block now
Net::Curl::Simple->new()->get( $uri, \&finished );
Net::Curl::Simple->new()->get( $uri2, \&finished );

# block until all requests are finished, may not be needed
Net::Curl::Simple::Async::loop();

sub finished
{
    my ( $curl, $result ) = @_;
    print "document body: $curl->{body}\n";
}

DESCRIPTION

If you use Net::Curl::Simple::Async your Net::Curl::Simple objects will no longer block.

If your code is using Net::Curl::Simple correctly (that is - processing any finished requests in callbacks), the only change needed to add asynchronous support is adding:

use Net::Curl::Simple::Async;

It will pick up best Async backend automatically. However, you may force some backends if you don't like the one detected:

use Irssi;
# Irssi backend would be picked
use Net::Curl::Simple::Async qw(AnyEvent POE);

You may need to call loop() function if your code does not provide any suitable looping mechanism.

FUNCTIONS

loop

Block until all requests are complete. Some backends may not support it. Most backends don't need it.

can_asynchdns

Will tell you whether libcurl has AsyncDNS capability.

warn_noasynchdns

Function used to warn about lack of AsynchDNS. You can overwrite it if you hate the warning.

{
    no warnings;
    # don't warn at all
    *Net::Curl::Simple::Async::warn_noasynchdns = sub ($) { };
}

Lack of AsynchDNS support in libcurl can severely reduce Net::Curl::Simple::Async efficiency. You should not disable the warning, just replace it with a method more suitable in your application.

BACKENDS

In order of preference (Net::Curl::Simple::Async will try them it that order):

EV

Awesome and very efficient. Use it whenever you can.

Irssi

Will be used if Irssi has been loaded. Does not support loop(), the function will issue a warning and won't block.

AnyEvent

Will be used if AnyEvent has been loaded. In most cases you will already have a looping mechanism on your own, but you can call loop() if you don't need anything better.

POE

Used under POE, only if no other backend could be detected. Slooow, avoid it. If you're using POE try POE::Loop::EV.

Select

Direct loop implementation using perl's builtin select. Will be used if no other backend has been found. You must call loop() to get anything done.

SEE ALSO

Net::Curl::Simple::UserAgent Net::Curl::Simple::Async Net::Curl::Easy

COPYRIGHT

Copyright (c) 2011 Przemyslaw Iskra <sparky at pld-linux.org>.

This program is free software; you can redistribute it and/or modify it under the same terms as perl itself.