-
Notifications
You must be signed in to change notification settings - Fork 10
/
filter.php
112 lines (105 loc) · 4.16 KB
/
filter.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
<?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/>.
/**
* Main filter class
*
* @package filter_syntaxhighlighter
* @author Mark Sharp <[email protected]>
* @copyright 2017 University of Chichester {@link https://www.chi.ac.uk}
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
defined('MOODLE_INTERNAL') || die();
/**
* Filter class for highlighting code syntax.
*
* @package filter_syntaxhighlighter
* @author Mark Sharp <[email protected]>
* @copyright 2017 University of Chichester {@link https://www.chi.ac.uk}
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
class filter_syntaxhighlighter extends moodle_text_filter {
/**
* The filter function is required, but the text just passes through.
*
* @param string $text HTML to be processed.
* @param array $options Options for filter.
*
* @return string String containing processed HTML.
*/
public function filter($text, array $options = array()) {
if (!is_string($text) || empty($text)) {
return $text;
}
// phpcs:disable moodle.Strings.ForbiddenStrings.Found
// RegExp detects optional language example input.
$re = "~(<pre>|)```(lang:(\w+);;[\r\n]{0,}|)(.*?)```(<\/pre>|)~isu";
// phpcs:enable moodle.Strings.ForbiddenStrings.Found
return preg_replace_callback($re, array($this, 'code_replace'), $text);
}
/**
* Replaces match group with formatted html.
*
* Match Group of regExp match
* * Prevents "<pre><pre><code>..." if <pre> in Atto used.
* mgrp[0] = "<pre>```lang:anything;;...code...```</pre>"
* * Recommended to place inside <pre> in Atto editor
* * (preserves \s+,\t,\r,\n chars)
* mgrp[1] = "<pre>"
* * With trailing line break (\r|\n|\r\n) for different
* * line break styles (preserve of empty rows in code block)
* mgrp[2] = "lang:anything;;\r\n"
* * Specified lang class
* mgrp[3] = "anything"
* mgrp[4] = "...code..."
* mgrp[5] = "</pre>"
*
* @param array $mgrp Match group from preg_replace.
*
* @return string
*/
private function code_replace($mgrp) {
return
'<pre><code' . ($mgrp[2] ? ' class="lang-' . $mgrp[3] .'"' : '') . '>' .
str_replace(['<p>', '</p>'], ['', "\n"], $mgrp[4]) .
'</code></pre>';
}
/**
* Loads the javascript and style sheets.
*
* @param moodle_page $page The page we are going to add requirements to.
* @param context $context The context which contents are going to be filtered.
*/
public function setup($page, $context) {
global $CFG;
static $jsinitialised = false;
if (empty($jsinitialised)) {
$css = get_config('filter_syntaxhighlighter', 'styleurl');
$cdn = get_config('filter_syntaxhighlighter', 'cdn');
if ($cdn) {
$css = 'https://cdnjs.cloudflare.com/ajax/libs/highlight.js/9.12.0/styles/' . $css . '.min.css';
} else {
$css = $CFG->wwwroot . '/filter/syntaxhighlighter/styles/' . $css . '.min.css';
}
$styleurl = new moodle_url($css);
$page->requires->css($styleurl);
$jsinitialised = true;
}
// Do this only in the context of a course the filter is enabled in.
if (array_key_exists("syntaxhighlighter", filter_get_active_in_context($context))) {
$page->requires->js_call_amd('filter_syntaxhighlighter/hljs', 'initHighlighting');
}
}
}