less 2.4.0 → 2.5.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Changelog.md +4 -0
- data/Gemfile +1 -1
- data/less.gemspec +1 -1
- data/lib/less/defaults.rb +3 -3
- data/lib/less/java_script/v8_context.rb +1 -1
- data/lib/less/js/.gitattributes +3 -2
- data/lib/less/js/.gitignore +18 -2
- data/lib/less/js/.jshintrc +11 -0
- data/lib/less/js/CHANGELOG.md +87 -2
- data/lib/less/js/CONTRIBUTING.md +4 -3
- data/lib/less/js/Gruntfile.js +290 -0
- data/lib/less/js/README.md +342 -12
- data/lib/less/js/benchmark/benchmark.less +194 -194
- data/lib/less/js/benchmark/less-benchmark.js +9 -10
- data/lib/less/js/bin/lessc +154 -12
- data/lib/less/js/bower.json +18 -0
- data/lib/less/js/build.gradle +347 -0
- data/lib/less/js/build/README.md +350 -0
- data/lib/less/js/build/browser-header.js +4 -0
- data/lib/less/js/build/build.yml +160 -0
- data/lib/less/js/build/require-rhino.js +7 -2
- data/lib/less/js/build/rhino-header.js +4 -0
- data/lib/less/js/build/rhino-modules.js +131 -0
- data/lib/less/js/build/tasks/.gitkeep +1 -0
- data/lib/less/js/dist/less-1.5.0.js +6914 -0
- data/lib/less/js/dist/less-1.5.0.min.js +13 -0
- data/lib/less/js/dist/less-1.5.1.js +6941 -0
- data/lib/less/js/dist/less-1.5.1.min.js +13 -0
- data/lib/less/js/dist/less-1.6.0.js +7485 -0
- data/lib/less/js/dist/less-1.6.0.min.js +16 -0
- data/lib/less/js/dist/less-1.6.1.js +7513 -0
- data/lib/less/js/dist/less-1.6.1.min.js +16 -0
- data/lib/less/js/dist/less-1.6.2.js +7624 -0
- data/lib/less/js/dist/less-1.6.2.min.js +16 -0
- data/lib/less/js/dist/less-rhino-1.5.1.js +6831 -0
- data/lib/less/js/dist/less-rhino-1.6.2.js +9017 -0
- data/lib/less/js/dist/lessc-rhino-1.6.2.js +449 -0
- data/lib/less/js/gradle/wrapper/gradle-wrapper.jar +0 -0
- data/lib/less/js/gradle/wrapper/gradle-wrapper.properties +6 -0
- data/lib/less/js/gradlew +164 -0
- data/lib/less/js/gradlew.bat +90 -0
- data/lib/less/js/lib/less/browser.js +482 -367
- data/lib/less/js/lib/less/colors.js +0 -1
- data/lib/less/js/lib/less/encoder.js +4 -0
- data/lib/less/js/lib/less/env.js +50 -19
- data/lib/less/js/lib/less/extend-visitor.js +66 -41
- data/lib/less/js/lib/less/functions.js +309 -104
- data/lib/less/js/lib/less/import-visitor.js +21 -10
- data/lib/less/js/lib/less/index.js +90 -68
- data/lib/less/js/lib/less/join-selector-visitor.js +11 -4
- data/lib/less/js/lib/less/lessc_helper.js +56 -45
- data/lib/less/js/lib/less/parser.js +830 -460
- data/lib/less/js/lib/less/rhino.js +380 -58
- data/lib/less/js/lib/less/source-map-output.js +141 -0
- data/lib/less/js/lib/less/to-css-visitor.js +215 -0
- data/lib/less/js/lib/less/tree.js +57 -5
- data/lib/less/js/lib/less/tree/alpha.js +13 -5
- data/lib/less/js/lib/less/tree/anonymous.js +11 -5
- data/lib/less/js/lib/less/tree/assignment.js +11 -5
- data/lib/less/js/lib/less/tree/call.js +19 -8
- data/lib/less/js/lib/less/tree/color.js +59 -36
- data/lib/less/js/lib/less/tree/comment.js +17 -4
- data/lib/less/js/lib/less/tree/condition.js +3 -3
- data/lib/less/js/lib/less/tree/dimension.js +161 -153
- data/lib/less/js/lib/less/tree/directive.js +39 -18
- data/lib/less/js/lib/less/tree/element.js +41 -18
- data/lib/less/js/lib/less/tree/expression.js +11 -5
- data/lib/less/js/lib/less/tree/extend.js +11 -1
- data/lib/less/js/lib/less/tree/import.js +34 -20
- data/lib/less/js/lib/less/tree/javascript.js +16 -10
- data/lib/less/js/lib/less/tree/keyword.js +5 -2
- data/lib/less/js/lib/less/tree/media.js +39 -22
- data/lib/less/js/lib/less/tree/mixin.js +135 -56
- data/lib/less/js/lib/less/tree/negative.js +4 -2
- data/lib/less/js/lib/less/tree/operation.js +17 -12
- data/lib/less/js/lib/less/tree/paren.js +5 -2
- data/lib/less/js/lib/less/tree/quoted.js +9 -6
- data/lib/less/js/lib/less/tree/rule.js +39 -21
- data/lib/less/js/lib/less/tree/ruleset.js +229 -145
- data/lib/less/js/lib/less/tree/selector.js +101 -34
- data/lib/less/js/lib/less/tree/unicode-descriptor.js +4 -3
- data/lib/less/js/lib/less/tree/url.js +33 -11
- data/lib/less/js/lib/less/tree/value.js +13 -6
- data/lib/less/js/lib/less/tree/variable.js +13 -8
- data/lib/less/js/lib/less/visitor.js +117 -25
- data/lib/less/js/lib/source-map/source-map-0.1.31.js +1933 -0
- data/lib/less/js/lib/source-map/source-map-footer.js +4 -0
- data/lib/less/js/lib/source-map/source-map-header.js +3 -0
- data/lib/less/js/package.json +30 -15
- data/lib/less/js/test/browser/common.js +131 -56
- data/lib/less/js/test/browser/css/global-vars/simple.css +3 -0
- data/lib/less/js/test/browser/css/modify-vars/simple.css +8 -0
- data/lib/less/js/test/browser/css/relative-urls/urls.css +8 -9
- data/lib/less/js/test/browser/css/rootpath-relative/urls.css +0 -1
- data/lib/less/js/test/browser/css/rootpath/urls.css +0 -1
- data/lib/less/js/test/browser/css/urls.css +18 -14
- data/lib/less/js/test/browser/es5.js +27 -0
- data/lib/less/js/test/{less/errors/color-operation-error.less → browser/less/console-errors/test-error.less} +0 -0
- data/lib/less/js/test/browser/less/console-errors/test-error.txt +2 -0
- data/lib/less/js/test/browser/less/global-vars/simple.less +3 -0
- data/lib/less/js/test/browser/less/modify-vars/imports/simple2.less +4 -0
- data/lib/less/js/test/browser/less/modify-vars/simple.less +8 -0
- data/lib/less/js/test/browser/less/relative-urls/urls.less +1 -1
- data/lib/less/js/test/browser/less/rootpath-relative/urls.less +1 -1
- data/lib/less/js/test/browser/less/rootpath/urls.less +1 -1
- data/lib/less/js/test/browser/less/urls.less +9 -1
- data/lib/less/js/test/browser/phantom-runner.js +112 -103
- data/lib/less/js/test/browser/runner-browser-options.js +42 -0
- data/lib/less/js/test/browser/{runner-browser.js → runner-browser-spec.js} +7 -2
- data/lib/less/js/test/browser/runner-console-errors.js +5 -0
- data/lib/less/js/test/browser/runner-errors-options.js +5 -0
- data/lib/less/js/test/browser/runner-errors-spec.js +4 -0
- data/lib/less/js/test/browser/runner-global-vars-options.js +4 -0
- data/lib/less/js/test/browser/runner-global-vars-spec.js +3 -0
- data/lib/less/js/test/browser/runner-legacy-options.js +4 -0
- data/lib/less/js/test/browser/{runner-legacy.js → runner-legacy-spec.js} +1 -4
- data/lib/less/js/test/browser/runner-main-options.js +15 -0
- data/lib/less/js/test/browser/runner-main-spec.js +3 -0
- data/lib/less/js/test/browser/runner-modify-vars-options.js +2 -0
- data/lib/less/js/test/browser/runner-modify-vars-spec.js +43 -0
- data/lib/less/js/test/browser/runner-no-js-errors-options.js +4 -0
- data/lib/less/js/test/browser/runner-no-js-errors-spec.js +4 -0
- data/lib/less/js/test/browser/runner-production-options.js +3 -0
- data/lib/less/js/test/browser/{runner-production.js → runner-production-spec.js} +1 -3
- data/lib/less/js/test/browser/runner-relative-urls-options.js +3 -0
- data/lib/less/js/test/browser/{runner-relative-urls.js → runner-relative-urls-spec.js} +1 -2
- data/lib/less/js/test/browser/runner-rootpath-options.js +3 -0
- data/lib/less/js/test/browser/runner-rootpath-relative-options.js +4 -0
- data/lib/less/js/test/browser/{runner-rootpath-relative.js → runner-rootpath-relative-spec.js} +1 -3
- data/lib/less/js/test/browser/{runner-rootpath.js → runner-rootpath-spec.js} +1 -2
- data/lib/less/js/test/browser/test-runner-template.tmpl +47 -0
- data/lib/less/js/test/css/colors.css +7 -0
- data/lib/less/js/test/css/comments.css +9 -4
- data/lib/less/js/test/css/compression/compression.css +3 -2
- data/lib/less/js/test/css/css-3.css +17 -5
- data/lib/less/js/test/css/css-guards.css +37 -0
- data/lib/less/js/test/css/debug/linenumbers-all.css +6 -0
- data/lib/less/js/test/css/debug/linenumbers-comments.css +5 -0
- data/lib/less/js/test/css/debug/linenumbers-mediaquery.css +5 -0
- data/lib/less/js/test/css/empty.css +0 -0
- data/lib/less/js/test/css/extend-chaining.css +9 -0
- data/lib/less/js/test/css/extend-selector.css +10 -2
- data/lib/less/js/test/css/extract-and-length.css +133 -0
- data/lib/less/js/test/css/functions.css +23 -10
- data/lib/less/js/test/css/globalVars/extended.css +12 -0
- data/lib/less/js/test/css/globalVars/simple.css +6 -0
- data/lib/less/js/test/css/import-inline.css +5 -0
- data/lib/less/js/test/css/import-once.css +12 -0
- data/lib/less/js/test/css/import-reference.css +49 -0
- data/lib/less/js/test/css/import.css +0 -2
- data/lib/less/js/test/css/media.css +21 -5
- data/lib/less/js/test/css/merge.css +26 -0
- data/lib/less/js/test/css/mixins-guards-default-func.css +129 -0
- data/lib/less/js/test/css/mixins-guards.css +6 -0
- data/lib/less/js/test/css/mixins-important.css +7 -0
- data/lib/less/js/test/css/mixins-interpolated.css +39 -0
- data/lib/less/js/test/css/mixins.css +20 -0
- data/lib/less/js/test/css/modifyVars/extended.css +9 -0
- data/lib/less/js/test/css/no-output.css +0 -0
- data/lib/less/js/test/css/parens.css +3 -0
- data/lib/less/js/test/css/property-name-interp.css +20 -0
- data/lib/less/js/test/css/selectors.css +12 -0
- data/lib/less/js/test/css/static-urls/urls.css +7 -4
- data/lib/less/js/test/css/strings.css +3 -0
- data/lib/less/js/test/css/url-args/urls.css +56 -0
- data/lib/less/js/test/css/urls.css +21 -9
- data/lib/less/js/test/index.js +45 -0
- data/lib/less/js/test/less-test.js +234 -191
- data/lib/less/js/test/less/colors.less +6 -0
- data/lib/less/js/test/less/comments.less +7 -1
- data/lib/less/js/test/less/compression/compression.less +21 -1
- data/lib/less/js/test/less/css-3.less +12 -0
- data/lib/less/js/test/less/css-guards.less +99 -0
- data/lib/less/js/test/less/debug/linenumbers.less +11 -1
- data/lib/less/js/test/less/empty.less +0 -0
- data/lib/less/js/test/less/errors/add-mixed-units.txt +4 -2
- data/lib/less/js/test/less/errors/add-mixed-units2.txt +4 -2
- data/lib/less/js/test/less/errors/color-func-invalid-color.less +3 -0
- data/lib/less/js/test/less/errors/color-func-invalid-color.txt +4 -0
- data/lib/less/js/test/less/errors/css-guard-default-func.less +4 -0
- data/lib/less/js/test/less/errors/css-guard-default-func.txt +4 -0
- data/lib/less/js/test/less/errors/import-subfolder2.txt +4 -2
- data/lib/less/js/test/less/errors/javascript-undefined-var.less +3 -0
- data/lib/less/js/test/less/errors/javascript-undefined-var.txt +4 -0
- data/lib/less/js/test/less/errors/mixins-guards-default-func-1.less +9 -0
- data/lib/less/js/test/less/errors/mixins-guards-default-func-1.txt +4 -0
- data/lib/less/js/test/less/errors/mixins-guards-default-func-2.less +9 -0
- data/lib/less/js/test/less/errors/mixins-guards-default-func-2.txt +4 -0
- data/lib/less/js/test/less/errors/mixins-guards-default-func-3.less +9 -0
- data/lib/less/js/test/less/errors/mixins-guards-default-func-3.txt +4 -0
- data/lib/less/js/test/less/errors/multiple-guards-on-css-selectors.less +4 -0
- data/lib/less/js/test/less/errors/multiple-guards-on-css-selectors.txt +4 -0
- data/lib/less/js/test/less/errors/multiple-guards-on-css-selectors2.less +4 -0
- data/lib/less/js/test/less/errors/multiple-guards-on-css-selectors2.txt +4 -0
- data/lib/less/js/test/less/errors/parse-error-curly-bracket.less +4 -1
- data/lib/less/js/test/less/errors/parse-error-curly-bracket.txt +4 -2
- data/lib/less/js/test/less/errors/parse-error-extra-parens.less +5 -0
- data/lib/less/js/test/less/errors/parse-error-extra-parens.txt +3 -0
- data/lib/less/js/test/less/errors/parse-error-missing-bracket.txt +2 -2
- data/lib/less/js/test/less/errors/parse-error-missing-parens.less +5 -0
- data/lib/less/js/test/less/errors/parse-error-missing-parens.txt +3 -0
- data/lib/less/js/test/less/errors/property-asterisk-only-name.less +3 -0
- data/lib/less/js/test/less/errors/property-asterisk-only-name.txt +4 -0
- data/lib/less/js/test/less/errors/property-interp-not-defined.less +1 -0
- data/lib/less/js/test/less/errors/property-interp-not-defined.txt +2 -0
- data/lib/less/js/test/less/errors/svg-gradient1.less +3 -0
- data/lib/less/js/test/less/errors/svg-gradient1.txt +4 -0
- data/lib/less/js/test/less/errors/svg-gradient2.less +3 -0
- data/lib/less/js/test/less/errors/svg-gradient2.txt +4 -0
- data/lib/less/js/test/less/errors/svg-gradient3.less +3 -0
- data/lib/less/js/test/less/errors/svg-gradient3.txt +4 -0
- data/lib/less/js/test/less/errors/unit-function.less +3 -0
- data/lib/less/js/test/less/errors/unit-function.txt +4 -0
- data/lib/less/js/test/less/extend-chaining.less +12 -0
- data/lib/less/js/test/less/extend-selector.less +15 -0
- data/lib/less/js/test/less/extract-and-length.less +133 -0
- data/lib/less/js/test/less/functions.less +15 -2
- data/lib/less/js/test/less/globalVars/extended.json +5 -0
- data/lib/less/js/test/less/globalVars/extended.less +10 -0
- data/lib/less/js/test/less/globalVars/simple.json +3 -0
- data/lib/less/js/test/less/globalVars/simple.less +3 -0
- data/lib/less/js/test/less/import-inline.less +2 -0
- data/lib/less/js/test/less/import-once.less +2 -0
- data/lib/less/js/test/less/import-reference.less +18 -0
- data/lib/less/js/test/less/import/import-and-relative-paths-test.less +11 -0
- data/lib/less/js/test/less/import/import-reference.less +43 -0
- data/lib/less/js/test/less/import/import-test-f.less +5 -0
- data/lib/less/js/test/less/import/invalid-css.less +1 -0
- data/lib/less/js/test/less/media.less +25 -1
- data/lib/less/js/test/less/merge.less +59 -0
- data/lib/less/js/test/less/mixins-args.less +10 -0
- data/lib/less/js/test/less/mixins-guards-default-func.less +195 -0
- data/lib/less/js/test/less/mixins-guards.less +16 -0
- data/lib/less/js/test/less/mixins-important.less +4 -1
- data/lib/less/js/test/less/mixins-interpolated.less +69 -0
- data/lib/less/js/test/less/mixins.less +27 -0
- data/lib/less/js/test/less/modifyVars/extended.json +5 -0
- data/lib/less/js/test/less/modifyVars/extended.less +11 -0
- data/lib/less/js/test/less/no-js-errors/no-js-errors.less +3 -0
- data/lib/less/js/test/less/no-js-errors/no-js-errors.txt +4 -0
- data/lib/less/js/test/less/no-output.less +2 -0
- data/lib/less/js/test/less/parens.less +4 -0
- data/lib/less/js/test/less/property-name-interp.less +53 -0
- data/lib/less/js/test/less/selectors.less +13 -0
- data/lib/less/js/test/less/sourcemaps/basic.json +3 -0
- data/lib/less/js/test/less/sourcemaps/basic.less +27 -0
- data/lib/less/js/test/less/sourcemaps/imported.css +7 -0
- data/lib/less/js/test/less/strings.less +6 -0
- data/lib/less/js/test/less/url-args/urls.less +63 -0
- data/lib/less/js/test/less/urls.less +15 -0
- data/lib/less/js/test/rhino/test-header.js +15 -0
- data/lib/less/js/test/sourcemaps/basic.json +1 -0
- data/lib/less/js/test/sourcemaps/index.html +17 -0
- data/lib/less/loader.rb +48 -40
- data/lib/less/version.rb +1 -1
- data/spec/less/parser_spec.rb +15 -15
- metadata +146 -40
- data/lib/less/js/Makefile +0 -102
- data/lib/less/js/build/header.js +0 -9
- data/lib/less/js/test/browser-test-prepare.js +0 -46
- data/lib/less/js/test/browser/runner-errors.js +0 -5
- data/lib/less/js/test/browser/runner-main.js +0 -15
- data/lib/less/js/test/browser/template.htm +0 -10
- data/lib/less/js/test/less/errors/color-operation-error.txt +0 -2
@@ -3,7 +3,7 @@
|
|
3
3
|
tree.mixin = {};
|
4
4
|
tree.mixin.Call = function (elements, args, index, currentFileInfo, important) {
|
5
5
|
this.selector = new(tree.Selector)(elements);
|
6
|
-
this.arguments = args;
|
6
|
+
this.arguments = (args && args.length) ? args : null;
|
7
7
|
this.index = index;
|
8
8
|
this.currentFileInfo = currentFileInfo;
|
9
9
|
this.important = important;
|
@@ -11,11 +11,17 @@ tree.mixin.Call = function (elements, args, index, currentFileInfo, important) {
|
|
11
11
|
tree.mixin.Call.prototype = {
|
12
12
|
type: "MixinCall",
|
13
13
|
accept: function (visitor) {
|
14
|
-
|
15
|
-
|
14
|
+
if (this.selector) {
|
15
|
+
this.selector = visitor.visit(this.selector);
|
16
|
+
}
|
17
|
+
if (this.arguments) {
|
18
|
+
this.arguments = visitor.visitArray(this.arguments);
|
19
|
+
}
|
16
20
|
},
|
17
21
|
eval: function (env) {
|
18
|
-
var mixins, mixin, args, rules = [], match = false, i, m, f, isRecursive, isOneFound
|
22
|
+
var mixins, mixin, args, rules = [], match = false, i, m, f, isRecursive, isOneFound, rule,
|
23
|
+
candidates = [], candidate, conditionResult = [], defaultFunc = tree.defaultFunc,
|
24
|
+
defaultResult, defNone = 0, defTrue = 1, defFalse = 2, count;
|
19
25
|
|
20
26
|
args = this.arguments && this.arguments.map(function (a) {
|
21
27
|
return { name: a.name, value: a.value.eval(env) };
|
@@ -24,6 +30,12 @@ tree.mixin.Call.prototype = {
|
|
24
30
|
for (i = 0; i < env.frames.length; i++) {
|
25
31
|
if ((mixins = env.frames[i].find(this.selector)).length > 0) {
|
26
32
|
isOneFound = true;
|
33
|
+
|
34
|
+
// To make `default()` function independent of definition order we have two "subpasses" here.
|
35
|
+
// At first we evaluate each guard *twice* (with `default() == true` and `default() == false`),
|
36
|
+
// and build candidate list with corresponding flags. Then, when we know all possible matches,
|
37
|
+
// we make a final decision.
|
38
|
+
|
27
39
|
for (m = 0; m < mixins.length; m++) {
|
28
40
|
mixin = mixins[m];
|
29
41
|
isRecursive = false;
|
@@ -36,51 +48,111 @@ tree.mixin.Call.prototype = {
|
|
36
48
|
if (isRecursive) {
|
37
49
|
continue;
|
38
50
|
}
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
51
|
+
|
52
|
+
if (mixin.matchArgs(args, env)) {
|
53
|
+
candidate = {mixin: mixin, group: defNone};
|
54
|
+
|
55
|
+
if (mixin.matchCondition) {
|
56
|
+
for (f = 0; f < 2; f++) {
|
57
|
+
defaultFunc.value(f);
|
58
|
+
conditionResult[f] = mixin.matchCondition(args, env);
|
46
59
|
}
|
60
|
+
if (conditionResult[0] || conditionResult[1]) {
|
61
|
+
if (conditionResult[0] != conditionResult[1]) {
|
62
|
+
candidate.group = conditionResult[1] ?
|
63
|
+
defTrue : defFalse;
|
64
|
+
}
|
65
|
+
|
66
|
+
candidates.push(candidate);
|
67
|
+
}
|
47
68
|
}
|
69
|
+
else {
|
70
|
+
candidates.push(candidate);
|
71
|
+
}
|
72
|
+
|
48
73
|
match = true;
|
49
74
|
}
|
50
75
|
}
|
76
|
+
|
77
|
+
defaultFunc.reset();
|
78
|
+
|
79
|
+
count = [0, 0, 0];
|
80
|
+
for (m = 0; m < candidates.length; m++) {
|
81
|
+
count[candidates[m].group]++;
|
82
|
+
}
|
83
|
+
|
84
|
+
if (count[defNone] > 0) {
|
85
|
+
defaultResult = defFalse;
|
86
|
+
} else {
|
87
|
+
defaultResult = defTrue;
|
88
|
+
if ((count[defTrue] + count[defFalse]) > 1) {
|
89
|
+
throw { type: 'Runtime',
|
90
|
+
message: 'Ambiguous use of `default()` found when matching for `'
|
91
|
+
+ this.format(args) + '`',
|
92
|
+
index: this.index, filename: this.currentFileInfo.filename };
|
93
|
+
}
|
94
|
+
}
|
95
|
+
|
96
|
+
for (m = 0; m < candidates.length; m++) {
|
97
|
+
candidate = candidates[m].group;
|
98
|
+
if ((candidate === defNone) || (candidate === defaultResult)) {
|
99
|
+
try {
|
100
|
+
mixin = candidates[m].mixin;
|
101
|
+
if (!(mixin instanceof tree.mixin.Definition)) {
|
102
|
+
mixin = new tree.mixin.Definition("", [], mixin.rules, null, false);
|
103
|
+
mixin.originalRuleset = mixins[m].originalRuleset || mixins[m];
|
104
|
+
}
|
105
|
+
Array.prototype.push.apply(
|
106
|
+
rules, mixin.eval(env, args, this.important).rules);
|
107
|
+
} catch (e) {
|
108
|
+
throw { message: e.message, index: this.index, filename: this.currentFileInfo.filename, stack: e.stack };
|
109
|
+
}
|
110
|
+
}
|
111
|
+
}
|
112
|
+
|
51
113
|
if (match) {
|
114
|
+
if (!this.currentFileInfo || !this.currentFileInfo.reference) {
|
115
|
+
for (i = 0; i < rules.length; i++) {
|
116
|
+
rule = rules[i];
|
117
|
+
if (rule.markReferenced) {
|
118
|
+
rule.markReferenced();
|
119
|
+
}
|
120
|
+
}
|
121
|
+
}
|
52
122
|
return rules;
|
53
123
|
}
|
54
124
|
}
|
55
125
|
}
|
56
126
|
if (isOneFound) {
|
57
127
|
throw { type: 'Runtime',
|
58
|
-
message: 'No matching definition was found for `' +
|
59
|
-
this.selector.toCSS().trim() + '(' +
|
60
|
-
(args ? args.map(function (a) {
|
61
|
-
var argValue = "";
|
62
|
-
if (a.name) {
|
63
|
-
argValue += a.name + ":";
|
64
|
-
}
|
65
|
-
if (a.value.toCSS) {
|
66
|
-
argValue += a.value.toCSS();
|
67
|
-
} else {
|
68
|
-
argValue += "???";
|
69
|
-
}
|
70
|
-
return argValue;
|
71
|
-
}).join(', ') : "") + ")`",
|
128
|
+
message: 'No matching definition was found for `' + this.format(args) + '`',
|
72
129
|
index: this.index, filename: this.currentFileInfo.filename };
|
73
130
|
} else {
|
74
|
-
throw { type:
|
75
|
-
|
76
|
-
|
131
|
+
throw { type: 'Name',
|
132
|
+
message: this.selector.toCSS().trim() + " is undefined",
|
133
|
+
index: this.index, filename: this.currentFileInfo.filename };
|
77
134
|
}
|
135
|
+
},
|
136
|
+
format: function (args) {
|
137
|
+
return this.selector.toCSS().trim() + '(' +
|
138
|
+
(args ? args.map(function (a) {
|
139
|
+
var argValue = "";
|
140
|
+
if (a.name) {
|
141
|
+
argValue += a.name + ":";
|
142
|
+
}
|
143
|
+
if (a.value.toCSS) {
|
144
|
+
argValue += a.value.toCSS();
|
145
|
+
} else {
|
146
|
+
argValue += "???";
|
147
|
+
}
|
148
|
+
return argValue;
|
149
|
+
}).join(', ') : "") + ")";
|
78
150
|
}
|
79
151
|
};
|
80
152
|
|
81
153
|
tree.mixin.Definition = function (name, params, rules, condition, variadic) {
|
82
154
|
this.name = name;
|
83
|
-
this.selectors = [new(tree.Selector)([new(tree.Element)(null, name)])];
|
155
|
+
this.selectors = [new(tree.Selector)([new(tree.Element)(null, name, this.index, this.currentFileInfo)])];
|
84
156
|
this.params = params;
|
85
157
|
this.condition = condition;
|
86
158
|
this.variadic = variadic;
|
@@ -88,8 +160,8 @@ tree.mixin.Definition = function (name, params, rules, condition, variadic) {
|
|
88
160
|
this.rules = rules;
|
89
161
|
this._lookups = {};
|
90
162
|
this.required = params.reduce(function (count, p) {
|
91
|
-
if (!p.name || (p.name && !p.value)) { return count + 1 }
|
92
|
-
else { return count }
|
163
|
+
if (!p.name || (p.name && !p.value)) { return count + 1; }
|
164
|
+
else { return count; }
|
93
165
|
}, 0);
|
94
166
|
this.parent = tree.Ruleset.prototype;
|
95
167
|
this.frames = [];
|
@@ -97,24 +169,28 @@ tree.mixin.Definition = function (name, params, rules, condition, variadic) {
|
|
97
169
|
tree.mixin.Definition.prototype = {
|
98
170
|
type: "MixinDefinition",
|
99
171
|
accept: function (visitor) {
|
100
|
-
this.params
|
101
|
-
|
102
|
-
|
172
|
+
if (this.params && this.params.length) {
|
173
|
+
this.params = visitor.visitArray(this.params);
|
174
|
+
}
|
175
|
+
this.rules = visitor.visitArray(this.rules);
|
176
|
+
if (this.condition) {
|
177
|
+
this.condition = visitor.visit(this.condition);
|
178
|
+
}
|
103
179
|
},
|
104
|
-
toCSS: function () { return ""; },
|
105
180
|
variable: function (name) { return this.parent.variable.call(this, name); },
|
106
181
|
variables: function () { return this.parent.variables.call(this); },
|
107
182
|
find: function () { return this.parent.find.apply(this, arguments); },
|
108
183
|
rulesets: function () { return this.parent.rulesets.apply(this); },
|
109
184
|
|
110
185
|
evalParams: function (env, mixinEnv, args, evaldArguments) {
|
111
|
-
|
186
|
+
/*jshint boss:true */
|
187
|
+
var frame = new(tree.Ruleset)(null, null),
|
112
188
|
varargs, arg,
|
113
189
|
params = this.params.slice(0),
|
114
190
|
i, j, val, name, isNamedFound, argIndex;
|
115
191
|
|
116
192
|
mixinEnv = new tree.evalEnv(mixinEnv, [frame].concat(mixinEnv.frames));
|
117
|
-
|
193
|
+
|
118
194
|
if (args) {
|
119
195
|
args = args.slice(0);
|
120
196
|
|
@@ -125,7 +201,7 @@ tree.mixin.Definition.prototype = {
|
|
125
201
|
for(j = 0; j < params.length; j++) {
|
126
202
|
if (!evaldArguments[j] && name === params[j].name) {
|
127
203
|
evaldArguments[j] = arg.value.eval(env);
|
128
|
-
frame.
|
204
|
+
frame.prependRule(new(tree.Rule)(name, arg.value.eval(env)));
|
129
205
|
isNamedFound = true;
|
130
206
|
break;
|
131
207
|
}
|
@@ -143,8 +219,8 @@ tree.mixin.Definition.prototype = {
|
|
143
219
|
}
|
144
220
|
argIndex = 0;
|
145
221
|
for (i = 0; i < params.length; i++) {
|
146
|
-
if (evaldArguments[i]) continue;
|
147
|
-
|
222
|
+
if (evaldArguments[i]) { continue; }
|
223
|
+
|
148
224
|
arg = args && args[argIndex];
|
149
225
|
|
150
226
|
if (name = params[i].name) {
|
@@ -153,7 +229,7 @@ tree.mixin.Definition.prototype = {
|
|
153
229
|
for (j = argIndex; j < args.length; j++) {
|
154
230
|
varargs.push(args[j].value.eval(env));
|
155
231
|
}
|
156
|
-
frame.
|
232
|
+
frame.prependRule(new(tree.Rule)(name, new(tree.Expression)(varargs).eval(env)));
|
157
233
|
} else {
|
158
234
|
val = arg && arg.value;
|
159
235
|
if (val) {
|
@@ -166,11 +242,11 @@ tree.mixin.Definition.prototype = {
|
|
166
242
|
' (' + args.length + ' for ' + this.arity + ')' };
|
167
243
|
}
|
168
244
|
|
169
|
-
frame.
|
245
|
+
frame.prependRule(new(tree.Rule)(name, val));
|
170
246
|
evaldArguments[i] = val;
|
171
247
|
}
|
172
248
|
}
|
173
|
-
|
249
|
+
|
174
250
|
if (params[i].variadic && args) {
|
175
251
|
for (j = argIndex; j < args.length; j++) {
|
176
252
|
evaldArguments[j] = args[j].value.eval(env);
|
@@ -185,35 +261,38 @@ tree.mixin.Definition.prototype = {
|
|
185
261
|
var _arguments = [],
|
186
262
|
mixinFrames = this.frames.concat(env.frames),
|
187
263
|
frame = this.evalParams(env, new(tree.evalEnv)(env, mixinFrames), args, _arguments),
|
188
|
-
|
264
|
+
rules, ruleset;
|
189
265
|
|
190
|
-
frame.
|
266
|
+
frame.prependRule(new(tree.Rule)('@arguments', new(tree.Expression)(_arguments).eval(env)));
|
191
267
|
|
192
|
-
rules =
|
193
|
-
this.parent.makeImportant.apply(this).rules : this.rules.slice(0);
|
268
|
+
rules = this.rules.slice(0);
|
194
269
|
|
195
|
-
ruleset = new(tree.Ruleset)(null, rules)
|
196
|
-
[this, frame].concat(mixinFrames)));
|
270
|
+
ruleset = new(tree.Ruleset)(null, rules);
|
197
271
|
ruleset.originalRuleset = this;
|
272
|
+
ruleset = ruleset.eval(new(tree.evalEnv)(env, [this, frame].concat(mixinFrames)));
|
273
|
+
if (important) {
|
274
|
+
ruleset = this.parent.makeImportant.apply(ruleset);
|
275
|
+
}
|
198
276
|
return ruleset;
|
199
277
|
},
|
200
278
|
matchCondition: function (args, env) {
|
201
|
-
|
202
279
|
if (this.condition && !this.condition.eval(
|
203
280
|
new(tree.evalEnv)(env,
|
204
|
-
[this.evalParams(env, new(tree.evalEnv)(env, this.frames.concat(env.frames)), args, [])]
|
205
|
-
.concat(
|
281
|
+
[this.evalParams(env, new(tree.evalEnv)(env, this.frames.concat(env.frames)), args, [])] // the parameter variables
|
282
|
+
.concat(this.frames) // the parent namespace/mixin frames
|
283
|
+
.concat(env.frames)))) { // the current environment frames
|
206
284
|
return false;
|
207
285
|
}
|
208
286
|
return true;
|
209
287
|
},
|
210
288
|
matchArgs: function (args, env) {
|
211
|
-
var argsLength = (args && args.length) || 0, len
|
289
|
+
var argsLength = (args && args.length) || 0, len;
|
212
290
|
|
213
291
|
if (! this.variadic) {
|
214
|
-
if (argsLength < this.required) { return false }
|
215
|
-
if (argsLength > this.params.length) { return false }
|
216
|
-
|
292
|
+
if (argsLength < this.required) { return false; }
|
293
|
+
if (argsLength > this.params.length) { return false; }
|
294
|
+
} else {
|
295
|
+
if (argsLength < (this.required - 1)) { return false; }
|
217
296
|
}
|
218
297
|
|
219
298
|
len = Math.min(argsLength, this.arity);
|
@@ -8,9 +8,11 @@ tree.Negative.prototype = {
|
|
8
8
|
accept: function (visitor) {
|
9
9
|
this.value = visitor.visit(this.value);
|
10
10
|
},
|
11
|
-
|
12
|
-
|
11
|
+
genCSS: function (env, output) {
|
12
|
+
output.add('-');
|
13
|
+
this.value.genCSS(env, output);
|
13
14
|
},
|
15
|
+
toCSS: tree.toCSS,
|
14
16
|
eval: function (env) {
|
15
17
|
if (env.isMathOn()) {
|
16
18
|
return (new(tree.Operation)('*', [new(tree.Dimension)(-1), this.value])).eval(env);
|
@@ -12,17 +12,14 @@ tree.Operation.prototype = {
|
|
12
12
|
},
|
13
13
|
eval: function (env) {
|
14
14
|
var a = this.operands[0].eval(env),
|
15
|
-
b = this.operands[1].eval(env)
|
16
|
-
temp;
|
15
|
+
b = this.operands[1].eval(env);
|
17
16
|
|
18
17
|
if (env.isMathOn()) {
|
19
18
|
if (a instanceof tree.Dimension && b instanceof tree.Color) {
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
message: "Can't substract or divide a color from a number" };
|
25
|
-
}
|
19
|
+
a = a.toColor();
|
20
|
+
}
|
21
|
+
if (b instanceof tree.Dimension && a instanceof tree.Color) {
|
22
|
+
b = b.toColor();
|
26
23
|
}
|
27
24
|
if (!a.operate) {
|
28
25
|
throw { type: "Operation",
|
@@ -34,10 +31,18 @@ tree.Operation.prototype = {
|
|
34
31
|
return new(tree.Operation)(this.op, [a, b], this.isSpaced);
|
35
32
|
}
|
36
33
|
},
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
34
|
+
genCSS: function (env, output) {
|
35
|
+
this.operands[0].genCSS(env, output);
|
36
|
+
if (this.isSpaced) {
|
37
|
+
output.add(" ");
|
38
|
+
}
|
39
|
+
output.add(this.op);
|
40
|
+
if (this.isSpaced) {
|
41
|
+
output.add(" ");
|
42
|
+
}
|
43
|
+
this.operands[1].genCSS(env, output);
|
44
|
+
},
|
45
|
+
toCSS: tree.toCSS
|
41
46
|
};
|
42
47
|
|
43
48
|
tree.operate = function (env, op, a, b) {
|
@@ -9,9 +9,12 @@ tree.Paren.prototype = {
|
|
9
9
|
accept: function (visitor) {
|
10
10
|
this.value = visitor.visit(this.value);
|
11
11
|
},
|
12
|
-
|
13
|
-
|
12
|
+
genCSS: function (env, output) {
|
13
|
+
output.add('(');
|
14
|
+
this.value.genCSS(env, output);
|
15
|
+
output.add(')');
|
14
16
|
},
|
17
|
+
toCSS: tree.toCSS,
|
15
18
|
eval: function (env) {
|
16
19
|
return new(tree.Paren)(this.value.eval(env));
|
17
20
|
}
|
@@ -9,13 +9,16 @@ tree.Quoted = function (str, content, escaped, index, currentFileInfo) {
|
|
9
9
|
};
|
10
10
|
tree.Quoted.prototype = {
|
11
11
|
type: "Quoted",
|
12
|
-
|
13
|
-
if (this.escaped) {
|
14
|
-
|
15
|
-
}
|
16
|
-
|
12
|
+
genCSS: function (env, output) {
|
13
|
+
if (!this.escaped) {
|
14
|
+
output.add(this.quote, this.currentFileInfo, this.index);
|
15
|
+
}
|
16
|
+
output.add(this.value);
|
17
|
+
if (!this.escaped) {
|
18
|
+
output.add(this.quote);
|
17
19
|
}
|
18
20
|
},
|
21
|
+
toCSS: tree.toCSS,
|
19
22
|
eval: function (env) {
|
20
23
|
var that = this;
|
21
24
|
var value = this.value.replace(/`([^`]+)`/g, function (_, exp) {
|
@@ -24,7 +27,7 @@ tree.Quoted.prototype = {
|
|
24
27
|
var v = new(tree.Variable)('@' + name, that.index, that.currentFileInfo).eval(env, true);
|
25
28
|
return (v instanceof tree.Quoted) ? v.value : v.toCSS();
|
26
29
|
});
|
27
|
-
return new(tree.Quoted)(this.quote + value + this.quote, value, this.escaped, this.index);
|
30
|
+
return new(tree.Quoted)(this.quote + value + this.quote, value, this.escaped, this.index, this.currentFileInfo);
|
28
31
|
},
|
29
32
|
compare: function (x) {
|
30
33
|
if (!x.toCSS) {
|
@@ -1,16 +1,14 @@
|
|
1
1
|
(function (tree) {
|
2
2
|
|
3
|
-
tree.Rule = function (name, value, important, index, currentFileInfo, inline) {
|
3
|
+
tree.Rule = function (name, value, important, merge, index, currentFileInfo, inline) {
|
4
4
|
this.name = name;
|
5
5
|
this.value = (value instanceof tree.Value) ? value : new(tree.Value)([value]);
|
6
6
|
this.important = important ? ' ' + important.trim() : '';
|
7
|
+
this.merge = merge;
|
7
8
|
this.index = index;
|
8
9
|
this.currentFileInfo = currentFileInfo;
|
9
10
|
this.inline = inline || false;
|
10
|
-
|
11
|
-
if (name.charAt(0) === '@') {
|
12
|
-
this.variable = true;
|
13
|
-
} else { this.variable = false }
|
11
|
+
this.variable = name.charAt && (name.charAt(0) === '@');
|
14
12
|
};
|
15
13
|
|
16
14
|
tree.Rule.prototype = {
|
@@ -18,33 +16,43 @@ tree.Rule.prototype = {
|
|
18
16
|
accept: function (visitor) {
|
19
17
|
this.value = visitor.visit(this.value);
|
20
18
|
},
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
e.index = this.index;
|
31
|
-
e.filename = this.currentFileInfo.filename;
|
32
|
-
throw e;
|
33
|
-
}
|
19
|
+
genCSS: function (env, output) {
|
20
|
+
output.add(this.name + (env.compress ? ':' : ': '), this.currentFileInfo, this.index);
|
21
|
+
try {
|
22
|
+
this.value.genCSS(env, output);
|
23
|
+
}
|
24
|
+
catch(e) {
|
25
|
+
e.index = this.index;
|
26
|
+
e.filename = this.currentFileInfo.filename;
|
27
|
+
throw e;
|
34
28
|
}
|
29
|
+
output.add(this.important + ((this.inline || (env.lastRule && env.compress)) ? "" : ";"), this.currentFileInfo, this.index);
|
35
30
|
},
|
31
|
+
toCSS: tree.toCSS,
|
36
32
|
eval: function (env) {
|
37
|
-
var strictMathBypass = false;
|
38
|
-
if (
|
33
|
+
var strictMathBypass = false, name = this.name;
|
34
|
+
if (typeof name !== "string") {
|
35
|
+
// expand 'primitive' name directly to get
|
36
|
+
// things faster (~10% for benchmark.less):
|
37
|
+
name = (name.length === 1)
|
38
|
+
&& (name[0] instanceof tree.Keyword)
|
39
|
+
? name[0].value : evalName(env, name);
|
40
|
+
}
|
41
|
+
if (name === "font" && !env.strictMath) {
|
39
42
|
strictMathBypass = true;
|
40
43
|
env.strictMath = true;
|
41
44
|
}
|
42
45
|
try {
|
43
|
-
return new(tree.Rule)(
|
46
|
+
return new(tree.Rule)(name,
|
44
47
|
this.value.eval(env),
|
45
48
|
this.important,
|
49
|
+
this.merge,
|
46
50
|
this.index, this.currentFileInfo, this.inline);
|
47
51
|
}
|
52
|
+
catch(e) {
|
53
|
+
e.index = e.index || this.index;
|
54
|
+
throw e;
|
55
|
+
}
|
48
56
|
finally {
|
49
57
|
if (strictMathBypass) {
|
50
58
|
env.strictMath = false;
|
@@ -55,8 +63,18 @@ tree.Rule.prototype = {
|
|
55
63
|
return new(tree.Rule)(this.name,
|
56
64
|
this.value,
|
57
65
|
"!important",
|
66
|
+
this.merge,
|
58
67
|
this.index, this.currentFileInfo, this.inline);
|
59
68
|
}
|
60
69
|
};
|
61
70
|
|
71
|
+
function evalName(env, name) {
|
72
|
+
var value = "", i, n = name.length,
|
73
|
+
output = {add: function (s) {value += s;}};
|
74
|
+
for (i = 0; i < n; i++) {
|
75
|
+
name[i].eval(env).genCSS(env, output);
|
76
|
+
}
|
77
|
+
return value;
|
78
|
+
}
|
79
|
+
|
62
80
|
})(require('../tree'));
|