define("ace/mode/matching_brace_outdent",["require","exports","module","ace/range"], function(require, exports, module){"use strict";
var Range = require("../range").Range;
var MatchingBraceOutdent = function () { };
(function () {
    this.checkOutdent = function (line, input) {
        if (!/^\s+$/.test(line))
            return false;
        return /^\s*\}/.test(input);
    };
    this.autoOutdent = function (doc, row) {
        var line = doc.getLine(row);
        var match = line.match(/^(\s*\})/);
        if (!match)
            return 0;
        var column = match[1].length;
        var openBracePos = doc.findMatchingBracket({ row: row, column: column });
        if (!openBracePos || openBracePos.row == row)
            return 0;
        var indent = this.$getIndent(doc.getLine(openBracePos.row));
        doc.replace(new Range(row, 0, row, column - 1), indent);
    };
    this.$getIndent = function (line) {
        return line.match(/^\s*/)[0];
    };
}).call(MatchingBraceOutdent.prototype);
exports.MatchingBraceOutdent = MatchingBraceOutdent;

});

define("ace/mode/livescript",["require","exports","module","ace/tokenizer","ace/mode/matching_brace_outdent","ace/mode/behaviour/cstyle","ace/mode/text"], function(require, exports, module){var identifier, LiveScriptMode, keywordend, stringfill;
identifier = '(?![\\d\\s])[$\\w\\xAA-\\uFFDC](?:(?!\\s)[$\\w\\xAA-\\uFFDC]|-[A-Za-z])*';
exports.Mode = LiveScriptMode = (function (superclass) {
    var indenter, prototype = extend$((import$(LiveScriptMode, superclass).displayName = 'LiveScriptMode', LiveScriptMode), superclass).prototype, constructor = LiveScriptMode;
    function LiveScriptMode() {
        var that;
        this.$tokenizer = new (require('../tokenizer')).Tokenizer(LiveScriptMode.Rules);
        if (that = require('../mode/matching_brace_outdent')) {
            this.$outdent = new that.MatchingBraceOutdent;
        }
        this.$id = "ace/mode/livescript";
        this.$behaviour = new (require("./behaviour/cstyle").CstyleBehaviour)();
    }
    indenter = RegExp('(?:[({[=:]|[-~]>|\\b(?:e(?:lse|xport)|d(?:o|efault)|t(?:ry|hen)|finally|import(?:\\s*all)?|const|var|let|new|catch(?:\\s*' + identifier + ')?))\\s*$');
    prototype.getNextLineIndent = function (state, line, tab) {
        var indent, tokens;
        indent = this.$getIndent(line);
        tokens = this.$tokenizer.getLineTokens(line, state).tokens;
        if (!(tokens.length && tokens[tokens.length - 1].type === 'comment')) {
            if (state === 'start' && indenter.test(line)) {
                indent += tab;
            }
        }
        return indent;
    };
    prototype.lineCommentStart = "#";
    prototype.blockComment = { start: "###", end: "###" };
    prototype.checkOutdent = function (state, line, input) {
        var ref$;
        return (ref$ = this.$outdent) != null ? ref$.checkOutdent(line, input) : void 8;
    };
    prototype.autoOutdent = function (state, doc, row) {
        var ref$;
        return (ref$ = this.$outdent) != null ? ref$.autoOutdent(doc, row) : void 8;
    };
    return LiveScriptMode;
}(require('../mode/text').Mode));
keywordend = '(?![$\\w]|-[A-Za-z]|\\s*:(?![:=]))';
stringfill = {
    defaultToken: 'string'
};
LiveScriptMode.Rules = {
    start: [
        {
            token: 'keyword',
            regex: '(?:t(?:h(?:is|row|en)|ry|ypeof!?)|c(?:on(?:tinue|st)|a(?:se|tch)|lass)|i(?:n(?:stanceof)?|mp(?:ort(?:\\s+all)?|lements)|[fs])|d(?:e(?:fault|lete|bugger)|o)|f(?:or(?:\\s+own)?|inally|unction)|s(?:uper|witch)|e(?:lse|x(?:tends|port)|val)|a(?:nd|rguments)|n(?:ew|ot)|un(?:less|til)|w(?:hile|ith)|o[fr]|return|break|let|var|loop)' + keywordend
        }, {
            token: 'constant.language',
            regex: '(?:true|false|yes|no|on|off|null|void|undefined)' + keywordend
        }, {
            token: 'invalid.illegal',
            regex: '(?:p(?:ackage|r(?:ivate|otected)|ublic)|i(?:mplements|nterface)|enum|static|yield)' + keywordend
        }, {
            token: 'language.support.class',
            regex: '(?:R(?:e(?:gExp|ferenceError)|angeError)|S(?:tring|yntaxError)|E(?:rror|valError)|Array|Boolean|Date|Function|Number|Object|TypeError|URIError)' + keywordend
        }, {
            token: 'language.support.function',
            regex: '(?:is(?:NaN|Finite)|parse(?:Int|Float)|Math|JSON|(?:en|de)codeURI(?:Component)?)' + keywordend
        }, {
            token: 'variable.language',
            regex: '(?:t(?:hat|il|o)|f(?:rom|allthrough)|it|by|e)' + keywordend
        }, {
            token: 'identifier',
            regex: identifier + '\\s*:(?![:=])'
        }, {
            token: 'variable',
            regex: identifier
        }, {
            token: 'keyword.operator',
            regex: '(?:\\.{3}|\\s+\\?)'
        }, {
            token: 'keyword.variable',
            regex: '(?:@+|::|\\.\\.)',
            next: 'key'
        }, {
            token: 'keyword.operator',
            regex: '\\.\\s*',
            next: 'key'
        }, {
            token: 'string',
            regex: '\\\\\\S[^\\s,;)}\\]]*'
        }, {
            token: 'string.doc',
            regex: '\'\'\'',
            next: 'qdoc'
        }, {
            token: 'string.doc',
            regex: '"""',
            next: 'qqdoc'
        }, {
            token: 'string',
            regex: '\'',
            next: 'qstring'
        }, {
            token: 'string',
            regex: '"',
            next: 'qqstring'
        }, {
            token: 'string',
            regex: '`',
            next: 'js'
        }, {
            token: 'string',
            regex: '<\\[',
            next: 'words'
        }, {
            token: 'string.regex',
            regex: '//',
            next: 'heregex'
        }, {
            token: 'comment.doc',
            regex: '/\\*',
            next: 'comment'
        }, {
            token: 'comment',
            regex: '#.*'
        }, {
            token: 'string.regex',
            regex: '\\/(?:[^[\\/\\n\\\\]*(?:(?:\\\\.|\\[[^\\]\\n\\\\]*(?:\\\\.[^\\]\\n\\\\]*)*\\])[^[\\/\\n\\\\]*)*)\\/[gimy$]{0,4}',
            next: 'key'
        }, {
            token: 'constant.numeric',
            regex: '(?:0x[\\da-fA-F][\\da-fA-F_]*|(?:[2-9]|[12]\\d|3[0-6])r[\\da-zA-Z][\\da-zA-Z_]*|(?:\\d[\\d_]*(?:\\.\\d[\\d_]*)?|\\.\\d[\\d_]*)(?:e[+-]?\\d[\\d_]*)?[\\w$]*)'
        }, {
            token: 'lparen',
            regex: '[({[]'
        }, {
            token: 'rparen',
            regex: '[)}\\]]',
            next: 'key'
        }, {
            token: 'keyword.operator',
            regex: '[\\^!|&%+\\-]+'
        }, {
            token: 'text',
            regex: '\\s+'
        }
    ],
    heregex: [
        {
            token: 'string.regex',
            regex: '.*?//[gimy$?]{0,4}',
            next: 'start'
        }, {
            token: 'string.regex',
            regex: '\\s*#{'
        }, {
            token: 'comment.regex',
            regex: '\\s+(?:#.*)?'
        }, {
            defaultToken: 'string.regex'
        }
    ],
    key: [
        {
            token: 'keyword.operator',
            regex: '[.?@!]+'
        }, {
            token: 'identifier',
            regex: identifier,
            next: 'start'
        }, {
            token: 'text',
            regex: '',
            next: 'start'
        }
    ],
    comment: [
        {
            token: 'comment.doc',
            regex: '.*?\\*/',
            next: 'start'
        }, {
            defaultToken: 'comment.doc'
        }
    ],
    qdoc: [
        {
            token: 'string',
            regex: ".*?'''",
            next: 'key'
        }, stringfill
    ],
    qqdoc: [
        {
            token: 'string',
            regex: '.*?"""',
            next: 'key'
        }, stringfill
    ],
    qstring: [
        {
            token: 'string',
            regex: '[^\\\\\']*(?:\\\\.[^\\\\\']*)*\'',
            next: 'key'
        }, stringfill
    ],
    qqstring: [
        {
            token: 'string',
            regex: '[^\\\\"]*(?:\\\\.[^\\\\"]*)*"',
            next: 'key'
        }, stringfill
    ],
    js: [
        {
            token: 'string',
            regex: '[^\\\\`]*(?:\\\\.[^\\\\`]*)*`',
            next: 'key'
        }, stringfill
    ],
    words: [
        {
            token: 'string',
            regex: '.*?\\]>',
            next: 'key'
        }, stringfill
    ]
};
function extend$(sub, sup) {
    function fun() { }
    fun.prototype = (sub.superclass = sup).prototype;
    (sub.prototype = new fun).constructor = sub;
    if (typeof sup.extended == 'function')
        sup.extended(sub);
    return sub;
}
function import$(obj, src) {
    var own = {}.hasOwnProperty;
    for (var key in src)
        if (own.call(src, key))
            obj[key] = src[key];
    return obj;
}

});                (function() {
                    window.require(["ace/mode/livescript"], function(m) {
                        if (typeof module == "object" && typeof exports == "object" && module) {
                            module.exports = m;
                        }
                    });
                })();