diff options
author | Henri Sara <hesara@vaadin.com> | 2012-11-28 14:26:06 +0200 |
---|---|---|
committer | Henri Sara <hesara@vaadin.com> | 2012-11-28 14:26:06 +0200 |
commit | deca3b2f6d702f41794ea6d63f35a15784d7b47b (patch) | |
tree | 431ad79fe938b8e7388ac795ba5e394fef6041e8 /theme-compiler | |
parent | 7fecb899c85c038415633857865cc5f20a3ab20e (diff) | |
download | vaadin-framework-deca3b2f6d702f41794ea6d63f35a15784d7b47b.tar.gz vaadin-framework-deca3b2f6d702f41794ea6d63f35a15784d7b47b.zip |
Add lookahead to eliminate SASS parsing ambiguity
Change-Id: Idcb27240f4bc79a4fc40a17eff7b0c8e43156c73
Diffstat (limited to 'theme-compiler')
-rw-r--r-- | theme-compiler/src/com/vaadin/sass/internal/parser/Parser.java | 111 | ||||
-rw-r--r-- | theme-compiler/src/com/vaadin/sass/internal/parser/Parser.jj | 2 |
2 files changed, 64 insertions, 49 deletions
diff --git a/theme-compiler/src/com/vaadin/sass/internal/parser/Parser.java b/theme-compiler/src/com/vaadin/sass/internal/parser/Parser.java index 266352e66f..f04d6fd77a 100644 --- a/theme-compiler/src/com/vaadin/sass/internal/parser/Parser.java +++ b/theme-compiler/src/com/vaadin/sass/internal/parser/Parser.java @@ -2322,28 +2322,30 @@ boolean isPseudoElement = false; } jj_consume_token(S); } - switch ((jj_ntk==-1)?jj_ntk():jj_ntk) { - case IDENT: + if (jj_2_5(2)) { param = jj_consume_token(IDENT); - d = convertIdent(param.image); - break; - case NUMBER: - param = jj_consume_token(NUMBER); + d = convertIdent(param.image); + } else { + switch ((jj_ntk==-1)?jj_ntk():jj_ntk) { + case NUMBER: + param = jj_consume_token(NUMBER); d = param.image; - break; - case LBRACKET: - case ANY: - case PARENT: - case DOT: - case COLON: - case INTERPOLATION: - case HASH: - d = simple_selector(null, ' '); - break; - default: - jj_la1[94] = jj_gen; - jj_consume_token(-1); - throw new ParseException(); + break; + case LBRACKET: + case ANY: + case PARENT: + case DOT: + case COLON: + case INTERPOLATION: + case IDENT: + case HASH: + d = simple_selector(null, ' '); + break; + default: + jj_la1[94] = jj_gen; + jj_consume_token(-1); + throw new ParseException(); + } } label_61: while (true) { @@ -2555,7 +2557,7 @@ boolean isPseudoElement = false; break; default: jj_la1[104] = jj_gen; - if (jj_2_5(3)) { + if (jj_2_6(3)) { declarationOrNestedProperties(); } else { switch ((jj_ntk==-1)?jj_ntk():jj_ntk) { @@ -2709,7 +2711,7 @@ boolean isPseudoElement = false; break; default: jj_la1[113] = jj_gen; - if (jj_2_6(3)) { + if (jj_2_7(3)) { declarationOrNestedProperties(); } else { switch ((jj_ntk==-1)?jj_ntk():jj_ntk) { @@ -2906,7 +2908,7 @@ boolean isPseudoElement = false; break; default: jj_la1[123] = jj_gen; - if (jj_2_7(5)) { + if (jj_2_8(5)) { listModifyDirective(); } else { switch ((jj_ntk==-1)?jj_ntk():jj_ntk) { @@ -2921,7 +2923,7 @@ boolean isPseudoElement = false; break; default: jj_la1[124] = jj_gen; - if (jj_2_8(3)) { + if (jj_2_9(3)) { declarationOrNestedProperties(); } else { switch ((jj_ntk==-1)?jj_ntk():jj_ntk) { @@ -3108,7 +3110,7 @@ boolean isPseudoElement = false; break; default: jj_la1[136] = jj_gen; - if (jj_2_9(5)) { + if (jj_2_10(5)) { listModifyDirective(); } else { switch ((jj_ntk==-1)?jj_ntk():jj_ntk) { @@ -3123,7 +3125,7 @@ boolean isPseudoElement = false; break; default: jj_la1[137] = jj_gen; - if (jj_2_10(3)) { + if (jj_2_11(3)) { declarationOrNestedProperties(); } else { switch ((jj_ntk==-1)?jj_ntk():jj_ntk) { @@ -3244,7 +3246,7 @@ boolean isPseudoElement = false; prev = first; label_93: while (true) { - if (jj_2_11(3)) { + if (jj_2_12(3)) { ; } else { break label_93; @@ -3523,11 +3525,11 @@ boolean isPseudoElement = false; } final public void listModifyDirective() throws ParseException { - if (jj_2_12(5)) { + if (jj_2_13(5)) { removeDirective(); - } else if (jj_2_13(5)) { - appendDirective(); } else if (jj_2_14(5)) { + appendDirective(); + } else if (jj_2_15(5)) { containsDirective(); } else { jj_consume_token(-1); @@ -4574,7 +4576,7 @@ LexicalUnit exp; res = first; label_147: while (true) { - if (jj_2_15(2)) { + if (jj_2_16(2)) { ; } else { break label_147; @@ -5706,11 +5708,23 @@ LexicalUnitImpl result = null; finally { jj_save(14, xla); } } + private boolean jj_2_16(int xla) { + jj_la = xla; jj_lastpos = jj_scanpos = token; + try { return !jj_3_16(); } + catch(LookaheadSuccess ls) { return true; } + finally { jj_save(15, xla); } + } + private boolean jj_3R_203() { if (jj_scan_token(IN)) return true; return false; } + private boolean jj_3_5() { + if (jj_scan_token(IDENT)) return true; + return false; + } + private boolean jj_3R_202() { if (jj_scan_token(PC)) return true; return false; @@ -5849,7 +5863,7 @@ LexicalUnitImpl result = null; return false; } - private boolean jj_3_7() { + private boolean jj_3_8() { if (jj_3R_157()) return true; return false; } @@ -5859,7 +5873,7 @@ LexicalUnitImpl result = null; return false; } - private boolean jj_3_6() { + private boolean jj_3_7() { if (jj_3R_162()) return true; return false; } @@ -5911,7 +5925,7 @@ LexicalUnitImpl result = null; return false; } - private boolean jj_3_14() { + private boolean jj_3_15() { if (jj_3R_167()) return true; return false; } @@ -5936,7 +5950,7 @@ LexicalUnitImpl result = null; return false; } - private boolean jj_3_5() { + private boolean jj_3_6() { if (jj_3R_162()) return true; return false; } @@ -5992,7 +6006,7 @@ LexicalUnitImpl result = null; return false; } - private boolean jj_3_15() { + private boolean jj_3_16() { Token xsp; xsp = jj_scanpos; if (jj_3R_168()) jj_scanpos = xsp; @@ -6000,7 +6014,7 @@ LexicalUnitImpl result = null; return false; } - private boolean jj_3_13() { + private boolean jj_3_14() { if (jj_3R_166()) return true; return false; } @@ -6010,7 +6024,7 @@ LexicalUnitImpl result = null; Token xsp; while (true) { xsp = jj_scanpos; - if (jj_3_15()) { jj_scanpos = xsp; break; } + if (jj_3_16()) { jj_scanpos = xsp; break; } } return false; } @@ -6074,7 +6088,7 @@ LexicalUnitImpl result = null; return false; } - private boolean jj_3_10() { + private boolean jj_3_11() { if (jj_3R_162()) return true; return false; } @@ -6139,7 +6153,7 @@ LexicalUnitImpl result = null; return false; } - private boolean jj_3_12() { + private boolean jj_3_13() { if (jj_3R_165()) return true; return false; } @@ -6147,11 +6161,11 @@ LexicalUnitImpl result = null; private boolean jj_3R_157() { Token xsp; xsp = jj_scanpos; - if (jj_3_12()) { - jj_scanpos = xsp; if (jj_3_13()) { jj_scanpos = xsp; - if (jj_3_14()) return true; + if (jj_3_14()) { + jj_scanpos = xsp; + if (jj_3_15()) return true; } } return false; @@ -6360,7 +6374,7 @@ LexicalUnitImpl result = null; return false; } - private boolean jj_3_8() { + private boolean jj_3_9() { if (jj_3R_162()) return true; return false; } @@ -6427,7 +6441,7 @@ LexicalUnitImpl result = null; return false; } - private boolean jj_3_11() { + private boolean jj_3_12() { Token xsp; xsp = jj_scanpos; if (jj_3R_163()) jj_scanpos = xsp; @@ -6519,7 +6533,7 @@ LexicalUnitImpl result = null; return false; } - private boolean jj_3_9() { + private boolean jj_3_10() { if (jj_3R_157()) return true; return false; } @@ -6611,7 +6625,7 @@ LexicalUnitImpl result = null; private static void jj_la1_init_3() { jj_la1_3 = new int[] {0x1,0x8,0x8,0x0,0x8,0x0,0x0,0x0,0x0,0x6,0x8,0x0,0x8,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0xc401f,0xc401f,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0xc401f,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x40000,0x40000,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x40000,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x40000,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x44000,0x0,0x0,0x0,0x0,0x44000,0x0,0x0,0x0,0x40000,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x10,0x0,0x0,0x0,0x0,0x0,0x0,0x44000,0x0,0x10,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x44000,0x0,0x40000,0x0,0x4000,0x44000,0x0,0x0,0x44000,0x0,0x6,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,}; } - final private JJCalls[] jj_2_rtns = new JJCalls[15]; + final private JJCalls[] jj_2_rtns = new JJCalls[16]; private boolean jj_rescan = false; private int jj_gc = 0; @@ -6813,7 +6827,7 @@ LexicalUnitImpl result = null; private void jj_rescan_token() { jj_rescan = true; - for (int i = 0; i < 15; i++) { + for (int i = 0; i < 16; i++) { try { JJCalls p = jj_2_rtns[i]; do { @@ -6835,6 +6849,7 @@ LexicalUnitImpl result = null; case 12: jj_3_13(); break; case 13: jj_3_14(); break; case 14: jj_3_15(); break; + case 15: jj_3_16(); break; } } p = p.next; diff --git a/theme-compiler/src/com/vaadin/sass/internal/parser/Parser.jj b/theme-compiler/src/com/vaadin/sass/internal/parser/Parser.jj index 47ffc4b6b9..b4754b092e 100644 --- a/theme-compiler/src/com/vaadin/sass/internal/parser/Parser.jj +++ b/theme-compiler/src/com/vaadin/sass/internal/parser/Parser.jj @@ -1315,7 +1315,7 @@ boolean isPseudoElement = false; } } | ( n=<FUNCTION> ( <S> )* ( - param=<IDENT> { d = convertIdent(param.image); } + LOOKAHEAD(2) param=<IDENT> { d = convertIdent(param.image); } | param=<NUMBER> { d = param.image; } | d=simple_selector(null, ' ') ) ( <S> )* ")" |