Updating vue-simplemde

parent 04e5f637
...@@ -12806,6 +12806,16 @@ function collapsedSpanAtSide(line, start) { ...@@ -12806,6 +12806,16 @@ function collapsedSpanAtSide(line, start) {
function collapsedSpanAtStart(line) { return collapsedSpanAtSide(line, true) } function collapsedSpanAtStart(line) { return collapsedSpanAtSide(line, true) }
function collapsedSpanAtEnd(line) { return collapsedSpanAtSide(line, false) } function collapsedSpanAtEnd(line) { return collapsedSpanAtSide(line, false) }
function collapsedSpanAround(line, ch) {
var sps = sawCollapsedSpans && line.markedSpans, found;
if (sps) { for (var i = 0; i < sps.length; ++i) {
var sp = sps[i];
if (sp.marker.collapsed && (sp.from == null || sp.from < ch) && (sp.to == null || sp.to > ch) &&
(!found || compareCollapsedMarkers(found, sp.marker) < 0)) { found = sp.marker; }
} }
return found
}
// Test whether there exists a collapsed span that partially // Test whether there exists a collapsed span that partially
// overlaps (covers the start or end, but not both) of a new span. // overlaps (covers the start or end, but not both) of a new span.
// Such overlap is not allowed. // Such overlap is not allowed.
...@@ -14840,12 +14850,11 @@ function coordsChar(cm, x, y) { ...@@ -14840,12 +14850,11 @@ function coordsChar(cm, x, y) {
var lineObj = getLine(doc, lineN); var lineObj = getLine(doc, lineN);
for (;;) { for (;;) {
var found = coordsCharInner(cm, lineObj, lineN, x, y); var found = coordsCharInner(cm, lineObj, lineN, x, y);
var merged = collapsedSpanAtEnd(lineObj); var collapsed = collapsedSpanAround(lineObj, found.ch + (found.xRel > 0 ? 1 : 0));
var mergedPos = merged && merged.find(0, true); if (!collapsed) { return found }
if (merged && (found.ch > mergedPos.from.ch || found.ch == mergedPos.from.ch && found.xRel > 0)) var rangeEnd = collapsed.find(1);
{ lineN = lineNo(lineObj = mergedPos.to.line); } if (rangeEnd.line == lineN) { return rangeEnd }
else lineObj = getLine(doc, lineN = rangeEnd.line);
{ return found }
} }
} }
...@@ -15336,8 +15345,10 @@ function updateHeightsInViewport(cm) { ...@@ -15336,8 +15345,10 @@ function updateHeightsInViewport(cm) {
// Read and store the height of line widgets associated with the // Read and store the height of line widgets associated with the
// given line. // given line.
function updateWidgetHeight(line) { function updateWidgetHeight(line) {
if (line.widgets) { for (var i = 0; i < line.widgets.length; ++i) if (line.widgets) { for (var i = 0; i < line.widgets.length; ++i) {
{ line.widgets[i].height = line.widgets[i].node.parentNode.offsetHeight; } } var w = line.widgets[i], parent = w.node.parentNode;
if (parent) { w.height = parent.offsetHeight; }
} }
} }
// Compute the lines that are visible in a given viewport (defaults // Compute the lines that are visible in a given viewport (defaults
...@@ -15603,6 +15614,7 @@ var NativeScrollbars = function(place, scroll, cm) { ...@@ -15603,6 +15614,7 @@ var NativeScrollbars = function(place, scroll, cm) {
this.cm = cm; this.cm = cm;
var vert = this.vert = elt("div", [elt("div", null, null, "min-width: 1px")], "CodeMirror-vscrollbar"); var vert = this.vert = elt("div", [elt("div", null, null, "min-width: 1px")], "CodeMirror-vscrollbar");
var horiz = this.horiz = elt("div", [elt("div", null, null, "height: 100%; min-height: 1px")], "CodeMirror-hscrollbar"); var horiz = this.horiz = elt("div", [elt("div", null, null, "height: 100%; min-height: 1px")], "CodeMirror-hscrollbar");
vert.tabIndex = horiz.tabIndex = -1;
place(vert); place(horiz); place(vert); place(horiz);
on(vert, "scroll", function () { on(vert, "scroll", function () {
...@@ -16854,7 +16866,7 @@ function addChangeToHistory(doc, change, selAfter, opId) { ...@@ -16854,7 +16866,7 @@ function addChangeToHistory(doc, change, selAfter, opId) {
if ((hist.lastOp == opId || if ((hist.lastOp == opId ||
hist.lastOrigin == change.origin && change.origin && hist.lastOrigin == change.origin && change.origin &&
((change.origin.charAt(0) == "+" && doc.cm && hist.lastModTime > time - doc.cm.options.historyEventDelay) || ((change.origin.charAt(0) == "+" && hist.lastModTime > time - (doc.cm ? doc.cm.options.historyEventDelay : 500)) ||
change.origin.charAt(0) == "*")) && change.origin.charAt(0) == "*")) &&
(cur = lastChangeEvent(hist, hist.lastOp == opId))) { (cur = lastChangeEvent(hist, hist.lastOp == opId))) {
// Merge this change into the last event // Merge this change into the last event
...@@ -17283,7 +17295,8 @@ function makeChangeInner(doc, change) { ...@@ -17283,7 +17295,8 @@ function makeChangeInner(doc, change) {
// Revert a change stored in a document's history. // Revert a change stored in a document's history.
function makeChangeFromHistory(doc, type, allowSelectionOnly) { function makeChangeFromHistory(doc, type, allowSelectionOnly) {
if (doc.cm && doc.cm.state.suppressEdits && !allowSelectionOnly) { return } var suppress = doc.cm && doc.cm.state.suppressEdits;
if (suppress && !allowSelectionOnly) { return }
var hist = doc.history, event, selAfter = doc.sel; var hist = doc.history, event, selAfter = doc.sel;
var source = type == "undo" ? hist.done : hist.undone, dest = type == "undo" ? hist.undone : hist.done; var source = type == "undo" ? hist.done : hist.undone, dest = type == "undo" ? hist.undone : hist.done;
...@@ -17308,8 +17321,10 @@ function makeChangeFromHistory(doc, type, allowSelectionOnly) { ...@@ -17308,8 +17321,10 @@ function makeChangeFromHistory(doc, type, allowSelectionOnly) {
return return
} }
selAfter = event; selAfter = event;
} } else if (suppress) {
else { break } source.push(event);
return
} else { break }
} }
// Build up a reverse change object to add to the opposite history // Build up a reverse change object to add to the opposite history
...@@ -17465,7 +17480,7 @@ function makeChangeSingleDocInEditor(cm, change, spans) { ...@@ -17465,7 +17480,7 @@ function makeChangeSingleDocInEditor(cm, change, spans) {
function replaceRange(doc, code, from, to, origin) { function replaceRange(doc, code, from, to, origin) {
if (!to) { to = from; } if (!to) { to = from; }
if (cmp(to, from) < 0) { var assign; if (cmp(to, from) < 0) { var assign;
(assign = [to, from], from = assign[0], to = assign[1], assign); } (assign = [to, from], from = assign[0], to = assign[1]); }
if (typeof code == "string") { code = doc.splitLines(code); } if (typeof code == "string") { code = doc.splitLines(code); }
makeChange(doc, {from: from, to: to, text: code, origin: origin}); makeChange(doc, {from: from, to: to, text: code, origin: origin});
} }
...@@ -17561,10 +17576,10 @@ function LeafChunk(lines) { ...@@ -17561,10 +17576,10 @@ function LeafChunk(lines) {
} }
LeafChunk.prototype = { LeafChunk.prototype = {
chunkSize: function chunkSize() { return this.lines.length }, chunkSize: function() { return this.lines.length },
// Remove the n lines at offset 'at'. // Remove the n lines at offset 'at'.
removeInner: function removeInner(at, n) { removeInner: function(at, n) {
var this$1 = this; var this$1 = this;
for (var i = at, e = at + n; i < e; ++i) { for (var i = at, e = at + n; i < e; ++i) {
...@@ -17577,13 +17592,13 @@ LeafChunk.prototype = { ...@@ -17577,13 +17592,13 @@ LeafChunk.prototype = {
}, },
// Helper used to collapse a small branch into a single leaf. // Helper used to collapse a small branch into a single leaf.
collapse: function collapse(lines) { collapse: function(lines) {
lines.push.apply(lines, this.lines); lines.push.apply(lines, this.lines);
}, },
// Insert the given array of lines at offset 'at', count them as // Insert the given array of lines at offset 'at', count them as
// having the given height. // having the given height.
insertInner: function insertInner(at, lines, height) { insertInner: function(at, lines, height) {
var this$1 = this; var this$1 = this;
this.height += height; this.height += height;
...@@ -17592,7 +17607,7 @@ LeafChunk.prototype = { ...@@ -17592,7 +17607,7 @@ LeafChunk.prototype = {
}, },
// Used to iterate over a part of the tree. // Used to iterate over a part of the tree.
iterN: function iterN(at, n, op) { iterN: function(at, n, op) {
var this$1 = this; var this$1 = this;
for (var e = at + n; at < e; ++at) for (var e = at + n; at < e; ++at)
...@@ -17616,9 +17631,9 @@ function BranchChunk(children) { ...@@ -17616,9 +17631,9 @@ function BranchChunk(children) {
} }
BranchChunk.prototype = { BranchChunk.prototype = {
chunkSize: function chunkSize() { return this.size }, chunkSize: function() { return this.size },
removeInner: function removeInner(at, n) { removeInner: function(at, n) {
var this$1 = this; var this$1 = this;
this.size -= n; this.size -= n;
...@@ -17644,13 +17659,13 @@ BranchChunk.prototype = { ...@@ -17644,13 +17659,13 @@ BranchChunk.prototype = {
} }
}, },
collapse: function collapse(lines) { collapse: function(lines) {
var this$1 = this; var this$1 = this;
for (var i = 0; i < this.children.length; ++i) { this$1.children[i].collapse(lines); } for (var i = 0; i < this.children.length; ++i) { this$1.children[i].collapse(lines); }
}, },
insertInner: function insertInner(at, lines, height) { insertInner: function(at, lines, height) {
var this$1 = this; var this$1 = this;
this.size += lines.length; this.size += lines.length;
...@@ -17679,7 +17694,7 @@ BranchChunk.prototype = { ...@@ -17679,7 +17694,7 @@ BranchChunk.prototype = {
}, },
// When a node has grown, check whether it should be split. // When a node has grown, check whether it should be split.
maybeSpill: function maybeSpill() { maybeSpill: function() {
if (this.children.length <= 10) { return } if (this.children.length <= 10) { return }
var me = this; var me = this;
do { do {
...@@ -17701,7 +17716,7 @@ BranchChunk.prototype = { ...@@ -17701,7 +17716,7 @@ BranchChunk.prototype = {
me.parent.maybeSpill(); me.parent.maybeSpill();
}, },
iterN: function iterN(at, n, op) { iterN: function(at, n, op) {
var this$1 = this; var this$1 = this;
for (var i = 0; i < this.children.length; ++i) { for (var i = 0; i < this.children.length; ++i) {
...@@ -17785,7 +17800,7 @@ function addLineWidget(doc, handle, node, options) { ...@@ -17785,7 +17800,7 @@ function addLineWidget(doc, handle, node, options) {
} }
return true return true
}); });
signalLater(cm, "lineWidgetAdded", cm, widget, typeof handle == "number" ? handle : lineNo(handle)); if (cm) { signalLater(cm, "lineWidgetAdded", cm, widget, typeof handle == "number" ? handle : lineNo(handle)); }
return widget return widget
} }
...@@ -18634,8 +18649,6 @@ function registerGlobalHandlers() { ...@@ -18634,8 +18649,6 @@ function registerGlobalHandlers() {
// Called when the window resizes // Called when the window resizes
function onResize(cm) { function onResize(cm) {
var d = cm.display; var d = cm.display;
if (d.lastWrapHeight == d.wrapper.clientHeight && d.lastWrapWidth == d.wrapper.clientWidth)
{ return }
// Might be a text scaling operation, clear size caches. // Might be a text scaling operation, clear size caches.
d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null; d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null;
d.scrollbarsClipped = false; d.scrollbarsClipped = false;
...@@ -18643,11 +18656,11 @@ function onResize(cm) { ...@@ -18643,11 +18656,11 @@ function onResize(cm) {
} }
var keyNames = { var keyNames = {
3: "Enter", 8: "Backspace", 9: "Tab", 13: "Enter", 16: "Shift", 17: "Ctrl", 18: "Alt", 3: "Pause", 8: "Backspace", 9: "Tab", 13: "Enter", 16: "Shift", 17: "Ctrl", 18: "Alt",
19: "Pause", 20: "CapsLock", 27: "Esc", 32: "Space", 33: "PageUp", 34: "PageDown", 35: "End", 19: "Pause", 20: "CapsLock", 27: "Esc", 32: "Space", 33: "PageUp", 34: "PageDown", 35: "End",
36: "Home", 37: "Left", 38: "Up", 39: "Right", 40: "Down", 44: "PrintScrn", 45: "Insert", 36: "Home", 37: "Left", 38: "Up", 39: "Right", 40: "Down", 44: "PrintScrn", 45: "Insert",
46: "Delete", 59: ";", 61: "=", 91: "Mod", 92: "Mod", 93: "Mod", 46: "Delete", 59: ";", 61: "=", 91: "Mod", 92: "Mod", 93: "Mod",
106: "*", 107: "=", 109: "-", 110: ".", 111: "/", 127: "Delete", 106: "*", 107: "=", 109: "-", 110: ".", 111: "/", 127: "Delete", 145: "ScrollLock",
173: "-", 186: ";", 187: "=", 188: ",", 189: "-", 190: ".", 191: "/", 192: "`", 219: "[", 220: "\\", 173: "-", 186: ";", 187: "=", 188: ",", 189: "-", 190: ".", 191: "/", 192: "`", 219: "[", 220: "\\",
221: "]", 222: "'", 63232: "Up", 63233: "Down", 63234: "Left", 63235: "Right", 63272: "Delete", 221: "]", 222: "'", 63232: "Up", 63233: "Down", 63234: "Left", 63235: "Right", 63272: "Delete",
63273: "Home", 63275: "End", 63276: "PageUp", 63277: "PageDown", 63302: "Insert" 63273: "Home", 63275: "End", 63276: "PageUp", 63277: "PageDown", 63302: "Insert"
...@@ -18794,6 +18807,9 @@ function keyName(event, noShift) { ...@@ -18794,6 +18807,9 @@ function keyName(event, noShift) {
if (presto && event.keyCode == 34 && event["char"]) { return false } if (presto && event.keyCode == 34 && event["char"]) { return false }
var name = keyNames[event.keyCode]; var name = keyNames[event.keyCode];
if (name == null || event.altGraphKey) { return false } if (name == null || event.altGraphKey) { return false }
// Ctrl-ScrollLock has keyCode 3, same as Ctrl-Pause,
// so we'll use event.code when available (Chrome 48+, FF 38+, Safari 10.1+)
if (event.keyCode == 3 && event.code) { name = event.code; }
return addModifierNames(name, event, noShift) return addModifierNames(name, event, noShift)
} }
...@@ -19133,18 +19149,26 @@ function lookupKeyForEditor(cm, name, handle) { ...@@ -19133,18 +19149,26 @@ function lookupKeyForEditor(cm, name, handle) {
// for bound mouse clicks. // for bound mouse clicks.
var stopSeq = new Delayed; var stopSeq = new Delayed;
function dispatchKey(cm, name, e, handle) { function dispatchKey(cm, name, e, handle) {
var seq = cm.state.keySeq; var seq = cm.state.keySeq;
if (seq) { if (seq) {
if (isModifierKey(name)) { return "handled" } if (isModifierKey(name)) { return "handled" }
stopSeq.set(50, function () { if (/\'$/.test(name))
if (cm.state.keySeq == seq) { { cm.state.keySeq = null; }
cm.state.keySeq = null; else
cm.display.input.reset(); { stopSeq.set(50, function () {
} if (cm.state.keySeq == seq) {
}); cm.state.keySeq = null;
name = seq + " " + name; cm.display.input.reset();
}
}); }
if (dispatchKeyInner(cm, seq + " " + name, e, handle)) { return true }
} }
return dispatchKeyInner(cm, name, e, handle)
}
function dispatchKeyInner(cm, name, e, handle) {
var result = lookupKeyForEditor(cm, name, handle); var result = lookupKeyForEditor(cm, name, handle);
if (result == "multi") if (result == "multi")
...@@ -19157,10 +19181,6 @@ function dispatchKey(cm, name, e, handle) { ...@@ -19157,10 +19181,6 @@ function dispatchKey(cm, name, e, handle) {
restartBlink(cm); restartBlink(cm);
} }
if (seq && !result && /\'$/.test(name)) {
e_preventDefault(e);
return true
}
return !!result return !!result
} }
...@@ -19372,8 +19392,8 @@ function leftButtonStartDrag(cm, event, pos, behavior) { ...@@ -19372,8 +19392,8 @@ function leftButtonStartDrag(cm, event, pos, behavior) {
var dragEnd = operation(cm, function (e) { var dragEnd = operation(cm, function (e) {
if (webkit) { display.scroller.draggable = false; } if (webkit) { display.scroller.draggable = false; }
cm.state.draggingText = false; cm.state.draggingText = false;
off(document, "mouseup", dragEnd); off(display.wrapper.ownerDocument, "mouseup", dragEnd);
off(document, "mousemove", mouseMove); off(display.wrapper.ownerDocument, "mousemove", mouseMove);
off(display.scroller, "dragstart", dragStart); off(display.scroller, "dragstart", dragStart);
off(display.scroller, "drop", dragEnd); off(display.scroller, "drop", dragEnd);
if (!moved) { if (!moved) {
...@@ -19382,7 +19402,7 @@ function leftButtonStartDrag(cm, event, pos, behavior) { ...@@ -19382,7 +19402,7 @@ function leftButtonStartDrag(cm, event, pos, behavior) {
{ extendSelection(cm.doc, pos, null, null, behavior.extend); } { extendSelection(cm.doc, pos, null, null, behavior.extend); }
// Work around unexplainable focus problem in IE9 (#2127) and Chrome (#3081) // Work around unexplainable focus problem in IE9 (#2127) and Chrome (#3081)
if (webkit || ie && ie_version == 9) if (webkit || ie && ie_version == 9)
{ setTimeout(function () {document.body.focus(); display.input.focus();}, 20); } { setTimeout(function () {display.wrapper.ownerDocument.body.focus(); display.input.focus();}, 20); }
else else
{ display.input.focus(); } { display.input.focus(); }
} }
...@@ -19397,8 +19417,8 @@ function leftButtonStartDrag(cm, event, pos, behavior) { ...@@ -19397,8 +19417,8 @@ function leftButtonStartDrag(cm, event, pos, behavior) {
dragEnd.copy = !behavior.moveOnDrag; dragEnd.copy = !behavior.moveOnDrag;
// IE's approach to draggable // IE's approach to draggable
if (display.scroller.dragDrop) { display.scroller.dragDrop(); } if (display.scroller.dragDrop) { display.scroller.dragDrop(); }
on(document, "mouseup", dragEnd); on(display.wrapper.ownerDocument, "mouseup", dragEnd);
on(document, "mousemove", mouseMove); on(display.wrapper.ownerDocument, "mousemove", mouseMove);
on(display.scroller, "dragstart", dragStart); on(display.scroller, "dragstart", dragStart);
on(display.scroller, "drop", dragEnd); on(display.scroller, "drop", dragEnd);
...@@ -19530,19 +19550,19 @@ function leftButtonSelect(cm, event, start, behavior) { ...@@ -19530,19 +19550,19 @@ function leftButtonSelect(cm, event, start, behavior) {
counter = Infinity; counter = Infinity;
e_preventDefault(e); e_preventDefault(e);
display.input.focus(); display.input.focus();
off(document, "mousemove", move); off(display.wrapper.ownerDocument, "mousemove", move);
off(document, "mouseup", up); off(display.wrapper.ownerDocument, "mouseup", up);
doc.history.lastSelOrigin = null; doc.history.lastSelOrigin = null;
} }
var move = operation(cm, function (e) { var move = operation(cm, function (e) {
if (!e_button(e)) { done(e); } if (e.buttons === 0 || !e_button(e)) { done(e); }
else { extend(e); } else { extend(e); }
}); });
var up = operation(cm, done); var up = operation(cm, done);
cm.state.selectingText = up; cm.state.selectingText = up;
on(document, "mousemove", move); on(display.wrapper.ownerDocument, "mousemove", move);
on(document, "mouseup", up); on(display.wrapper.ownerDocument, "mouseup", up);
} }
// Used when mouse-selecting to adjust the anchor to the proper side // Used when mouse-selecting to adjust the anchor to the proper side
...@@ -19672,6 +19692,7 @@ function defineOptions(CodeMirror) { ...@@ -19672,6 +19692,7 @@ function defineOptions(CodeMirror) {
clearCaches(cm); clearCaches(cm);
regChange(cm); regChange(cm);
}, true); }, true);
option("lineSeparator", null, function (cm, val) { option("lineSeparator", null, function (cm, val) {
cm.doc.lineSep = val; cm.doc.lineSep = val;
if (!val) { return } if (!val) { return }
...@@ -20078,7 +20099,7 @@ function applyTextInput(cm, inserted, deleted, sel, origin) { ...@@ -20078,7 +20099,7 @@ function applyTextInput(cm, inserted, deleted, sel, origin) {
var paste = cm.state.pasteIncoming || origin == "paste"; var paste = cm.state.pasteIncoming || origin == "paste";
var textLines = splitLinesAuto(inserted), multiPaste = null; var textLines = splitLinesAuto(inserted), multiPaste = null;
// When pasing N lines into N selections, insert one line per selection // When pasting N lines into N selections, insert one line per selection
if (paste && sel.ranges.length > 1) { if (paste && sel.ranges.length > 1) {
if (lastCopied && lastCopied.text.join("\n") == inserted) { if (lastCopied && lastCopied.text.join("\n") == inserted) {
if (sel.ranges.length % lastCopied.text.length == 0) { if (sel.ranges.length % lastCopied.text.length == 0) {
...@@ -20814,8 +20835,12 @@ ContentEditableInput.prototype.showSelection = function (info, takeFocus) { ...@@ -20814,8 +20835,12 @@ ContentEditableInput.prototype.showSelection = function (info, takeFocus) {
this.showMultipleSelections(info); this.showMultipleSelections(info);
}; };
ContentEditableInput.prototype.getSelection = function () {
return this.cm.display.wrapper.ownerDocument.getSelection()
};
ContentEditableInput.prototype.showPrimarySelection = function () { ContentEditableInput.prototype.showPrimarySelection = function () {
var sel = window.getSelection(), cm = this.cm, prim = cm.doc.sel.primary(); var sel = this.getSelection(), cm = this.cm, prim = cm.doc.sel.primary();
var from = prim.from(), to = prim.to(); var from = prim.from(), to = prim.to();
if (cm.display.viewTo == cm.display.viewFrom || from.line >= cm.display.viewTo || to.line < cm.display.viewFrom) { if (cm.display.viewTo == cm.display.viewFrom || from.line >= cm.display.viewTo || to.line < cm.display.viewFrom) {
...@@ -20882,13 +20907,13 @@ ContentEditableInput.prototype.showMultipleSelections = function (info) { ...@@ -20882,13 +20907,13 @@ ContentEditableInput.prototype.showMultipleSelections = function (info) {
}; };
ContentEditableInput.prototype.rememberSelection = function () { ContentEditableInput.prototype.rememberSelection = function () {
var sel = window.getSelection(); var sel = this.getSelection();
this.lastAnchorNode = sel.anchorNode; this.lastAnchorOffset = sel.anchorOffset; this.lastAnchorNode = sel.anchorNode; this.lastAnchorOffset = sel.anchorOffset;
this.lastFocusNode = sel.focusNode; this.lastFocusOffset = sel.focusOffset; this.lastFocusNode = sel.focusNode; this.lastFocusOffset = sel.focusOffset;
}; };
ContentEditableInput.prototype.selectionInEditor = function () { ContentEditableInput.prototype.selectionInEditor = function () {
var sel = window.getSelection(); var sel = this.getSelection();
if (!sel.rangeCount) { return false } if (!sel.rangeCount) { return false }
var node = sel.getRangeAt(0).commonAncestorContainer; var node = sel.getRangeAt(0).commonAncestorContainer;
return contains(this.div, node) return contains(this.div, node)
...@@ -20923,14 +20948,14 @@ ContentEditableInput.prototype.receivedFocus = function () { ...@@ -20923,14 +20948,14 @@ ContentEditableInput.prototype.receivedFocus = function () {
}; };
ContentEditableInput.prototype.selectionChanged = function () { ContentEditableInput.prototype.selectionChanged = function () {
var sel = window.getSelection(); var sel = this.getSelection();
return sel.anchorNode != this.lastAnchorNode || sel.anchorOffset != this.lastAnchorOffset || return sel.anchorNode != this.lastAnchorNode || sel.anchorOffset != this.lastAnchorOffset ||
sel.focusNode != this.lastFocusNode || sel.focusOffset != this.lastFocusOffset sel.focusNode != this.lastFocusNode || sel.focusOffset != this.lastFocusOffset
}; };
ContentEditableInput.prototype.pollSelection = function () { ContentEditableInput.prototype.pollSelection = function () {
if (this.readDOMTimeout != null || this.gracePeriod || !this.selectionChanged()) { return } if (this.readDOMTimeout != null || this.gracePeriod || !this.selectionChanged()) { return }
var sel = window.getSelection(), cm = this.cm; var sel = this.getSelection(), cm = this.cm;
// On Android Chrome (version 56, at least), backspacing into an // On Android Chrome (version 56, at least), backspacing into an
// uneditable block element will put the cursor in that element, // uneditable block element will put the cursor in that element,
// and then, because it's not editable, hide the virtual keyboard. // and then, because it's not editable, hide the virtual keyboard.
...@@ -21064,7 +21089,7 @@ ContentEditableInput.prototype.setUneditable = function (node) { ...@@ -21064,7 +21089,7 @@ ContentEditableInput.prototype.setUneditable = function (node) {
}; };
ContentEditableInput.prototype.onKeyPress = function (e) { ContentEditableInput.prototype.onKeyPress = function (e) {
if (e.charCode == 0) { return } if (e.charCode == 0 || this.composing) { return }
e.preventDefault(); e.preventDefault();
if (!this.cm.isReadOnly()) if (!this.cm.isReadOnly())
{ operation(this.cm, applyTextInput)(this.cm, String.fromCharCode(e.charCode == null ? e.keyCode : e.charCode), 0); } { operation(this.cm, applyTextInput)(this.cm, String.fromCharCode(e.charCode == null ? e.keyCode : e.charCode), 0); }
...@@ -21104,12 +21129,13 @@ function isInGutter(node) { ...@@ -21104,12 +21129,13 @@ function isInGutter(node) {
function badPos(pos, bad) { if (bad) { pos.bad = true; } return pos } function badPos(pos, bad) { if (bad) { pos.bad = true; } return pos }
function domTextBetween(cm, from, to, fromLine, toLine) { function domTextBetween(cm, from, to, fromLine, toLine) {
var text = "", closing = false, lineSep = cm.doc.lineSeparator(); var text = "", closing = false, lineSep = cm.doc.lineSeparator(), extraLinebreak = false;
function recognizeMarker(id) { return function (marker) { return marker.id == id; } } function recognizeMarker(id) { return function (marker) { return marker.id == id; } }
function close() { function close() {
if (closing) { if (closing) {
text += lineSep; text += lineSep;
closing = false; if (extraLinebreak) { text += lineSep; }
closing = extraLinebreak = false;
} }
} }
function addText(str) { function addText(str) {
...@@ -21121,8 +21147,8 @@ function domTextBetween(cm, from, to, fromLine, toLine) { ...@@ -21121,8 +21147,8 @@ function domTextBetween(cm, from, to, fromLine, toLine) {
function walk(node) { function walk(node) {
if (node.nodeType == 1) { if (node.nodeType == 1) {
var cmText = node.getAttribute("cm-text"); var cmText = node.getAttribute("cm-text");
if (cmText != null) { if (cmText) {
addText(cmText || node.textContent.replace(/\u200b/g, "")); addText(cmText);
return return
} }
var markerID = node.getAttribute("cm-marker"), range$$1; var markerID = node.getAttribute("cm-marker"), range$$1;
...@@ -21133,19 +21159,24 @@ function domTextBetween(cm, from, to, fromLine, toLine) { ...@@ -21133,19 +21159,24 @@ function domTextBetween(cm, from, to, fromLine, toLine) {
return return
} }
if (node.getAttribute("contenteditable") == "false") { return } if (node.getAttribute("contenteditable") == "false") { return }
var isBlock = /^(pre|div|p)$/i.test(node.nodeName); var isBlock = /^(pre|div|p|li|table|br)$/i.test(node.nodeName);
if (!/^br$/i.test(node.nodeName) && node.textContent.length == 0) { return }
if (isBlock) { close(); } if (isBlock) { close(); }
for (var i = 0; i < node.childNodes.length; i++) for (var i = 0; i < node.childNodes.length; i++)
{ walk(node.childNodes[i]); } { walk(node.childNodes[i]); }
if (/^(pre|p)$/i.test(node.nodeName)) { extraLinebreak = true; }
if (isBlock) { closing = true; } if (isBlock) { closing = true; }
} else if (node.nodeType == 3) { } else if (node.nodeType == 3) {
addText(node.nodeValue); addText(node.nodeValue.replace(/\u200b/g, "").replace(/\u00a0/g, " "));
} }
} }
for (;;) { for (;;) {
walk(from); walk(from);
if (from == to) { break } if (from == to) { break }
from = from.nextSibling; from = from.nextSibling;
extraLinebreak = false;
} }
return text return text
} }
...@@ -21246,13 +21277,10 @@ TextareaInput.prototype.init = function (display) { ...@@ -21246,13 +21277,10 @@ TextareaInput.prototype.init = function (display) {
var this$1 = this; var this$1 = this;
var input = this, cm = this.cm; var input = this, cm = this.cm;
this.createField(display);
var te = this.textarea;
// Wraps and hides input textarea display.wrapper.insertBefore(this.wrapper, display.wrapper.firstChild);
var div = this.wrapper = hiddenTextarea();
// The semihidden textarea that is focused when the editor is
// focused, and receives input.
var te = this.textarea = div.firstChild;
display.wrapper.insertBefore(div, display.wrapper.firstChild);
// Needed to hide big blue blinking cursor on Mobile Safari (doesn't seem to work in iOS 8 anymore) // Needed to hide big blue blinking cursor on Mobile Safari (doesn't seem to work in iOS 8 anymore)
if (ios) { te.style.width = "0px"; } if (ios) { te.style.width = "0px"; }
...@@ -21319,6 +21347,14 @@ TextareaInput.prototype.init = function (display) { ...@@ -21319,6 +21347,14 @@ TextareaInput.prototype.init = function (display) {
}); });
}; };
TextareaInput.prototype.createField = function (_display) {
// Wraps and hides input textarea
this.wrapper = hiddenTextarea();
// The semihidden textarea that is focused when the editor is
// focused, and receives input.
this.textarea = this.wrapper.firstChild;
};
TextareaInput.prototype.prepareSelection = function () { TextareaInput.prototype.prepareSelection = function () {
// Redraw the selection and/or cursor // Redraw the selection and/or cursor
var cm = this.cm, display = cm.display, doc = cm.doc; var cm = this.cm, display = cm.display, doc = cm.doc;
...@@ -21712,7 +21748,7 @@ CodeMirror$1.fromTextArea = fromTextArea; ...@@ -21712,7 +21748,7 @@ CodeMirror$1.fromTextArea = fromTextArea;
addLegacyProps(CodeMirror$1); addLegacyProps(CodeMirror$1);
CodeMirror$1.version = "5.31.0"; CodeMirror$1.version = "5.39.0";
return CodeMirror$1; return CodeMirror$1;
...@@ -46544,7 +46580,7 @@ CodeMirror.defineMode("markdown", function(cmCfg, modeCfg) { ...@@ -46544,7 +46580,7 @@ CodeMirror.defineMode("markdown", function(cmCfg, modeCfg) {
, setextHeaderRE = /^ *(?:\={1,}|-{1,})\s*$/ , setextHeaderRE = /^ *(?:\={1,}|-{1,})\s*$/
, textRE = /^[^#!\[\]*_\\<>` "'(~:]+/ , textRE = /^[^#!\[\]*_\\<>` "'(~:]+/
, fencedCodeRE = /^(~~~+|```+)[ \t]*([\w+#-]*)[^\n`]*$/ , fencedCodeRE = /^(~~~+|```+)[ \t]*([\w+#-]*)[^\n`]*$/
, linkDefRE = /^\s*\[[^\]]+?\]:\s*\S+(\s*\S*\s*)?$/ // naive link-definition , linkDefRE = /^\s*\[[^\]]+?\]:.*$/ // naive link-definition
, punctuation = /[!\"#$%&\'()*+,\-\.\/:;<=>?@\[\\\]^_`{|}~—]/ , punctuation = /[!\"#$%&\'()*+,\-\.\/:;<=>?@\[\\\]^_`{|}~—]/
, expandedTab = " " // CommonMark specifies tab as 4 spaces , expandedTab = " " // CommonMark specifies tab as 4 spaces
...@@ -46567,6 +46603,8 @@ CodeMirror.defineMode("markdown", function(cmCfg, modeCfg) { ...@@ -46567,6 +46603,8 @@ CodeMirror.defineMode("markdown", function(cmCfg, modeCfg) {
function blankLine(state) { function blankLine(state) {
// Reset linkTitle state // Reset linkTitle state
state.linkTitle = false; state.linkTitle = false;
state.linkHref = false;
state.linkText = false;
// Reset EM state // Reset EM state
state.em = false; state.em = false;
// Reset STRONG state // Reset STRONG state
...@@ -46578,8 +46616,17 @@ CodeMirror.defineMode("markdown", function(cmCfg, modeCfg) { ...@@ -46578,8 +46616,17 @@ CodeMirror.defineMode("markdown", function(cmCfg, modeCfg) {
// Reset state.indentedCode // Reset state.indentedCode
state.indentedCode = false; state.indentedCode = false;
if (state.f == htmlBlock) { if (state.f == htmlBlock) {
state.f = inlineNormal; var exit = htmlModeMissing
state.block = blockNormal; if (!exit) {
var inner = CodeMirror.innerMode(htmlMode, state.htmlState)
exit = inner.mode.name == "xml" && inner.state.tagStart === null &&
(!inner.state.context && inner.state.tokenize.isInText)
}
if (exit) {
state.f = inlineNormal;
state.block = blockNormal;
state.htmlState = null;
}
} }
// Reset state.trailingSpace // Reset state.trailingSpace
state.trailingSpace = 0; state.trailingSpace = 0;
...@@ -46605,6 +46652,12 @@ CodeMirror.defineMode("markdown", function(cmCfg, modeCfg) { ...@@ -46605,6 +46652,12 @@ CodeMirror.defineMode("markdown", function(cmCfg, modeCfg) {
if (state.indentationDiff === null) { if (state.indentationDiff === null) {
state.indentationDiff = state.indentation; state.indentationDiff = state.indentation;
if (prevLineIsList) { if (prevLineIsList) {
// Reset inline styles which shouldn't propagate aross list items
state.em = false;
state.strong = false;
state.code = false;
state.strikethrough = false;
state.list = null; state.list = null;
// While this list item's marker's indentation is less than the deepest // While this list item's marker's indentation is less than the deepest
// list item's content's indentation,pop the deepest list item // list item's content's indentation,pop the deepest list item
...@@ -46980,7 +47033,7 @@ CodeMirror.defineMode("markdown", function(cmCfg, modeCfg) { ...@@ -46980,7 +47033,7 @@ CodeMirror.defineMode("markdown", function(cmCfg, modeCfg) {
return type + tokenTypes.linkEmail; return type + tokenTypes.linkEmail;
} }
if (modeCfg.xml && ch === '<' && stream.match(/^(!--|[a-z]+(?:\s+[a-z_:.\-]+(?:\s*=\s*[^ >]+)?)*\s*>)/i, false)) { if (modeCfg.xml && ch === '<' && stream.match(/^(!--|\?|!\[CDATA\[|[a-z][a-z0-9-]*(?:\s+[a-z_:.\-]+(?:\s*=\s*[^>]+)?)*\s*(?:>|$))/i, false)) {
var end = stream.string.indexOf(">", stream.pos); var end = stream.string.indexOf(">", stream.pos);
if (end != -1) { if (end != -1) {
var atts = stream.string.substring(stream.start, end); var atts = stream.string.substring(stream.start, end);
...@@ -47065,7 +47118,7 @@ CodeMirror.defineMode("markdown", function(cmCfg, modeCfg) { ...@@ -47065,7 +47118,7 @@ CodeMirror.defineMode("markdown", function(cmCfg, modeCfg) {
} }
if (ch === ' ') { if (ch === ' ') {
if (stream.match(/ +$/, false)) { if (stream.match(/^ +$/, false)) {
state.trailingSpace++; state.trailingSpace++;
} else if (state.trailingSpace) { } else if (state.trailingSpace) {
state.trailingSpaceNewLine = true; state.trailingSpaceNewLine = true;
...@@ -47231,6 +47284,7 @@ CodeMirror.defineMode("markdown", function(cmCfg, modeCfg) { ...@@ -47231,6 +47284,7 @@ CodeMirror.defineMode("markdown", function(cmCfg, modeCfg) {
formatting: false, formatting: false,
linkText: s.linkText, linkText: s.linkText,
linkTitle: s.linkTitle, linkTitle: s.linkTitle,
linkHref: s.linkHref,
code: s.code, code: s.code,
em: s.em, em: s.em,
strong: s.strong, strong: s.strong,
...@@ -47310,6 +47364,8 @@ CodeMirror.defineMode("markdown", function(cmCfg, modeCfg) { ...@@ -47310,6 +47364,8 @@ CodeMirror.defineMode("markdown", function(cmCfg, modeCfg) {
return mode; return mode;
}, "xml"); }, "xml");
CodeMirror.defineMIME("text/markdown", "markdown");
CodeMirror.defineMIME("text/x-markdown", "markdown"); CodeMirror.defineMIME("text/x-markdown", "markdown");
}); });
...@@ -47373,6 +47429,7 @@ var xmlConfig = { ...@@ -47373,6 +47429,7 @@ var xmlConfig = {
doNotIndent: {}, doNotIndent: {},
allowUnquoted: false, allowUnquoted: false,
allowMissing: false, allowMissing: false,
allowMissingTagName: false,
caseFold: false caseFold: false
} }
...@@ -47483,8 +47540,9 @@ CodeMirror.defineMode("xml", function(editorConf, config_) { ...@@ -47483,8 +47540,9 @@ CodeMirror.defineMode("xml", function(editorConf, config_) {
stream.next(); stream.next();
} }
return style; return style;
}; }
} }
function doctype(depth) { function doctype(depth) {
return function(stream, state) { return function(stream, state) {
var ch; var ch;
...@@ -47547,6 +47605,9 @@ CodeMirror.defineMode("xml", function(editorConf, config_) { ...@@ -47547,6 +47605,9 @@ CodeMirror.defineMode("xml", function(editorConf, config_) {
state.tagName = stream.current(); state.tagName = stream.current();
setStyle = "tag"; setStyle = "tag";
return attrState; return attrState;
} else if (config.allowMissingTagName && type == "endTag") {
setStyle = "tag bracket";
return attrState(type, stream, state);
} else { } else {
setStyle = "error"; setStyle = "error";
return tagNameState; return tagNameState;
...@@ -47565,6 +47626,9 @@ CodeMirror.defineMode("xml", function(editorConf, config_) { ...@@ -47565,6 +47626,9 @@ CodeMirror.defineMode("xml", function(editorConf, config_) {
setStyle = "tag error"; setStyle = "tag error";
return closeStateErr; return closeStateErr;
} }
} else if (config.allowMissingTagName && type == "endTag") {
setStyle = "tag bracket";
return closeState(type, stream, state);
} else { } else {
setStyle = "error"; setStyle = "error";
return closeStateErr; return closeStateErr;
...@@ -47818,10 +47882,11 @@ CodeMirror.overlayMode = function(base, overlay, combine) { ...@@ -47818,10 +47882,11 @@ CodeMirror.overlayMode = function(base, overlay, combine) {
/* WEBPACK VAR INJECTION */(function(global) {/** /* WEBPACK VAR INJECTION */(function(global) {/**
* marked - a markdown parser * marked - a markdown parser
* Copyright (c) 2011-2014, Christopher Jeffrey. (MIT Licensed) * Copyright (c) 2011-2014, Christopher Jeffrey. (MIT Licensed)
* https://github.com/chjj/marked * https://github.com/markedjs/marked
*/ */
;(function() { ;(function(root) {
'use strict';
/** /**
* Block-Level Grammar * Block-Level Grammar
...@@ -47831,55 +47896,60 @@ var block = { ...@@ -47831,55 +47896,60 @@ var block = {
newline: /^\n+/, newline: /^\n+/,
code: /^( {4}[^\n]+\n*)+/, code: /^( {4}[^\n]+\n*)+/,
fences: noop, fences: noop,
hr: /^( *[-*_]){3,} *(?:\n+|$)/, hr: /^ {0,3}((?:- *){3,}|(?:_ *){3,}|(?:\* *){3,})(?:\n+|$)/,
heading: /^ *(#{1,6}) *([^\n]+?) *#* *(?:\n+|$)/, heading: /^ *(#{1,6}) *([^\n]+?) *#* *(?:\n+|$)/,
nptable: noop, nptable: noop,
lheading: /^([^\n]+)\n *(=|-){2,} *(?:\n+|$)/, blockquote: /^( {0,3}> ?(paragraph|[^\n]*)(?:\n|$))+/,
blockquote: /^( *>[^\n]+(\n(?!def)[^\n]+)*\n*)+/,
list: /^( *)(bull) [\s\S]+?(?:hr|def|\n{2,}(?! )(?!\1bull )\n*|\s*$)/, list: /^( *)(bull) [\s\S]+?(?:hr|def|\n{2,}(?! )(?!\1bull )\n*|\s*$)/,
html: /^ *(?:comment *(?:\n|\s*$)|closed *(?:\n{2,}|\s*$)|closing *(?:\n{2,}|\s*$))/, html: /^ *(?:comment *(?:\n|\s*$)|closed *(?:\n{2,}|\s*$)|closing *(?:\n{2,}|\s*$))/,
def: /^ *\[([^\]]+)\]: *<?([^\s>]+)>?(?: +["(]([^\n]+)[")])? *(?:\n+|$)/, def: /^ {0,3}\[(label)\]: *\n? *<?([^\s>]+)>?(?:(?: +\n? *| *\n *)(title))? *(?:\n+|$)/,
table: noop, table: noop,
paragraph: /^((?:[^\n]+\n?(?!hr|heading|lheading|blockquote|tag|def))+)\n*/, lheading: /^([^\n]+)\n *(=|-){2,} *(?:\n+|$)/,
paragraph: /^([^\n]+(?:\n?(?!hr|heading|lheading| {0,3}>|tag)[^\n]+)+)/,
text: /^[^\n]+/ text: /^[^\n]+/
}; };
block._label = /(?:\\[\[\]]|[^\[\]])+/;
block._title = /(?:"(?:\\"|[^"]|"[^"\n]*")*"|'\n?(?:[^'\n]+\n?)*'|\([^()]*\))/;
block.def = edit(block.def)
.replace('label', block._label)
.replace('title', block._title)
.getRegex();
block.bullet = /(?:[*+-]|\d+\.)/; block.bullet = /(?:[*+-]|\d+\.)/;
block.item = /^( *)(bull) [^\n]*(?:\n(?!\1bull )[^\n]*)*/; block.item = /^( *)(bull) [^\n]*(?:\n(?!\1bull )[^\n]*)*/;
block.item = replace(block.item, 'gm') block.item = edit(block.item, 'gm')
(/bull/g, block.bullet) .replace(/bull/g, block.bullet)
(); .getRegex();
block.list = replace(block.list) block.list = edit(block.list)
(/bull/g, block.bullet) .replace(/bull/g, block.bullet)
('hr', '\\n+(?=\\1?(?:[-*_] *){3,}(?:\\n+|$))') .replace('hr', '\\n+(?=\\1?(?:(?:- *){3,}|(?:_ *){3,}|(?:\\* *){3,})(?:\\n+|$))')
('def', '\\n+(?=' + block.def.source + ')') .replace('def', '\\n+(?=' + block.def.source + ')')
(); .getRegex();
block.blockquote = replace(block.blockquote)
('def', block.def)
();
block._tag = '(?!(?:' block._tag = '(?!(?:'
+ 'a|em|strong|small|s|cite|q|dfn|abbr|data|time|code' + 'a|em|strong|small|s|cite|q|dfn|abbr|data|time|code'
+ '|var|samp|kbd|sub|sup|i|b|u|mark|ruby|rt|rp|bdi|bdo' + '|var|samp|kbd|sub|sup|i|b|u|mark|ruby|rt|rp|bdi|bdo'
+ '|span|br|wbr|ins|del|img)\\b)\\w+(?!:/|[^\\w\\s@]*@)\\b'; + '|span|br|wbr|ins|del|img)\\b)\\w+(?!:|[^\\w\\s@]*@)\\b';
block.html = replace(block.html) block.html = edit(block.html)
('comment', /<!--[\s\S]*?-->/) .replace('comment', /<!--[\s\S]*?-->/)
('closed', /<(tag)[\s\S]+?<\/\1>/) .replace('closed', /<(tag)[\s\S]+?<\/\1>/)
('closing', /<tag(?:"[^"]*"|'[^']*'|[^'">])*?>/) .replace('closing', /<tag(?:"[^"]*"|'[^']*'|\s[^'"\/>\s]*)*?\/?>/)
(/tag/g, block._tag) .replace(/tag/g, block._tag)
(); .getRegex();
block.paragraph = replace(block.paragraph) block.paragraph = edit(block.paragraph)
('hr', block.hr) .replace('hr', block.hr)
('heading', block.heading) .replace('heading', block.heading)
('lheading', block.lheading) .replace('lheading', block.lheading)
('blockquote', block.blockquote) .replace('tag', '<' + block._tag)
('tag', '<' + block._tag) .getRegex();
('def', block.def)
(); block.blockquote = edit(block.blockquote)
.replace('paragraph', block.paragraph)
.getRegex();
/** /**
* Normal Block Grammar * Normal Block Grammar
...@@ -47892,16 +47962,16 @@ block.normal = merge({}, block); ...@@ -47892,16 +47962,16 @@ block.normal = merge({}, block);
*/ */
block.gfm = merge({}, block.normal, { block.gfm = merge({}, block.normal, {
fences: /^ *(`{3,}|~{3,})[ \.]*(\S+)? *\n([\s\S]*?)\s*\1 *(?:\n+|$)/, fences: /^ *(`{3,}|~{3,})[ \.]*(\S+)? *\n([\s\S]*?)\n? *\1 *(?:\n+|$)/,
paragraph: /^/, paragraph: /^/,
heading: /^ *(#{1,6}) +([^\n]+?) *#* *(?:\n+|$)/ heading: /^ *(#{1,6}) +([^\n]+?) *#* *(?:\n+|$)/
}); });
block.gfm.paragraph = replace(block.paragraph) block.gfm.paragraph = edit(block.paragraph)
('(?!', '(?!' .replace('(?!', '(?!'
+ block.gfm.fences.source.replace('\\1', '\\2') + '|' + block.gfm.fences.source.replace('\\1', '\\2') + '|'
+ block.list.source.replace('\\1', '\\3') + '|') + block.list.source.replace('\\1', '\\3') + '|')
(); .getRegex();
/** /**
* GFM + Tables Block Grammar * GFM + Tables Block Grammar
...@@ -47964,17 +48034,19 @@ Lexer.prototype.lex = function(src) { ...@@ -47964,17 +48034,19 @@ Lexer.prototype.lex = function(src) {
* Lexing * Lexing
*/ */
Lexer.prototype.token = function(src, top, bq) { Lexer.prototype.token = function(src, top) {
var src = src.replace(/^ +$/gm, '') src = src.replace(/^ +$/gm, '');
, next var next,
, loose loose,
, cap cap,
, bull bull,
, b b,
, item item,
, space space,
, i i,
, l; tag,
l,
isordered;
while (src) { while (src) {
// newline // newline
...@@ -48054,17 +48126,6 @@ Lexer.prototype.token = function(src, top, bq) { ...@@ -48054,17 +48126,6 @@ Lexer.prototype.token = function(src, top, bq) {
continue; continue;
} }
// lheading
if (cap = this.rules.lheading.exec(src)) {
src = src.substring(cap[0].length);
this.tokens.push({
type: 'heading',
depth: cap[2] === '=' ? 1 : 2,
text: cap[1]
});
continue;
}
// hr // hr
if (cap = this.rules.hr.exec(src)) { if (cap = this.rules.hr.exec(src)) {
src = src.substring(cap[0].length); src = src.substring(cap[0].length);
...@@ -48087,7 +48148,7 @@ Lexer.prototype.token = function(src, top, bq) { ...@@ -48087,7 +48148,7 @@ Lexer.prototype.token = function(src, top, bq) {
// Pass `top` to keep the current // Pass `top` to keep the current
// "toplevel" state. This is exactly // "toplevel" state. This is exactly
// how markdown.pl works. // how markdown.pl works.
this.token(cap, top, true); this.token(cap, top);
this.tokens.push({ this.tokens.push({
type: 'blockquote_end' type: 'blockquote_end'
...@@ -48100,10 +48161,12 @@ Lexer.prototype.token = function(src, top, bq) { ...@@ -48100,10 +48161,12 @@ Lexer.prototype.token = function(src, top, bq) {
if (cap = this.rules.list.exec(src)) { if (cap = this.rules.list.exec(src)) {
src = src.substring(cap[0].length); src = src.substring(cap[0].length);
bull = cap[2]; bull = cap[2];
isordered = bull.length > 1;
this.tokens.push({ this.tokens.push({
type: 'list_start', type: 'list_start',
ordered: bull.length > 1 ordered: isordered,
start: isordered ? +bull : ''
}); });
// Get each top-level item. // Get each top-level item.
...@@ -48156,7 +48219,7 @@ Lexer.prototype.token = function(src, top, bq) { ...@@ -48156,7 +48219,7 @@ Lexer.prototype.token = function(src, top, bq) {
}); });
// Recurse. // Recurse.
this.token(item, false, bq); this.token(item, false);
this.tokens.push({ this.tokens.push({
type: 'list_item_end' type: 'list_item_end'
...@@ -48185,12 +48248,16 @@ Lexer.prototype.token = function(src, top, bq) { ...@@ -48185,12 +48248,16 @@ Lexer.prototype.token = function(src, top, bq) {
} }
// def // def
if ((!bq && top) && (cap = this.rules.def.exec(src))) { if (top && (cap = this.rules.def.exec(src))) {
src = src.substring(cap[0].length); src = src.substring(cap[0].length);
this.tokens.links[cap[1].toLowerCase()] = { if (cap[3]) cap[3] = cap[3].substring(1, cap[3].length - 1);
href: cap[2], tag = cap[1].toLowerCase();
title: cap[3] if (!this.tokens.links[tag]) {
}; this.tokens.links[tag] = {
href: cap[2],
title: cap[3]
};
}
continue; continue;
} }
...@@ -48228,6 +48295,17 @@ Lexer.prototype.token = function(src, top, bq) { ...@@ -48228,6 +48295,17 @@ Lexer.prototype.token = function(src, top, bq) {
continue; continue;
} }
// lheading
if (cap = this.rules.lheading.exec(src)) {
src = src.substring(cap[0].length);
this.tokens.push({
type: 'heading',
depth: cap[2] === '=' ? 1 : 2,
text: cap[1]
});
continue;
}
// top-level paragraph // top-level paragraph
if (top && (cap = this.rules.paragraph.exec(src))) { if (top && (cap = this.rules.paragraph.exec(src))) {
src = src.substring(cap[0].length); src = src.substring(cap[0].length);
...@@ -48252,8 +48330,7 @@ Lexer.prototype.token = function(src, top, bq) { ...@@ -48252,8 +48330,7 @@ Lexer.prototype.token = function(src, top, bq) {
} }
if (src) { if (src) {
throw new throw new Error('Infinite loop on byte: ' + src.charCodeAt(0));
Error('Infinite loop on byte: ' + src.charCodeAt(0));
} }
} }
...@@ -48266,31 +48343,39 @@ Lexer.prototype.token = function(src, top, bq) { ...@@ -48266,31 +48343,39 @@ Lexer.prototype.token = function(src, top, bq) {
var inline = { var inline = {
escape: /^\\([\\`*{}\[\]()#+\-.!_>])/, escape: /^\\([\\`*{}\[\]()#+\-.!_>])/,
autolink: /^<([^ >]+(@|:\/)[^ >]+)>/, autolink: /^<(scheme:[^\s\x00-\x1f<>]*|email)>/,
url: noop, url: noop,
tag: /^<!--[\s\S]*?-->|^<\/?\w+(?:"[^"]*"|'[^']*'|[^'">])*?>/, tag: /^<!--[\s\S]*?-->|^<\/?[a-zA-Z0-9\-]+(?:"[^"]*"|'[^']*'|\s[^<'">\/\s]*)*?\/?>/,
link: /^!?\[(inside)\]\(href\)/, link: /^!?\[(inside)\]\(href\)/,
reflink: /^!?\[(inside)\]\s*\[([^\]]*)\]/, reflink: /^!?\[(inside)\]\s*\[([^\]]*)\]/,
nolink: /^!?\[((?:\[[^\]]*\]|[^\[\]])*)\]/, nolink: /^!?\[((?:\[[^\[\]]*\]|\\[\[\]]|[^\[\]])*)\]/,
strong: /^__([\s\S]+?)__(?!_)|^\*\*([\s\S]+?)\*\*(?!\*)/, strong: /^__([\s\S]+?)__(?!_)|^\*\*([\s\S]+?)\*\*(?!\*)/,
em: /^\b_((?:[^_]|__)+?)_\b|^\*((?:\*\*|[\s\S])+?)\*(?!\*)/, em: /^_([^\s_](?:[^_]|__)+?[^\s_])_\b|^\*((?:\*\*|[^*])+?)\*(?!\*)/,
code: /^(`+)\s*([\s\S]*?[^`])\s*\1(?!`)/, code: /^(`+)\s*([\s\S]*?[^`]?)\s*\1(?!`)/,
br: /^ {2,}\n(?!\s*$)/, br: /^ {2,}\n(?!\s*$)/,
del: noop, del: noop,
text: /^[\s\S]+?(?=[\\<!\[_*`]| {2,}\n|$)/ text: /^[\s\S]+?(?=[\\<!\[`*]|\b_| {2,}\n|$)/
}; };
inline._inside = /(?:\[[^\]]*\]|[^\[\]]|\](?=[^\[]*\]))*/; inline._scheme = /[a-zA-Z][a-zA-Z0-9+.-]{1,31}/;
inline._email = /[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+(@)[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+(?![-_])/;
inline.autolink = edit(inline.autolink)
.replace('scheme', inline._scheme)
.replace('email', inline._email)
.getRegex()
inline._inside = /(?:\[[^\[\]]*\]|\\[\[\]]|[^\[\]]|\](?=[^\[]*\]))*/;
inline._href = /\s*<?([\s\S]*?)>?(?:\s+['"]([\s\S]*?)['"])?\s*/; inline._href = /\s*<?([\s\S]*?)>?(?:\s+['"]([\s\S]*?)['"])?\s*/;
inline.link = replace(inline.link) inline.link = edit(inline.link)
('inside', inline._inside) .replace('inside', inline._inside)
('href', inline._href) .replace('href', inline._href)
(); .getRegex();
inline.reflink = replace(inline.reflink) inline.reflink = edit(inline.reflink)
('inside', inline._inside) .replace('inside', inline._inside)
(); .getRegex();
/** /**
* Normal Inline Grammar * Normal Inline Grammar
...@@ -48312,13 +48397,16 @@ inline.pedantic = merge({}, inline.normal, { ...@@ -48312,13 +48397,16 @@ inline.pedantic = merge({}, inline.normal, {
*/ */
inline.gfm = merge({}, inline.normal, { inline.gfm = merge({}, inline.normal, {
escape: replace(inline.escape)('])', '~|])')(), escape: edit(inline.escape).replace('])', '~|])').getRegex(),
url: /^(https?:\/\/[^\s<]+[^<.,:;"')\]\s])/, url: edit(/^((?:ftp|https?):\/\/|www\.)(?:[a-zA-Z0-9\-]+\.?)+[^\s<]*|^email/)
.replace('email', inline._email)
.getRegex(),
_backpedal: /(?:[^?!.,:;*_~()&]+|\([^)]*\)|&(?![a-zA-Z0-9]+;$)|[?!.,:;*_~)]+(?!$))+/,
del: /^~~(?=\S)([\s\S]*?\S)~~/, del: /^~~(?=\S)([\s\S]*?\S)~~/,
text: replace(inline.text) text: edit(inline.text)
(']|', '~]|') .replace(']|', '~]|')
('|', '|https?://|') .replace('|', '|https?://|ftp://|www\\.|[a-zA-Z0-9.!#$%&\'*+/=?^_`{\\|}~-]+@|')
() .getRegex()
}); });
/** /**
...@@ -48326,8 +48414,8 @@ inline.gfm = merge({}, inline.normal, { ...@@ -48326,8 +48414,8 @@ inline.gfm = merge({}, inline.normal, {
*/ */
inline.breaks = merge({}, inline.gfm, { inline.breaks = merge({}, inline.gfm, {
br: replace(inline.br)('{2,}', '*')(), br: edit(inline.br).replace('{2,}', '*').getRegex(),
text: replace(inline.gfm.text)('{2,}', '*')() text: edit(inline.gfm.text).replace('{2,}', '*').getRegex()
}); });
/** /**
...@@ -48338,12 +48426,11 @@ function InlineLexer(links, options) { ...@@ -48338,12 +48426,11 @@ function InlineLexer(links, options) {
this.options = options || marked.defaults; this.options = options || marked.defaults;
this.links = links; this.links = links;
this.rules = inline.normal; this.rules = inline.normal;
this.renderer = this.options.renderer || new Renderer; this.renderer = this.options.renderer || new Renderer();
this.renderer.options = this.options; this.renderer.options = this.options;
if (!this.links) { if (!this.links) {
throw new throw new Error('Tokens array requires a `links` property.');
Error('Tokens array requires a `links` property.');
} }
if (this.options.gfm) { if (this.options.gfm) {
...@@ -48377,11 +48464,11 @@ InlineLexer.output = function(src, links, options) { ...@@ -48377,11 +48464,11 @@ InlineLexer.output = function(src, links, options) {
*/ */
InlineLexer.prototype.output = function(src) { InlineLexer.prototype.output = function(src) {
var out = '' var out = '',
, link link,
, text text,
, href href,
, cap; cap;
while (src) { while (src) {
// escape // escape
...@@ -48395,10 +48482,8 @@ InlineLexer.prototype.output = function(src) { ...@@ -48395,10 +48482,8 @@ InlineLexer.prototype.output = function(src) {
if (cap = this.rules.autolink.exec(src)) { if (cap = this.rules.autolink.exec(src)) {
src = src.substring(cap[0].length); src = src.substring(cap[0].length);
if (cap[2] === '@') { if (cap[2] === '@') {
text = cap[1].charAt(6) === ':' text = escape(this.mangle(cap[1]));
? this.mangle(cap[1].substring(7)) href = 'mailto:' + text;
: this.mangle(cap[1]);
href = this.mangle('mailto:') + text;
} else { } else {
text = escape(cap[1]); text = escape(cap[1]);
href = text; href = text;
...@@ -48409,9 +48494,19 @@ InlineLexer.prototype.output = function(src) { ...@@ -48409,9 +48494,19 @@ InlineLexer.prototype.output = function(src) {
// url (gfm) // url (gfm)
if (!this.inLink && (cap = this.rules.url.exec(src))) { if (!this.inLink && (cap = this.rules.url.exec(src))) {
cap[0] = this.rules._backpedal.exec(cap[0])[0];
src = src.substring(cap[0].length); src = src.substring(cap[0].length);
text = escape(cap[1]); if (cap[2] === '@') {
href = text; text = escape(cap[0]);
href = 'mailto:' + text;
} else {
text = escape(cap[0]);
if (cap[1] === 'www.') {
href = 'http://' + text;
} else {
href = text;
}
}
out += this.renderer.link(href, null, text); out += this.renderer.link(href, null, text);
continue; continue;
} }
...@@ -48478,7 +48573,7 @@ InlineLexer.prototype.output = function(src) { ...@@ -48478,7 +48573,7 @@ InlineLexer.prototype.output = function(src) {
// code // code
if (cap = this.rules.code.exec(src)) { if (cap = this.rules.code.exec(src)) {
src = src.substring(cap[0].length); src = src.substring(cap[0].length);
out += this.renderer.codespan(escape(cap[2], true)); out += this.renderer.codespan(escape(cap[2].trim(), true));
continue; continue;
} }
...@@ -48504,8 +48599,7 @@ InlineLexer.prototype.output = function(src) { ...@@ -48504,8 +48599,7 @@ InlineLexer.prototype.output = function(src) {
} }
if (src) { if (src) {
throw new throw new Error('Infinite loop on byte: ' + src.charCodeAt(0));
Error('Infinite loop on byte: ' + src.charCodeAt(0));
} }
} }
...@@ -48517,8 +48611,8 @@ InlineLexer.prototype.output = function(src) { ...@@ -48517,8 +48611,8 @@ InlineLexer.prototype.output = function(src) {
*/ */
InlineLexer.prototype.outputLink = function(cap, link) { InlineLexer.prototype.outputLink = function(cap, link) {
var href = escape(link.href) var href = escape(link.href),
, title = link.title ? escape(link.title) : null; title = link.title ? escape(link.title) : null;
return cap[0].charAt(0) !== '!' return cap[0].charAt(0) !== '!'
? this.renderer.link(href, title, this.output(cap[1])) ? this.renderer.link(href, title, this.output(cap[1]))
...@@ -48554,10 +48648,10 @@ InlineLexer.prototype.smartypants = function(text) { ...@@ -48554,10 +48648,10 @@ InlineLexer.prototype.smartypants = function(text) {
InlineLexer.prototype.mangle = function(text) { InlineLexer.prototype.mangle = function(text) {
if (!this.options.mangle) return text; if (!this.options.mangle) return text;
var out = '' var out = '',
, l = text.length l = text.length,
, i = 0 i = 0,
, ch; ch;
for (; i < l; i++) { for (; i < l; i++) {
ch = text.charCodeAt(i); ch = text.charCodeAt(i);
...@@ -48626,9 +48720,10 @@ Renderer.prototype.hr = function() { ...@@ -48626,9 +48720,10 @@ Renderer.prototype.hr = function() {
return this.options.xhtml ? '<hr/>\n' : '<hr>\n'; return this.options.xhtml ? '<hr/>\n' : '<hr>\n';
}; };
Renderer.prototype.list = function(body, ordered) { Renderer.prototype.list = function(body, ordered, start) {
var type = ordered ? 'ol' : 'ul'; var type = ordered ? 'ol' : 'ul',
return '<' + type + '>\n' + body + '</' + type + '>\n'; startatt = (ordered && start !== 1) ? (' start="' + start + '"') : '';
return '<' + type + startatt + '>\n' + body + '</' + type + '>\n';
}; };
Renderer.prototype.listitem = function(text) { Renderer.prototype.listitem = function(text) {
...@@ -48690,12 +48785,15 @@ Renderer.prototype.link = function(href, title, text) { ...@@ -48690,12 +48785,15 @@ Renderer.prototype.link = function(href, title, text) {
.replace(/[^\w:]/g, '') .replace(/[^\w:]/g, '')
.toLowerCase(); .toLowerCase();
} catch (e) { } catch (e) {
return ''; return text;
} }
if (prot.indexOf('javascript:') === 0 || prot.indexOf('vbscript:') === 0) { if (prot.indexOf('javascript:') === 0 || prot.indexOf('vbscript:') === 0 || prot.indexOf('data:') === 0) {
return ''; return text;
} }
} }
if (this.options.baseUrl && !originIndependentUrl.test(href)) {
href = resolveUrl(this.options.baseUrl, href);
}
var out = '<a href="' + href + '"'; var out = '<a href="' + href + '"';
if (title) { if (title) {
out += ' title="' + title + '"'; out += ' title="' + title + '"';
...@@ -48705,6 +48803,9 @@ Renderer.prototype.link = function(href, title, text) { ...@@ -48705,6 +48803,9 @@ Renderer.prototype.link = function(href, title, text) {
}; };
Renderer.prototype.image = function(href, title, text) { Renderer.prototype.image = function(href, title, text) {
if (this.options.baseUrl && !originIndependentUrl.test(href)) {
href = resolveUrl(this.options.baseUrl, href);
}
var out = '<img src="' + href + '" alt="' + text + '"'; var out = '<img src="' + href + '" alt="' + text + '"';
if (title) { if (title) {
out += ' title="' + title + '"'; out += ' title="' + title + '"';
...@@ -48717,6 +48818,32 @@ Renderer.prototype.text = function(text) { ...@@ -48717,6 +48818,32 @@ Renderer.prototype.text = function(text) {
return text; return text;
}; };
/**
* TextRenderer
* returns only the textual part of the token
*/
function TextRenderer() {}
// no need for block level renderers
TextRenderer.prototype.strong =
TextRenderer.prototype.em =
TextRenderer.prototype.codespan =
TextRenderer.prototype.del =
TextRenderer.prototype.text = function (text) {
return text;
}
TextRenderer.prototype.link =
TextRenderer.prototype.image = function(href, title, text) {
return '' + text;
}
TextRenderer.prototype.br = function() {
return '';
}
/** /**
* Parsing & Compiling * Parsing & Compiling
*/ */
...@@ -48725,7 +48852,7 @@ function Parser(options) { ...@@ -48725,7 +48852,7 @@ function Parser(options) {
this.tokens = []; this.tokens = [];
this.token = null; this.token = null;
this.options = options || marked.defaults; this.options = options || marked.defaults;
this.options.renderer = this.options.renderer || new Renderer; this.options.renderer = this.options.renderer || new Renderer();
this.renderer = this.options.renderer; this.renderer = this.options.renderer;
this.renderer.options = this.options; this.renderer.options = this.options;
} }
...@@ -48734,8 +48861,8 @@ function Parser(options) { ...@@ -48734,8 +48861,8 @@ function Parser(options) {
* Static Parse Method * Static Parse Method
*/ */
Parser.parse = function(src, options, renderer) { Parser.parse = function(src, options) {
var parser = new Parser(options, renderer); var parser = new Parser(options);
return parser.parse(src); return parser.parse(src);
}; };
...@@ -48744,7 +48871,12 @@ Parser.parse = function(src, options, renderer) { ...@@ -48744,7 +48871,12 @@ Parser.parse = function(src, options, renderer) {
*/ */
Parser.prototype.parse = function(src) { Parser.prototype.parse = function(src) {
this.inline = new InlineLexer(src.links, this.options, this.renderer); this.inline = new InlineLexer(src.links, this.options);
// use an InlineLexer with a TextRenderer to extract pure text
this.inlineText = new InlineLexer(
src.links,
merge({}, this.options, {renderer: new TextRenderer()})
);
this.tokens = src.reverse(); this.tokens = src.reverse();
var out = ''; var out = '';
...@@ -48801,7 +48933,7 @@ Parser.prototype.tok = function() { ...@@ -48801,7 +48933,7 @@ Parser.prototype.tok = function() {
return this.renderer.heading( return this.renderer.heading(
this.inline.output(this.token.text), this.inline.output(this.token.text),
this.token.depth, this.token.depth,
this.token.text); unescape(this.inlineText.output(this.token.text)));
} }
case 'code': { case 'code': {
return this.renderer.code(this.token.text, return this.renderer.code(this.token.text,
...@@ -48809,18 +48941,16 @@ Parser.prototype.tok = function() { ...@@ -48809,18 +48941,16 @@ Parser.prototype.tok = function() {
this.token.escaped); this.token.escaped);
} }
case 'table': { case 'table': {
var header = '' var header = '',
, body = '' body = '',
, i i,
, row row,
, cell cell,
, flags j;
, j;
// header // header
cell = ''; cell = '';
for (i = 0; i < this.token.header.length; i++) { for (i = 0; i < this.token.header.length; i++) {
flags = { header: true, align: this.token.align[i] };
cell += this.renderer.tablecell( cell += this.renderer.tablecell(
this.inline.output(this.token.header[i]), this.inline.output(this.token.header[i]),
{ header: true, align: this.token.align[i] } { header: true, align: this.token.align[i] }
...@@ -48844,7 +48974,7 @@ Parser.prototype.tok = function() { ...@@ -48844,7 +48974,7 @@ Parser.prototype.tok = function() {
return this.renderer.table(header, body); return this.renderer.table(header, body);
} }
case 'blockquote_start': { case 'blockquote_start': {
var body = ''; body = '';
while (this.next().type !== 'blockquote_end') { while (this.next().type !== 'blockquote_end') {
body += this.tok(); body += this.tok();
...@@ -48853,17 +48983,18 @@ Parser.prototype.tok = function() { ...@@ -48853,17 +48983,18 @@ Parser.prototype.tok = function() {
return this.renderer.blockquote(body); return this.renderer.blockquote(body);
} }
case 'list_start': { case 'list_start': {
var body = '' body = '';
, ordered = this.token.ordered; var ordered = this.token.ordered,
start = this.token.start;
while (this.next().type !== 'list_end') { while (this.next().type !== 'list_end') {
body += this.tok(); body += this.tok();
} }
return this.renderer.list(body, ordered); return this.renderer.list(body, ordered, start);
} }
case 'list_item_start': { case 'list_item_start': {
var body = ''; body = '';
while (this.next().type !== 'list_item_end') { while (this.next().type !== 'list_item_end') {
body += this.token.type === 'text' body += this.token.type === 'text'
...@@ -48874,7 +49005,7 @@ Parser.prototype.tok = function() { ...@@ -48874,7 +49005,7 @@ Parser.prototype.tok = function() {
return this.renderer.listitem(body); return this.renderer.listitem(body);
} }
case 'loose_item_start': { case 'loose_item_start': {
var body = ''; body = '';
while (this.next().type !== 'list_item_end') { while (this.next().type !== 'list_item_end') {
body += this.tok(); body += this.tok();
...@@ -48911,8 +49042,8 @@ function escape(html, encode) { ...@@ -48911,8 +49042,8 @@ function escape(html, encode) {
} }
function unescape(html) { function unescape(html) {
// explicitly match decimal, hex, and named HTML entities // explicitly match decimal, hex, and named HTML entities
return html.replace(/&(#(?:\d+)|(?:#x[0-9A-Fa-f]+)|(?:\w+));?/g, function(_, n) { return html.replace(/&(#(?:\d+)|(?:#x[0-9A-Fa-f]+)|(?:\w+));?/ig, function(_, n) {
n = n.toLowerCase(); n = n.toLowerCase();
if (n === 'colon') return ':'; if (n === 'colon') return ':';
if (n.charAt(0) === '#') { if (n.charAt(0) === '#') {
...@@ -48924,25 +49055,53 @@ function unescape(html) { ...@@ -48924,25 +49055,53 @@ function unescape(html) {
}); });
} }
function replace(regex, opt) { function edit(regex, opt) {
regex = regex.source; regex = regex.source;
opt = opt || ''; opt = opt || '';
return function self(name, val) { return {
if (!name) return new RegExp(regex, opt); replace: function(name, val) {
val = val.source || val; val = val.source || val;
val = val.replace(/(^|[^\[])\^/g, '$1'); val = val.replace(/(^|[^\[])\^/g, '$1');
regex = regex.replace(name, val); regex = regex.replace(name, val);
return self; return this;
},
getRegex: function() {
return new RegExp(regex, opt);
}
}; };
} }
function resolveUrl(base, href) {
if (!baseUrls[' ' + base]) {
// we can ignore everything in base after the last slash of its path component,
// but we might need to add _that_
// https://tools.ietf.org/html/rfc3986#section-3
if (/^[^:]+:\/*[^/]*$/.test(base)) {
baseUrls[' ' + base] = base + '/';
} else {
baseUrls[' ' + base] = base.replace(/[^/]*$/, '');
}
}
base = baseUrls[' ' + base];
if (href.slice(0, 2) === '//') {
return base.replace(/:[\s\S]*/, ':') + href;
} else if (href.charAt(0) === '/') {
return base.replace(/(:\/*[^/]*)[\s\S]*/, '$1') + href;
} else {
return base + href;
}
}
var baseUrls = {};
var originIndependentUrl = /^$|^[a-z][a-z0-9+.-]*:|^[?#]/i;
function noop() {} function noop() {}
noop.exec = noop; noop.exec = noop;
function merge(obj) { function merge(obj) {
var i = 1 var i = 1,
, target target,
, key; key;
for (; i < arguments.length; i++) { for (; i < arguments.length; i++) {
target = arguments[i]; target = arguments[i];
...@@ -48956,12 +49115,20 @@ function merge(obj) { ...@@ -48956,12 +49115,20 @@ function merge(obj) {
return obj; return obj;
} }
/** /**
* Marked * Marked
*/ */
function marked(src, opt, callback) { function marked(src, opt, callback) {
// throw error in case of non string input
if (typeof src === 'undefined' || src === null) {
throw new Error('marked(): input parameter is undefined or null');
}
if (typeof src !== 'string') {
throw new Error('marked(): input parameter is of type '
+ Object.prototype.toString.call(src) + ', string expected');
}
if (callback || typeof opt === 'function') { if (callback || typeof opt === 'function') {
if (!callback) { if (!callback) {
callback = opt; callback = opt;
...@@ -48970,10 +49137,10 @@ function marked(src, opt, callback) { ...@@ -48970,10 +49137,10 @@ function marked(src, opt, callback) {
opt = merge({}, marked.defaults, opt || {}); opt = merge({}, marked.defaults, opt || {});
var highlight = opt.highlight var highlight = opt.highlight,
, tokens tokens,
, pending pending,
, i = 0; i = 0;
try { try {
tokens = Lexer.lex(src, opt) tokens = Lexer.lex(src, opt)
...@@ -49035,9 +49202,9 @@ function marked(src, opt, callback) { ...@@ -49035,9 +49202,9 @@ function marked(src, opt, callback) {
if (opt) opt = merge({}, marked.defaults, opt); if (opt) opt = merge({}, marked.defaults, opt);
return Parser.parse(Lexer.lex(src, opt), opt); return Parser.parse(Lexer.lex(src, opt), opt);
} catch (e) { } catch (e) {
e.message += '\nPlease report this to https://github.com/chjj/marked.'; e.message += '\nPlease report this to https://github.com/markedjs/marked.';
if ((opt || marked.defaults).silent) { if ((opt || marked.defaults).silent) {
return '<p>An error occured:</p><pre>' return '<p>An error occurred:</p><pre>'
+ escape(e.message + '', true) + escape(e.message + '', true)
+ '</pre>'; + '</pre>';
} }
...@@ -49069,8 +49236,9 @@ marked.defaults = { ...@@ -49069,8 +49236,9 @@ marked.defaults = {
langPrefix: 'lang-', langPrefix: 'lang-',
smartypants: false, smartypants: false,
headerPrefix: '', headerPrefix: '',
renderer: new Renderer, renderer: new Renderer(),
xhtml: false xhtml: false,
baseUrl: null
}; };
/** /**
...@@ -49081,6 +49249,7 @@ marked.Parser = Parser; ...@@ -49081,6 +49249,7 @@ marked.Parser = Parser;
marked.parser = Parser.parse; marked.parser = Parser.parse;
marked.Renderer = Renderer; marked.Renderer = Renderer;
marked.TextRenderer = TextRenderer;
marked.Lexer = Lexer; marked.Lexer = Lexer;
marked.lexer = Lexer.lex; marked.lexer = Lexer.lex;
...@@ -49095,12 +49264,9 @@ if (true) { ...@@ -49095,12 +49264,9 @@ if (true) {
} else if (typeof define === 'function' && define.amd) { } else if (typeof define === 'function' && define.amd) {
define(function() { return marked; }); define(function() { return marked; });
} else { } else {
this.marked = marked; root.marked = marked;
} }
})(this || (typeof window !== 'undefined' ? window : global));
}).call(function() {
return this || (typeof window !== 'undefined' ? window : global);
}());
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(41))) /* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(41)))
...@@ -99660,7 +99826,7 @@ exports.default = { ...@@ -99660,7 +99826,7 @@ exports.default = {
/* 499 */ /* 499 */
/***/ (function(module, exports, __webpack_require__) { /***/ (function(module, exports, __webpack_require__) {
!function(e,t){ true?module.exports=t(__webpack_require__(500),__webpack_require__(202)):"function"==typeof define&&define.amd?define("VueSimpleMDE",["simplemde","marked"],t):"object"==typeof exports?exports.VueSimpleMDE=t(require("simplemde"),require("marked")):e.VueSimpleMDE=t(e.SimpleMDE,e.marked)}(this,function(e,t){return function(e){function t(r){if(n[r])return n[r].exports;var i=n[r]={i:r,l:!1,exports:{}};return e[r].call(i.exports,i,i.exports,t),i.l=!0,i.exports}var n={};return t.m=e,t.c=n,t.d=function(e,n,r){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="",t(t.s=0)}([function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=n(1);n.d(t,"markdownEditor",function(){return r.a}),t.default={markdownEditor:r.a,install:function(e){e.component("markdown-editor",r.a)}}},function(e,t,n){"use strict";function r(e){n(2)}var i=n(8),o=n(11),a=n(7),s=r,u=a(i.a,o.a,!1,s,null,null);t.a=u.exports},function(e,t,n){var r=n(3);"string"==typeof r&&(r=[[e.i,r,""]]),r.locals&&(e.exports=r.locals);n(5)("c9294450",r,!0)},function(e,t,n){t=e.exports=n(4)(void 0),t.push([e.i,".markdown-editor .markdown-body{padding:.5em}.markdown-editor .editor-preview-active,.markdown-editor .editor-preview-active-side{display:block}",""])},function(e,t){function n(e,t){var n=e[1]||"",i=e[3];if(!i)return n;if(t&&"function"==typeof btoa){var o=r(i);return[n].concat(i.sources.map(function(e){return"/*# sourceURL="+i.sourceRoot+e+" */"})).concat([o]).join("\n")}return[n].join("\n")}function r(e){return"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,"+btoa(unescape(encodeURIComponent(JSON.stringify(e))))+" */"}e.exports=function(e){var t=[];return t.toString=function(){return this.map(function(t){var r=n(t,e);return t[2]?"@media "+t[2]+"{"+r+"}":r}).join("")},t.i=function(e,n){"string"==typeof e&&(e=[[null,e,""]]);for(var r={},i=0;i<this.length;i++){var o=this[i][0];"number"==typeof o&&(r[o]=!0)}for(i=0;i<e.length;i++){var a=e[i];"number"==typeof a[0]&&r[a[0]]||(n&&!a[2]?a[2]=n:n&&(a[2]="("+a[2]+") and ("+n+")"),t.push(a))}},t}},function(e,t,n){function r(e){for(var t=0;t<e.length;t++){var n=e[t],r=c[n.id];if(r){r.refs++;for(var i=0;i<r.parts.length;i++)r.parts[i](n.parts[i]);for(;i<n.parts.length;i++)r.parts.push(o(n.parts[i]));r.parts.length>n.parts.length&&(r.parts.length=n.parts.length)}else{for(var a=[],i=0;i<n.parts.length;i++)a.push(o(n.parts[i]));c[n.id]={id:n.id,refs:1,parts:a}}}}function i(){var e=document.createElement("style");return e.type="text/css",l.appendChild(e),e}function o(e){var t,n,r=document.querySelector('style[data-vue-ssr-id~="'+e.id+'"]');if(r){if(m)return v;r.parentNode.removeChild(r)}if(h){var o=p++;r=f||(f=i()),t=a.bind(null,r,o,!1),n=a.bind(null,r,o,!0)}else r=i(),t=s.bind(null,r),n=function(){r.parentNode.removeChild(r)};return t(e),function(r){if(r){if(r.css===e.css&&r.media===e.media&&r.sourceMap===e.sourceMap)return;t(e=r)}else n()}}function a(e,t,n,r){var i=n?"":r.css;if(e.styleSheet)e.styleSheet.cssText=g(t,i);else{var o=document.createTextNode(i),a=e.childNodes;a[t]&&e.removeChild(a[t]),a.length?e.insertBefore(o,a[t]):e.appendChild(o)}}function s(e,t){var n=t.css,r=t.media,i=t.sourceMap;if(r&&e.setAttribute("media",r),i&&(n+="\n/*# sourceURL="+i.sources[0]+" */",n+="\n/*# sourceMappingURL=data:application/json;base64,"+btoa(unescape(encodeURIComponent(JSON.stringify(i))))+" */"),e.styleSheet)e.styleSheet.cssText=n;else{for(;e.firstChild;)e.removeChild(e.firstChild);e.appendChild(document.createTextNode(n))}}var u="undefined"!=typeof document;if("undefined"!=typeof DEBUG&&DEBUG&&!u)throw new Error("vue-style-loader cannot be used in a non-browser environment. Use { target: 'node' } in your Webpack config to indicate a server-rendering environment.");var d=n(6),c={},l=u&&(document.head||document.getElementsByTagName("head")[0]),f=null,p=0,m=!1,v=function(){},h="undefined"!=typeof navigator&&/msie [6-9]\b/.test(navigator.userAgent.toLowerCase());e.exports=function(e,t,n){m=n;var i=d(e,t);return r(i),function(t){for(var n=[],o=0;o<i.length;o++){var a=i[o],s=c[a.id];s.refs--,n.push(s)}t?(i=d(e,t),r(i)):i=[];for(var o=0;o<n.length;o++){var s=n[o];if(0===s.refs){for(var u=0;u<s.parts.length;u++)s.parts[u]();delete c[s.id]}}}};var g=function(){var e=[];return function(t,n){return e[t]=n,e.filter(Boolean).join("\n")}}()},function(e,t){e.exports=function(e,t){for(var n=[],r={},i=0;i<t.length;i++){var o=t[i],a=o[0],s=o[1],u=o[2],d=o[3],c={id:e+":"+i,css:s,media:u,sourceMap:d};r[a]?r[a].parts.push(c):n.push(r[a]={id:a,parts:[c]})}return n}},function(e,t){e.exports=function(e,t,n,r,i,o){var a,s=e=e||{},u=typeof e.default;"object"!==u&&"function"!==u||(a=e,s=e.default);var d="function"==typeof s?s.options:s;t&&(d.render=t.render,d.staticRenderFns=t.staticRenderFns,d._compiled=!0),n&&(d.functional=!0),i&&(d._scopeId=i);var c;if(o?(c=function(e){e=e||this.$vnode&&this.$vnode.ssrContext||this.parent&&this.parent.$vnode&&this.parent.$vnode.ssrContext,e||"undefined"==typeof __VUE_SSR_CONTEXT__||(e=__VUE_SSR_CONTEXT__),r&&r.call(this,e),e&&e._registeredComponents&&e._registeredComponents.add(o)},d._ssrRegister=c):r&&(c=r),c){var l=d.functional,f=l?d.render:d.beforeCreate;l?(d._injectStyles=c,d.render=function(e,t){return c.call(t),f(e,t)}):d.beforeCreate=f?[].concat(f,c):[c]}return{esModule:a,exports:s,options:d}}},function(e,t,n){"use strict";var r=n(9),i=n.n(r),o=n(10),a=n.n(o);t.a={name:"markdown-editor",props:{value:String,previewClass:String,autoinit:{type:Boolean,default:function(){return!0}},highlight:{type:Boolean,default:function(){return!1}},sanitize:{type:Boolean,default:function(){return!1}},configs:{type:Object,default:function(){return{}}}},mounted:function(){this.autoinit&&this.initialize()},activated:function(){var e=this.simplemde;if(e){(e.isSideBySideActive()||e.isPreviewActive())&&e.toggleFullScreen()}},methods:{initialize:function(){var e={element:this.$el.firstElementChild,initialValue:this.value,renderingConfig:{}};Object.assign(e,this.configs),this.highlight&&(e.renderingConfig.codeSyntaxHighlighting=!0),a.a.setOptions({sanitize:this.sanitize}),this.simplemde=new i.a(e);var t=this.previewClass||"";this.addPreviewClass(t),this.bindingEvents()},bindingEvents:function(){var e=this;this.simplemde.codemirror.on("change",function(){e.$emit("input",e.simplemde.value())})},addPreviewClass:function(e){var t=this.simplemde.codemirror.getWrapperElement(),n=document.createElement("div");t.nextSibling.className+=" "+e,n.className="editor-preview "+e,t.appendChild(n)}},destroyed:function(){this.simplemde=null},watch:{value:function(e){e!==this.simplemde.value()&&this.simplemde.value(e)}}}},function(t,n){t.exports=e},function(e,n){e.exports=t},function(e,t,n){"use strict";var r=function(){var e=this,t=e.$createElement;e._self._c;return e._m(0)},i=[function(){var e=this,t=e.$createElement,n=e._self._c||t;return n("div",{staticClass:"markdown-editor"},[n("textarea")])}],o={render:r,staticRenderFns:i};t.a=o}])}); !function(e,t){ true?module.exports=t(__webpack_require__(500),__webpack_require__(202)):"function"==typeof define&&define.amd?define("VueSimpleMDE",["simplemde","marked"],t):"object"==typeof exports?exports.VueSimpleMDE=t(require("simplemde"),require("marked")):e.VueSimpleMDE=t(e.SimpleMDE,e.marked)}(this,function(e,t){return function(e){function t(r){if(n[r])return n[r].exports;var i=n[r]={i:r,l:!1,exports:{}};return e[r].call(i.exports,i,i.exports,t),i.l=!0,i.exports}var n={};return t.m=e,t.c=n,t.d=function(e,n,r){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="",t(t.s=0)}([function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=n(1);n.d(t,"markdownEditor",function(){return r.a}),t.default={markdownEditor:r.a,install:function(e){e.component("markdown-editor",r.a)}}},function(e,t,n){"use strict";function r(e){n(2)}var i=n(8),o=n(11),a=n(7),s=r,u=a(i.a,o.a,!1,s,null,null);t.a=u.exports},function(e,t,n){var r=n(3);"string"==typeof r&&(r=[[e.i,r,""]]),r.locals&&(e.exports=r.locals);n(5)("c9294450",r,!0)},function(e,t,n){t=e.exports=n(4)(void 0),t.push([e.i,".markdown-editor .markdown-body{padding:.5em}.markdown-editor .editor-preview-active,.markdown-editor .editor-preview-active-side{display:block}",""])},function(e,t){function n(e,t){var n=e[1]||"",i=e[3];if(!i)return n;if(t&&"function"==typeof btoa){var o=r(i);return[n].concat(i.sources.map(function(e){return"/*# sourceURL="+i.sourceRoot+e+" */"})).concat([o]).join("\n")}return[n].join("\n")}function r(e){return"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,"+btoa(unescape(encodeURIComponent(JSON.stringify(e))))+" */"}e.exports=function(e){var t=[];return t.toString=function(){return this.map(function(t){var r=n(t,e);return t[2]?"@media "+t[2]+"{"+r+"}":r}).join("")},t.i=function(e,n){"string"==typeof e&&(e=[[null,e,""]]);for(var r={},i=0;i<this.length;i++){var o=this[i][0];"number"==typeof o&&(r[o]=!0)}for(i=0;i<e.length;i++){var a=e[i];"number"==typeof a[0]&&r[a[0]]||(n&&!a[2]?a[2]=n:n&&(a[2]="("+a[2]+") and ("+n+")"),t.push(a))}},t}},function(e,t,n){function r(e){for(var t=0;t<e.length;t++){var n=e[t],r=c[n.id];if(r){r.refs++;for(var i=0;i<r.parts.length;i++)r.parts[i](n.parts[i]);for(;i<n.parts.length;i++)r.parts.push(o(n.parts[i]));r.parts.length>n.parts.length&&(r.parts.length=n.parts.length)}else{for(var a=[],i=0;i<n.parts.length;i++)a.push(o(n.parts[i]));c[n.id]={id:n.id,refs:1,parts:a}}}}function i(){var e=document.createElement("style");return e.type="text/css",l.appendChild(e),e}function o(e){var t,n,r=document.querySelector('style[data-vue-ssr-id~="'+e.id+'"]');if(r){if(m)return v;r.parentNode.removeChild(r)}if(h){var o=p++;r=f||(f=i()),t=a.bind(null,r,o,!1),n=a.bind(null,r,o,!0)}else r=i(),t=s.bind(null,r),n=function(){r.parentNode.removeChild(r)};return t(e),function(r){if(r){if(r.css===e.css&&r.media===e.media&&r.sourceMap===e.sourceMap)return;t(e=r)}else n()}}function a(e,t,n,r){var i=n?"":r.css;if(e.styleSheet)e.styleSheet.cssText=g(t,i);else{var o=document.createTextNode(i),a=e.childNodes;a[t]&&e.removeChild(a[t]),a.length?e.insertBefore(o,a[t]):e.appendChild(o)}}function s(e,t){var n=t.css,r=t.media,i=t.sourceMap;if(r&&e.setAttribute("media",r),i&&(n+="\n/*# sourceURL="+i.sources[0]+" */",n+="\n/*# sourceMappingURL=data:application/json;base64,"+btoa(unescape(encodeURIComponent(JSON.stringify(i))))+" */"),e.styleSheet)e.styleSheet.cssText=n;else{for(;e.firstChild;)e.removeChild(e.firstChild);e.appendChild(document.createTextNode(n))}}var u="undefined"!=typeof document;if("undefined"!=typeof DEBUG&&DEBUG&&!u)throw new Error("vue-style-loader cannot be used in a non-browser environment. Use { target: 'node' } in your Webpack config to indicate a server-rendering environment.");var d=n(6),c={},l=u&&(document.head||document.getElementsByTagName("head")[0]),f=null,p=0,m=!1,v=function(){},h="undefined"!=typeof navigator&&/msie [6-9]\b/.test(navigator.userAgent.toLowerCase());e.exports=function(e,t,n){m=n;var i=d(e,t);return r(i),function(t){for(var n=[],o=0;o<i.length;o++){var a=i[o],s=c[a.id];s.refs--,n.push(s)}t?(i=d(e,t),r(i)):i=[];for(var o=0;o<n.length;o++){var s=n[o];if(0===s.refs){for(var u=0;u<s.parts.length;u++)s.parts[u]();delete c[s.id]}}}};var g=function(){var e=[];return function(t,n){return e[t]=n,e.filter(Boolean).join("\n")}}()},function(e,t){e.exports=function(e,t){for(var n=[],r={},i=0;i<t.length;i++){var o=t[i],a=o[0],s=o[1],u=o[2],d=o[3],c={id:e+":"+i,css:s,media:u,sourceMap:d};r[a]?r[a].parts.push(c):n.push(r[a]={id:a,parts:[c]})}return n}},function(e,t){e.exports=function(e,t,n,r,i,o){var a,s=e=e||{},u=typeof e.default;"object"!==u&&"function"!==u||(a=e,s=e.default);var d="function"==typeof s?s.options:s;t&&(d.render=t.render,d.staticRenderFns=t.staticRenderFns,d._compiled=!0),n&&(d.functional=!0),i&&(d._scopeId=i);var c;if(o?(c=function(e){e=e||this.$vnode&&this.$vnode.ssrContext||this.parent&&this.parent.$vnode&&this.parent.$vnode.ssrContext,e||"undefined"==typeof __VUE_SSR_CONTEXT__||(e=__VUE_SSR_CONTEXT__),r&&r.call(this,e),e&&e._registeredComponents&&e._registeredComponents.add(o)},d._ssrRegister=c):r&&(c=r),c){var l=d.functional,f=l?d.render:d.beforeCreate;l?(d._injectStyles=c,d.render=function(e,t){return c.call(t),f(e,t)}):d.beforeCreate=f?[].concat(f,c):[c]}return{esModule:a,exports:s,options:d}}},function(e,t,n){"use strict";var r=n(9),i=n.n(r),o=n(10),a=n.n(o);t.a={name:"markdown-editor",props:{value:String,previewClass:String,autoinit:{type:Boolean,default:function(){return!0}},highlight:{type:Boolean,default:function(){return!1}},sanitize:{type:Boolean,default:function(){return!1}},configs:{type:Object,default:function(){return{}}}},mounted:function(){this.autoinit&&this.initialize()},activated:function(){var e=this.simplemde;if(e){(e.isSideBySideActive()||e.isPreviewActive())&&e.toggleFullScreen()}},methods:{initialize:function(){var e=Object.assign({element:this.$el.firstElementChild,initialValue:this.value,renderingConfig:{}},this.configs);e.initialValue&&this.$emit("input",e.initialValue),this.highlight&&(e.renderingConfig.codeSyntaxHighlighting=!0),a.a.setOptions({sanitize:this.sanitize}),this.simplemde=new i.a(e);var t=this.previewClass||"";this.addPreviewClass(t),this.bindingEvents()},bindingEvents:function(){var e=this;this.simplemde.codemirror.on("change",function(){e.$emit("input",e.simplemde.value())})},addPreviewClass:function(e){var t=this.simplemde.codemirror.getWrapperElement(),n=document.createElement("div");t.nextSibling.className+=" "+e,n.className="editor-preview "+e,t.appendChild(n)}},destroyed:function(){this.simplemde=null},watch:{value:function(e){e!==this.simplemde.value()&&this.simplemde.value(e)}}}},function(t,n){t.exports=e},function(e,n){e.exports=t},function(e,t,n){"use strict";var r=function(){var e=this,t=e.$createElement;e._self._c;return e._m(0)},i=[function(){var e=this,t=e.$createElement,n=e._self._c||t;return n("div",{staticClass:"markdown-editor"},[n("textarea")])}],o={render:r,staticRenderFns:i};t.a=o}])});
/***/ }), /***/ }),
/* 500 */ /* 500 */
...@@ -101741,16 +101907,53 @@ module.exports = SimpleMDE; ...@@ -101741,16 +101907,53 @@ module.exports = SimpleMDE;
replacements[i] = "\n"; replacements[i] = "\n";
} else { } else {
var indent = match[1], after = match[5]; var indent = match[1], after = match[5];
var bullet = unorderedListRE.test(match[2]) || match[2].indexOf(">") >= 0 var numbered = !(unorderedListRE.test(match[2]) || match[2].indexOf(">") >= 0);
? match[2].replace("x", " ") var bullet = numbered ? (parseInt(match[3], 10) + 1) + match[4] : match[2].replace("x", " ");
: (parseInt(match[3], 10) + 1) + match[4];
replacements[i] = "\n" + indent + bullet + after; replacements[i] = "\n" + indent + bullet + after;
if (numbered) incrementRemainingMarkdownListNumbers(cm, pos);
} }
} }
cm.replaceSelections(replacements); cm.replaceSelections(replacements);
}; };
// Auto-updating Markdown list numbers when a new item is added to the
// middle of a list
function incrementRemainingMarkdownListNumbers(cm, pos) {
var startLine = pos.line, lookAhead = 0, skipCount = 0;
var startItem = listRE.exec(cm.getLine(startLine)), startIndent = startItem[1];
do {
lookAhead += 1;
var nextLineNumber = startLine + lookAhead;
var nextLine = cm.getLine(nextLineNumber), nextItem = listRE.exec(nextLine);
if (nextItem) {
var nextIndent = nextItem[1];
var newNumber = (parseInt(startItem[3], 10) + lookAhead - skipCount);
var nextNumber = (parseInt(nextItem[3], 10)), itemNumber = nextNumber;
if (startIndent === nextIndent && !isNaN(nextNumber)) {
if (newNumber === nextNumber) itemNumber = nextNumber + 1;
if (newNumber > nextNumber) itemNumber = newNumber + 1;
cm.replaceRange(
nextLine.replace(listRE, nextIndent + itemNumber + nextItem[4] + nextItem[5]),
{
line: nextLineNumber, ch: 0
}, {
line: nextLineNumber, ch: nextLine.length
});
} else {
if (startIndent.length > nextIndent.length) return;
// This doesn't run if the next line immediatley indents, as it is
// not clear of the users intention (new indented item or same level)
if ((startIndent.length < nextIndent.length) && (lookAhead === 1)) return;
skipCount += 1;
}
}
} while (nextItem);
}
}); });
...@@ -101874,7 +102077,7 @@ CodeMirror.commands.shiftTabAndUnindentMarkdownList = function (cm) { ...@@ -101874,7 +102077,7 @@ CodeMirror.commands.shiftTabAndUnindentMarkdownList = function (cm) {
{name: "ASN.1", mime: "text/x-ttcn-asn", mode: "asn.1", ext: ["asn", "asn1"]}, {name: "ASN.1", mime: "text/x-ttcn-asn", mode: "asn.1", ext: ["asn", "asn1"]},
{name: "Asterisk", mime: "text/x-asterisk", mode: "asterisk", file: /^extensions\.conf$/i}, {name: "Asterisk", mime: "text/x-asterisk", mode: "asterisk", file: /^extensions\.conf$/i},
{name: "Brainfuck", mime: "text/x-brainfuck", mode: "brainfuck", ext: ["b", "bf"]}, {name: "Brainfuck", mime: "text/x-brainfuck", mode: "brainfuck", ext: ["b", "bf"]},
{name: "C", mime: "text/x-csrc", mode: "clike", ext: ["c", "h"]}, {name: "C", mime: "text/x-csrc", mode: "clike", ext: ["c", "h", "ino"]},
{name: "C++", mime: "text/x-c++src", mode: "clike", ext: ["cpp", "c++", "cc", "cxx", "hpp", "h++", "hh", "hxx"], alias: ["cpp"]}, {name: "C++", mime: "text/x-c++src", mode: "clike", ext: ["cpp", "c++", "cc", "cxx", "hpp", "h++", "hh", "hxx"], alias: ["cpp"]},
{name: "Cobol", mime: "text/x-cobol", mode: "cobol", ext: ["cob", "cpy"]}, {name: "Cobol", mime: "text/x-cobol", mode: "cobol", ext: ["cob", "cpy"]},
{name: "C#", mime: "text/x-csharp", mode: "clike", ext: ["cs"], alias: ["csharp"]}, {name: "C#", mime: "text/x-csharp", mode: "clike", ext: ["cs"], alias: ["csharp"]},
...@@ -101921,7 +102124,7 @@ CodeMirror.commands.shiftTabAndUnindentMarkdownList = function (cm) { ...@@ -101921,7 +102124,7 @@ CodeMirror.commands.shiftTabAndUnindentMarkdownList = function (cm) {
{name: "Haxe", mime: "text/x-haxe", mode: "haxe", ext: ["hx"]}, {name: "Haxe", mime: "text/x-haxe", mode: "haxe", ext: ["hx"]},
{name: "HXML", mime: "text/x-hxml", mode: "haxe", ext: ["hxml"]}, {name: "HXML", mime: "text/x-hxml", mode: "haxe", ext: ["hxml"]},
{name: "ASP.NET", mime: "application/x-aspx", mode: "htmlembedded", ext: ["aspx"], alias: ["asp", "aspx"]}, {name: "ASP.NET", mime: "application/x-aspx", mode: "htmlembedded", ext: ["aspx"], alias: ["asp", "aspx"]},
{name: "HTML", mime: "text/html", mode: "htmlmixed", ext: ["html", "htm"], alias: ["xhtml"]}, {name: "HTML", mime: "text/html", mode: "htmlmixed", ext: ["html", "htm", "handlebars", "hbs"], alias: ["xhtml"]},
{name: "HTTP", mime: "message/http", mode: "http"}, {name: "HTTP", mime: "message/http", mode: "http"},
{name: "IDL", mime: "text/x-idl", mode: "idl", ext: ["pro"]}, {name: "IDL", mime: "text/x-idl", mode: "idl", ext: ["pro"]},
{name: "Pug", mime: "text/x-pug", mode: "pug", ext: ["jade", "pug"], alias: ["jade"]}, {name: "Pug", mime: "text/x-pug", mode: "pug", ext: ["jade", "pug"], alias: ["jade"]},
...@@ -101951,14 +102154,14 @@ CodeMirror.commands.shiftTabAndUnindentMarkdownList = function (cm) { ...@@ -101951,14 +102154,14 @@ CodeMirror.commands.shiftTabAndUnindentMarkdownList = function (cm) {
{name: "NSIS", mime: "text/x-nsis", mode: "nsis", ext: ["nsh", "nsi"]}, {name: "NSIS", mime: "text/x-nsis", mode: "nsis", ext: ["nsh", "nsi"]},
{name: "NTriples", mimes: ["application/n-triples", "application/n-quads", "text/n-triples"], {name: "NTriples", mimes: ["application/n-triples", "application/n-quads", "text/n-triples"],
mode: "ntriples", ext: ["nt", "nq"]}, mode: "ntriples", ext: ["nt", "nq"]},
{name: "Objective C", mime: "text/x-objectivec", mode: "clike", ext: ["m", "mm"], alias: ["objective-c", "objc"]}, {name: "Objective-C", mime: "text/x-objectivec", mode: "clike", ext: ["m", "mm"], alias: ["objective-c", "objc"]},
{name: "OCaml", mime: "text/x-ocaml", mode: "mllike", ext: ["ml", "mli", "mll", "mly"]}, {name: "OCaml", mime: "text/x-ocaml", mode: "mllike", ext: ["ml", "mli", "mll", "mly"]},
{name: "Octave", mime: "text/x-octave", mode: "octave", ext: ["m"]}, {name: "Octave", mime: "text/x-octave", mode: "octave", ext: ["m"]},
{name: "Oz", mime: "text/x-oz", mode: "oz", ext: ["oz"]}, {name: "Oz", mime: "text/x-oz", mode: "oz", ext: ["oz"]},
{name: "Pascal", mime: "text/x-pascal", mode: "pascal", ext: ["p", "pas"]}, {name: "Pascal", mime: "text/x-pascal", mode: "pascal", ext: ["p", "pas"]},
{name: "PEG.js", mime: "null", mode: "pegjs", ext: ["jsonld"]}, {name: "PEG.js", mime: "null", mode: "pegjs", ext: ["jsonld"]},
{name: "Perl", mime: "text/x-perl", mode: "perl", ext: ["pl", "pm"]}, {name: "Perl", mime: "text/x-perl", mode: "perl", ext: ["pl", "pm"]},
{name: "PHP", mime: ["application/x-httpd-php", "text/x-php"], mode: "php", ext: ["php", "php3", "php4", "php5", "php7", "phtml"]}, {name: "PHP", mimes: ["text/x-php", "application/x-httpd-php", "application/x-httpd-php-open"], mode: "php", ext: ["php", "php3", "php4", "php5", "php7", "phtml"]},
{name: "Pig", mime: "text/x-pig", mode: "pig", ext: ["pig"]}, {name: "Pig", mime: "text/x-pig", mode: "pig", ext: ["pig"]},
{name: "Plain Text", mime: "text/plain", mode: "null", ext: ["txt", "text", "conf", "def", "list", "log"]}, {name: "Plain Text", mime: "text/plain", mode: "null", ext: ["txt", "text", "conf", "def", "list", "log"]},
{name: "PLSQL", mime: "text/x-plsql", mode: "sql", ext: ["pls"]}, {name: "PLSQL", mime: "text/x-plsql", mode: "sql", ext: ["pls"]},
...@@ -101985,6 +102188,7 @@ CodeMirror.commands.shiftTabAndUnindentMarkdownList = function (cm) { ...@@ -101985,6 +102188,7 @@ CodeMirror.commands.shiftTabAndUnindentMarkdownList = function (cm) {
{name: "Smalltalk", mime: "text/x-stsrc", mode: "smalltalk", ext: ["st"]}, {name: "Smalltalk", mime: "text/x-stsrc", mode: "smalltalk", ext: ["st"]},
{name: "Smarty", mime: "text/x-smarty", mode: "smarty", ext: ["tpl"]}, {name: "Smarty", mime: "text/x-smarty", mode: "smarty", ext: ["tpl"]},
{name: "Solr", mime: "text/x-solr", mode: "solr"}, {name: "Solr", mime: "text/x-solr", mode: "solr"},
{name: "SML", mime: "text/x-sml", mode: "mllike", ext: ["sml", "sig", "fun", "smackspec"]},
{name: "Soy", mime: "text/x-soy", mode: "soy", ext: ["soy"], alias: ["closure template"]}, {name: "Soy", mime: "text/x-soy", mode: "soy", ext: ["soy"], alias: ["closure template"]},
{name: "SPARQL", mime: "application/sparql-query", mode: "sparql", ext: ["rq", "sparql"], alias: ["sparul"]}, {name: "SPARQL", mime: "application/sparql-query", mode: "sparql", ext: ["rq", "sparql"], alias: ["sparul"]},
{name: "Spreadsheet", mime: "text/x-spreadsheet", mode: "spreadsheet", alias: ["excel", "formula"]}, {name: "Spreadsheet", mime: "text/x-spreadsheet", mode: "spreadsheet", alias: ["excel", "formula"]},
...@@ -101994,7 +102198,7 @@ CodeMirror.commands.shiftTabAndUnindentMarkdownList = function (cm) { ...@@ -101994,7 +102198,7 @@ CodeMirror.commands.shiftTabAndUnindentMarkdownList = function (cm) {
{name: "Stylus", mime: "text/x-styl", mode: "stylus", ext: ["styl"]}, {name: "Stylus", mime: "text/x-styl", mode: "stylus", ext: ["styl"]},
{name: "Swift", mime: "text/x-swift", mode: "swift", ext: ["swift"]}, {name: "Swift", mime: "text/x-swift", mode: "swift", ext: ["swift"]},
{name: "sTeX", mime: "text/x-stex", mode: "stex"}, {name: "sTeX", mime: "text/x-stex", mode: "stex"},
{name: "LaTeX", mime: "text/x-latex", mode: "stex", ext: ["text", "ltx"], alias: ["tex"]}, {name: "LaTeX", mime: "text/x-latex", mode: "stex", ext: ["text", "ltx", "tex"], alias: ["tex"]},
{name: "SystemVerilog", mime: "text/x-systemverilog", mode: "verilog", ext: ["v", "sv", "svh"]}, {name: "SystemVerilog", mime: "text/x-systemverilog", mode: "verilog", ext: ["v", "sv", "svh"]},
{name: "Tcl", mime: "text/x-tcl", mode: "tcl", ext: ["tcl"]}, {name: "Tcl", mime: "text/x-tcl", mode: "tcl", ext: ["tcl"]},
{name: "Textile", mime: "text/x-textile", mode: "textile", ext: ["textile"]}, {name: "Textile", mime: "text/x-textile", mode: "textile", ext: ["textile"]},
...@@ -102117,6 +102321,7 @@ CodeMirror.commands.shiftTabAndUnindentMarkdownList = function (cm) { ...@@ -102117,6 +102321,7 @@ CodeMirror.commands.shiftTabAndUnindentMarkdownList = function (cm) {
clearPlaceholder(cm); clearPlaceholder(cm);
var elt = cm.state.placeholder = document.createElement("pre"); var elt = cm.state.placeholder = document.createElement("pre");
elt.style.cssText = "height: 0; overflow: visible"; elt.style.cssText = "height: 0; overflow: visible";
elt.style.direction = cm.getOption("direction");
elt.className = "CodeMirror-placeholder"; elt.className = "CodeMirror-placeholder";
var placeHolder = cm.getOption("placeholder") var placeHolder = cm.getOption("placeholder")
if (typeof placeHolder == "string") placeHolder = document.createTextNode(placeHolder) if (typeof placeHolder == "string") placeHolder = document.createTextNode(placeHolder)
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment