summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrew Dolgov <[email protected]>2013-05-01 21:06:48 +0400
committerAndrew Dolgov <[email protected]>2013-05-01 21:06:48 +0400
commitb4d1690097946bdf89dc88f218e7790126f4fd3b (patch)
tree29ff67cd5aabb724103599632570a4f627a3cd34
parentf11015058d6e313d3cabc3d3edc0230a5b6b4c26 (diff)
move common methods to feeditem_common
-rw-r--r--classes/feeditem.php2
-rw-r--r--classes/feeditem/atom.php44
-rw-r--r--classes/feeditem/common.php48
-rw-r--r--classes/feeditem/rss.php43
4 files changed, 51 insertions, 86 deletions
diff --git a/classes/feeditem.php b/classes/feeditem.php
index cc39fcee7..e64a13fdc 100644
--- a/classes/feeditem.php
+++ b/classes/feeditem.php
@@ -1,5 +1,5 @@
<?php
-class FeedItem {
+abstract class FeedItem {
abstract function get_id();
abstract function get_date();
abstract function get_link();
diff --git a/classes/feeditem/atom.php b/classes/feeditem/atom.php
index 1a9db9020..df1c31d99 100644
--- a/classes/feeditem/atom.php
+++ b/classes/feeditem/atom.php
@@ -1,13 +1,5 @@
<?php
-class FeedItem_Atom {
- private $elem;
- private $xpath;
-
- function __construct($elem, $doc, $xpath) {
- $this->elem = $elem;
- $this->xpath = $xpath;
- }
-
+class FeedItem_Atom extends FeedItem_Common {
function get_id() {
$id = $this->elem->getElementsByTagName("id")->item(0);
@@ -60,19 +52,6 @@ class FeedItem_Atom {
}
}
- // todo
- function get_comments_url() {
-
- }
-
- function get_comments_count() {
- $comments = $this->xpath->query("slash:comments", $this->elem)->item(0);
-
- if ($comments) {
- return $comments->nodeValue;
- }
- }
-
function get_categories() {
$categories = $this->elem->getElementsByTagName("category");
$cats = array();
@@ -125,26 +104,5 @@ class FeedItem_Atom {
return $encs;
}
- function get_author() {
- $author = $this->elem->getElementsByTagName("author")->item(0);
-
- if ($author) {
- $name = $author->getElementsByTagName("name")->item(0);
-
- if ($name) return $name->nodeValue;
-
- $email = $author->getElementsByTagName("email")->item(0);
-
- if ($email) return $email->nodeValue;
-
- }
-
- $author = $this->xpath->query("dc:creator", $this->elem)->item(0);
-
- if ($author) {
- return $author->nodeValue;
- }
-
- }
}
?>
diff --git a/classes/feeditem/common.php b/classes/feeditem/common.php
new file mode 100644
index 000000000..fca9433a4
--- /dev/null
+++ b/classes/feeditem/common.php
@@ -0,0 +1,48 @@
+<?php
+abstract class FeedItem_Common extends FeedItem {
+ protected $elem;
+ protected $xpath;
+ protected $doc;
+
+ function __construct($elem, $doc, $xpath) {
+ $this->elem = $elem;
+ $this->xpath = $xpath;
+ $this->doc = $doc;
+ }
+
+ function get_author() {
+ $author = $this->elem->getElementsByTagName("author")->item(0);
+
+ if ($author) {
+ $name = $author->getElementsByTagName("name")->item(0);
+
+ if ($name) return $name->nodeValue;
+
+ $email = $author->getElementsByTagName("email")->item(0);
+
+ if ($email) return $email->nodeValue;
+ }
+
+ $author = $this->xpath->query("dc:creator", $this->elem)->item(0);
+
+ if ($author) {
+ return $author->nodeValue;
+ }
+ }
+
+ // todo
+ function get_comments_url() {
+
+ }
+
+ function get_comments_count() {
+ $comments = $this->xpath->query("slash:comments", $this->elem)->item(0);
+
+ if ($comments) {
+ return $comments->nodeValue;
+ }
+ }
+
+
+}
+?>
diff --git a/classes/feeditem/rss.php b/classes/feeditem/rss.php
index 9e54a9c09..29c8cb6b4 100644
--- a/classes/feeditem/rss.php
+++ b/classes/feeditem/rss.php
@@ -1,13 +1,5 @@
<?php
-class FeedItem_RSS {
- private $elem;
- private $xpath;
-
- function __construct($elem, $doc, $xpath) {
- $this->elem = $elem;
- $this->xpath = $xpath;
- }
-
+class FeedItem_RSS extends FeedItem_Common {
function get_id() {
$id = $this->elem->getElementsByTagName("guid")->item(0);
@@ -58,19 +50,6 @@ class FeedItem_RSS {
}
}
- // todo
- function get_comments_url() {
-
- }
-
- function get_comments_count() {
- $comments = $this->xpath->query("slash:comments", $this->elem)->item(0);
-
- if ($comments) {
- return $comments->nodeValue;
- }
- }
-
function get_categories() {
$categories = $this->elem->getElementsByTagName("category");
$cats = array();
@@ -118,25 +97,5 @@ class FeedItem_RSS {
return $encs;
}
- function get_author() {
- $author = $this->elem->getElementsByTagName("author")->item(0);
-
- if ($author) {
- $name = $author->getElementsByTagName("name")->item(0);
-
- if ($name) return $name->nodeValue;
-
- $email = $author->getElementsByTagName("email")->item(0);
-
- if ($email) return $email->nodeValue;
- }
-
- $author = $this->xpath->query("dc:creator", $this->elem)->item(0);
-
- if ($author) {
- return $author->nodeValue;
- }
-
- }
}
?>