diff options
author | Pushkar Joshi | 2012-02-24 12:08:49 -0800 |
---|---|---|
committer | Pushkar Joshi | 2012-02-24 12:08:49 -0800 |
commit | 03ca7a5ed13c25faaa9100bb666e062fd15335e6 (patch) | |
tree | c51112223ceb9121cd595a60335eb2795215590f /imports/codemirror/mode/htmlembedded/htmlembedded.js | |
parent | fcb12cc09eb3cd3b42bd215877ba18f449275b75 (diff) | |
parent | 053fc63a2950c7a5ee4ebf98033b64d474a3c46e (diff) | |
download | ninja-03ca7a5ed13c25faaa9100bb666e062fd15335e6.tar.gz |
Merge branch 'pentool' into brushtool
Conflicts:
imports/codemirror/mode/scheme/scheme.js
js/tools/BrushTool.js
Diffstat (limited to 'imports/codemirror/mode/htmlembedded/htmlembedded.js')
-rwxr-xr-x | imports/codemirror/mode/htmlembedded/htmlembedded.js | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/imports/codemirror/mode/htmlembedded/htmlembedded.js b/imports/codemirror/mode/htmlembedded/htmlembedded.js new file mode 100755 index 00000000..08e170ea --- /dev/null +++ b/imports/codemirror/mode/htmlembedded/htmlembedded.js | |||
@@ -0,0 +1,68 @@ | |||
1 | CodeMirror.defineMode("htmlembedded", function(config, parserConfig) { | ||
2 | |||
3 | //config settings | ||
4 | var scriptStartRegex = parserConfig.scriptStartRegex || /^<%/i, | ||
5 | scriptEndRegex = parserConfig.scriptEndRegex || /^%>/i; | ||
6 | |||
7 | //inner modes | ||
8 | var scriptingMode, htmlMixedMode; | ||
9 | |||
10 | //tokenizer when in html mode | ||
11 | function htmlDispatch(stream, state) { | ||
12 | if (stream.match(scriptStartRegex, false)) { | ||
13 | state.token=scriptingDispatch; | ||
14 | return scriptingMode.token(stream, state.scriptState); | ||
15 | } | ||
16 | else | ||
17 | return htmlMixedMode.token(stream, state.htmlState); | ||
18 | } | ||
19 | |||
20 | //tokenizer when in scripting mode | ||
21 | function scriptingDispatch(stream, state) { | ||
22 | if (stream.match(scriptEndRegex, false)) { | ||
23 | state.token=htmlDispatch; | ||
24 | return htmlMixedMode.token(stream, state.htmlState); | ||
25 | } | ||
26 | else | ||
27 | return scriptingMode.token(stream, state.scriptState); | ||
28 | } | ||
29 | |||
30 | |||
31 | return { | ||
32 | startState: function() { | ||
33 | scriptingMode = scriptingMode || CodeMirror.getMode(config, parserConfig.scriptingModeSpec); | ||
34 | htmlMixedMode = htmlMixedMode || CodeMirror.getMode(config, "htmlmixed"); | ||
35 | return { | ||
36 | token : parserConfig.startOpen ? scriptingDispatch : htmlDispatch, | ||
37 | htmlState : htmlMixedMode.startState(), | ||
38 | scriptState : scriptingMode.startState() | ||
39 | } | ||
40 | }, | ||
41 | |||
42 | token: function(stream, state) { | ||
43 | return state.token(stream, state); | ||
44 | }, | ||
45 | |||
46 | indent: function(state, textAfter) { | ||
47 | if (state.token == htmlDispatch) | ||
48 | return htmlMixedMode.indent(state.htmlState, textAfter); | ||
49 | else | ||
50 | return scriptingMode.indent(state.scriptState, textAfter); | ||
51 | }, | ||
52 | |||
53 | copyState: function(state) { | ||
54 | return { | ||
55 | token : state.token, | ||
56 | htmlState : CodeMirror.copyState(htmlMixedMode, state.htmlState), | ||
57 | scriptState : CodeMirror.copyState(scriptingMode, state.scriptState) | ||
58 | } | ||
59 | }, | ||
60 | |||
61 | |||
62 | electricChars: "/{}:" | ||
63 | } | ||
64 | }); | ||
65 | |||
66 | CodeMirror.defineMIME("application/x-ejs", { name: "htmlembedded", scriptingModeSpec:"javascript"}); | ||
67 | CodeMirror.defineMIME("application/x-aspx", { name: "htmlembedded", scriptingModeSpec:"text/x-csharp"}); | ||
68 | CodeMirror.defineMIME("application/x-jsp", { name: "htmlembedded", scriptingModeSpec:"text/x-java"}); | ||