lib/gollum/public/gollum/livepreview/js/ace/lib/ace/mode/lua.js in gollum-3.1.2 vs lib/gollum/public/gollum/livepreview/js/ace/lib/ace/mode/lua.js in gollum-3.1.3

- old
+ new

@@ -31,22 +31,27 @@ define(function(require, exports, module) { "use strict"; var oop = require("../lib/oop"); var TextMode = require("./text").Mode; -var Tokenizer = require("../tokenizer").Tokenizer; var LuaHighlightRules = require("./lua_highlight_rules").LuaHighlightRules; var LuaFoldMode = require("./folding/lua").FoldMode; var Range = require("../range").Range; +var WorkerClient = require("../worker/worker_client").WorkerClient; var Mode = function() { - this.$tokenizer = new Tokenizer(new LuaHighlightRules().getRules()); + this.HighlightRules = LuaHighlightRules; + this.foldingRules = new LuaFoldMode(); }; oop.inherits(Mode, TextMode); (function() { + + this.lineCommentStart = "--"; + this.blockComment = {start: "--[", end: "]--"}; + var indentKeywords = { "function": 1, "then": 1, "do": 1, "else": 1, @@ -64,11 +69,11 @@ function getNetIndentLevel(tokens) { var level = 0; // Support single-line blocks by decrementing the indent level if // an ending token is found - for (var i in tokens){ + for (var i = 0; i < tokens.length; i++) { var token = tokens[i]; if (token.type == "keyword") { if (token.value in indentKeywords) { level += indentKeywords[token.value]; } @@ -91,11 +96,11 @@ this.getNextLineIndent = function(state, line, tab) { var indent = this.$getIndent(line); var level = 0; - var tokenizedLine = this.$tokenizer.getLineTokens(line, state); + var tokenizedLine = this.getTokenizer().getLineTokens(line, state); var tokens = tokenizedLine.tokens; if (state == "start") { level = getNetIndentLevel(tokens); } @@ -115,31 +120,47 @@ return false; if (line.match(/^\s*[\)\}\]]$/)) return true; - var tokens = this.$tokenizer.getLineTokens(line.trim(), state).tokens; + var tokens = this.getTokenizer().getLineTokens(line.trim(), state).tokens; if (!tokens || !tokens.length) return false; return (tokens[0].type == "keyword" && outdentKeywords.indexOf(tokens[0].value) != -1); }; this.autoOutdent = function(state, session, row) { var prevLine = session.getLine(row - 1); var prevIndent = this.$getIndent(prevLine).length; - var prevTokens = this.$tokenizer.getLineTokens(prevLine, "start").tokens; + var prevTokens = this.getTokenizer().getLineTokens(prevLine, "start").tokens; var tabLength = session.getTabString().length; var expectedIndent = prevIndent + tabLength * getNetIndentLevel(prevTokens); var curIndent = this.$getIndent(session.getLine(row)).length; if (curIndent < expectedIndent) { // User already outdented // return; } session.outdentRows(new Range(row, 0, row + 2, 0)); }; + this.createWorker = function(session) { + var worker = new WorkerClient(["ace"], "ace/mode/lua_worker", "Worker"); + worker.attachToDocument(session.getDocument()); + + worker.on("annotate", function(e) { + session.setAnnotations(e.data); + }); + + worker.on("terminate", function() { + session.clearAnnotations(); + }); + + return worker; + }; + + this.$id = "ace/mode/lua"; }).call(Mode.prototype); exports.Mode = Mode; });