1 <?php 2 // This file is part of Moodle - http://moodle.org/ 3 // 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. 8 // 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. 13 // 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/>. 16 17 /** 18 * Backup code for the gapselect question type. 19 * @package qtype_gapselect 20 * @copyright 2011 The Open University 21 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later 22 */ 23 24 25 defined('MOODLE_INTERNAL') || die(); 26 27 28 /** 29 * Provides the information to backup gapselect questions. 30 * 31 * @copyright 2011 The Open University 32 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later 33 */ 34 class backup_qtype_gapselect_plugin extends backup_qtype_plugin { 35 36 /** 37 * Returns the qtype information to attach to question element. 38 */ 39 protected function define_question_plugin_structure() { 40 41 // Define the virtual plugin element with the condition to fulfill. 42 $plugin = $this->get_plugin_element(null, '../../qtype', 'gapselect'); 43 44 // Create one standard named plugin element (the visible container). 45 $pluginwrapper = new backup_nested_element($this->get_recommended_name()); 46 47 // Connect the visible container ASAP. 48 $plugin->add_child($pluginwrapper); 49 50 // This qtype uses standard question_answers, add them here 51 // to the tree before any other information that will use them. 52 $this->add_question_question_answers($pluginwrapper); 53 54 // Now create the qtype own structures. 55 $gapselect = new backup_nested_element('gapselect', array('id'), array( 56 'shuffleanswers', 'correctfeedback', 'correctfeedbackformat', 57 'partiallycorrectfeedback', 'partiallycorrectfeedbackformat', 58 'incorrectfeedback', 'incorrectfeedbackformat', 'shownumcorrect')); 59 60 // Now the own qtype tree. 61 $pluginwrapper->add_child($gapselect); 62 63 // Set source to populate the data. 64 $gapselect->set_source_table('question_gapselect', 65 array('questionid' => backup::VAR_PARENTID)); 66 67 // Don't need to annotate ids or files. 68 69 return $plugin; 70 } 71 }
title
Description
Body
title
Description
Body
title
Description
Body
title
Body