codemirror-rails 2.24 → 2.32

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (90) hide show
  1. data/.gitignore +1 -0
  2. data/Rakefile +19 -0
  3. data/codemirror-rails.gemspec +6 -1
  4. data/lib/codemirror/rails/version.rb +2 -2
  5. data/test/dummy/README.rdoc +261 -0
  6. data/test/dummy/Rakefile +7 -0
  7. data/test/dummy/app/assets/javascripts/application.js +15 -0
  8. data/test/dummy/app/assets/stylesheets/application.css +13 -0
  9. data/test/dummy/app/controllers/application_controller.rb +3 -0
  10. data/test/dummy/app/helpers/application_helper.rb +2 -0
  11. data/test/dummy/app/mailers/.gitkeep +0 -0
  12. data/test/dummy/app/models/.gitkeep +0 -0
  13. data/test/dummy/app/views/layouts/application.html.erb +14 -0
  14. data/test/dummy/config.ru +4 -0
  15. data/test/dummy/config/application.rb +56 -0
  16. data/test/dummy/config/boot.rb +10 -0
  17. data/test/dummy/config/environment.rb +5 -0
  18. data/test/dummy/config/environments/development.rb +37 -0
  19. data/test/dummy/config/environments/production.rb +67 -0
  20. data/test/dummy/config/environments/test.rb +37 -0
  21. data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
  22. data/test/dummy/config/initializers/inflections.rb +15 -0
  23. data/test/dummy/config/initializers/mime_types.rb +5 -0
  24. data/test/dummy/config/initializers/secret_token.rb +7 -0
  25. data/test/dummy/config/initializers/session_store.rb +8 -0
  26. data/test/dummy/config/initializers/wrap_parameters.rb +14 -0
  27. data/test/dummy/config/locales/en.yml +5 -0
  28. data/test/dummy/config/routes.rb +58 -0
  29. data/test/dummy/lib/assets/.gitkeep +0 -0
  30. data/test/dummy/log/.gitkeep +0 -0
  31. data/test/dummy/public/404.html +26 -0
  32. data/test/dummy/public/422.html +26 -0
  33. data/test/dummy/public/500.html +25 -0
  34. data/test/dummy/public/favicon.ico +0 -0
  35. data/test/dummy/script/rails +6 -0
  36. data/test/integration/codemirror_rails_integration_test.rb +13 -0
  37. data/test/test_helper.rb +13 -0
  38. data/vendor/assets/javascripts/codemirror.js +381 -197
  39. data/vendor/assets/javascripts/codemirror/keymaps/emacs.js +1 -1
  40. data/vendor/assets/javascripts/codemirror/keymaps/vim.js +649 -94
  41. data/vendor/assets/javascripts/codemirror/modes/clike.js +53 -7
  42. data/vendor/assets/javascripts/codemirror/modes/coffeescript.js +12 -7
  43. data/vendor/assets/javascripts/codemirror/modes/diff.js +24 -5
  44. data/vendor/assets/javascripts/codemirror/modes/ecl.js +2 -2
  45. data/vendor/assets/javascripts/codemirror/modes/erlang.js +463 -0
  46. data/vendor/assets/javascripts/codemirror/modes/gfm.js +38 -2
  47. data/vendor/assets/javascripts/codemirror/modes/go.js +1 -1
  48. data/vendor/assets/javascripts/codemirror/modes/groovy.js +1 -1
  49. data/vendor/assets/javascripts/codemirror/modes/haxe.js +432 -0
  50. data/vendor/assets/javascripts/codemirror/modes/javascript.js +1 -1
  51. data/vendor/assets/javascripts/codemirror/modes/less.js +93 -93
  52. data/vendor/assets/javascripts/codemirror/modes/markdown.js +29 -6
  53. data/vendor/assets/javascripts/codemirror/modes/mysql.js +6 -8
  54. data/vendor/assets/javascripts/codemirror/modes/ocaml.js +114 -0
  55. data/vendor/assets/javascripts/codemirror/modes/pascal.js +1 -1
  56. data/vendor/assets/javascripts/codemirror/modes/pig.js +2 -2
  57. data/vendor/assets/javascripts/codemirror/modes/plsql.js +2 -2
  58. data/vendor/assets/javascripts/codemirror/modes/python.js +13 -16
  59. data/vendor/assets/javascripts/codemirror/modes/ruby.js +3 -8
  60. data/vendor/assets/javascripts/codemirror/modes/scheme.js +74 -46
  61. data/vendor/assets/javascripts/codemirror/modes/shell.js +22 -7
  62. data/vendor/assets/javascripts/codemirror/modes/stex.js +7 -5
  63. data/vendor/assets/javascripts/codemirror/modes/tiddlywiki.js +14 -14
  64. data/vendor/assets/javascripts/codemirror/modes/vb.js +260 -0
  65. data/vendor/assets/javascripts/codemirror/modes/verilog.js +1 -1
  66. data/vendor/assets/javascripts/codemirror/modes/xml.js +2 -1
  67. data/vendor/assets/javascripts/codemirror/modes/xquery.js +3 -3
  68. data/vendor/assets/javascripts/codemirror/utils/closetag.js +24 -34
  69. data/vendor/assets/javascripts/codemirror/utils/dialog.js +5 -1
  70. data/vendor/assets/javascripts/codemirror/utils/foldcode.js +10 -5
  71. data/vendor/assets/javascripts/codemirror/utils/formatting.js +8 -3
  72. data/vendor/assets/javascripts/codemirror/utils/loadmode.js +2 -1
  73. data/vendor/assets/javascripts/codemirror/utils/match-highlighter.js +1 -1
  74. data/vendor/assets/javascripts/codemirror/utils/multiplex.js +81 -0
  75. data/vendor/assets/javascripts/codemirror/utils/overlay.js +2 -1
  76. data/vendor/assets/javascripts/codemirror/utils/pig-hint.js +123 -0
  77. data/vendor/assets/javascripts/codemirror/utils/search.js +16 -12
  78. data/vendor/assets/javascripts/codemirror/utils/searchcursor.js +1 -1
  79. data/vendor/assets/javascripts/codemirror/utils/simple-hint.js +4 -0
  80. data/vendor/assets/javascripts/codemirror/utils/xml-hint.js +137 -0
  81. data/vendor/assets/stylesheets/codemirror.css +59 -4
  82. data/vendor/assets/stylesheets/codemirror/modes/tiddlywiki.css +14 -21
  83. data/vendor/assets/stylesheets/codemirror/themes/ambiance.css +1 -2
  84. data/vendor/assets/stylesheets/codemirror/themes/erlang-dark.css +21 -0
  85. data/vendor/assets/stylesheets/codemirror/themes/lesser-dark.css +2 -3
  86. data/vendor/assets/stylesheets/codemirror/themes/night.css +1 -1
  87. data/vendor/assets/stylesheets/codemirror/themes/vibrant-ink.css +27 -0
  88. data/vendor/assets/stylesheets/codemirror/utils/dialog.css +4 -0
  89. metadata +98 -5
  90. data/vendor/assets/javascripts/codemirror/modes/rpm-spec.css +0 -5
@@ -69,7 +69,7 @@ CodeMirror.defineMode("gfm", function(config, parserConfig) {
69
69
  function handleText(stream, mdState) {
70
70
  var match;
71
71
  if (stream.match(/^\w+:\/\/\S+/)) {
72
- return 'linkhref';
72
+ return 'link';
73
73
  }
74
74
  if (stream.match(/^[^\[*\\<>` _][^\[*\\<>` ]*[^\[*\\<>` _]/)) {
75
75
  return mdMode.getType(mdState);
@@ -102,7 +102,43 @@ CodeMirror.defineMode("gfm", function(config, parserConfig) {
102
102
  },
103
103
 
104
104
  token: function(stream, state) {
105
- return state.token(stream, state);
105
+ /* Parse GFM double bracket links */
106
+ if ((ch = stream.peek()) != undefined && ch == '[') {
107
+ stream.next(); // Advance the stream
108
+
109
+ /* Only handle double bracket links */
110
+ if ((ch = stream.peek()) == undefined || ch != '[') {
111
+ stream.backUp(1);
112
+ return state.token(stream, state);
113
+ }
114
+
115
+ while ((ch = stream.next()) != undefined && ch != ']') {}
116
+
117
+ if (ch == ']' && (ch = stream.next()) != undefined && ch == ']')
118
+ return 'link';
119
+
120
+ /* If we did not find the second ']' */
121
+ stream.backUp(1);
122
+ }
123
+
124
+ /* Match GFM latex formulas, as well as latex formulas within '$' */
125
+ if (stream.match(/^\$[^\$]+\$/)) {
126
+ return "string";
127
+ }
128
+
129
+ if (stream.match(/^\\\((.*?)\\\)/)) {
130
+ return "string";
131
+ }
132
+
133
+ if (stream.match(/^\$\$[^\$]+\$\$/)) {
134
+ return "string";
135
+ }
136
+
137
+ if (stream.match(/^\\\[(.*?)\\\]/)) {
138
+ return "string";
139
+ }
140
+
141
+ return state.token(stream, state);
106
142
  }
107
143
  }
108
144
  }, "markdown");
@@ -70,7 +70,7 @@ CodeMirror.defineMode("go", function(config, parserConfig) {
70
70
  return "keyword";
71
71
  }
72
72
  if (atoms.propertyIsEnumerable(cur)) return "atom";
73
- return "word";
73
+ return "variable";
74
74
  }
75
75
 
76
76
  function tokenString(quote) {
@@ -59,7 +59,7 @@ CodeMirror.defineMode("groovy", function(config, parserConfig) {
59
59
  if (blockKeywords.propertyIsEnumerable(cur)) curPunc = "newstatement";
60
60
  return "keyword";
61
61
  }
62
- return "word";
62
+ return "variable";
63
63
  }
64
64
  tokenBase.isBase = true;
65
65
 
@@ -0,0 +1,432 @@
1
+ CodeMirror.defineMode("haxe", function(config, parserConfig) {
2
+ var indentUnit = config.indentUnit;
3
+
4
+ // Tokenizer
5
+
6
+ var keywords = function(){
7
+ function kw(type) {return {type: type, style: "keyword"};}
8
+ var A = kw("keyword a"), B = kw("keyword b"), C = kw("keyword c");
9
+ var operator = kw("operator"), atom = {type: "atom", style: "atom"}, attribute = {type:"attribute", style: "attribute"}
10
+ var type = kw("typedef");
11
+ return {
12
+ "if": A, "while": A, "else": B, "do": B, "try": B,
13
+ "return": C, "break": C, "continue": C, "new": C, "throw": C,
14
+ "var": kw("var"), "inline":attribute, "static": attribute, "using":kw("import"),
15
+ "public": attribute, "private": attribute, "cast": kw("cast"), "import": kw("import"), "macro": kw("macro"),
16
+ "function": kw("function"), "catch": kw("catch"), "untyped": kw("untyped"), "callback": kw("cb"),
17
+ "for": kw("for"), "switch": kw("switch"), "case": kw("case"), "default": kw("default"),
18
+ "in": operator, "never": kw("property_access"), "trace":kw("trace"),
19
+ "class": type, "enum":type, "interface":type, "typedef":type, "extends":type, "implements":type, "dynamic":type,
20
+ "true": atom, "false": atom, "null": atom
21
+ };
22
+ }();
23
+
24
+ var isOperatorChar = /[+\-*&%=<>!?|]/;
25
+
26
+ function chain(stream, state, f) {
27
+ state.tokenize = f;
28
+ return f(stream, state);
29
+ }
30
+
31
+ function nextUntilUnescaped(stream, end) {
32
+ var escaped = false, next;
33
+ while ((next = stream.next()) != null) {
34
+ if (next == end && !escaped)
35
+ return false;
36
+ escaped = !escaped && next == "\\";
37
+ }
38
+ return escaped;
39
+ }
40
+
41
+ // Used as scratch variables to communicate multiple values without
42
+ // consing up tons of objects.
43
+ var type, content;
44
+ function ret(tp, style, cont) {
45
+ type = tp; content = cont;
46
+ return style;
47
+ }
48
+
49
+ function haxeTokenBase(stream, state) {
50
+ var ch = stream.next();
51
+ if (ch == '"' || ch == "'")
52
+ return chain(stream, state, haxeTokenString(ch));
53
+ else if (/[\[\]{}\(\),;\:\.]/.test(ch))
54
+ return ret(ch);
55
+ else if (ch == "0" && stream.eat(/x/i)) {
56
+ stream.eatWhile(/[\da-f]/i);
57
+ return ret("number", "number");
58
+ }
59
+ else if (/\d/.test(ch) || ch == "-" && stream.eat(/\d/)) {
60
+ stream.match(/^\d*(?:\.\d*)?(?:[eE][+\-]?\d+)?/);
61
+ return ret("number", "number");
62
+ }
63
+ else if (state.reAllowed && (ch == "~" && stream.eat(/\//))) {
64
+ nextUntilUnescaped(stream, "/");
65
+ stream.eatWhile(/[gimsu]/);
66
+ return ret("regexp", "string-2");
67
+ }
68
+ else if (ch == "/") {
69
+ if (stream.eat("*")) {
70
+ return chain(stream, state, haxeTokenComment);
71
+ }
72
+ else if (stream.eat("/")) {
73
+ stream.skipToEnd();
74
+ return ret("comment", "comment");
75
+ }
76
+ else {
77
+ stream.eatWhile(isOperatorChar);
78
+ return ret("operator", null, stream.current());
79
+ }
80
+ }
81
+ else if (ch == "#") {
82
+ stream.skipToEnd();
83
+ return ret("conditional", "meta");
84
+ }
85
+ else if (ch == "@") {
86
+ stream.eat(/:/);
87
+ stream.eatWhile(/[\w_]/);
88
+ return ret ("metadata", "meta");
89
+ }
90
+ else if (isOperatorChar.test(ch)) {
91
+ stream.eatWhile(isOperatorChar);
92
+ return ret("operator", null, stream.current());
93
+ }
94
+ else {
95
+ var word;
96
+ if(/[A-Z]/.test(ch))
97
+ {
98
+ stream.eatWhile(/[\w_<>]/);
99
+ word = stream.current();
100
+ return ret("type", "variable-3", word);
101
+ }
102
+ else
103
+ {
104
+ stream.eatWhile(/[\w_]/);
105
+ var word = stream.current(), known = keywords.propertyIsEnumerable(word) && keywords[word];
106
+ return (known && state.kwAllowed) ? ret(known.type, known.style, word) :
107
+ ret("variable", "variable", word);
108
+ }
109
+ }
110
+ }
111
+
112
+ function haxeTokenString(quote) {
113
+ return function(stream, state) {
114
+ if (!nextUntilUnescaped(stream, quote))
115
+ state.tokenize = haxeTokenBase;
116
+ return ret("string", "string");
117
+ };
118
+ }
119
+
120
+ function haxeTokenComment(stream, state) {
121
+ var maybeEnd = false, ch;
122
+ while (ch = stream.next()) {
123
+ if (ch == "/" && maybeEnd) {
124
+ state.tokenize = haxeTokenBase;
125
+ break;
126
+ }
127
+ maybeEnd = (ch == "*");
128
+ }
129
+ return ret("comment", "comment");
130
+ }
131
+
132
+ // Parser
133
+
134
+ var atomicTypes = {"atom": true, "number": true, "variable": true, "string": true, "regexp": true};
135
+
136
+ function HaxeLexical(indented, column, type, align, prev, info) {
137
+ this.indented = indented;
138
+ this.column = column;
139
+ this.type = type;
140
+ this.prev = prev;
141
+ this.info = info;
142
+ if (align != null) this.align = align;
143
+ }
144
+
145
+ function inScope(state, varname) {
146
+ for (var v = state.localVars; v; v = v.next)
147
+ if (v.name == varname) return true;
148
+ }
149
+
150
+ function parseHaxe(state, style, type, content, stream) {
151
+ var cc = state.cc;
152
+ // Communicate our context to the combinators.
153
+ // (Less wasteful than consing up a hundred closures on every call.)
154
+ cx.state = state; cx.stream = stream; cx.marked = null, cx.cc = cc;
155
+
156
+ if (!state.lexical.hasOwnProperty("align"))
157
+ state.lexical.align = true;
158
+
159
+ while(true) {
160
+ var combinator = cc.length ? cc.pop() : statement;
161
+ if (combinator(type, content)) {
162
+ while(cc.length && cc[cc.length - 1].lex)
163
+ cc.pop()();
164
+ if (cx.marked) return cx.marked;
165
+ if (type == "variable" && inScope(state, content)) return "variable-2";
166
+ if (type == "variable" && imported(state, content)) return "variable-3";
167
+ return style;
168
+ }
169
+ }
170
+ }
171
+
172
+ function imported(state, typename)
173
+ {
174
+ if (/[a-z]/.test(typename.charAt(0)))
175
+ return false;
176
+ var len = state.importedtypes.length;
177
+ for (var i = 0; i<len; i++)
178
+ if(state.importedtypes[i]==typename) return true;
179
+ }
180
+
181
+
182
+ function registerimport(importname) {
183
+ var state = cx.state;
184
+ for (var t = state.importedtypes; t; t = t.next)
185
+ if(t.name == importname) return;
186
+ state.importedtypes = { name: importname, next: state.importedtypes };
187
+ }
188
+ // Combinator utils
189
+
190
+ var cx = {state: null, column: null, marked: null, cc: null};
191
+ function pass() {
192
+ for (var i = arguments.length - 1; i >= 0; i--) cx.cc.push(arguments[i]);
193
+ }
194
+ function cont() {
195
+ pass.apply(null, arguments);
196
+ return true;
197
+ }
198
+ function register(varname) {
199
+ var state = cx.state;
200
+ if (state.context) {
201
+ cx.marked = "def";
202
+ for (var v = state.localVars; v; v = v.next)
203
+ if (v.name == varname) return;
204
+ state.localVars = {name: varname, next: state.localVars};
205
+ }
206
+ }
207
+
208
+ // Combinators
209
+
210
+ var defaultVars = {name: "this", next: null};
211
+ function pushcontext() {
212
+ if (!cx.state.context) cx.state.localVars = defaultVars;
213
+ cx.state.context = {prev: cx.state.context, vars: cx.state.localVars};
214
+ }
215
+ function popcontext() {
216
+ cx.state.localVars = cx.state.context.vars;
217
+ cx.state.context = cx.state.context.prev;
218
+ }
219
+ function pushlex(type, info) {
220
+ var result = function() {
221
+ var state = cx.state;
222
+ state.lexical = new HaxeLexical(state.indented, cx.stream.column(), type, null, state.lexical, info)
223
+ };
224
+ result.lex = true;
225
+ return result;
226
+ }
227
+ function poplex() {
228
+ var state = cx.state;
229
+ if (state.lexical.prev) {
230
+ if (state.lexical.type == ")")
231
+ state.indented = state.lexical.indented;
232
+ state.lexical = state.lexical.prev;
233
+ }
234
+ }
235
+ poplex.lex = true;
236
+
237
+ function expect(wanted) {
238
+ return function expecting(type) {
239
+ if (type == wanted) return cont();
240
+ else if (wanted == ";") return pass();
241
+ else return cont(arguments.callee);
242
+ };
243
+ }
244
+
245
+ function statement(type) {
246
+ if (type == "@") return cont(metadef)
247
+ if (type == "var") return cont(pushlex("vardef"), vardef1, expect(";"), poplex);
248
+ if (type == "keyword a") return cont(pushlex("form"), expression, statement, poplex);
249
+ if (type == "keyword b") return cont(pushlex("form"), statement, poplex);
250
+ if (type == "{") return cont(pushlex("}"), pushcontext, block, poplex, popcontext);
251
+ if (type == ";") return cont();
252
+ if (type == "attribute") return cont(maybeattribute);
253
+ if (type == "function") return cont(functiondef);
254
+ if (type == "for") return cont(pushlex("form"), expect("("), pushlex(")"), forspec1, expect(")"),
255
+ poplex, statement, poplex);
256
+ if (type == "variable") return cont(pushlex("stat"), maybelabel);
257
+ if (type == "switch") return cont(pushlex("form"), expression, pushlex("}", "switch"), expect("{"),
258
+ block, poplex, poplex);
259
+ if (type == "case") return cont(expression, expect(":"));
260
+ if (type == "default") return cont(expect(":"));
261
+ if (type == "catch") return cont(pushlex("form"), pushcontext, expect("("), funarg, expect(")"),
262
+ statement, poplex, popcontext);
263
+ if (type == "import") return cont(importdef, expect(";"));
264
+ if (type == "typedef") return cont(typedef);
265
+ return pass(pushlex("stat"), expression, expect(";"), poplex);
266
+ }
267
+ function expression(type) {
268
+ if (atomicTypes.hasOwnProperty(type)) return cont(maybeoperator);
269
+ if (type == "function") return cont(functiondef);
270
+ if (type == "keyword c") return cont(maybeexpression);
271
+ if (type == "(") return cont(pushlex(")"), maybeexpression, expect(")"), poplex, maybeoperator);
272
+ if (type == "operator") return cont(expression);
273
+ if (type == "[") return cont(pushlex("]"), commasep(expression, "]"), poplex, maybeoperator);
274
+ if (type == "{") return cont(pushlex("}"), commasep(objprop, "}"), poplex, maybeoperator);
275
+ return cont();
276
+ }
277
+ function maybeexpression(type) {
278
+ if (type.match(/[;\}\)\],]/)) return pass();
279
+ return pass(expression);
280
+ }
281
+
282
+ function maybeoperator(type, value) {
283
+ if (type == "operator" && /\+\+|--/.test(value)) return cont(maybeoperator);
284
+ if (type == "operator" || type == ":") return cont(expression);
285
+ if (type == ";") return;
286
+ if (type == "(") return cont(pushlex(")"), commasep(expression, ")"), poplex, maybeoperator);
287
+ if (type == ".") return cont(property, maybeoperator);
288
+ if (type == "[") return cont(pushlex("]"), expression, expect("]"), poplex, maybeoperator);
289
+ }
290
+
291
+ function maybeattribute(type, value) {
292
+ if (type == "attribute") return cont(maybeattribute);
293
+ if (type == "function") return cont(functiondef);
294
+ if (type == "var") return cont(vardef1);
295
+ }
296
+
297
+ function metadef(type, value) {
298
+ if(type == ":") return cont(metadef);
299
+ if(type == "variable") return cont(metadef);
300
+ if(type == "(") return cont(pushlex(")"), comasep(metaargs, ")"), poplex, statement)
301
+ }
302
+ function metaargs(type, value) {
303
+ if(typ == "variable") return cont();
304
+ }
305
+
306
+ function importdef (type, value) {
307
+ if(type == "variable" && /[A-Z]/.test(value.charAt(0))) { registerimport(value); return cont(); }
308
+ else if(type == "variable" || type == "property" || type == ".") return cont(importdef);
309
+ }
310
+
311
+ function typedef (type, value)
312
+ {
313
+ if(type == "variable" && /[A-Z]/.test(value.charAt(0))) { registerimport(value); return cont(); }
314
+ }
315
+
316
+ function maybelabel(type) {
317
+ if (type == ":") return cont(poplex, statement);
318
+ return pass(maybeoperator, expect(";"), poplex);
319
+ }
320
+ function property(type) {
321
+ if (type == "variable") {cx.marked = "property"; return cont();}
322
+ }
323
+ function objprop(type) {
324
+ if (type == "variable") cx.marked = "property";
325
+ if (atomicTypes.hasOwnProperty(type)) return cont(expect(":"), expression);
326
+ }
327
+ function commasep(what, end) {
328
+ function proceed(type) {
329
+ if (type == ",") return cont(what, proceed);
330
+ if (type == end) return cont();
331
+ return cont(expect(end));
332
+ }
333
+ return function commaSeparated(type) {
334
+ if (type == end) return cont();
335
+ else return pass(what, proceed);
336
+ };
337
+ }
338
+ function block(type) {
339
+ if (type == "}") return cont();
340
+ return pass(statement, block);
341
+ }
342
+ function vardef1(type, value) {
343
+ if (type == "variable"){register(value); return cont(typeuse, vardef2);}
344
+ return cont();
345
+ }
346
+ function vardef2(type, value) {
347
+ if (value == "=") return cont(expression, vardef2);
348
+ if (type == ",") return cont(vardef1);
349
+ }
350
+ function forspec1(type, value) {
351
+ if (type == "variable") {
352
+ register(value);
353
+ }
354
+ return cont(pushlex(")"), pushcontext, forin, expression, poplex, statement, popcontext);
355
+ }
356
+ function forin(type, value) {
357
+ if (value == "in") return cont();
358
+ }
359
+ function functiondef(type, value) {
360
+ if (type == "variable") {register(value); return cont(functiondef);}
361
+ if (value == "new") return cont(functiondef);
362
+ if (type == "(") return cont(pushlex(")"), pushcontext, commasep(funarg, ")"), poplex, typeuse, statement, popcontext);
363
+ }
364
+ function typeuse(type, value) {
365
+ if(type == ":") return cont(typestring);
366
+ }
367
+ function typestring(type, value) {
368
+ if(type == "type") return cont();
369
+ if(type == "variable") return cont();
370
+ if(type == "{") return cont(pushlex("}"), commasep(typeprop, "}"), poplex);
371
+ }
372
+ function typeprop(type, value) {
373
+ if(type == "variable") return cont(typeuse);
374
+ }
375
+ function funarg(type, value) {
376
+ if (type == "variable") {register(value); return cont(typeuse);}
377
+ }
378
+
379
+ // Interface
380
+
381
+ return {
382
+ startState: function(basecolumn) {
383
+ var defaulttypes = ["Int", "Float", "String", "Void", "Std", "Bool", "Dynamic", "Array"];
384
+ return {
385
+ tokenize: haxeTokenBase,
386
+ reAllowed: true,
387
+ kwAllowed: true,
388
+ cc: [],
389
+ lexical: new HaxeLexical((basecolumn || 0) - indentUnit, 0, "block", false),
390
+ localVars: parserConfig.localVars,
391
+ importedtypes: defaulttypes,
392
+ context: parserConfig.localVars && {vars: parserConfig.localVars},
393
+ indented: 0
394
+ };
395
+ },
396
+
397
+ token: function(stream, state) {
398
+ if (stream.sol()) {
399
+ if (!state.lexical.hasOwnProperty("align"))
400
+ state.lexical.align = false;
401
+ state.indented = stream.indentation();
402
+ }
403
+ if (stream.eatSpace()) return null;
404
+ var style = state.tokenize(stream, state);
405
+ if (type == "comment") return style;
406
+ state.reAllowed = !!(type == "operator" || type == "keyword c" || type.match(/^[\[{}\(,;:]$/));
407
+ state.kwAllowed = type != '.';
408
+ return parseHaxe(state, style, type, content, stream);
409
+ },
410
+
411
+ indent: function(state, textAfter) {
412
+ if (state.tokenize != haxeTokenBase) return 0;
413
+ var firstChar = textAfter && textAfter.charAt(0), lexical = state.lexical;
414
+ if (lexical.type == "stat" && firstChar == "}") lexical = lexical.prev;
415
+ var type = lexical.type, closing = firstChar == type;
416
+ if (type == "vardef") return lexical.indented + 4;
417
+ else if (type == "form" && firstChar == "{") return lexical.indented;
418
+ else if (type == "stat" || type == "form") return lexical.indented + indentUnit;
419
+ else if (lexical.info == "switch" && !closing)
420
+ return lexical.indented + (/^(?:case|default)\b/.test(textAfter) ? indentUnit : 2 * indentUnit);
421
+ else if (lexical.align) return lexical.column + (closing ? 0 : 1);
422
+ else return lexical.indented + (closing ? 0 : indentUnit);
423
+ },
424
+ compareStates: function(state1, state2) {
425
+ return (state1.localVars == state2.localVars) && (state1.context == state2.context);
426
+ },
427
+
428
+ electricChars: "{}"
429
+ };
430
+ });
431
+
432
+ CodeMirror.defineMIME("text/x-haxe", "haxe");