summaryrefslogtreecommitdiff
path: root/core
diff options
context:
space:
mode:
authorBharat Mediratta <bharat@menalto.com>2008-11-20 02:59:43 +0000
committerBharat Mediratta <bharat@menalto.com>2008-11-20 02:59:43 +0000
commit611627231b6a712053e05734d7509b1d3751151b (patch)
tree84ef749090c5d43582b9b93f02b50104176a6d17 /core
parentc3fc1cb7ec91783a7953486c8a83aa8008dd5406 (diff)
Clean up the MediaRSS module a little bit:
* Media_RSS_Controller::$LIMIT is now self::$page_size * We use ORM_MPTT descendant_counts() * If the page is out of bounds, put it on a boundary * Move pub_date into the controller to simplify the mrss file * Put all the view assignment in one block for easier reading * Removed stray ; from the end of lines in the mrss file Clean up ORM_MPTT a bit: * fix spelling: decendent -> descendant * Remove unnecessary order_by() clauses * Set the default for $type to null (not "all").
Diffstat (limited to 'core')
-rw-r--r--core/libraries/ORM_MPTT.php30
1 files changed, 14 insertions, 16 deletions
diff --git a/core/libraries/ORM_MPTT.php b/core/libraries/ORM_MPTT.php
index 2a1c257b..5cdf9c02 100644
--- a/core/libraries/ORM_MPTT.php
+++ b/core/libraries/ORM_MPTT.php
@@ -128,10 +128,7 @@ class ORM_MPTT_Core extends ORM {
*/
function children_count() {
if (!isset($this->children_count)) {
- $this->children_count =
- $this->where("parent_id", $this->id)
- ->orderby("id", "ASC")
- ->count_all();
+ $this->children_count = $this->where("parent_id", $this->id)->count_all();
}
return $this->children_count;
}
@@ -144,18 +141,20 @@ class ORM_MPTT_Core extends ORM {
* @param string type to return
* @return object ORM_Iterator
*/
- function decendents($limit=NULL, $offset=0, $type="all") {
+ function descendants($limit=NULL, $offset=0, $type=null) {
// @todo create a unit test
// @todo set up caching in an array; using type=all allows us to cache as decendents[$type]
// @todo needs to take into account the offset and limit as well
$this->where("left >=", $this->left)
->where("right <=", $this->right);
- if ($type != "all") {
+ if ($type) {
$this->where("type", $type);
}
- $descendants =
- $this->orderby("id", "ASC")
- ->find_all($limit, $offset);
+
+ // @todo: make the order column data driven
+ $this->orderby("id", "ASC");
+
+ $descendants = $this->find_all($limit, $offset);
return $descendants;
}
@@ -165,21 +164,20 @@ class ORM_MPTT_Core extends ORM {
* @param string type to count
* @return integer child count
*/
- function decendents_count($type=all) {
+ function descendants_count($type=null) {
// @todo create a unit test
// @todo set up caching in an array;; using type=all allows us to cache as decendents[$type]
$this->where("left >=", $this->left)
- ->where("right <=", $this->right);
- if ($type != "all") {
+ ->where("right <=", $this->right);
+ if ($type) {
$this->where("type", $type);
}
-
+
// @todo does it make sense to order it before counting?
- return $this->orderby("id", "ASC")
- ->count_all();
+ return $this->count_all();
}
-
+
/**
* @see ORM::reload
*/