diff options
| author | Bharat Mediratta <bharat@menalto.com> | 2008-11-20 02:59:43 +0000 |
|---|---|---|
| committer | Bharat Mediratta <bharat@menalto.com> | 2008-11-20 02:59:43 +0000 |
| commit | 611627231b6a712053e05734d7509b1d3751151b (patch) | |
| tree | 84ef749090c5d43582b9b93f02b50104176a6d17 /core | |
| parent | c3fc1cb7ec91783a7953486c8a83aa8008dd5406 (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.php | 30 |
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 */ |
