2 // This file is part of Moodle - http://moodle.org/
4 // Moodle is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
9 // Moodle is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
14 // You should have received a copy of the GNU General Public License
15 // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
18 * Calculated multiple-choice question definition class.
21 * @subpackage calculatedmulti
22 * @copyright 2011 The Open University
23 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
27 defined('MOODLE_INTERNAL') || die();
29 require_once($CFG->dirroot . '/question/type/multichoice/question.php');
30 require_once($CFG->dirroot . '/question/type/calculated/question.php');
34 * Represents a calculated multiple-choice multiple-response question.
36 * @copyright 2011 The Open University
37 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
39 class qtype_calculatedmulti_single_question extends qtype_multichoice_single_question
40 implements qtype_calculated_question_with_expressions {
42 /** @var qtype_calculated_dataset_loader helper for loading the dataset. */
43 public $datasetloader;
45 /** @var qtype_calculated_variable_substituter stores the dataset we are using. */
49 * @var bool wheter the dataset item to use should be chose based on attempt
50 * start time, rather than randomly.
54 public function start_attempt(question_attempt_step $step, $variant) {
55 qtype_calculated_question_helper::start_attempt($this, $step, $variant);
56 parent::start_attempt($step, $variant);
59 public function apply_attempt_state(question_attempt_step $step) {
60 qtype_calculated_question_helper::apply_attempt_state($this, $step);
61 parent::apply_attempt_state($step);
64 public function calculate_all_expressions() {
65 qtype_calculatedmulti_calculate_helper::calculate_all_expressions($this);
69 public function get_num_variants() {
70 return $this->datasetloader->get_number_of_items();
73 public function get_variants_selection_seed() {
74 if (!empty($this->synchronised) &&
75 $this->datasetloader->datasets_are_synchronised($this->category)) {
76 return 'category' . $this->category;
78 return parent::get_variants_selection_seed();
85 * Represents a calculated multiple-choice multiple-response question.
87 * @copyright 2011 The Open University
88 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
90 class qtype_calculatedmulti_multi_question extends qtype_multichoice_multi_question
91 implements qtype_calculated_question_with_expressions {
93 /** @var qtype_calculated_dataset_loader helper for loading the dataset. */
94 public $datasetloader;
96 /** @var qtype_calculated_variable_substituter stores the dataset we are using. */
100 * @var bool wheter the dataset item to use should be chose based on attempt
101 * start time, rather than randomly.
103 public $synchronised;
105 public function start_attempt(question_attempt_step $step, $variant) {
106 qtype_calculated_question_helper::start_attempt($this, $step, $variant);
107 parent::start_attempt($step, $variant);
110 public function apply_attempt_state(question_attempt_step $step) {
111 qtype_calculated_question_helper::apply_attempt_state($this, $step);
112 parent::apply_attempt_state($step);
115 public function calculate_all_expressions() {
116 qtype_calculatedmulti_calculate_helper::calculate_all_expressions($this);
122 * Helper to abstract common code between qtype_calculatedmulti_single_question
123 * and qtype_calculatedmulti_multi_question.
125 * @copyright 2011 The Open University
126 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
128 abstract class qtype_calculatedmulti_calculate_helper {
130 * Calculate all the exressions in a qtype_calculatedmulti_single_question
131 * or qtype_calculatedmulti_multi_question.
132 * @param unknown_type $question
134 public static function calculate_all_expressions(
135 qtype_calculated_question_with_expressions $question) {
136 $question->questiontext = $question->vs->replace_expressions_in_text(
137 $question->questiontext);
138 $question->generalfeedback = $question->vs->replace_expressions_in_text(
139 $question->generalfeedback);
141 foreach ($question->answers as $ans) {
142 if ($ans->answer && $ans->answer !== '*') {
143 $ans->answer = $question->vs->replace_expressions_in_text($ans->answer,
144 $ans->correctanswerlength, $ans->correctanswerformat);
146 $ans->feedback = $question->vs->replace_expressions_in_text($ans->feedback,
147 $ans->correctanswerlength, $ans->correctanswerformat);