Hi,
This includes several patches I needed, which are attached.
[PATCH 1/3] Add $request as parameter to callback function:
Currently it is not possible to know, which request finished in the callback as the URL might not be the same due to 301 and is not unique anyway.
By providing the request to the callback this is changed and allows a very flexible implementation.
I also changed Request class name to be more RollingCurl specific as it is else cluttering the namespace.
[PATCH 2/3] Add rolling curl group:
This is an implementation using the power of OO programming by extending rolling curl to allow finishing groups of requests, which allows priotizing and also giving back feedback, when each group is finished.
The usage is really easy:
Inheriting from the base class allows processing of groups and requests directly from the class:
Test Class
class TestCurlRequest extends RollingCurlGroupRequest { public $test_verbose = false;
function process($output, $info)
{
echo "Processing " . $this->url . "\n";
if ($this->test_verbose)
print_r($info);
parent::process($output, $info);
}
}
class TestCurlGroup extends RollingCurlGroup {
function process($output, $info, $request)
{
echo "Group CB: Progress " . $this->name . " (" . ($this->finished_requests+1) . "/" . $this->num_requests . ")\n";
parent::process($output, $info, $request);
}
function finished()
{
echo "Group CB: Finished " . $group->name . "\n";
parent::finished();
}
}
Main function:
$group = new TestCurlGroup("High");
$group->add(new TestCurlRequest("www.google.de"));
$group->add(new TestCurlRequest("www.yahoo.de"));
$group->add(new TestCurlRequest("www.newyorktimes.com"));
$reqs[] = $group;
$group = new TestCurlGroup("Normal");
$group->add(new TestCurlRequest("twitter.com"));
$group->add(new TestCurlRequest("www.bing.com"));
$group->add(new TestCurlRequest("m.facebook.com"));
$reqs[] = $group;
$reqs[] = new TestCurlRequest("www.kernel.org");
$rc = new GroupRollingCurl(); /* Note: No callback here, as its done in Request class*/
foreach ($reqs as $req)
$rc->add($req);
$rc->window_size = $window_size;
return $rc->execute();
Due to the power of polymorphism, the same function (add) can be used for adding requests and groups of requests.
The "callback" in request and groups is:
process($output, $info)
and
process($request, $output, $info)
Also finished is available for groups.
[PATCH 3/3] Allow custom options to overwrite default ones
Issue #12 fixed in a patch. Dependent on patches before.
Hope you enjoy!
Please apply.
The patches are also available in the master branch of my fork of rolling-curl at github:
http://github.com/LionsAd/rolling-curl
Best Wishes,
Fabian (LionsAd)
Comment #1
Posted on Aug 5, 2010 by Swift Rhino[PATCH] Add __destruct function to RollingCurlRequest.
Ooops, forgot one patch.
Here it is. Else it gives an error that the __destruct function is not defined.
Comment #2
Posted on Sep 12, 2010 by Massive Cat(No comment was entered for this change.)
Status: Fixed
Labels:
Type-Defect
Priority-Medium