From 1f8db780916610c2c9e1ed08625b7479362989e5 Mon Sep 17 00:00:00 2001 From: tjhunt Date: Tue, 20 Mar 2007 14:30:44 +0000 Subject: [PATCH] MDL-6386/MDL-6462 - yet more special character issues with multianswer. I think I have got them all this time. --- question/type/multianswer/questiontype.php | 16 ++++++++-------- question/type/questiontype.php | 2 +- 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/question/type/multianswer/questiontype.php b/question/type/multianswer/questiontype.php index d50b0e99a2..971d29dc0a 100644 --- a/question/type/multianswer/questiontype.php +++ b/question/type/multianswer/questiontype.php @@ -236,7 +236,7 @@ class embedded_cloze_qtype extends default_questiontype { $inputname = $nameprefix.$positionkey; if (isset($state->responses[$positionkey])) { - $response = stripslashes($state->responses[$positionkey]); + $response = $state->responses[$positionkey]; } else { $response = null; } @@ -277,7 +277,7 @@ class embedded_cloze_qtype extends default_questiontype { } if (!empty($chosenanswer->feedback)) { - $feedback = str_replace("'", "\\'", $chosenanswer->feedback); + $feedback = s(str_replace(array("\\", "'"), array("\\\\", "\\'"), $chosenanswer->feedback)); $popup = " onmouseover=\"return overlib('$feedback', STICKY, MOUSEOFF, CAPTION, '$strfeedback', FGCOLOR, '#FFFFFF');\" ". " onmouseout=\"return nd();\" "; } @@ -297,7 +297,7 @@ class embedded_cloze_qtype extends default_questiontype { case 'shortanswer': case 'numerical': echo " "; + type=\"text\" value=\"".s($response, true)."\" size=\"12\" /> "; if (!empty($feedback) && !empty($USER->screenreader)) { echo "pixpath/i/feedback.gif\" alt=\"$feedback\" />"; } @@ -308,7 +308,7 @@ class embedded_cloze_qtype extends default_questiontype { foreach ($answers as $mcanswer) { $selected = $response == $mcanswer->id ? ' selected="selected" ' : ''; - $outputoptions .= ""; + $outputoptions .= ''; } // In the next line, $readonly is invalid HTML, but it works in // all browsers. $disabled would be valid, but then the JS for @@ -344,7 +344,7 @@ class embedded_cloze_qtype extends default_questiontype { $teststate = clone($state); $state->raw_grade = 0; foreach($question->options->questions as $key => $wrapped) { - $state->responses[$key] = html_entity_decode($state->responses[$key]); + $state->responses[$key] = $state->responses[$key]; $teststate->responses = array('' => $state->responses[$key]); $teststate->raw_grade = 0; if (false === $QTYPES[$wrapped->qtype] @@ -650,7 +650,6 @@ define("ANSWER_REGEX_ANSWER_TYPE_SHORTANSWER", 5); define("ANSWER_REGEX_ALTERNATIVES", 6); function qtype_multianswer_extract_question($text) { - $question = new stdClass; $question->qtype = 'multianswer'; $question->questiontext = $text; @@ -701,7 +700,7 @@ function qtype_multianswer_extract_question($text) { $wrapped->fraction[] = '0'; } if (isset($altregs[ANSWER_ALTERNATIVE_REGEX_FEEDBACK])) { - $wrapped->feedback[] = $altregs[ANSWER_ALTERNATIVE_REGEX_FEEDBACK]; + $wrapped->feedback[] = html_entity_decode($altregs[ANSWER_ALTERNATIVE_REGEX_FEEDBACK], ENT_QUOTES, 'UTF-8'); } else { $wrapped->feedback[] = ''; } @@ -715,7 +714,8 @@ function qtype_multianswer_extract_question($text) { $wrapped->tolerance[] = 0; } } else { // Tolerance can stay undefined for non numerical questions - $wrapped->answer[] = $altregs[ANSWER_ALTERNATIVE_REGEX_ANSWER]; + // Undo quoting done by the HTML editor. + $wrapped->answer[] = html_entity_decode($altregs[ANSWER_ALTERNATIVE_REGEX_ANSWER], ENT_QUOTES, 'UTF-8'); } $tmp = explode($altregs[0], $remainingalts, 2); $remainingalts = $tmp[1]; diff --git a/question/type/questiontype.php b/question/type/questiontype.php index 0bb442b140..1419b59b1e 100644 --- a/question/type/questiontype.php +++ b/question/type/questiontype.php @@ -436,7 +436,7 @@ class default_questiontype { if ($question->options->answers) { foreach ($question->options->answers as $answer) { if (((int) $answer->fraction) === 1) { - return array('' => $answer->answer); + return array('' => addslashes($answer->answer)); } } } -- 2.39.5