FindAdv: Do not use data from included listing if in search mode

Fixes #11496 	"Find and replace (advanced)" is too slow
This commit is contained in:
Kornel Benko 2019-02-27 10:17:56 +01:00
parent b1f93e0982
commit aaffcd0b39
2 changed files with 20 additions and 13 deletions

View File

@ -967,10 +967,15 @@ int InsetInclude::plaintext(odocstringstream & os,
} }
if (isVerbatim(params()) || isListings(params())) { if (isVerbatim(params()) || isListings(params())) {
if (op.for_search) {
os << '[' << screenLabel() << ']';
}
else {
os << '[' << screenLabel() << '\n' os << '[' << screenLabel() << '\n'
// FIXME: We don't know the encoding of the file, default to UTF-8. // FIXME: We don't know the encoding of the file, default to UTF-8.
<< includedFileName(buffer(), params()).fileContents("UTF-8") << includedFileName(buffer(), params()).fileContents("UTF-8")
<< "\n]"; << "\n]";
}
return PLAINTEXT_NEWLINE + 1; // one char on a separate line return PLAINTEXT_NEWLINE + 1; // one char on a separate line
} }

View File

@ -2920,12 +2920,12 @@ docstring stringifyFromCursor(DocIterator const & cur, int len)
runparams.linelen = 10000; //lyxrc.plaintext_linelen; runparams.linelen = 10000; //lyxrc.plaintext_linelen;
// No side effect of file copying and image conversion // No side effect of file copying and image conversion
runparams.dryrun = true; runparams.dryrun = true;
runparams.for_search = true;
LYXERR(Debug::FIND, "Stringifying with cur: " LYXERR(Debug::FIND, "Stringifying with cur: "
<< cur << ", from pos: " << cur.pos() << ", end: " << end); << cur << ", from pos: " << cur.pos() << ", end: " << end);
docstring result = par.asString(cur.pos(), end, return par.asString(cur.pos(), end,
AS_STR_INSETS | AS_STR_SKIPDELETE | AS_STR_PLAINTEXT, AS_STR_INSETS | AS_STR_SKIPDELETE | AS_STR_PLAINTEXT,
&runparams); &runparams);
return result;
} else if (cur.inMathed()) { } else if (cur.inMathed()) {
CursorSlice cs = cur.top(); CursorSlice cs = cur.top();
MathData md = cs.cell(); MathData md = cs.cell();
@ -3134,7 +3134,7 @@ int findForwardAdv(DocIterator & cur, MatchStringAdv & match)
MatchResult mres = match(cur, -1, false); MatchResult mres = match(cur, -1, false);
int match_len = mres.match_len; int match_len = mres.match_len;
LYXERR(Debug::FIND, "match_len: " << match_len); LYXERR(Debug::FIND, "match_len: " << match_len);
if ((mres.pos > 10000) || (mres.match2end > 10000) || (match_len > 10000)) { if ((mres.pos > 100000) || (mres.match2end > 100000) || (match_len > 100000)) {
LYXERR0("BIG LENGTHS: " << mres.pos << ", " << match_len << ", " << mres.match2end); LYXERR0("BIG LENGTHS: " << mres.pos << ", " << match_len << ", " << mres.match2end);
match_len = 0; match_len = 0;
} }
@ -3144,10 +3144,6 @@ int findForwardAdv(DocIterator & cur, MatchStringAdv & match)
while (mres.pos > 5 && (increment > 5)) { while (mres.pos > 5 && (increment > 5)) {
DocIterator old_cur = cur; DocIterator old_cur = cur;
for (int i = 0; i < increment && cur; cur.forwardPos(), i++) { for (int i = 0; i < increment && cur; cur.forwardPos(), i++) {
/*
while (cur && cur.depth() != old_cur.depth())
cur.forwardPos();
*/
} }
if (! cur) { if (! cur) {
cur = old_cur; cur = old_cur;
@ -3307,9 +3303,15 @@ docstring stringifyFromForSearch(FindAndReplaceOptions const & opt,
return docstring(); return docstring();
if (!opt.ignoreformat) if (!opt.ignoreformat)
return latexifyFromCursor(cur, len); return latexifyFromCursor(cur, len);
else else {
if (len < 0) {
return stringifyFromCursor(cur, len); return stringifyFromCursor(cur, len);
} }
else {
return stringifyFromCursor(cur, len);
}
}
}
FindAndReplaceOptions::FindAndReplaceOptions( FindAndReplaceOptions::FindAndReplaceOptions(