* minimize redraws during completion

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@23105 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Stefan Schimanski 2008-02-21 19:43:16 +00:00
parent 1bf7b59d60
commit 833f0bab52
5 changed files with 79 additions and 19 deletions

View File

@ -2190,12 +2190,51 @@ DocIterator const & BufferView::inlineCompletionPos() const
}
void BufferView::setInlineCompletion(DocIterator const & pos,
bool samePar(DocIterator const & a, DocIterator const & b)
{
if (a.empty() && b.empty())
return true;
if (a.empty() || b.empty())
return false;
return &a.innerParagraph() == &b.innerParagraph();
}
void BufferView::setInlineCompletion(Cursor & cur, DocIterator const & pos,
docstring const & completion, size_t uniqueChars)
{
d->inlineCompletionPos = pos;
uniqueChars = min(completion.size(), uniqueChars);
bool changed = d->inlineCompletion != completion
|| d->inlineCompletionUniqueChars != uniqueChars;
bool singlePar = true;
d->inlineCompletion = completion;
d->inlineCompletionUniqueChars = min(completion.size(), uniqueChars);
lyxerr << "setInlineCompletion pos=" << pos << " completion=" << completion << " uniqueChars=" << uniqueChars << std::endl;
// at new position?
DocIterator const & old = d->inlineCompletionPos;
if (old != pos) {
lyxerr << "inlineCompletionPos changed" << std::endl;
// old or pos are in another paragraph?
if ((!samePar(cur, pos) && !pos.empty())
|| (!samePar(cur, old) && !old.empty())) {
singlePar = false;
lyxerr << "different paragraph" << std::endl;
}
d->inlineCompletionPos = pos;
}
// set update flags
if (changed) {
lyxerr << "inlineCompletion changed" << std::endl;
Update::flags flags
= cur.disp_.update() | Update::Force;
if (singlePar && !(flags | Update::SinglePar))
flags = flags | Update::SinglePar;
cur.updateFlags(flags);
}
}
} // namespace lyx

View File

@ -169,8 +169,9 @@ public:
/// return the position in the buffer of the inline completion postfix.
DocIterator const & inlineCompletionPos() const;
/// set the inline completion postfix and its position in the buffer.
void setInlineCompletion(DocIterator const & pos, docstring const & completion,
size_t uniqueChars = 0);
/// Updates the updateFlags in \c cur.
void setInlineCompletion(Cursor & cur, DocIterator const & pos,
docstring const & completion, size_t uniqueChars = 0);
/// translate and insert a character, using the correct keymap.
void translateAndInsert(char_type c, Text * t, Cursor & cur);

View File

@ -119,12 +119,13 @@ public:
}
private:
///
Inset::CompletionListPtr list;
};
GuiCompleter::GuiCompleter(GuiWorkArea * gui, QObject * parent)
: QCompleter(parent), gui_(gui)
: QCompleter(parent), gui_(gui), updateLock_(0)
{
// Setup the completion popup
setModel(new GuiCompletionModel(this, Inset::CompletionListPtr()));
@ -235,10 +236,8 @@ void GuiCompleter::updateVisibility(Cursor & cur, bool start, bool keep, bool cu
inline_timer_.stop();
// hide old inline completion
if (inlineVisible()) {
gui_->bufferView().setInlineCompletion(DocIterator(), docstring());
cur.updateFlags(Update::Force | Update::SinglePar);
}
if (inlineVisible())
gui_->bufferView().setInlineCompletion(cur, DocIterator(), docstring());
}
// we inserted something and are in a possible popup state?
@ -261,7 +260,10 @@ void GuiCompleter::updateVisibility(Cursor & cur, bool start, bool keep, bool cu
void GuiCompleter::updateVisibility(bool start, bool keep)
{
Cursor cur = gui_->bufferView().cursor();
cur.updateFlags(Update::None);
updateVisibility(cur, start, keep);
if (cur.disp_.update())
gui_->bufferView().processUpdateFlags(cur.disp_.update());
}
@ -320,8 +322,7 @@ void GuiCompleter::updateInline(Cursor & cur, QString const & completion)
// set inline completion at cursor position
size_t uniqueTo = max(longestUniqueCompletion().size(), prefix.size());
gui_->bufferView().setInlineCompletion(cur, postfix, uniqueTo - prefix.size());
cur.updateFlags(Update::Force | Update::SinglePar);
gui_->bufferView().setInlineCompletion(cur, cur, postfix, uniqueTo - prefix.size());
}
@ -344,9 +345,6 @@ void GuiCompleter::updatePopup(Cursor & cur)
complete(insetRect);
QTreeView * p = static_cast<QTreeView *>(popup());
p->setColumnWidth(0, popup()->width() - 22 - p->verticalScrollBar()->width());
// update highlight
updateInline(cur, currentCompletion());
}
@ -404,6 +402,8 @@ void GuiCompleter::showInline(Cursor & cur)
void GuiCompleter::showPopup()
{
Cursor cur = gui_->bufferView().cursor();
cur.updateFlags(Update::None);
showPopup(cur);
// redraw if needed
@ -415,6 +415,8 @@ void GuiCompleter::showPopup()
void GuiCompleter::showInline()
{
Cursor cur = gui_->bufferView().cursor();
cur.updateFlags(Update::None);
showInline(cur);
// redraw if needed
@ -438,7 +440,8 @@ void GuiCompleter::activate()
void GuiCompleter::tab()
{
BufferView * bv = &gui_->bufferView();
Cursor & cur = bv->cursor();
Cursor cur = bv->cursor();
cur.updateFlags(Update::None);
// check that inline completion is active
if (!inlineVisible()) {
@ -512,7 +515,9 @@ void GuiCompleter::setCurrentCompletion(QString const & s)
// select the first if s is empty
if (s.length() == 0) {
updateLock_++;
popup()->setCurrentIndex(model.index(0, 0));
updateLock_--;
return;
}
@ -530,7 +535,9 @@ void GuiCompleter::setCurrentCompletion(QString const & s)
if (i == n)
i = 0;
updateLock_++;
popup()->setCurrentIndex(model.index(i, 0));
updateLock_--;
}
@ -561,11 +568,14 @@ docstring GuiCompleter::longestUniqueCompletion() const {
void GuiCompleter::popupActivated(const QString & completion)
{
Cursor & cur = gui_->bufferView().cursor();
Cursor cur = gui_->bufferView().cursor();
cur.updateFlags(Update::None);
docstring prefix = cur.inset().completionPrefix(cur);
docstring postfix = from_utf8(fromqstr(completion.mid(prefix.length())));
cur.inset().insertCompletion(cur, postfix, true);
updateVisibility(cur, false);
if (cur.disp_.update())
gui_->bufferView().processUpdateFlags(cur.disp_.update());
}
@ -573,8 +583,14 @@ void GuiCompleter::popupActivated(const QString & completion)
void GuiCompleter::popupHighlighted(const QString & completion)
{
if (updateLock_ > 0)
return;
Cursor cur = gui_->bufferView().cursor();
cur.updateFlags(Update::None);
updateInline(cur, completion);
if (cur.disp_.update())
gui_->bufferView().processUpdateFlags(cur.disp_.update());
}

View File

@ -107,6 +107,8 @@ private:
QTimer inline_timer_;
///
QString last_selection_;
/// lock to stop updates of the inline completion
int updateLock_;
}; // GuiCompleter
} // namespace frontend

View File

@ -541,7 +541,9 @@ bool InsetText::insertCompletion(Cursor & cur, docstring const & s,
if (!completionSupported(cur))
return false;
BOOST_ASSERT(cur.bv().cursor() == cur);
cur.insert(s);
cur.bv().cursor() = cur;
return true;
}