summaryrefslogtreecommitdiffstats
path: root/sass/src
diff options
context:
space:
mode:
Diffstat (limited to 'sass/src')
-rw-r--r--sass/src/com/vaadin/sass/parser/LexicalUnitImpl.java7
-rw-r--r--sass/src/com/vaadin/sass/parser/Parser.java12
-rw-r--r--sass/src/com/vaadin/sass/parser/Parser.jj12
-rw-r--r--sass/src/com/vaadin/sass/tree/CommentNode.java2
-rw-r--r--sass/src/com/vaadin/sass/util/ColorUtil.java2
-rw-r--r--sass/src/com/vaadin/sass/visitor/VariableVisitor.java18
6 files changed, 34 insertions, 19 deletions
diff --git a/sass/src/com/vaadin/sass/parser/LexicalUnitImpl.java b/sass/src/com/vaadin/sass/parser/LexicalUnitImpl.java
index 2a62c0dcf9..e268da8ed5 100644
--- a/sass/src/com/vaadin/sass/parser/LexicalUnitImpl.java
+++ b/sass/src/com/vaadin/sass/parser/LexicalUnitImpl.java
@@ -572,4 +572,11 @@ public class LexicalUnitImpl implements LexicalUnit, SCSSLexicalUnit,
return new LexicalUnitImpl(SAC_OPERATOR_SLASH, line, column, previous);
}
+ @Override
+ public LexicalUnitImpl clone() {
+ LexicalUnitImpl cloned = new LexicalUnitImpl(type, line, column,
+ (LexicalUnitImpl) prev);
+ cloned.replaceValue(this);
+ return cloned;
+ }
}
diff --git a/sass/src/com/vaadin/sass/parser/Parser.java b/sass/src/com/vaadin/sass/parser/Parser.java
index cc9c39176e..710c7d5be7 100644
--- a/sass/src/com/vaadin/sass/parser/Parser.java
+++ b/sass/src/com/vaadin/sass/parser/Parser.java
@@ -25,7 +25,6 @@ import org.w3c.flute.parser.selectors.SelectorFactoryImpl;
import org.w3c.flute.parser.selectors.ConditionFactoryImpl;
import org.w3c.flute.util.Encoding;
-
import com.vaadin.sass.handler.*;
import com.vaadin.sass.tree.*;
@@ -556,9 +555,14 @@ public class Parser implements org.w3c.css.sac.Parser, ParserConstants {
label_7:
while (true) {
;
- if(token.specialToken!=null){
- documentHandler.comment(token.specialToken.image);
- }
+ if (token.specialToken != null){
+ Token tmp_t = token.specialToken;
+ while (tmp_t.specialToken != null) tmp_t = tmp_t.specialToken;
+ while (tmp_t != null) {
+ documentHandler.comment(tmp_t.image);
+ tmp_t = tmp_t.next;
+ }
+ }
switch ((jj_ntk==-1)?jj_ntk():jj_ntk) {
case VARIABLE:
variable();
diff --git a/sass/src/com/vaadin/sass/parser/Parser.jj b/sass/src/com/vaadin/sass/parser/Parser.jj
index 2f43be5f6e..62892c8159 100644
--- a/sass/src/com/vaadin/sass/parser/Parser.jj
+++ b/sass/src/com/vaadin/sass/parser/Parser.jj
@@ -43,7 +43,6 @@ import org.w3c.flute.parser.selectors.SelectorFactoryImpl;
import org.w3c.flute.parser.selectors.ConditionFactoryImpl;
import org.w3c.flute.util.Encoding;
-
import com.vaadin.sass.handler.*;
import com.vaadin.sass.tree.*;
@@ -733,9 +732,14 @@ void afterImportDeclaration() :
{
(
{
- if(token.specialToken!=null){
- documentHandler.comment(token.specialToken.image);
- }
+ if (token.specialToken != null){
+ Token tmp_t = token.specialToken;
+ while (tmp_t.specialToken != null) tmp_t = tmp_t.specialToken;
+ while (tmp_t != null) {
+ documentHandler.comment(tmp_t.image);
+ tmp_t = tmp_t.next;
+ }
+ }
}
( variable() | mixinDirective() | includeDirective() | styleRule() | media()| page() | fontFace()
| { l = getLocator(); } ret=skipStatement()
diff --git a/sass/src/com/vaadin/sass/tree/CommentNode.java b/sass/src/com/vaadin/sass/tree/CommentNode.java
index 649d2df581..3bdb563312 100644
--- a/sass/src/com/vaadin/sass/tree/CommentNode.java
+++ b/sass/src/com/vaadin/sass/tree/CommentNode.java
@@ -21,6 +21,6 @@ public class CommentNode extends Node {
@Override
public String toString() {
- return comment.trim();
+ return comment;
}
}
diff --git a/sass/src/com/vaadin/sass/util/ColorUtil.java b/sass/src/com/vaadin/sass/util/ColorUtil.java
index 9abcf57310..fe3f8f6e9b 100644
--- a/sass/src/com/vaadin/sass/util/ColorUtil.java
+++ b/sass/src/com/vaadin/sass/util/ColorUtil.java
@@ -81,7 +81,7 @@ public class ColorUtil {
hslParam = (LexicalUnitImpl) hslParam.getNextLexicalUnit();
i++;
}
- float h = ((hue.getFloatValue() % 360) + 360) % 360 / 360;
+ float h = ((hue.getIntegerValue() % 360) + 360) % 360 / 360f;
float s = saturation.getFloatValue() / 100;
float l = lightness.getFloatValue() / 100;
float m2, m1;
diff --git a/sass/src/com/vaadin/sass/visitor/VariableVisitor.java b/sass/src/com/vaadin/sass/visitor/VariableVisitor.java
index 8a567dacae..bb790a0aee 100644
--- a/sass/src/com/vaadin/sass/visitor/VariableVisitor.java
+++ b/sass/src/com/vaadin/sass/visitor/VariableVisitor.java
@@ -52,16 +52,16 @@ public class VariableVisitor implements Visitor {
if (value == null) {
return;
}
- for (String variable : variables.keySet()) {
- if (value.getLexicalUnitType() == SCSSLexicalUnit.SCSS_VARIABLE) {
- if (value.getStringValue().contains(variable)) {
- LexicalUnitImpl lexVal = (LexicalUnitImpl) value;
- lexVal.replaceValue(variables.get(variable));
- }
- } else if (value.getLexicalUnitType() == SCSSLexicalUnit.SAC_FUNCTION) {
- LexicalUnit params = value.getParameters();
- updateValue(params, variables);
+ if (value.getLexicalUnitType() == SCSSLexicalUnit.SCSS_VARIABLE) {
+ LexicalUnitImpl variableValue = variables.get(
+ value.getStringValue()).clone();
+ if (variableValue != null) {
+ LexicalUnitImpl lexVal = (LexicalUnitImpl) value;
+ lexVal.replaceValue(variableValue);
}
+ } else if (value.getLexicalUnitType() == SCSSLexicalUnit.SAC_FUNCTION) {
+ LexicalUnit params = value.getParameters();
+ updateValue(params, variables);
}
LexicalUnit next = value.getNextLexicalUnit();
updateValue(next, variables);