From d2d8c4d74da37354ba0c69c3b8875cee090dd38c Mon Sep 17 00:00:00 2001
From: bbedward
`);
+ return `\x00CODEBLOCK${blockIndex++}\x00`;
+ });
+
+ // Extract and replace inline code
+ html = html.replace(/`([^`]+)`/g, (match, code) => {
+ // Escape HTML entities in code
+ const escapedCode = code.replace(/&/g, '&')
+ .replace(//g, '>');
+ inlineCode.push(`${escapedCode}${escapedCode}`);
+ return `\x00INLINECODE${inlineIndex++}\x00`;
+ });
+
+ // Now process everything else
+ // Escape HTML entities (but not in code blocks)
html = html.replace(/&/g, '&')
.replace(//g, '>');
@@ -15,7 +42,7 @@ function markdownToHtml(text) {
html = html.replace(/^## (.*?)$/gm, '$1
');
html = html.replace(/^# (.*?)$/gm, '$1
');
- // Bold and italic
+ // Bold and italic (order matters!)
html = html.replace(/\*\*\*(.*?)\*\*\*/g, '$1');
html = html.replace(/\*\*(.*?)\*\*/g, '$1');
html = html.replace(/\*(.*?)\*/g, '$1');
@@ -23,10 +50,6 @@ function markdownToHtml(text) {
html = html.replace(/__(.*?)__/g, '$1');
html = html.replace(/_(.*?)_/g, '$1');
- // Code blocks
- html = html.replace(/```([\s\S]*?)```/g, '
');
- html = html.replace(/`(.*?)`/g, '$1$1');
-
// Links
html = html.replace(/\[([^\]]+)\]\(([^)]+)\)/g, '$1');
@@ -43,8 +66,16 @@ function markdownToHtml(text) {
// Detect plain URLs and wrap them in anchor tags (but not inside existing or markdown links)
html = html.replace(/(^|[^"'>])((https?|file):\/\/[^\s<]+)/g, '$1$2');
+ // Restore code blocks and inline code BEFORE line break processing
+ html = html.replace(/\x00CODEBLOCK(\d+)\x00/g, (match, index) => {
+ return codeBlocks[parseInt(index)];
+ });
- // Line breaks
+ html = html.replace(/\x00INLINECODE(\d+)\x00/g, (match, index) => {
+ return inlineCode[parseInt(index)];
+ });
+
+ // Line breaks (after code blocks are restored)
html = html.replace(/\n\n/g, '
');
html = html.replace(/\n/g, '
');
@@ -53,5 +84,22 @@ function markdownToHtml(text) {
html = '
' + html + '
'; } + // Clean up the final HTML + // Remove/g, ''); + html = html.replace(/
\s*
\s*<\/p>/g, ''); + html = html.replace(/
\s*
\s*<\/p>/g, '');
+
+ // Remove excessive line breaks
+ html = html.replace(/(
){3,}/g, '
'); // Max 2 consecutive line breaks
+ html = html.replace(/(<\/p>)\s*(
)/g, '$1$2'); // Remove whitespace between paragraphs + + // Remove leading/trailing whitespace + html = html.trim(); + return html; } \ No newline at end of file