showdown/src/subParsers/githubCodeBlocks.js

47 lines
1.6 KiB
JavaScript
Raw Normal View History

2015-01-16 05:21:33 +08:00
/**
* Handle github codeblocks prior to running HashHTML so that
* HTML contained within the codeblock gets escaped properly
* Example:
* ```ruby
* def hello_world(x)
* puts "Hello, #{x}"
* end
* ```
*/
showdown.subParser('githubCodeBlocks', function (text, options, globals) {
2015-01-19 19:37:21 +08:00
'use strict';
2015-01-16 05:21:33 +08:00
// early exit if option is not enabled
if (!options.ghCodeBlocks) {
return text;
}
text = globals.converter._dispatch('githubCodeBlocks.before', text, options);
2015-01-19 19:37:21 +08:00
text += '~0';
2015-01-16 05:21:33 +08:00
text = text.replace(/(?:^|\n)```(.*)\n([\s\S]*?)\n```/g, function (wholeMatch, language, codeblock) {
var end = (options.omitExtraWLInCodeBlocks) ? '' : '\n';
2015-01-16 05:21:33 +08:00
// First parse the github code block
2015-01-19 19:37:21 +08:00
codeblock = showdown.subParser('encodeCode')(codeblock);
codeblock = showdown.subParser('detab')(codeblock);
codeblock = codeblock.replace(/^\n+/g, ''); // trim leading newlines
codeblock = codeblock.replace(/\n+$/g, ''); // trim trailing whitespace
2015-01-16 05:21:33 +08:00
codeblock = '<pre><code' + (language ? ' class="' + language + ' language-' + language + '"' : '') + '>' + codeblock + end + '</code></pre>';
2015-01-16 05:21:33 +08:00
codeblock = showdown.subParser('hashBlock')(codeblock, options, globals);
// Since GHCodeblocks can be false positives, we need to
// store the primitive text and the parsed text in a global var,
// and then return a token
return '\n\n~G' + (globals.ghCodeBlocks.push({text: wholeMatch, codeblock: codeblock}) - 1) + 'G\n\n';
2015-01-19 19:37:21 +08:00
});
2015-01-16 05:21:33 +08:00
2015-01-19 19:37:21 +08:00
// attacklab: strip sentinel
text = text.replace(/~0/, '');
2015-01-16 05:21:33 +08:00
return globals.converter._dispatch('githubCodeBlocks.after', text, options);
2015-01-16 05:21:33 +08:00
});