summaryrefslogtreecommitdiffstats
path: root/public/prism/prism-solution-file.js
blob: 08f1d16c02594799118f2589c81178872a57f02c (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
(function (Prism) {
  var guid = {
    // https://en.wikipedia.org/wiki/Universally_unique_identifier#Format
    pattern: /\{[\da-f]{8}-[\da-f]{4}-[\da-f]{4}-[\da-f]{4}-[\da-f]{12}\}/i,
    alias: 'constant',
    inside: {
      punctuation: /[{}]/,
    },
  };

  Prism.languages['solution-file'] = {
    comment: {
      pattern: /#.*/,
      greedy: true,
    },
    string: {
      pattern: /"[^"\r\n]*"|'[^'\r\n]*'/,
      greedy: true,
      inside: {
        guid: guid,
      },
    },
    object: {
      // Foo
      //   Bar("abs") = 9
      //   EndBar
      //   Prop = TRUE
      // EndFoo
      pattern:
        /^([ \t]*)(?:([A-Z]\w*)\b(?=.*(?:\r\n?|\n)(?:\1[ \t].*(?:\r\n?|\n))*\1End\2(?=[ \t]*$))|End[A-Z]\w*(?=[ \t]*$))/m,
      lookbehind: true,
      greedy: true,
      alias: 'keyword',
    },
    property: {
      pattern: /^([ \t]*)(?!\s)[^\r\n"#=()]*[^\s"#=()](?=\s*=)/m,
      lookbehind: true,
      inside: {
        guid: guid,
      },
    },
    guid: guid,
    number: /\b\d+(?:\.\d+)*\b/,
    boolean: /\b(?:FALSE|TRUE)\b/,
    operator: /=/,
    punctuation: /[(),]/,
  };

  Prism.languages['sln'] = Prism.languages['solution-file'];
})(Prism);
w"> = []); env.code = env.code.replace(placeholderPattern, function (match) { if (typeof replaceFilter === 'function' && !replaceFilter(match)) { return match; } var i = tokenStack.length; var placeholder; // Check for existing strings while ( env.code.indexOf((placeholder = getPlaceholder(language, i))) !== -1 ) { ++i; } // Create a sparse array tokenStack[i] = match; return placeholder; }); // Switch the grammar to markup env.grammar = Prism.languages.markup; }, }, tokenizePlaceholders: { /** * Replace placeholders with proper tokens after tokenizing. * * @param {object} env The environment of the `after-tokenize` hook. * @param {string} language The language id. */ value: function (env, language) { if (env.language !== language || !env.tokenStack) { return; } // Switch the grammar back env.grammar = Prism.languages[language]; var j = 0; var keys = Object.keys(env.tokenStack); function walkTokens(tokens) { for (var i = 0; i < tokens.length; i++) { // all placeholders are replaced already if (j >= keys.length) { break; } var token = tokens[i]; if ( typeof token === 'string' || (token.content && typeof token.content === 'string') ) { var k = keys[j]; var t = env.tokenStack[k]; var s = typeof token === 'string' ? token : token.content; var placeholder = getPlaceholder(language, k); var index = s.indexOf(placeholder); if (index > -1) { ++j; var before = s.substring(0, index); var middle = new Prism.Token( language, Prism.tokenize(t, env.grammar), 'language-' + language, t ); var after = s.substring(index + placeholder.length); var replacement = []; if (before) { replacement.push.apply(replacement, walkTokens([before])); } replacement.push(middle); if (after) { replacement.push.apply(replacement, walkTokens([after])); } if (typeof token === 'string') { tokens.splice.apply(tokens, [i, 1].concat(replacement)); } else { token.content = replacement; } } } else if ( token.content /* && typeof token.content !== 'string' */ ) { walkTokens(token.content); } } return tokens; } walkTokens(env.tokens); }, }, }); })(Prism);