final(?) tweaks for removeAutoInsets() and removed one redundant conditional clause elsewhere

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@3382 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Allan Rae 2002-01-15 11:44:16 +00:00
parent fb424bae1b
commit b06f4c5af2
3 changed files with 31 additions and 5 deletions

View File

@ -107,11 +107,10 @@ bool BufferView::insertLyXFile(string const & filen)
bool BufferView::removeAutoInsets()
{
LyXCursor tmpcursor = text->cursor;
Paragraph * cur_par = tmpcursor.par();
Paragraph * cur_par = text->cursor.par();
Paragraph * cur_par_prev = cur_par ? cur_par->previous() : 0;
Paragraph * cur_par_next = cur_par ? cur_par->next() : 0;
pos_type cur_pos = tmpcursor.pos();
pos_type cur_pos = text->cursor.pos();
bool found = false;
@ -153,6 +152,11 @@ bool BufferView::removeAutoInsets()
// The previous setCursor line was deleted and that
// was the cur_par line. This can only happen if an
// error box was the sole item on cur_par.
// It is possible for cur_par_prev to be stray if
// the line it pointed to only had a error box on it
// so we have to set it to a known correct value.
// This is often the same value it already had.
cur_par_prev = par->previous();
if (cur_par_prev) {
// '|' = par, '.' = cur_par, 'E' = error box
// First step below may occur before while{}
@ -203,6 +207,20 @@ bool BufferView::removeAutoInsets()
}
}
// It is possible that the last line is empty if it was cur_par and/or
// only had an error inset on it.
if (text->setCursor(this, text->ownerParagraph(), 0)
&& 0 == cur_par_next) {
cur_par = cur_par_prev;
cur_pos = cur_par->size();
} else if (cur_pos > cur_par->size()) {
// Some C-Enter lines were removed by the setCursor call which
// then invalidated cur_pos. It could still be "wrong" because
// the cursor may appear to have jumped but since we collapsed
// some C-Enter lines this should be a reasonable compromise.
cur_pos = cur_par->size();
}
text->setCursorIntern(this, cur_par, cur_pos);
return found;

View File

@ -1,3 +1,11 @@
2002-01-15 Allan Rae <rae@lyx.org>
* text.C (insertChar): removed conditional truism.
* BufferView2.C (removeAutoInsets): More tweaks.
cur_par_prev could be a stray pointer. Check for trailing empty line
in case last line was cur_par and only had an error inset on it.
2002-01-14 Jean-Marc Lasgouttes <lasgouttes@freesurf.fr>
* lyx_cb.C (MenuWrite): buffer->fileName is guaranteed to be

View File

@ -1892,8 +1892,8 @@ void LyXText::insertChar(BufferView * bview, char c)
return;
}
} else if (IsNewlineChar(c)) {
if (cursor.par() == cursor.par()
&& cursor.pos() <= beginningOfMainBody(bview->buffer(), cursor.par())) {
if (cursor.pos() <= beginningOfMainBody(bview->buffer(),
cursor.par())) {
charInserted();
return;
}