/lenasys/trunk

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/lenasys/trunk

« back to all changes in this revision

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

  • Committer: gustav.hartvigsson at gmail
  • Date: 2013-04-02 12:13:01 UTC
  • mfrom: (4.2.7 hitlerhorabajs)
  • Revision ID: gustav.hartvigsson@gmail.com-20130402121301-ytfzuo7y6cku9s3o
Merge from implemenation group 2:s branch.

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