See Release Notes
Long Term Support Release
<?php // This file is part of Moodle - http://moodle.org/ // // Moodle is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // Moodle is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with Moodle. If not, see <http://www.gnu.org/licenses/>. /**< * Wrap content in quotes, and escape all quotes used.> * Wrap content in quotes, and escape all special JSON characters used.* * @package core * @category output * @copyright 2016 Andrew Nicols <andrew@nicols.co.uk> * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ namespace core\output; /**< * Wrap content in quotes, and escape all quotes used.> * Wrap content in quotes, and escape all special JSON characters used.* * @copyright 2016 Andrew Nicols <andrew@nicols.co.uk> * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class mustache_quote_helper { /**< * Wrap content in quotes, and escape all quotes used.> * Wrap content in quotes, and escape all special JSON characters used.* * Note: This helper is only compatible with the standard {{ }} delimeters. * * @param string $text The text to parse for arguments.< * @param Mustache_LambdaHelper $helper Used to render nested mustache variables.> * @param \Mustache_LambdaHelper $helper Used to render nested mustache variables.* @return string */ public function quote($text, \Mustache_LambdaHelper $helper) {< // Split the text into an array of variables.$content = trim($text); $content = $helper->render($content);< // Escape the {{ and the ". < $content = str_replace('"', '\\"', $content);> // Escape the {{ and JSON encode. > $content = json_encode($content);$content = preg_replace('([{}]{2,3})', '{{=<% %>=}}${0}<%={{ }}=%>', $content);< return '"' . $content . '"';> return $content;} }