From 728ff21b9fd6342acc927ab4496f640cd1e7a709 Mon Sep 17 00:00:00 2001 From: Andrew Davis Date: Tue, 15 May 2012 07:46:45 +0700 Subject: [PATCH] MDL-32860 grade: refactored graded_users_iterator --- grade/lib.php | 80 ++++++++++++++++++++++++++++++++++++++------------- 1 file changed, 60 insertions(+), 20 deletions(-) diff --git a/grade/lib.php b/grade/lib.php index 8c969f28994..7f13b7fbf0f 100644 --- a/grade/lib.php +++ b/grade/lib.php @@ -32,16 +32,56 @@ require_once $CFG->libdir.'/gradelib.php'; * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class graded_users_iterator { - public $course; - public $grade_items; - public $groupid; - public $users_rs; - public $grades_rs; - public $gradestack; - public $sortfield1; - public $sortorder1; - public $sortfield2; - public $sortorder2; + + /** + * The couse whose users we are interested in + */ + protected $course; + + /** + * An array of grade items or null if only user data was requested + */ + protected $grade_items; + + /** + * The group ID we are interested in. 0 means all groups. + */ + protected $groupid; + + /** + * A recordset of graded users + */ + protected $users_rs; + + /** + * A recordset of user grades (grade_grade instances) + */ + protected $grades_rs; + + /** + * Array used when moving to next user while iterating through the grades recordset + */ + protected $gradestack; + + /** + * The first field of the users table by which the array of users will be sorted + */ + protected $sortfield1; + + /** + * Should sortfield1 be ASC or DESC + */ + protected $sortorder1; + + /** + * The second field of the users table by which the array of users will be sorted + */ + protected $sortfield2; + + /** + * Should sortfield2 be ASC or DESC + */ + protected $sortorder2; /** * Constructor @@ -54,7 +94,7 @@ class graded_users_iterator { * @param string $sortfield2 The second field of the users table by which the array of users will be sorted * @param string $sortorder2 The order in which the second sorting field will be sorted (ASC or DESC) */ - public function graded_users_iterator($course, $grade_items=null, $groupid=0, + public function __construct($course, $grade_items=null, $groupid=0, $sortfield1='lastname', $sortorder1='ASC', $sortfield2='firstname', $sortorder2='ASC') { $this->course = $course; @@ -70,6 +110,7 @@ class graded_users_iterator { /** * Initialise the iterator + * * @return boolean success */ public function init() { @@ -174,7 +215,7 @@ class graded_users_iterator { * Returns information about the next user * @return mixed array of user info, all grades and feedback or null when no more users found */ - function next_user() { + public function next_user() { if (!$this->users_rs) { return false; // no users present } @@ -238,10 +279,9 @@ class graded_users_iterator { } /** - * Close the iterator, do not forget to call this function. - * @return void + * Close the iterator, do not forget to call this function */ - function close() { + public function close() { if ($this->users_rs) { $this->users_rs->close(); $this->users_rs = null; @@ -255,23 +295,23 @@ class graded_users_iterator { /** - * _push + * Add a grade_grade instance to the grade stack * * @param grade_grade $grade Grade object * * @return void */ - function _push($grade) { + private function _push($grade) { array_push($this->gradestack, $grade); } /** - * _pop + * Remove a grade_grade instance from the grade stack * - * @return object current grade object + * @return grade_grade current grade object */ - function _pop() { + private function _pop() { global $DB; if (empty($this->gradestack)) { if (empty($this->grades_rs) || !$this->grades_rs->valid()) {