summaryrefslogtreecommitdiffstats
path: root/vendor/fguillot/picofeed/picofeed
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/fguillot/picofeed/picofeed')
-rwxr-xr-xvendor/fguillot/picofeed/picofeed55
1 files changed, 25 insertions, 30 deletions
diff --git a/vendor/fguillot/picofeed/picofeed b/vendor/fguillot/picofeed/picofeed
index 525331197..23f474613 100755
--- a/vendor/fguillot/picofeed/picofeed
+++ b/vendor/fguillot/picofeed/picofeed
@@ -1,32 +1,35 @@
#!/usr/bin/env php
<?php
-require_once './vendor/autoload.php';
+require_once 'vendor/autoload.php';
use PicoFeed\Reader\Reader;
-use PicoFeed\Logging\Logging;
+use PicoFeed\Logging\Logger;
+use PicoFeed\PicoFeedException;
function get_feed($url, $disable_filtering = false)
{
- $reader = new Reader;
- $reader->download($url);
+ try {
- $parser = $reader->getParser();
+ $reader = new Reader;
+ $resource = $reader->discover($url);
- if ($disable_filtering) {
- $parser->disableContentFiltering();
- }
-
- if ($parser !== false) {
-
- $feed = $parser->execute();
+ $parser = $reader->getParser(
+ $resource->getUrl(),
+ $resource->getContent(),
+ $resource->getEncoding()
+ );
- if ($feed !== false) {
- return $feed;
+ if ($disable_filtering) {
+ $parser->disableContentFiltering();
}
- }
- return false;
+ return $parser->execute();
+ }
+ catch (PicoFeedException $e) {
+ echo 'Exception thrown ===> "'.$e->getMessage().'"'.PHP_EOL;
+ return false;
+ }
}
function get_item($feed, $item_id)
@@ -45,42 +48,34 @@ function get_item($feed, $item_id)
function dump_feed($url)
{
$feed = get_feed($url);
-
- if ($feed === false) {
- die("Unable to fetch the feed\n");
- }
-
echo $feed;
}
function debug_feed($url)
{
get_feed($url);
- print_r(Logging::getMessages());
+ print_r(Logger::getMessages());
}
function dump_item($url, $item_id)
{
$feed = get_feed($url);
- if ($feed === false) {
- die("Unable to fetch the feed\n");
+ if ($feed !== false) {
+ get_item($feed, $item_id);
}
-
- get_item($feed, $item_id);
}
function nofilter_item($url, $item_id)
{
$feed = get_feed($url, true);
- if ($feed === false) {
- die("Unable to fetch the feed\n");
+ if ($feed !== false) {
+ get_item($feed, $item_id);
}
-
- get_item($feed, $item_id);
}
+// Parse command line arguments
if ($argc === 4) {
switch ($argv[1]) {
case 'item':