feat(smoothLivePreview): fix weird effects due to parsing incomplete input

This commit is contained in:
Estevão Soares dos Santos 2015-07-14 17:10:52 +01:00
parent 7ee2017c56
commit 62ba3733cd
6 changed files with 11 additions and 15 deletions

BIN
dist/showdown.js vendored

Binary file not shown.

BIN
dist/showdown.js.map vendored

Binary file not shown.

BIN
dist/showdown.min.js vendored

Binary file not shown.

Binary file not shown.

View File

@ -65,6 +65,11 @@ function getDefaultOpts(simple) {
default: false, default: false,
describe: 'Turn on/off GFM tasklist support', describe: 'Turn on/off GFM tasklist support',
type: 'boolean' type: 'boolean'
},
smoothLivePreview: {
default: false,
describe: 'Prevents weird effects in live previews due to incomplete input',
type: 'boolean'
} }
}; };
if (simple === false) { if (simple === false) {

View File

@ -2,7 +2,7 @@ showdown.subParser('headers', function (text, options, globals) {
'use strict'; 'use strict';
var prefixHeader = options.prefixHeaderId, var prefixHeader = options.prefixHeaderId,
headerLevelStart = (isNaN(parseInt(options.headerLevelStart))) ? 1 : parseInt(options.headerLevelStart); headerLevelStart = (isNaN(parseInt(options.headerLevelStart))) ? 1 : parseInt(options.headerLevelStart),
// Set text-style headers: // Set text-style headers:
// Header 1 // Header 1
@ -11,7 +11,10 @@ showdown.subParser('headers', function (text, options, globals) {
// Header 2 // Header 2
// -------- // --------
// //
text = text.replace(/^(.+)[ \t]*\n=+[ \t]*\n+/gm, function (wholeMatch, m1) { setextRegexH1 = (options.smoothLivePreview) ? /^(.+)[ \t]*\n={2,}[ \t]*\n+/gm : /^(.+)[ \t]*\n=+[ \t]*\n+/gm,
setextRegexH2 = (options.smoothLivePreview) ? /^(.+)[ \t]*\n-{2,}[ \t]*\n+/gm : /^(.+)[ \t]*\n-+[ \t]*\n+/gm;
text = text.replace(setextRegexH1, function (wholeMatch, m1) {
var spanGamut = showdown.subParser('spanGamut')(m1, options, globals), var spanGamut = showdown.subParser('spanGamut')(m1, options, globals),
hID = (options.noHeaderId) ? '' : ' id="' + headerId(m1) + '"', hID = (options.noHeaderId) ? '' : ' id="' + headerId(m1) + '"',
@ -20,7 +23,7 @@ showdown.subParser('headers', function (text, options, globals) {
return showdown.subParser('hashBlock')(hashBlock, options, globals); return showdown.subParser('hashBlock')(hashBlock, options, globals);
}); });
text = text.replace(/^(.+)[ \t]*\n-+[ \t]*\n+/gm, function (matchFound, m1) { text = text.replace(setextRegexH2, function (matchFound, m1) {
var spanGamut = showdown.subParser('spanGamut')(m1, options, globals), var spanGamut = showdown.subParser('spanGamut')(m1, options, globals),
hID = (options.noHeaderId) ? '' : ' id="' + headerId(m1) + '"', hID = (options.noHeaderId) ? '' : ' id="' + headerId(m1) + '"',
hLevel = headerLevelStart + 1, hLevel = headerLevelStart + 1,
@ -35,18 +38,6 @@ showdown.subParser('headers', function (text, options, globals) {
// ... // ...
// ###### Header 6 // ###### Header 6
// //
/*
text = text.replace(/
^(\#{1,6}) // $1 = string of #'s
[ \t]*
(.+?) // $2 = Header text
[ \t]*
\#* // optional closing #'s (not counted)
\n+
/gm, function() {...});
*/
text = text.replace(/^(#{1,6})[ \t]*(.+?)[ \t]*#*\n+/gm, function (wholeMatch, m1, m2) { text = text.replace(/^(#{1,6})[ \t]*(.+?)[ \t]*#*\n+/gm, function (wholeMatch, m1, m2) {
var span = showdown.subParser('spanGamut')(m2, options, globals), var span = showdown.subParser('spanGamut')(m2, options, globals),
hID = (options.noHeaderId) ? '' : ' id="' + headerId(m2) + '"', hID = (options.noHeaderId) ? '' : ' id="' + headerId(m2) + '"',