FindAdv: Discard table decorations

That way we do not match the whole table but only the cell contents.
The problem I had was
1.) Document language Spanish
2.) Table (copied from English doc) => language English
3.) All cell contents Spanish

Now search for English text led to a selection of the whole
table, although there was no English content in any cell.
This commit is contained in:
Kornel Benko 2018-11-07 09:35:16 +01:00
parent 4f1cd00b02
commit 9d304c0a1d

View File

@ -1472,8 +1472,35 @@ void LatexInfo::buildEntries(bool isPatternString)
found.parenthesiscount = 0; found.parenthesiscount = 0;
evaluatingMath = true; evaluatingMath = true;
} }
else else {
continue; // begin|end of unknown env, discard
found = keys[key];
// discard spaces and '%' before pos(0)
int pos = sub.position(size_t(0));
int count;
for (count = 0; pos - count > 0; count++) {
char c = interval.par[pos-count-1];
if ((c != ' ') && (c != '%'))
break;
}
found.keytype = KeyInfo::doRemove;
found._tokenstart = pos - count;
if (sub.str(1).compare(0, 5, "begin") == 0) {
size_t pos1 = pos + sub.str(0).length();
if (interval.par[pos1] == '[') {
pos1 = interval.findclosing(pos1+1, interval.par.length(), '[', ']')+1;
}
found._dataEnd = interval.findclosing(pos1+1, interval.par.length()) + 1;
found._dataStart = found._dataEnd;
}
else {
found._dataStart = pos + sub.str(0).length();
found._dataEnd = found._dataStart;
}
found._tokensize = count + found._dataEnd - pos;
found.parenthesiscount = 0;
found.disabled = true;
}
} }
else if (found.keytype != KeyInfo::isRegex) { else if (found.keytype != KeyInfo::isRegex) {
found._tokenstart = sub.position(size_t(0)); found._tokenstart = sub.position(size_t(0));
@ -1574,6 +1601,7 @@ void LatexInfo::buildKeys(bool isPatternString)
// Same effect as previous, parameter will survive (because there is no one anyway) // Same effect as previous, parameter will survive (because there is no one anyway)
// No split // No split
makeKey("noindent", KeyInfo(KeyInfo::isStandard, 0, true), isPatternString); makeKey("noindent", KeyInfo(KeyInfo::isStandard, 0, true), isPatternString);
makeKey("hline|tabularnewline|toprule|bottomrule|midrule", KeyInfo(KeyInfo::doRemove, 0, true), isPatternString);
// like ('tiny{}' or '\tiny ' ... } // like ('tiny{}' or '\tiny ' ... }
makeKey("footnotesize|tiny|scriptsize|small|large|Large|LARGE|huge|Huge", KeyInfo(KeyInfo::isSize, 0, true), isPatternString); makeKey("footnotesize|tiny|scriptsize|small|large|Large|LARGE|huge|Huge", KeyInfo(KeyInfo::isSize, 0, true), isPatternString);
@ -1762,8 +1790,13 @@ int LatexInfo::dispatch(ostringstream &os, int previousStart, KeyInfo &actual)
break; break;
} }
case KeyInfo::doRemove: { case KeyInfo::doRemove: {
// Remove the key with all parameters // Remove the key with all parameters and following spaces
interval.addIntervall(actual._tokenstart, actual._dataEnd+1); size_t pos;
for (pos = actual._dataEnd+1; pos < interval.par.length(); pos++) {
if (interval.par[pos] != ' ')
break;
}
interval.addIntervall(actual._tokenstart, pos);
nextKeyIdx = getNextKey(); nextKeyIdx = getNextKey();
break; break;
} }