(function (Prism) { var keywords = /\b(?:ACT|ACTIFSUB|CARRAY|CASE|CLEARGIF|COA|COA_INT|CONSTANTS|CONTENT|CUR|EDITPANEL|EFFECT|EXT|FILE|FLUIDTEMPLATE|FORM|FRAME|FRAMESET|GIFBUILDER|GMENU|GMENU_FOLDOUT|GMENU_LAYERS|GP|HMENU|HRULER|HTML|IENV|IFSUB|IMAGE|IMGMENU|IMGMENUITEM|IMGTEXT|IMG_RESOURCE|INCLUDE_TYPOSCRIPT|JSMENU|JSMENUITEM|LLL|LOAD_REGISTER|NO|PAGE|RECORDS|RESTORE_REGISTER|TEMPLATE|TEXT|TMENU|TMENUITEM|TMENU_LAYERS|USER|USER_INT|_GIFBUILDER|global|globalString|globalVar)\b/; Prism.languages.typoscript = { comment: [ { // multiline comments /* */ pattern: /(^|[^\\])\/\*[\s\S]*?(?:\*\/|$)/, lookbehind: true, }, { // double-slash comments - ignored when backslashes or colon is found in front // also ignored whenever directly after an equal-sign, because it would probably be an url without protocol pattern: /(^|[^\\:= \t]|(?:^|[^= \t])[ \t]+)\/\/.*/, lookbehind: true, greedy: true, }, { // hash comments - ignored when leading quote is found for hex colors in strings pattern: /(^|[^"'])#.*/, lookbehind: true, greedy: true, }, ], function: [ { // old include style pattern: //, inside: { string: { pattern: /"[^"\r\n]*"|'[^'\r\n]*'/, inside: { keyword: keywords, }, }, keyword: { pattern: /INCLUDE_TYPOSCRIPT/, }, }, }, { // new include style pattern: /@import\s*(?:"[^"\r\n]*"|'[^'\r\n]*')/, inside: { string: /"[^"\r\n]*"|'[^'\r\n]*'/, }, }, ], string: { pattern: /^([^=]*=[< ]?)(?:(?!\]\n).)*/, lookbehind: true, inside: { function: /\{\$.*\}/, // constants include keyword: keywords, number: /^\d+$/, punctuation: /[,|:]/, }, }, keyword: keywords, number: { // special highlighting for indexes of arrays in tags pattern: /\b\d+\s*[.{=]/, inside: { operator: /[.{=]/, }, }, tag: { pattern: /\.?[-\w\\]+\.?/, inside: { punctuation: /\./, }, }, punctuation: /[{}[\];(),.:|]/, operator: /[<>]=?|[!=]=?=?|--?|\+\+?|&&?|\|\|?|[?*/~^%]/, }; Prism.languages.tsconfig = Prism.languages.typoscript; })(Prism);