Projekt

Obecné

Profil

Stáhnout (35.2 KB) Statistiky
| Větev: | Tag: | Revize:
1
ace.define("ace/mode/css_highlight_rules",["require","exports","module","ace/lib/oop","ace/lib/lang","ace/mode/text_highlight_rules"], function(require, exports, module) {
2
"use strict";
3

    
4
var oop = require("../lib/oop");
5
var lang = require("../lib/lang");
6
var TextHighlightRules = require("./text_highlight_rules").TextHighlightRules;
7
var supportType = exports.supportType = "align-content|align-items|align-self|all|animation|animation-delay|animation-direction|animation-duration|animation-fill-mode|animation-iteration-count|animation-name|animation-play-state|animation-timing-function|backface-visibility|background|background-attachment|background-blend-mode|background-clip|background-color|background-image|background-origin|background-position|background-repeat|background-size|border|border-bottom|border-bottom-color|border-bottom-left-radius|border-bottom-right-radius|border-bottom-style|border-bottom-width|border-collapse|border-color|border-image|border-image-outset|border-image-repeat|border-image-slice|border-image-source|border-image-width|border-left|border-left-color|border-left-style|border-left-width|border-radius|border-right|border-right-color|border-right-style|border-right-width|border-spacing|border-style|border-top|border-top-color|border-top-left-radius|border-top-right-radius|border-top-style|border-top-width|border-width|bottom|box-shadow|box-sizing|caption-side|clear|clip|color|column-count|column-fill|column-gap|column-rule|column-rule-color|column-rule-style|column-rule-width|column-span|column-width|columns|content|counter-increment|counter-reset|cursor|direction|display|empty-cells|filter|flex|flex-basis|flex-direction|flex-flow|flex-grow|flex-shrink|flex-wrap|float|font|font-family|font-size|font-size-adjust|font-stretch|font-style|font-variant|font-weight|hanging-punctuation|height|justify-content|left|letter-spacing|line-height|list-style|list-style-image|list-style-position|list-style-type|margin|margin-bottom|margin-left|margin-right|margin-top|max-height|max-width|max-zoom|min-height|min-width|min-zoom|nav-down|nav-index|nav-left|nav-right|nav-up|opacity|order|outline|outline-color|outline-offset|outline-style|outline-width|overflow|overflow-x|overflow-y|padding|padding-bottom|padding-left|padding-right|padding-top|page-break-after|page-break-before|page-break-inside|perspective|perspective-origin|position|quotes|resize|right|tab-size|table-layout|text-align|text-align-last|text-decoration|text-decoration-color|text-decoration-line|text-decoration-style|text-indent|text-justify|text-overflow|text-shadow|text-transform|top|transform|transform-origin|transform-style|transition|transition-delay|transition-duration|transition-property|transition-timing-function|unicode-bidi|user-select|user-zoom|vertical-align|visibility|white-space|width|word-break|word-spacing|word-wrap|z-index";
8
var supportFunction = exports.supportFunction = "rgb|rgba|url|attr|counter|counters";
9
var supportConstant = exports.supportConstant = "absolute|after-edge|after|all-scroll|all|alphabetic|always|antialiased|armenian|auto|avoid-column|avoid-page|avoid|balance|baseline|before-edge|before|below|bidi-override|block-line-height|block|bold|bolder|border-box|both|bottom|box|break-all|break-word|capitalize|caps-height|caption|center|central|char|circle|cjk-ideographic|clone|close-quote|col-resize|collapse|column|consider-shifts|contain|content-box|cover|crosshair|cubic-bezier|dashed|decimal-leading-zero|decimal|default|disabled|disc|disregard-shifts|distribute-all-lines|distribute-letter|distribute-space|distribute|dotted|double|e-resize|ease-in|ease-in-out|ease-out|ease|ellipsis|end|exclude-ruby|fill|fixed|georgian|glyphs|grid-height|groove|hand|hanging|hebrew|help|hidden|hiragana-iroha|hiragana|horizontal|icon|ideograph-alpha|ideograph-numeric|ideograph-parenthesis|ideograph-space|ideographic|inactive|include-ruby|inherit|initial|inline-block|inline-box|inline-line-height|inline-table|inline|inset|inside|inter-ideograph|inter-word|invert|italic|justify|katakana-iroha|katakana|keep-all|last|left|lighter|line-edge|line-through|line|linear|list-item|local|loose|lower-alpha|lower-greek|lower-latin|lower-roman|lowercase|lr-tb|ltr|mathematical|max-height|max-size|medium|menu|message-box|middle|move|n-resize|ne-resize|newspaper|no-change|no-close-quote|no-drop|no-open-quote|no-repeat|none|normal|not-allowed|nowrap|nw-resize|oblique|open-quote|outset|outside|overline|padding-box|page|pointer|pre-line|pre-wrap|pre|preserve-3d|progress|relative|repeat-x|repeat-y|repeat|replaced|reset-size|ridge|right|round|row-resize|rtl|s-resize|scroll|se-resize|separate|slice|small-caps|small-caption|solid|space|square|start|static|status-bar|step-end|step-start|steps|stretch|strict|sub|super|sw-resize|table-caption|table-cell|table-column-group|table-column|table-footer-group|table-header-group|table-row-group|table-row|table|tb-rl|text-after-edge|text-before-edge|text-bottom|text-size|text-top|text|thick|thin|transparent|underline|upper-alpha|upper-latin|upper-roman|uppercase|use-script|vertical-ideographic|vertical-text|visible|w-resize|wait|whitespace|z-index|zero|zoom";
10
var supportConstantColor = exports.supportConstantColor = "aliceblue|antiquewhite|aqua|aquamarine|azure|beige|bisque|black|blanchedalmond|blue|blueviolet|brown|burlywood|cadetblue|chartreuse|chocolate|coral|cornflowerblue|cornsilk|crimson|cyan|darkblue|darkcyan|darkgoldenrod|darkgray|darkgreen|darkgrey|darkkhaki|darkmagenta|darkolivegreen|darkorange|darkorchid|darkred|darksalmon|darkseagreen|darkslateblue|darkslategray|darkslategrey|darkturquoise|darkviolet|deeppink|deepskyblue|dimgray|dimgrey|dodgerblue|firebrick|floralwhite|forestgreen|fuchsia|gainsboro|ghostwhite|gold|goldenrod|gray|green|greenyellow|grey|honeydew|hotpink|indianred|indigo|ivory|khaki|lavender|lavenderblush|lawngreen|lemonchiffon|lightblue|lightcoral|lightcyan|lightgoldenrodyellow|lightgray|lightgreen|lightgrey|lightpink|lightsalmon|lightseagreen|lightskyblue|lightslategray|lightslategrey|lightsteelblue|lightyellow|lime|limegreen|linen|magenta|maroon|mediumaquamarine|mediumblue|mediumorchid|mediumpurple|mediumseagreen|mediumslateblue|mediumspringgreen|mediumturquoise|mediumvioletred|midnightblue|mintcream|mistyrose|moccasin|navajowhite|navy|oldlace|olive|olivedrab|orange|orangered|orchid|palegoldenrod|palegreen|paleturquoise|palevioletred|papayawhip|peachpuff|peru|pink|plum|powderblue|purple|rebeccapurple|red|rosybrown|royalblue|saddlebrown|salmon|sandybrown|seagreen|seashell|sienna|silver|skyblue|slateblue|slategray|slategrey|snow|springgreen|steelblue|tan|teal|thistle|tomato|turquoise|violet|wheat|white|whitesmoke|yellow|yellowgreen";
11
var supportConstantFonts = exports.supportConstantFonts = "arial|century|comic|courier|cursive|fantasy|garamond|georgia|helvetica|impact|lucida|symbol|system|tahoma|times|trebuchet|utopia|verdana|webdings|sans-serif|serif|monospace";
12

    
13
var numRe = exports.numRe = "\\-?(?:(?:[0-9]+(?:\\.[0-9]+)?)|(?:\\.[0-9]+))";
14
var pseudoElements = exports.pseudoElements = "(\\:+)\\b(after|before|first-letter|first-line|moz-selection|selection)\\b";
15
var pseudoClasses  = exports.pseudoClasses =  "(:)\\b(active|checked|disabled|empty|enabled|first-child|first-of-type|focus|hover|indeterminate|invalid|last-child|last-of-type|link|not|nth-child|nth-last-child|nth-last-of-type|nth-of-type|only-child|only-of-type|required|root|target|valid|visited)\\b";
16

    
17
var CssHighlightRules = function() {
18

    
19
    var keywordMapper = this.createKeywordMapper({
20
        "support.function": supportFunction,
21
        "support.constant": supportConstant,
22
        "support.type": supportType,
23
        "support.constant.color": supportConstantColor,
24
        "support.constant.fonts": supportConstantFonts
25
    }, "text", true);
26

    
27
    this.$rules = {
28
        "start" : [{
29
            include : ["strings", "url", "comments"]
30
        }, {
31
            token: "paren.lparen",
32
            regex: "\\{",
33
            next:  "ruleset"
34
        }, {
35
            token: "paren.rparen",
36
            regex: "\\}"
37
        }, {
38
            token: "string",
39
            regex: "@(?!viewport)",
40
            next:  "media"
41
        }, {
42
            token: "keyword",
43
            regex: "#[a-z0-9-_]+"
44
        }, {
45
            token: "keyword",
46
            regex: "%"
47
        }, {
48
            token: "variable",
49
            regex: "\\.[a-z0-9-_]+"
50
        }, {
51
            token: "string",
52
            regex: ":[a-z0-9-_]+"
53
        }, {
54
            token : "constant.numeric",
55
            regex : numRe
56
        }, {
57
            token: "constant",
58
            regex: "[a-z0-9-_]+"
59
        }, {
60
            caseInsensitive: true
61
        }],
62

    
63
        "media": [{
64
            include : ["strings", "url", "comments"]
65
        }, {
66
            token: "paren.lparen",
67
            regex: "\\{",
68
            next:  "start"
69
        }, {
70
            token: "paren.rparen",
71
            regex: "\\}",
72
            next:  "start"
73
        }, {
74
            token: "string",
75
            regex: ";",
76
            next:  "start"
77
        }, {
78
            token: "keyword",
79
            regex: "(?:media|supports|document|charset|import|namespace|media|supports|document"
80
                + "|page|font|keyframes|viewport|counter-style|font-feature-values"
81
                + "|swash|ornaments|annotation|stylistic|styleset|character-variant)"
82
        }],
83

    
84
        "comments" : [{
85
            token: "comment", // multi line comment
86
            regex: "\\/\\*",
87
            push: [{
88
                token : "comment",
89
                regex : "\\*\\/",
90
                next : "pop"
91
            }, {
92
                defaultToken : "comment"
93
            }]
94
        }],
95

    
96
        "ruleset" : [{
97
            regex : "-(webkit|ms|moz|o)-",
98
            token : "text"
99
        }, {
100
            token : "punctuation.operator",
101
            regex : "[:;]"
102
        }, {
103
            token : "paren.rparen",
104
            regex : "\\}",
105
            next : "start"
106
        }, {
107
            include : ["strings", "url", "comments"]
108
        }, {
109
            token : ["constant.numeric", "keyword"],
110
            regex : "(" + numRe + ")(ch|cm|deg|em|ex|fr|gd|grad|Hz|in|kHz|mm|ms|pc|pt|px|rad|rem|s|turn|vh|vmax|vmin|vm|vw|%)"
111
        }, {
112
            token : "constant.numeric",
113
            regex : numRe
114
        }, {
115
            token : "constant.numeric",  // hex6 color
116
            regex : "#[a-f0-9]{6}"
117
        }, {
118
            token : "constant.numeric", // hex3 color
119
            regex : "#[a-f0-9]{3}"
120
        }, {
121
            token : ["punctuation", "entity.other.attribute-name.pseudo-element.css"],
122
            regex : pseudoElements
123
        }, {
124
            token : ["punctuation", "entity.other.attribute-name.pseudo-class.css"],
125
            regex : pseudoClasses
126
        }, {
127
            include: "url"
128
        }, {
129
            token : keywordMapper,
130
            regex : "\\-?[a-zA-Z_][a-zA-Z0-9_\\-]*"
131
        }, {
132
            caseInsensitive: true
133
        }],
134

    
135
        url: [{
136
            token : "support.function",
137
            regex : "(?:url(:?-prefix)?|domain|regexp)\\(",
138
            push: [{
139
                token : "support.function",
140
                regex : "\\)",
141
                next : "pop"
142
            }, {
143
                defaultToken: "string"
144
            }]
145
        }],
146

    
147
        strings: [{
148
            token : "string.start",
149
            regex : "'",
150
            push : [{
151
                token : "string.end",
152
                regex : "'|$",
153
                next: "pop"
154
            }, {
155
                include : "escapes"
156
            }, {
157
                token : "constant.language.escape",
158
                regex : /\\$/,
159
                consumeLineEnd: true
160
            }, {
161
                defaultToken: "string"
162
            }]
163
        }, {
164
            token : "string.start",
165
            regex : '"',
166
            push : [{
167
                token : "string.end",
168
                regex : '"|$',
169
                next: "pop"
170
            }, {
171
                include : "escapes"
172
            }, {
173
                token : "constant.language.escape",
174
                regex : /\\$/,
175
                consumeLineEnd: true
176
            }, {
177
                defaultToken: "string"
178
            }]
179
        }],
180
        escapes: [{
181
            token : "constant.language.escape",
182
            regex : /\\([a-fA-F\d]{1,6}|[^a-fA-F\d])/
183
        }]
184

    
185
    };
186

    
187
    this.normalizeRules();
188
};
189

    
190
oop.inherits(CssHighlightRules, TextHighlightRules);
191

    
192
exports.CssHighlightRules = CssHighlightRules;
193

    
194
});
195

    
196
ace.define("ace/mode/less_highlight_rules",["require","exports","module","ace/lib/oop","ace/mode/text_highlight_rules","ace/mode/css_highlight_rules"], function(require, exports, module) {
197
"use strict";
198

    
199
var oop = require("../lib/oop");
200
var TextHighlightRules = require("./text_highlight_rules").TextHighlightRules;
201
var CssHighlightRules = require('./css_highlight_rules');
202

    
203
var LessHighlightRules = function() {
204

    
205

    
206
    var keywordList = "@import|@media|@font-face|@keyframes|@-webkit-keyframes|@supports|" + 
207
        "@charset|@plugin|@namespace|@document|@page|@viewport|@-ms-viewport|" +
208
        "or|and|when|not";
209

    
210
    var keywords = keywordList.split('|');
211

    
212
    var properties = CssHighlightRules.supportType.split('|');
213

    
214
    var keywordMapper = this.createKeywordMapper({
215
        "support.constant": CssHighlightRules.supportConstant,
216
        "keyword": keywordList,
217
        "support.constant.color": CssHighlightRules.supportConstantColor,
218
        "support.constant.fonts": CssHighlightRules.supportConstantFonts
219
    }, "identifier", true);   
220

    
221
    var numRe = "\\-?(?:(?:[0-9]+)|(?:[0-9]*\\.[0-9]+))";
222

    
223
    this.$rules = {
224
        "start" : [
225
            {
226
                token : "comment",
227
                regex : "\\/\\/.*$"
228
            },
229
            {
230
                token : "comment", // multi line comment
231
                regex : "\\/\\*",
232
                next : "comment"
233
            }, {
234
                token : "string", // single line
235
                regex : '["](?:(?:\\\\.)|(?:[^"\\\\]))*?["]'
236
            }, {
237
                token : "string", // single line
238
                regex : "['](?:(?:\\\\.)|(?:[^'\\\\]))*?[']"
239
            }, {
240
                token : ["constant.numeric", "keyword"],
241
                regex : "(" + numRe + ")(ch|cm|deg|em|ex|fr|gd|grad|Hz|in|kHz|mm|ms|pc|pt|px|rad|rem|s|turn|vh|vm|vw|%)"
242
            }, {
243
                token : "constant.numeric", // hex6 color
244
                regex : "#[a-f0-9]{6}"
245
            }, {
246
                token : "constant.numeric", // hex3 color
247
                regex : "#[a-f0-9]{3}"
248
            }, {
249
                token : "constant.numeric",
250
                regex : numRe
251
            }, {
252
                token : ["support.function", "paren.lparen", "string", "paren.rparen"],
253
                regex : "(url)(\\()(.*)(\\))"
254
            }, {
255
                token : ["support.function", "paren.lparen"],
256
                regex : "(:extend|[a-z0-9_\\-]+)(\\()"
257
            }, {
258
                token : function(value) {
259
                    if (keywords.indexOf(value.toLowerCase()) > -1)
260
                        return "keyword";
261
                    else
262
                        return "variable";
263
                },
264
                regex : "[@\\$][a-z0-9_\\-@\\$]*\\b"
265
            }, {
266
                token : "variable",
267
                regex : "[@\\$]\\{[a-z0-9_\\-@\\$]*\\}"
268
            }, {
269
                token : function(first, second) {
270
                    if(properties.indexOf(first.toLowerCase()) > -1) {
271
                        return ["support.type.property", "text"];
272
                    }
273
                    else {
274
                        return ["support.type.unknownProperty", "text"];
275
                    }
276
                },
277
                regex : "([a-z0-9-_]+)(\\s*:)"
278
            }, {
279
                token : "keyword",
280
                regex : "&"   // special case - always treat as keyword
281
            }, {
282
                token : keywordMapper,
283
                regex : "\\-?[@a-z_][@a-z0-9_\\-]*"
284
            }, {
285
                token: "variable.language",
286
                regex: "#[a-z0-9-_]+"
287
            }, {
288
                token: "variable.language",
289
                regex: "\\.[a-z0-9-_]+"
290
            }, {
291
                token: "variable.language",
292
                regex: ":[a-z_][a-z0-9-_]*"
293
            }, {
294
                token: "constant",
295
                regex: "[a-z0-9-_]+"
296
            }, {
297
                token : "keyword.operator",
298
                regex : "<|>|<=|>=|=|!=|-|%|\\+|\\*"
299
            }, {
300
                token : "paren.lparen",
301
                regex : "[[({]"
302
            }, {
303
                token : "paren.rparen",
304
                regex : "[\\])}]"
305
            }, {
306
                token : "text",
307
                regex : "\\s+"
308
            }, {
309
                caseInsensitive: true
310
            }
311
        ],
312
        "comment" : [
313
            {
314
                token : "comment", // closing comment
315
                regex : "\\*\\/",
316
                next : "start"
317
            }, {
318
                defaultToken : "comment"
319
            }
320
        ]
321
    };
322
    this.normalizeRules();
323
};
324

    
325
oop.inherits(LessHighlightRules, TextHighlightRules);
326

    
327
exports.LessHighlightRules = LessHighlightRules;
328

    
329
});
330

    
331
ace.define("ace/mode/matching_brace_outdent",["require","exports","module","ace/range"], function(require, exports, module) {
332
"use strict";
333

    
334
var Range = require("../range").Range;
335

    
336
var MatchingBraceOutdent = function() {};
337

    
338
(function() {
339

    
340
    this.checkOutdent = function(line, input) {
341
        if (! /^\s+$/.test(line))
342
            return false;
343

    
344
        return /^\s*\}/.test(input);
345
    };
346

    
347
    this.autoOutdent = function(doc, row) {
348
        var line = doc.getLine(row);
349
        var match = line.match(/^(\s*\})/);
350

    
351
        if (!match) return 0;
352

    
353
        var column = match[1].length;
354
        var openBracePos = doc.findMatchingBracket({row: row, column: column});
355

    
356
        if (!openBracePos || openBracePos.row == row) return 0;
357

    
358
        var indent = this.$getIndent(doc.getLine(openBracePos.row));
359
        doc.replace(new Range(row, 0, row, column-1), indent);
360
    };
361

    
362
    this.$getIndent = function(line) {
363
        return line.match(/^\s*/)[0];
364
    };
365

    
366
}).call(MatchingBraceOutdent.prototype);
367

    
368
exports.MatchingBraceOutdent = MatchingBraceOutdent;
369
});
370

    
371
ace.define("ace/mode/behaviour/css",["require","exports","module","ace/lib/oop","ace/mode/behaviour","ace/mode/behaviour/cstyle","ace/token_iterator"], function(require, exports, module) {
372
"use strict";
373

    
374
var oop = require("../../lib/oop");
375
var Behaviour = require("../behaviour").Behaviour;
376
var CstyleBehaviour = require("./cstyle").CstyleBehaviour;
377
var TokenIterator = require("../../token_iterator").TokenIterator;
378

    
379
var CssBehaviour = function () {
380

    
381
    this.inherit(CstyleBehaviour);
382

    
383
    this.add("colon", "insertion", function (state, action, editor, session, text) {
384
        if (text === ':' && editor.selection.isEmpty()) {
385
            var cursor = editor.getCursorPosition();
386
            var iterator = new TokenIterator(session, cursor.row, cursor.column);
387
            var token = iterator.getCurrentToken();
388
            if (token && token.value.match(/\s+/)) {
389
                token = iterator.stepBackward();
390
            }
391
            if (token && token.type === 'support.type') {
392
                var line = session.doc.getLine(cursor.row);
393
                var rightChar = line.substring(cursor.column, cursor.column + 1);
394
                if (rightChar === ':') {
395
                    return {
396
                       text: '',
397
                       selection: [1, 1]
398
                    };
399
                }
400
                if (/^(\s+[^;]|\s*$)/.test(line.substring(cursor.column))) {
401
                    return {
402
                       text: ':;',
403
                       selection: [1, 1]
404
                    };
405
                }
406
            }
407
        }
408
    });
409

    
410
    this.add("colon", "deletion", function (state, action, editor, session, range) {
411
        var selected = session.doc.getTextRange(range);
412
        if (!range.isMultiLine() && selected === ':') {
413
            var cursor = editor.getCursorPosition();
414
            var iterator = new TokenIterator(session, cursor.row, cursor.column);
415
            var token = iterator.getCurrentToken();
416
            if (token && token.value.match(/\s+/)) {
417
                token = iterator.stepBackward();
418
            }
419
            if (token && token.type === 'support.type') {
420
                var line = session.doc.getLine(range.start.row);
421
                var rightChar = line.substring(range.end.column, range.end.column + 1);
422
                if (rightChar === ';') {
423
                    range.end.column ++;
424
                    return range;
425
                }
426
            }
427
        }
428
    });
429

    
430
    this.add("semicolon", "insertion", function (state, action, editor, session, text) {
431
        if (text === ';' && editor.selection.isEmpty()) {
432
            var cursor = editor.getCursorPosition();
433
            var line = session.doc.getLine(cursor.row);
434
            var rightChar = line.substring(cursor.column, cursor.column + 1);
435
            if (rightChar === ';') {
436
                return {
437
                   text: '',
438
                   selection: [1, 1]
439
                };
440
            }
441
        }
442
    });
443

    
444
    this.add("!important", "insertion", function (state, action, editor, session, text) {
445
        if (text === '!' && editor.selection.isEmpty()) {
446
            var cursor = editor.getCursorPosition();
447
            var line = session.doc.getLine(cursor.row);
448

    
449
            if (/^\s*(;|}|$)/.test(line.substring(cursor.column))) {
450
                return {
451
                    text: '!important',
452
                    selection: [10, 10]
453
                };
454
            }
455
        }
456
    });
457

    
458
};
459
oop.inherits(CssBehaviour, CstyleBehaviour);
460

    
461
exports.CssBehaviour = CssBehaviour;
462
});
463

    
464
ace.define("ace/mode/css_completions",["require","exports","module"], function(require, exports, module) {
465
"use strict";
466

    
467
var propertyMap = {
468
    "background": {"#$0": 1},
469
    "background-color": {"#$0": 1, "transparent": 1, "fixed": 1},
470
    "background-image": {"url('/$0')": 1},
471
    "background-repeat": {"repeat": 1, "repeat-x": 1, "repeat-y": 1, "no-repeat": 1, "inherit": 1},
472
    "background-position": {"bottom":2, "center":2, "left":2, "right":2, "top":2, "inherit":2},
473
    "background-attachment": {"scroll": 1, "fixed": 1},
474
    "background-size": {"cover": 1, "contain": 1},
475
    "background-clip": {"border-box": 1, "padding-box": 1, "content-box": 1},
476
    "background-origin": {"border-box": 1, "padding-box": 1, "content-box": 1},
477
    "border": {"solid $0": 1, "dashed $0": 1, "dotted $0": 1, "#$0": 1},
478
    "border-color": {"#$0": 1},
479
    "border-style": {"solid":2, "dashed":2, "dotted":2, "double":2, "groove":2, "hidden":2, "inherit":2, "inset":2, "none":2, "outset":2, "ridged":2},
480
    "border-collapse": {"collapse": 1, "separate": 1},
481
    "bottom": {"px": 1, "em": 1, "%": 1},
482
    "clear": {"left": 1, "right": 1, "both": 1, "none": 1},
483
    "color": {"#$0": 1, "rgb(#$00,0,0)": 1},
484
    "cursor": {"default": 1, "pointer": 1, "move": 1, "text": 1, "wait": 1, "help": 1, "progress": 1, "n-resize": 1, "ne-resize": 1, "e-resize": 1, "se-resize": 1, "s-resize": 1, "sw-resize": 1, "w-resize": 1, "nw-resize": 1},
485
    "display": {"none": 1, "block": 1, "inline": 1, "inline-block": 1, "table-cell": 1},
486
    "empty-cells": {"show": 1, "hide": 1},
487
    "float": {"left": 1, "right": 1, "none": 1},
488
    "font-family": {"Arial":2,"Comic Sans MS":2,"Consolas":2,"Courier New":2,"Courier":2,"Georgia":2,"Monospace":2,"Sans-Serif":2, "Segoe UI":2,"Tahoma":2,"Times New Roman":2,"Trebuchet MS":2,"Verdana": 1},
489
    "font-size": {"px": 1, "em": 1, "%": 1},
490
    "font-weight": {"bold": 1, "normal": 1},
491
    "font-style": {"italic": 1, "normal": 1},
492
    "font-variant": {"normal": 1, "small-caps": 1},
493
    "height": {"px": 1, "em": 1, "%": 1},
494
    "left": {"px": 1, "em": 1, "%": 1},
495
    "letter-spacing": {"normal": 1},
496
    "line-height": {"normal": 1},
497
    "list-style-type": {"none": 1, "disc": 1, "circle": 1, "square": 1, "decimal": 1, "decimal-leading-zero": 1, "lower-roman": 1, "upper-roman": 1, "lower-greek": 1, "lower-latin": 1, "upper-latin": 1, "georgian": 1, "lower-alpha": 1, "upper-alpha": 1},
498
    "margin": {"px": 1, "em": 1, "%": 1},
499
    "margin-right": {"px": 1, "em": 1, "%": 1},
500
    "margin-left": {"px": 1, "em": 1, "%": 1},
501
    "margin-top": {"px": 1, "em": 1, "%": 1},
502
    "margin-bottom": {"px": 1, "em": 1, "%": 1},
503
    "max-height": {"px": 1, "em": 1, "%": 1},
504
    "max-width": {"px": 1, "em": 1, "%": 1},
505
    "min-height": {"px": 1, "em": 1, "%": 1},
506
    "min-width": {"px": 1, "em": 1, "%": 1},
507
    "overflow": {"hidden": 1, "visible": 1, "auto": 1, "scroll": 1},
508
    "overflow-x": {"hidden": 1, "visible": 1, "auto": 1, "scroll": 1},
509
    "overflow-y": {"hidden": 1, "visible": 1, "auto": 1, "scroll": 1},
510
    "padding": {"px": 1, "em": 1, "%": 1},
511
    "padding-top": {"px": 1, "em": 1, "%": 1},
512
    "padding-right": {"px": 1, "em": 1, "%": 1},
513
    "padding-bottom": {"px": 1, "em": 1, "%": 1},
514
    "padding-left": {"px": 1, "em": 1, "%": 1},
515
    "page-break-after": {"auto": 1, "always": 1, "avoid": 1, "left": 1, "right": 1},
516
    "page-break-before": {"auto": 1, "always": 1, "avoid": 1, "left": 1, "right": 1},
517
    "position": {"absolute": 1, "relative": 1, "fixed": 1, "static": 1},
518
    "right": {"px": 1, "em": 1, "%": 1},
519
    "table-layout": {"fixed": 1, "auto": 1},
520
    "text-decoration": {"none": 1, "underline": 1, "line-through": 1, "blink": 1},
521
    "text-align": {"left": 1, "right": 1, "center": 1, "justify": 1},
522
    "text-transform": {"capitalize": 1, "uppercase": 1, "lowercase": 1, "none": 1},
523
    "top": {"px": 1, "em": 1, "%": 1},
524
    "vertical-align": {"top": 1, "bottom": 1},
525
    "visibility": {"hidden": 1, "visible": 1},
526
    "white-space": {"nowrap": 1, "normal": 1, "pre": 1, "pre-line": 1, "pre-wrap": 1},
527
    "width": {"px": 1, "em": 1, "%": 1},
528
    "word-spacing": {"normal": 1},
529
    "filter": {"alpha(opacity=$0100)": 1},
530

    
531
    "text-shadow": {"$02px 2px 2px #777": 1},
532
    "text-overflow": {"ellipsis-word": 1, "clip": 1, "ellipsis": 1},
533
    "-moz-border-radius": 1,
534
    "-moz-border-radius-topright": 1,
535
    "-moz-border-radius-bottomright": 1,
536
    "-moz-border-radius-topleft": 1,
537
    "-moz-border-radius-bottomleft": 1,
538
    "-webkit-border-radius": 1,
539
    "-webkit-border-top-right-radius": 1,
540
    "-webkit-border-top-left-radius": 1,
541
    "-webkit-border-bottom-right-radius": 1,
542
    "-webkit-border-bottom-left-radius": 1,
543
    "-moz-box-shadow": 1,
544
    "-webkit-box-shadow": 1,
545
    "transform": {"rotate($00deg)": 1, "skew($00deg)": 1},
546
    "-moz-transform": {"rotate($00deg)": 1, "skew($00deg)": 1},
547
    "-webkit-transform": {"rotate($00deg)": 1, "skew($00deg)": 1 }
548
};
549

    
550
var CssCompletions = function() {
551

    
552
};
553

    
554
(function() {
555

    
556
    this.completionsDefined = false;
557

    
558
    this.defineCompletions = function() {
559
        if (document) {
560
            var style = document.createElement('c').style;
561

    
562
            for (var i in style) {
563
                if (typeof style[i] !== 'string')
564
                    continue;
565

    
566
                var name = i.replace(/[A-Z]/g, function(x) {
567
                    return '-' + x.toLowerCase();
568
                });
569

    
570
                if (!propertyMap.hasOwnProperty(name))
571
                    propertyMap[name] = 1;
572
            }
573
        }
574

    
575
        this.completionsDefined = true;
576
    };
577

    
578
    this.getCompletions = function(state, session, pos, prefix) {
579
        if (!this.completionsDefined) {
580
            this.defineCompletions();
581
        }
582

    
583
        if (state==='ruleset' || session.$mode.$id == "ace/mode/scss") {
584
            var line = session.getLine(pos.row).substr(0, pos.column);
585
            if (/:[^;]+$/.test(line)) {
586
                /([\w\-]+):[^:]*$/.test(line);
587

    
588
                return this.getPropertyValueCompletions(state, session, pos, prefix);
589
            } else {
590
                return this.getPropertyCompletions(state, session, pos, prefix);
591
            }
592
        }
593

    
594
        return [];
595
    };
596

    
597
    this.getPropertyCompletions = function(state, session, pos, prefix) {
598
        var properties = Object.keys(propertyMap);
599
        return properties.map(function(property){
600
            return {
601
                caption: property,
602
                snippet: property + ': $0;',
603
                meta: "property",
604
                score: 1000000
605
            };
606
        });
607
    };
608

    
609
    this.getPropertyValueCompletions = function(state, session, pos, prefix) {
610
        var line = session.getLine(pos.row).substr(0, pos.column);
611
        var property = (/([\w\-]+):[^:]*$/.exec(line) || {})[1];
612

    
613
        if (!property)
614
            return [];
615
        var values = [];
616
        if (property in propertyMap && typeof propertyMap[property] === "object") {
617
            values = Object.keys(propertyMap[property]);
618
        }
619
        return values.map(function(value){
620
            return {
621
                caption: value,
622
                snippet: value,
623
                meta: "property value",
624
                score: 1000000
625
            };
626
        });
627
    };
628

    
629
}).call(CssCompletions.prototype);
630

    
631
exports.CssCompletions = CssCompletions;
632
});
633

    
634
ace.define("ace/mode/folding/cstyle",["require","exports","module","ace/lib/oop","ace/range","ace/mode/folding/fold_mode"], function(require, exports, module) {
635
"use strict";
636

    
637
var oop = require("../../lib/oop");
638
var Range = require("../../range").Range;
639
var BaseFoldMode = require("./fold_mode").FoldMode;
640

    
641
var FoldMode = exports.FoldMode = function(commentRegex) {
642
    if (commentRegex) {
643
        this.foldingStartMarker = new RegExp(
644
            this.foldingStartMarker.source.replace(/\|[^|]*?$/, "|" + commentRegex.start)
645
        );
646
        this.foldingStopMarker = new RegExp(
647
            this.foldingStopMarker.source.replace(/\|[^|]*?$/, "|" + commentRegex.end)
648
        );
649
    }
650
};
651
oop.inherits(FoldMode, BaseFoldMode);
652

    
653
(function() {
654
    
655
    this.foldingStartMarker = /([\{\[\(])[^\}\]\)]*$|^\s*(\/\*)/;
656
    this.foldingStopMarker = /^[^\[\{\(]*([\}\]\)])|^[\s\*]*(\*\/)/;
657
    this.singleLineBlockCommentRe= /^\s*(\/\*).*\*\/\s*$/;
658
    this.tripleStarBlockCommentRe = /^\s*(\/\*\*\*).*\*\/\s*$/;
659
    this.startRegionRe = /^\s*(\/\*|\/\/)#?region\b/;
660
    this._getFoldWidgetBase = this.getFoldWidget;
661
    this.getFoldWidget = function(session, foldStyle, row) {
662
        var line = session.getLine(row);
663
    
664
        if (this.singleLineBlockCommentRe.test(line)) {
665
            if (!this.startRegionRe.test(line) && !this.tripleStarBlockCommentRe.test(line))
666
                return "";
667
        }
668
    
669
        var fw = this._getFoldWidgetBase(session, foldStyle, row);
670
    
671
        if (!fw && this.startRegionRe.test(line))
672
            return "start"; // lineCommentRegionStart
673
    
674
        return fw;
675
    };
676

    
677
    this.getFoldWidgetRange = function(session, foldStyle, row, forceMultiline) {
678
        var line = session.getLine(row);
679
        
680
        if (this.startRegionRe.test(line))
681
            return this.getCommentRegionBlock(session, line, row);
682
        
683
        var match = line.match(this.foldingStartMarker);
684
        if (match) {
685
            var i = match.index;
686

    
687
            if (match[1])
688
                return this.openingBracketBlock(session, match[1], row, i);
689
                
690
            var range = session.getCommentFoldRange(row, i + match[0].length, 1);
691
            
692
            if (range && !range.isMultiLine()) {
693
                if (forceMultiline) {
694
                    range = this.getSectionRange(session, row);
695
                } else if (foldStyle != "all")
696
                    range = null;
697
            }
698
            
699
            return range;
700
        }
701

    
702
        if (foldStyle === "markbegin")
703
            return;
704

    
705
        var match = line.match(this.foldingStopMarker);
706
        if (match) {
707
            var i = match.index + match[0].length;
708

    
709
            if (match[1])
710
                return this.closingBracketBlock(session, match[1], row, i);
711

    
712
            return session.getCommentFoldRange(row, i, -1);
713
        }
714
    };
715
    
716
    this.getSectionRange = function(session, row) {
717
        var line = session.getLine(row);
718
        var startIndent = line.search(/\S/);
719
        var startRow = row;
720
        var startColumn = line.length;
721
        row = row + 1;
722
        var endRow = row;
723
        var maxRow = session.getLength();
724
        while (++row < maxRow) {
725
            line = session.getLine(row);
726
            var indent = line.search(/\S/);
727
            if (indent === -1)
728
                continue;
729
            if  (startIndent > indent)
730
                break;
731
            var subRange = this.getFoldWidgetRange(session, "all", row);
732
            
733
            if (subRange) {
734
                if (subRange.start.row <= startRow) {
735
                    break;
736
                } else if (subRange.isMultiLine()) {
737
                    row = subRange.end.row;
738
                } else if (startIndent == indent) {
739
                    break;
740
                }
741
            }
742
            endRow = row;
743
        }
744
        
745
        return new Range(startRow, startColumn, endRow, session.getLine(endRow).length);
746
    };
747
    this.getCommentRegionBlock = function(session, line, row) {
748
        var startColumn = line.search(/\s*$/);
749
        var maxRow = session.getLength();
750
        var startRow = row;
751
        
752
        var re = /^\s*(?:\/\*|\/\/|--)#?(end)?region\b/;
753
        var depth = 1;
754
        while (++row < maxRow) {
755
            line = session.getLine(row);
756
            var m = re.exec(line);
757
            if (!m) continue;
758
            if (m[1]) depth--;
759
            else depth++;
760

    
761
            if (!depth) break;
762
        }
763

    
764
        var endRow = row;
765
        if (endRow > startRow) {
766
            return new Range(startRow, startColumn, endRow, line.length);
767
        }
768
    };
769

    
770
}).call(FoldMode.prototype);
771

    
772
});
773

    
774
ace.define("ace/mode/less",["require","exports","module","ace/lib/oop","ace/mode/text","ace/mode/less_highlight_rules","ace/mode/matching_brace_outdent","ace/mode/behaviour/css","ace/mode/css_completions","ace/mode/folding/cstyle"], function(require, exports, module) {
775
"use strict";
776

    
777
var oop = require("../lib/oop");
778
var TextMode = require("./text").Mode;
779
var LessHighlightRules = require("./less_highlight_rules").LessHighlightRules;
780
var MatchingBraceOutdent = require("./matching_brace_outdent").MatchingBraceOutdent;
781
var CssBehaviour = require("./behaviour/css").CssBehaviour;
782
var CssCompletions = require("./css_completions").CssCompletions;
783

    
784
var CStyleFoldMode = require("./folding/cstyle").FoldMode;
785

    
786
var Mode = function() {
787
    this.HighlightRules = LessHighlightRules;
788
    this.$outdent = new MatchingBraceOutdent();
789
    this.$behaviour = new CssBehaviour();
790
    this.$completer = new CssCompletions();
791
    this.foldingRules = new CStyleFoldMode();
792
};
793
oop.inherits(Mode, TextMode);
794

    
795
(function() {
796

    
797
    this.lineCommentStart = "//";
798
    this.blockComment = {start: "/*", end: "*/"};
799
    
800
    this.getNextLineIndent = function(state, line, tab) {
801
        var indent = this.$getIndent(line);
802
        var tokens = this.getTokenizer().getLineTokens(line, state).tokens;
803
        if (tokens.length && tokens[tokens.length-1].type == "comment") {
804
            return indent;
805
        }
806

    
807
        var match = line.match(/^.*\{\s*$/);
808
        if (match) {
809
            indent += tab;
810
        }
811

    
812
        return indent;
813
    };
814

    
815
    this.checkOutdent = function(state, line, input) {
816
        return this.$outdent.checkOutdent(line, input);
817
    };
818

    
819
    this.autoOutdent = function(state, doc, row) {
820
        this.$outdent.autoOutdent(doc, row);
821
    };
822

    
823
    this.getCompletions = function(state, session, pos, prefix) {
824
        return this.$completer.getCompletions("ruleset", session, pos, prefix);
825
    };
826

    
827
    this.$id = "ace/mode/less";
828
}).call(Mode.prototype);
829

    
830
exports.Mode = Mode;
831

    
832
});                (function() {
833
                    ace.require(["ace/mode/less"], function(m) {
834
                        if (typeof module == "object" && typeof exports == "object" && module) {
835
                            module.exports = m;
836
                        }
837
                    });
838
                })();
839
            
(106-106/244)