Skip to content

Commit

Permalink
test
Browse files Browse the repository at this point in the history
  • Loading branch information
ciscorn committed Nov 20, 2024
1 parent bf1b494 commit e9f8757
Show file tree
Hide file tree
Showing 3 changed files with 136 additions and 2 deletions.
2 changes: 1 addition & 1 deletion src/content/CodeBlock.svelte
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
<script lang="ts">
import Prism from 'prismjs';
import 'prism-svelte';
import './prism-svelte.js';
let {
content,
Expand Down
2 changes: 1 addition & 1 deletion src/content/examples/plain/content.svelte.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,4 +11,4 @@ description: Plain map.

<Demo />

<CodeBlock content={demoRaw} />
<CodeBlock content={demoRaw} />
134 changes: 134 additions & 0 deletions src/content/prism-svelte.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,134 @@
const blocks = '(if|else if|await|then|catch|each|html|debug)';

import Prism from 'prismjs';

Prism.languages.svelte = Prism.languages.extend('markup', {
each: {
pattern: new RegExp('{[#/]each' + '(?:(?:\\{(?:(?:\\{(?:[^{}])*\\})|(?:[^{}]))*\\})|(?:[^{}]))*}'),
inside: {
'language-javascript': [
{
pattern: /(as[\s\S]*)\([\s\S]*\)(?=\s*\})/,
lookbehind: true,
inside: Prism.languages['javascript']
},
{
pattern: /(as[\s]*)[\s\S]*(?=\s*)/,
lookbehind: true,
inside: Prism.languages['javascript']
},
{
pattern: /(#each[\s]*)[\s\S]*(?=as)/,
lookbehind: true,
inside: Prism.languages['javascript']
}
],
keyword: /[#/]each|as/,
punctuation: /{|}/
}
},
block: {
pattern: new RegExp('{[#:/@]/s' + blocks + '(?:(?:\\{(?:(?:\\{(?:[^{}])*\\})|(?:[^{}]))*\\})|(?:[^{}]))*}'),
inside: {
punctuation: /^{|}$/,
keyword: [new RegExp('[#:/@]' + blocks + '( )*'), /as/, /then/],
'language-javascript': {
pattern: /[\s\S]*/,
inside: Prism.languages['javascript']
}
}
},
tag: {
pattern:
/<\/?(?!\d)[^\s>\/=$<%]+(?:\s(?:\s*[^\s>\/=]+(?:\s*=\s*(?:(?:"[^"]*"|'[^']*'|[^\s'">=]+(?=[\s>]))|(?:"[^"]*"|'[^']*'|{[\s\S]+?}(?=[\s/>])))|(?=[\s/>])))+)?\s*\/?>/i,

Check failure

Code scanning / CodeQL

Inefficient regular expression High

This part of the regular expression may cause exponential backtracking on strings containing many repetitions of '""!='.
greedy: true,
inside: {
tag: {
pattern: /^<\/?[^\s>\/]+/i,
inside: {
punctuation: /^<\/?/,
namespace: /^[^\s>\/:]+:/
}
},
'language-javascript': {
pattern: /\{(?:(?:\{(?:(?:\{(?:[^{}])*\})|(?:[^{}]))*\})|(?:[^{}]))*\}/,
inside: Prism.languages['javascript']
},
'attr-value': {
pattern: /=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+)/i,
inside: {
punctuation: [
/^=/,
{
pattern: /^(\s*)["']|["']$/,
lookbehind: true
}
],
'language-javascript': {
pattern: /{[\s\S]+}/,
inside: Prism.languages['javascript']
}
}
},
punctuation: /\/?>/,
'attr-name': {
pattern: /[^\s>\/]+/,
inside: {
namespace: /^[^\s>\/:]+:/
}
}
}
},
'language-javascript': {
pattern: /\{(?:(?:\{(?:(?:\{(?:[^{}])*\})|(?:[^{}]))*\})|(?:[^{}]))*\}/,
lookbehind: true,
inside: Prism.languages['javascript']
}
});

Prism.languages.svelte['tag'].inside['attr-value'].inside['entity'] = Prism.languages.svelte['entity'];

Prism.hooks.add('wrap', (env) => {
if (env.type === 'entity') {
env.attributes['title'] = env.content.replace(/&amp;/, '&');
}
});

Object.defineProperty(Prism.languages.svelte.tag, 'addInlined', {
value: function addInlined(tagName, lang) {
const includedCdataInside = {};
includedCdataInside['language-' + lang] = {
pattern: /(^<!\[CDATA\[)[\s\S]+?(?=\]\]>$)/i,
lookbehind: true,
inside: Prism.languages[lang]
};
includedCdataInside['cdata'] = /^<!\[CDATA\[|\]\]>$/i;

const inside = {
'included-cdata': {
pattern: /<!\[CDATA\[[\s\S]*?\]\]>/i,
inside: includedCdataInside
}
};
inside['language-' + lang] = {
pattern: /[\s\S]+/,
inside: Prism.languages[lang]
};

const def = {};
def[tagName] = {
pattern: RegExp(
/(<__[\s\S]*?>)(?:<!\[CDATA\[[\s\S]*?\]\]>\s*|[\s\S])*?(?=<\/__>)/.source.replace(/__/g, tagName),

Check failure

Code scanning / CodeQL

Inefficient regular expression High

This part of the regular expression may cause exponential backtracking on strings starting with '<__>' and containing many repetitions of '<!\[cdata\[\]\]>'.

Check failure

Code scanning / CodeQL

Inefficient regular expression High

This part of the regular expression may cause exponential backtracking on strings starting with '<__><!\[cdata\[' and containing many repetitions of '\]\]><!\[cdata\['.
'i'
),
lookbehind: true,
greedy: true,
inside
};

Prism.languages.insertBefore('svelte', 'cdata', def);
}
});

Prism.languages.svelte.tag.addInlined('style', 'css');
Prism.languages.svelte.tag.addInlined('script', 'javascript');

0 comments on commit e9f8757

Please sign in to comment.