Blame view

mobile/source/ext/codeMirror2/mode/htmlmixed/htmlmixed.js 2.67 KB
a1684257   Administrator   first commit
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
  CodeMirror.defineMode("htmlmixed", function(config, parserConfig) {
    var htmlMode = CodeMirror.getMode(config, {name: "xml", htmlMode: true});
    var jsMode = CodeMirror.getMode(config, "javascript");
    var cssMode = CodeMirror.getMode(config, "css");
  
    function html(stream, state) {
      var style = htmlMode.token(stream, state.htmlState);
      if (style == "tag" && stream.current() == ">" && state.htmlState.context) {
        if (/^script$/i.test(state.htmlState.context.tagName)) {
          state.token = javascript;
          state.localState = jsMode.startState(htmlMode.indent(state.htmlState, ""));
          state.mode = "javascript";
        }
        else if (/^style$/i.test(state.htmlState.context.tagName)) {
          state.token = css;
          state.localState = cssMode.startState(htmlMode.indent(state.htmlState, ""));
          state.mode = "css";
        }
      }
      return style;
    }
    function maybeBackup(stream, pat, style) {
      var cur = stream.current();
      var close = cur.search(pat);
      if (close > -1) stream.backUp(cur.length - close);
      return style;
    }
    function javascript(stream, state) {
      if (stream.match(/^<\/\s*script\s*>/i, false)) {
        state.token = html;
        state.curState = null;
        state.mode = "html";
        return html(stream, state);
      }
      return maybeBackup(stream, /<\/\s*script\s*>/,
                         jsMode.token(stream, state.localState));
    }
    function css(stream, state) {
      if (stream.match(/^<\/\s*style\s*>/i, false)) {
        state.token = html;
        state.localState = null;
        state.mode = "html";
        return html(stream, state);
      }
      return maybeBackup(stream, /<\/\s*style\s*>/,
                         cssMode.token(stream, state.localState));
    }
  
    return {
      startState: function() {
        var state = htmlMode.startState();
        return {token: html, localState: null, mode: "html", htmlState: state};
      },
  
      copyState: function(state) {
        if (state.localState)
          var local = CodeMirror.copyState(state.token == css ? cssMode : jsMode, state.localState);
        return {token: state.token, localState: local, mode: state.mode,
                htmlState: CodeMirror.copyState(htmlMode, state.htmlState)};
      },
  
      token: function(stream, state) {
        return state.token(stream, state);
      },
  
      indent: function(state, textAfter) {
        if (state.token == html || /^\s*<\//.test(textAfter))
          return htmlMode.indent(state.htmlState, textAfter);
        else if (state.token == javascript)
          return jsMode.indent(state.localState, textAfter);
        else
          return cssMode.indent(state.localState, textAfter);
      },
  
      electricChars: "/{}:"
    }
  });
  
  CodeMirror.defineMIME("text/html", "htmlmixed");