Merge pull request #83 from kythyria/master
A slight fix for the Penny Arcade plugin
This commit is contained in:
commit
ae6d8b658b
1 changed files with 42 additions and 12 deletions
|
@ -5,7 +5,7 @@ class Af_PennyArcade extends Plugin {
|
||||||
private $host;
|
private $host;
|
||||||
|
|
||||||
function about() {
|
function about() {
|
||||||
return array(1.0,
|
return array(1.1,
|
||||||
"Strip unnecessary stuff from PA feeds",
|
"Strip unnecessary stuff from PA feeds",
|
||||||
"fox");
|
"fox");
|
||||||
}
|
}
|
||||||
|
@ -22,25 +22,22 @@ class Af_PennyArcade extends Plugin {
|
||||||
|
|
||||||
if (strpos($article["link"], "penny-arcade.com") !== FALSE && strpos($article["title"], "Comic:") !== FALSE) {
|
if (strpos($article["link"], "penny-arcade.com") !== FALSE && strpos($article["title"], "Comic:") !== FALSE) {
|
||||||
if (strpos($article["plugin_data"], "pennyarcade,$owner_uid:") === FALSE) {
|
if (strpos($article["plugin_data"], "pennyarcade,$owner_uid:") === FALSE) {
|
||||||
|
|
||||||
|
if ($debug_enabled) {
|
||||||
|
_debug("af_pennyarcade: Processing comic");
|
||||||
|
}
|
||||||
|
|
||||||
$doc = new DOMDocument();
|
$doc = new DOMDocument();
|
||||||
@$doc->loadHTML(fetch_file_contents($article["link"]));
|
$doc->loadHTML(fetch_file_contents($article["link"]));
|
||||||
|
|
||||||
$basenode = false;
|
$basenode = false;
|
||||||
|
|
||||||
if ($doc) {
|
if ($doc) {
|
||||||
$xpath = new DOMXPath($doc);
|
$xpath = new DOMXPath($doc);
|
||||||
$entries = $xpath->query('(//img[@src])'); // we might also check for img[@class='strip'] I guess...
|
$entries = $xpath->query('(//div[@class="post comic"])');
|
||||||
|
|
||||||
$matches = array();
|
|
||||||
|
|
||||||
foreach ($entries as $entry) {
|
foreach ($entries as $entry) {
|
||||||
|
$basenode = $entry;
|
||||||
if (preg_match("/(http:\/\/art.penny-arcade.com\/.*)/i", $entry->getAttribute("src"), $matches)) {
|
|
||||||
|
|
||||||
$basenode = $entry;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($basenode) {
|
if ($basenode) {
|
||||||
|
@ -52,6 +49,39 @@ class Af_PennyArcade extends Plugin {
|
||||||
$article["content"] = $article["stored"]["content"];
|
$article["content"] = $article["stored"]["content"];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (strpos($article["link"], "penny-arcade.com") !== FALSE && strpos($article["title"], "News Post:") !== FALSE) {
|
||||||
|
if (strpos($article["plugin_data"], "pennyarcade,$owner_uid:") === FALSE) {
|
||||||
|
if ($debug_enabled) {
|
||||||
|
_debug("af_pennyarcade: Processing news post");
|
||||||
|
}
|
||||||
|
$doc = new DOMDocument();
|
||||||
|
$doc->loadHTML(fetch_file_contents($article["link"]));
|
||||||
|
|
||||||
|
if ($doc) {
|
||||||
|
$xpath = new DOMXPath($doc);
|
||||||
|
$entries = $xpath->query('(//div[@class="post"])');
|
||||||
|
|
||||||
|
$basenode = false;
|
||||||
|
|
||||||
|
foreach ($entries as $entry) {
|
||||||
|
$basenode = $entry;
|
||||||
|
}
|
||||||
|
|
||||||
|
$uninteresting = $xpath->query('(//div[@class="heading"])');
|
||||||
|
foreach ($uninteresting as $i) {
|
||||||
|
$i->parentNode->removeChild($i);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($basenode){
|
||||||
|
$article["content"] = $doc->saveXML($basenode);
|
||||||
|
$article["plugin_data"] = "pennyarcade,$owner_uid:" . $article["plugin_data"];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (isset($article["stored"]["content"])) {
|
||||||
|
$article["content"] = $article["stored"]["content"];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return $article;
|
return $article;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue