Prism.languages.haxe = Prism.languages.extend('clike', { string: { // Strings can be multi-line pattern: /"(?:[^"\\]|\\[\s\S])*"/, greedy: true, }, 'class-name': [ { pattern: /(\b(?:abstract|class|enum|extends|implements|interface|new|typedef)\s+)[A-Z_]\w*/, lookbehind: true, }, // based on naming convention /\b[A-Z]\w*/, ], // The final look-ahead prevents highlighting of keywords if expressions such as "haxe.macro.Expr" keyword: /\bthis\b|\b(?:abstract|as|break|case|cast|catch|class|continue|default|do|dynamic|else|enum|extends|extern|final|for|from|function|if|implements|import|in|inline|interface|macro|new|null|operator|overload|override|package|private|public|return|static|super|switch|throw|to|try|typedef|untyped|using|var|while)(?!\.)\b/, function: { pattern: /\b[a-z_]\w*(?=\s*(?:<[^<>]*>\s*)?\()/i, greedy: true, }, operator: /\.{3}|\+\+|--|&&|\|\||->|=>|(?:<{1,3}|[-+*/%!=&|^])=?|[?:~]/, }); Prism.languages.insertBefore('haxe', 'string', { 'string-interpolation': { pattern: /'(?:[^'\\]|\\[\s\S])*'/, greedy: true, inside: { interpolation: { pattern: /(^|[^\\])\$(?:\w+|\{[^{}]+\})/, lookbehind: true, inside: { 'interpolation-punctuation': { pattern: /^\$\{?|\}$/, alias: 'punctuation', }, expression: { pattern: /[\s\S]+/, inside: Prism.languages.haxe, }, }, }, string: /[\s\S]+/, }, }, }); Prism.languages.insertBefore('haxe', 'class-name', { regex: { pattern: /~\/(?:[^\/\\\r\n]|\\.)+\/[a-z]*/, greedy: true, inside: { 'regex-flags': /\b[a-z]+$/, 'regex-source': { pattern: /^(~\/)[\s\S]+(?=\/$)/, lookbehind: true, alias: 'language-regex', inside: Prism.languages.regex, }, 'regex-delimiter': /^~\/|\/$/, }, }, }); Prism.languages.insertBefore('haxe', 'keyword', { preprocessor: { pattern: /#(?:else|elseif|end|if)\b.*/, alias: 'property', }, metadata: { pattern: /@:?[\w.]+/, alias: 'symbol', }, reification: { pattern: /\$(?:\w+|(?=\{))/, alias: 'important', }, });