mirror of https://github.com/adamdruppe/arsd.git
my precious dom selector got so many bugs in that other pull
This commit is contained in:
parent
6b4301c25a
commit
32601f07ed
21
dom.d
21
dom.d
|
@ -4726,7 +4726,7 @@ int intFromHex(string hex) {
|
||||||
// It is important that the 2 character possibilities go first here for accurate lexing
|
// It is important that the 2 character possibilities go first here for accurate lexing
|
||||||
"~=", "*=", "|=", "^=", "$=", "!=", // "::" should be there too for full standard
|
"~=", "*=", "|=", "^=", "$=", "!=", // "::" should be there too for full standard
|
||||||
"<<", // my any-parent extension (reciprocal of whitespace)
|
"<<", // my any-parent extension (reciprocal of whitespace)
|
||||||
" - ", // previous-sibling extension (whitespace required to disambiguate tag-names)
|
// " - ", // previous-sibling extension (whitespace required to disambiguate tag-names)
|
||||||
".", ">", "+", "*", ":", "[", "]", "=", "\"", "#", ",", " ", "~", "<"
|
".", ">", "+", "*", ":", "[", "]", "=", "\"", "#", ",", " ", "~", "<"
|
||||||
]; // other is white space or a name.
|
]; // other is white space or a name.
|
||||||
|
|
||||||
|
@ -4757,7 +4757,7 @@ int intFromHex(string hex) {
|
||||||
foreach (sizediff_t tidx, immutable token; selectorTokens) {
|
foreach (sizediff_t tidx, immutable token; selectorTokens) {
|
||||||
if (c == token[0]) {
|
if (c == token[0]) {
|
||||||
if (token.length > 1) {
|
if (token.length > 1) {
|
||||||
assert(token.length == 2); // we don't have 3-char tokens yet
|
assert(token.length == 2, token); // we don't have 3-char tokens yet
|
||||||
if (str.length-stpos < 2 || str[stpos+1] != token[1]) continue;
|
if (str.length-stpos < 2 || str[stpos+1] != token[1]) continue;
|
||||||
}
|
}
|
||||||
return tidx;
|
return tidx;
|
||||||
|
@ -4782,9 +4782,15 @@ int intFromHex(string hex) {
|
||||||
}
|
}
|
||||||
++curpos;
|
++curpos;
|
||||||
}
|
}
|
||||||
} else if (ch <= 32) {
|
} else if (ch < 32) { // The < instead of <= is INTENTIONAL. See note from adr below.
|
||||||
// we should consider unicode spaces too, but... unicode sux anyway.
|
|
||||||
++curpos;
|
++curpos;
|
||||||
|
|
||||||
|
// FROM ADR: This does NOT catch ' '! Spaces have semantic meaning in CSS! While
|
||||||
|
// "foo bar" is clear, and can only have one meaning, consider ".foo .bar".
|
||||||
|
// That is not the same as ".foo.bar". If the space is stripped, important
|
||||||
|
// information is lost, despite the tokens being separatable anyway.
|
||||||
|
//
|
||||||
|
// The parser really needs to be aware of the presence of a space.
|
||||||
} else {
|
} else {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -5187,7 +5193,7 @@ int intFromHex(string hex) {
|
||||||
SelectorPart current;
|
SelectorPart current;
|
||||||
void commit() {
|
void commit() {
|
||||||
// might as well skip null items
|
// might as well skip null items
|
||||||
if(current !is SelectorPart.init) {
|
if(!current.isCleanSlateExceptSeparation()) {
|
||||||
s.parts ~= current;
|
s.parts ~= current;
|
||||||
current = current.init; // start right over
|
current = current.init; // start right over
|
||||||
}
|
}
|
||||||
|
@ -5233,6 +5239,11 @@ int intFromHex(string hex) {
|
||||||
current.tagNameFilter = "*";
|
current.tagNameFilter = "*";
|
||||||
break;
|
break;
|
||||||
case " ":
|
case " ":
|
||||||
|
// If some other separation has already been set,
|
||||||
|
// this is irrelevant whitespace, so we should skip it.
|
||||||
|
// this happens in the case of "foo > bar" for example.
|
||||||
|
if(current.isCleanSlateExceptSeparation() && current.separation > 0)
|
||||||
|
continue;
|
||||||
commit();
|
commit();
|
||||||
current.separation = 0; // tree
|
current.separation = 0; // tree
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in New Issue