diff --git a/src/helper/merge-html-plugin.ts b/src/helper/merge-html-plugin.ts
index 96eb5ce5..3ca2fe3f 100644
--- a/src/helper/merge-html-plugin.ts
+++ b/src/helper/merge-html-plugin.ts
@@ -19,14 +19,10 @@ export const mergeHTMLPlugin = (function () {
.replace(/'/g, ''');
}
- /* plugin itself */
-
const mergeHTMLPlugin: HLJSPlugin = {
- // preserve the original HTML token stream
'before:highlightElement': ({ el }: {el: Node}) => {
originalStream = nodeStream(el);
},
- // merge it afterwards with the highlighted token stream
'after:highlightElement': ({ el, result, text }: {el: Element; result: HighlightResult; text: string}) => {
if (originalStream.length === 0) return;
@@ -37,8 +33,6 @@ export const mergeHTMLPlugin = (function () {
}
};
- /* Stream merging support functions */
-
interface Event {
event: 'start' | 'stop';
offset: number;
@@ -62,9 +56,6 @@ export const mergeHTMLPlugin = (function () {
node: child
});
offset = _nodeStream(child, offset);
- // Prevent void elements from having an end tag that would actually
- // double them in the output. There are more void elements in HTML
- // but we list only those realistically expected in code display.
if (tag(child).match(/br|hr|img|input/) == null) {
result.push({
event: 'stop',
@@ -92,27 +83,9 @@ export const mergeHTMLPlugin = (function () {
return (original[0].offset < highlighted[0].offset) ? original : highlighted;
}
- /*
- To avoid starting the stream just before it should stop the order is
- ensured that original always starts first and closes last:
-
- if (event1 == 'start' && event2 == 'start')
- return original;
- if (event1 == 'start' && event2 == 'stop')
- return highlighted;
- if (event1 == 'stop' && event2 == 'start')
- return original;
- if (event1 == 'stop' && event2 == 'stop')
- return highlighted;
-
- ... which is collapsed to:
- */
return highlighted[0].event === 'start' ? original : highlighted;
}
- /**
- * @param {Node} node
- */
function open (node: Node): void {
function attributeString (attr: Attr): string {
return ' ' + attr.nodeName + '="' + escapeHTML(attr.value) + '"';
@@ -134,12 +107,6 @@ export const mergeHTMLPlugin = (function () {
result += escapeHTML(value.substring(processed, stream[0].offset));
processed = stream[0].offset;
if (stream === original) {
- /*
- On any opening or closing tag of the original markup we first close
- the entire highlighted node stack, then render the original tag along
- with all the following original tags at the same offset and then
- reopen all the tags on the highlighted stack.
- */
nodeStack.reverse().forEach(close);
do {
render(stream.splice(0, 1)[0]);