~elof-bigestans/lenasys/elofsbranch

« back to all changes in this revision

Viewing changes to js/ace/mode-sql.js

  • Committer: Gustav Hartvigsson
  • Date: 2013-04-04 18:10:23 UTC
  • mfrom: (12.2.4 lenasys)
  • Revision ID: gustav.hartvigsson@gmail.com-20130404181023-um5z5jx0jwth4hv9
Merging with implementation group 2's branch, containts an error,
will be fixed. (hopefully).

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/* ***** BEGIN LICENSE BLOCK *****
 
2
 * Distributed under the BSD license:
 
3
 *
 
4
 * Copyright (c) 2010, Ajax.org B.V.
 
5
 * All rights reserved.
 
6
 * 
 
7
 * Redistribution and use in source and binary forms, with or without
 
8
 * modification, are permitted provided that the following conditions are met:
 
9
 *     * Redistributions of source code must retain the above copyright
 
10
 *       notice, this list of conditions and the following disclaimer.
 
11
 *     * Redistributions in binary form must reproduce the above copyright
 
12
 *       notice, this list of conditions and the following disclaimer in the
 
13
 *       documentation and/or other materials provided with the distribution.
 
14
 *     * Neither the name of Ajax.org B.V. nor the
 
15
 *       names of its contributors may be used to endorse or promote products
 
16
 *       derived from this software without specific prior written permission.
 
17
 * 
 
18
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
 
19
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 
20
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 
21
 * DISCLAIMED. IN NO EVENT SHALL AJAX.ORG B.V. BE LIABLE FOR ANY
 
22
 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 
23
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 
24
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 
25
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 
26
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 
27
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 
28
 *
 
29
 * ***** END LICENSE BLOCK ***** */
 
30
 
 
31
define('ace/mode/sql', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/mode/text', 'ace/tokenizer', 'ace/mode/sql_highlight_rules', 'ace/range'], function(require, exports, module) {
 
32
 
 
33
 
 
34
var oop = require("../lib/oop");
 
35
var TextMode = require("./text").Mode;
 
36
var Tokenizer = require("../tokenizer").Tokenizer;
 
37
var SqlHighlightRules = require("./sql_highlight_rules").SqlHighlightRules;
 
38
var Range = require("../range").Range;
 
39
 
 
40
var Mode = function() {
 
41
    this.$tokenizer = new Tokenizer(new SqlHighlightRules().getRules());
 
42
};
 
43
oop.inherits(Mode, TextMode);
 
44
 
 
45
(function() {
 
46
 
 
47
    this.lineCommentStart = "--";
 
48
 
 
49
}).call(Mode.prototype);
 
50
 
 
51
exports.Mode = Mode;
 
52
 
 
53
});
 
54
 
 
55
define('ace/mode/sql_highlight_rules', ['require', 'exports', 'module' , 'ace/lib/oop', 'ace/mode/text_highlight_rules'], function(require, exports, module) {
 
56
 
 
57
 
 
58
var oop = require("../lib/oop");
 
59
var TextHighlightRules = require("./text_highlight_rules").TextHighlightRules;
 
60
 
 
61
var SqlHighlightRules = function() {
 
62
 
 
63
    var keywords = (
 
64
        "select|insert|update|delete|from|where|and|or|group|by|order|limit|offset|having|as|case|" +
 
65
        "when|else|end|type|left|right|join|on|outer|desc|asc"
 
66
    );
 
67
 
 
68
    var builtinConstants = (
 
69
        "true|false|null"
 
70
    );
 
71
 
 
72
    var builtinFunctions = (
 
73
        "count|min|max|avg|sum|rank|now|coalesce"
 
74
    );
 
75
 
 
76
    var keywordMapper = this.createKeywordMapper({
 
77
        "support.function": builtinFunctions,
 
78
        "keyword": keywords,
 
79
        "constant.language": builtinConstants
 
80
    }, "identifier", true);
 
81
 
 
82
    this.$rules = {
 
83
        "start" : [ {
 
84
            token : "comment",
 
85
            regex : "--.*$"
 
86
        }, {
 
87
            token : "string",           // " string
 
88
            regex : '".*?"'
 
89
        }, {
 
90
            token : "string",           // ' string
 
91
            regex : "'.*?'"
 
92
        }, {
 
93
            token : "constant.numeric", // float
 
94
            regex : "[+-]?\\d+(?:(?:\\.\\d*)?(?:[eE][+-]?\\d+)?)?\\b"
 
95
        }, {
 
96
            token : keywordMapper,
 
97
            regex : "[a-zA-Z_$][a-zA-Z0-9_$]*\\b"
 
98
        }, {
 
99
            token : "keyword.operator",
 
100
            regex : "\\+|\\-|\\/|\\/\\/|%|<@>|@>|<@|&|\\^|~|<|>|<=|=>|==|!=|<>|="
 
101
        }, {
 
102
            token : "paren.lparen",
 
103
            regex : "[\\(]"
 
104
        }, {
 
105
            token : "paren.rparen",
 
106
            regex : "[\\)]"
 
107
        }, {
 
108
            token : "text",
 
109
            regex : "\\s+"
 
110
        } ]
 
111
    };
 
112
};
 
113
 
 
114
oop.inherits(SqlHighlightRules, TextHighlightRules);
 
115
 
 
116
exports.SqlHighlightRules = SqlHighlightRules;
 
117
});
 
118