aboutsummaryrefslogtreecommitdiffstats
path: root/public/prism/prism-haxe.js
blob: 028459fbc7e11fceccfe0bdc0f9e885227744e97 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
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',
  },
});
"> { punctuation: /^\||\|$/, }, }, directive: { pattern: /( )(?! )[^:]+::/, lookbehind: true, alias: 'function', inside: { punctuation: /::$/, }, }, }, }, 'link-target': [ { pattern: /(^[\t ]*\.\. )\[[^\]]+\]/m, lookbehind: true, alias: 'string', inside: { punctuation: /^\[|\]$/, }, }, { pattern: /(^[\t ]*\.\. )_(?:`[^`]+`|(?:[^:\\]|\\.)+):/m, lookbehind: true, alias: 'string', inside: { punctuation: /^_|:$/, }, }, ], directive: { pattern: /(^[\t ]*\.\. )[^:]+::/m, lookbehind: true, alias: 'function', inside: { punctuation: /::$/, }, }, comment: { // The two alternatives try to prevent highlighting of blank comments pattern: /(^[\t ]*\.\.)(?:(?: .+)?(?:(?:\r?\n|\r).+)+| .+)(?=(?:\r?\n|\r){2}|$)/m, lookbehind: true, }, title: [ // Overlined and underlined { pattern: /^(([!"#$%&'()*+,\-.\/:;<=>?@\[\\\]^_`{|}~])\2+)(?:\r?\n|\r).+(?:\r?\n|\r)\1$/m, inside: { punctuation: /^[!"#$%&'()*+,\-.\/:;<=>?@\[\\\]^_`{|}~]+|[!"#$%&'()*+,\-.\/:;<=>?@\[\\\]^_`{|}~]+$/, important: /.+/, }, }, // Underlined only { pattern: /(^|(?:\r?\n|\r){2}).+(?:\r?\n|\r)([!"#$%&'()*+,\-.\/:;<=>?@\[\\\]^_`{|}~])\2+(?=\r?\n|\r|$)/, lookbehind: true, inside: { punctuation: /[!"#$%&'()*+,\-.\/:;<=>?@\[\\\]^_`{|}~]+$/, important: /.+/, }, }, ], hr: { pattern: /((?:\r?\n|\r){2})([!"#$%&'()*+,\-.\/:;<=>?@\[\\\]^_`{|}~])\2{3,}(?=(?:\r?\n|\r){2})/, lookbehind: true, alias: 'punctuation', }, field: { pattern: /(^[\t ]*):[^:\r\n]+:(?= )/m, lookbehind: true, alias: 'attr-name', }, 'command-line-option': { pattern: /(^[\t ]*)(?:[+-][a-z\d]|(?:--|\/)[a-z\d-]+)(?:[ =](?:[a-z][\w-]*|<[^<>]+>))?(?:, (?:[+-][a-z\d]|(?:--|\/)[a-z\d-]+)(?:[ =](?:[a-z][\w-]*|<[^<>]+>))?)*(?=(?:\r?\n|\r)? {2,}\S)/im, lookbehind: true, alias: 'symbol', }, 'literal-block': { pattern: /::(?:\r?\n|\r){2}([ \t]+)(?![ \t]).+(?:(?:\r?\n|\r)\1.+)*/, inside: { 'literal-block-punctuation': { pattern: /^::/, alias: 'punctuation', }, }, }, 'quoted-literal-block': { pattern: /::(?:\r?\n|\r){2}([!"#$%&'()*+,\-.\/:;<=>?@\[\\\]^_`{|}~]).*(?:(?:\r?\n|\r)\1.*)*/, inside: { 'literal-block-punctuation': { pattern: /^(?:::|([!"#$%&'()*+,\-.\/:;<=>?@\[\\\]^_`{|}~])\1*)/m, alias: 'punctuation', }, }, }, 'list-bullet': { pattern: /(^[\t ]*)(?:[*+\-•‣⁃]|\(?(?:\d+|[a-z]|[ivxdclm]+)\)|(?:\d+|[a-z]|[ivxdclm]+)\.)(?= )/im, lookbehind: true, alias: 'punctuation', }, 'doctest-block': { pattern: /(^[\t ]*)>>> .+(?:(?:\r?\n|\r).+)*/m, lookbehind: true, inside: { punctuation: /^>>>/, }, }, inline: [ { pattern: /(^|[\s\-:\/'"<(\[{])(?::[^:]+:`.*?`|`.*?`:[^:]+:|(\*\*?|``?|\|)(?!\s)(?:(?!\2).)*\S\2(?=[\s\-.,:;!?\\\/'")\]}]|$))/m, lookbehind: true, inside: { bold: { pattern: /(^\*\*).+(?=\*\*$)/, lookbehind: true, }, italic: { pattern: /(^\*).+(?=\*$)/, lookbehind: true, }, 'inline-literal': { pattern: /(^``).+(?=``$)/, lookbehind: true, alias: 'symbol', }, role: { pattern: /^:[^:]+:|:[^:]+:$/, alias: 'function', inside: { punctuation: /^:|:$/, }, }, 'interpreted-text': { pattern: /(^`).+(?=`$)/, lookbehind: true, alias: 'attr-value', }, substitution: { pattern: /(^\|).+(?=\|$)/, lookbehind: true, alias: 'attr-value', }, punctuation: /\*\*?|``?|\|/, }, }, ], link: [ { pattern: /\[[^\[\]]+\]_(?=[\s\-.,:;!?\\\/'")\]}]|$)/, alias: 'string', inside: { punctuation: /^\[|\]_$/, }, }, { pattern: /(?:\b[a-z\d]+(?:[_.:+][a-z\d]+)*_?_|`[^`]+`_?_|_`[^`]+`)(?=[\s\-.,:;!?\\\/'")\]}]|$)/i, alias: 'string', inside: { punctuation: /^_?`|`$|`?_?_$/, }, }, ], // Line block start, // quote attribution, // explicit markup start, // and anonymous hyperlink target shortcut (__) punctuation: { pattern: /(^[\t ]*)(?:\|(?= |$)|(?:---?|—|\.\.|__)(?= )|\.\.$)/m, lookbehind: true, }, };