mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-07 09:46:54 +00:00
Fix bug 2727.
* math_scriptinset.C (notifyCursorLeaves): call recordUndoInset before deleting a cell; if the nucleus does not have scripts anymore, delete it and replace it by its contents at enclosing level. (write): output scripts even when they are empty. git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/branches/BRANCH_1_4_X@14794 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
01010f76e8
commit
31f3506938
@ -1,3 +1,13 @@
|
|||||||
|
2006-08-17 Jean-Marc Lasgouttes <lasgouttes@lyx.org>
|
||||||
|
|
||||||
|
Fix bug 2727.
|
||||||
|
|
||||||
|
* math_scriptinset.C (notifyCursorLeaves): call recordUndoInset
|
||||||
|
before deleting a cell; if the nucleus does not have scripts
|
||||||
|
anymore, delete it and replace it by its contents at enclosing
|
||||||
|
level.
|
||||||
|
(write): output scripts even when they are empty.
|
||||||
|
|
||||||
2006-08-17 Jean-Marc Lasgouttes <lasgouttes@lyx.org>
|
2006-08-17 Jean-Marc Lasgouttes <lasgouttes@lyx.org>
|
||||||
|
|
||||||
* math_inset.C (cell): make debug message more explicit.
|
* math_inset.C (cell): make debug message more explicit.
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
#include "cursor.h"
|
#include "cursor.h"
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
#include "funcrequest.h"
|
#include "funcrequest.h"
|
||||||
|
#include "undo.h"
|
||||||
|
|
||||||
#include <boost/assert.hpp>
|
#include <boost/assert.hpp>
|
||||||
|
|
||||||
@ -432,10 +433,10 @@ void MathScriptInset::write(WriteStream & os) const
|
|||||||
os << "{}";
|
os << "{}";
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hasDown() && down().size())
|
if (hasDown() /*&& down().size()*/)
|
||||||
os << "_{" << down() << '}';
|
os << "_{" << down() << '}';
|
||||||
|
|
||||||
if (hasUp() && up().size())
|
if (hasUp() /*&& up().size()*/)
|
||||||
os << "^{" << up() << '}';
|
os << "^{" << up() << '}';
|
||||||
|
|
||||||
if (lock_ && !os.latex())
|
if (lock_ && !os.latex())
|
||||||
@ -563,15 +564,28 @@ void MathScriptInset::notifyCursorLeaves(LCursor & cur)
|
|||||||
// Case of two scripts. In this case, 1 = super, 2 = sub
|
// Case of two scripts. In this case, 1 = super, 2 = sub
|
||||||
if (cur.idx() == 2 && cell(2).empty()) {
|
if (cur.idx() == 2 && cell(2).empty()) {
|
||||||
// must be a subscript...
|
// must be a subscript...
|
||||||
|
recordUndoInset(cur);
|
||||||
removeScript(false);
|
removeScript(false);
|
||||||
} else if (cur.idx() == 1 && cell(1).empty()) {
|
} else if (cur.idx() == 1 && cell(1).empty()) {
|
||||||
// must be a superscript...
|
// must be a superscript...
|
||||||
|
recordUndoInset(cur);
|
||||||
removeScript(true);
|
removeScript(true);
|
||||||
}
|
}
|
||||||
} else if (nargs() > 1 && cur.idx() == 1 && cell(1).empty()) {
|
} else if (nargs() > 1 && cur.idx() == 1 && cell(1).empty()) {
|
||||||
// could be either subscript or super script
|
// could be either subscript or super script
|
||||||
|
recordUndoInset(cur);
|
||||||
removeScript(cell_1_is_up_);
|
removeScript(cell_1_is_up_);
|
||||||
}
|
// Let the script inset commit suicide. This is
|
||||||
|
// modelled on LCursor.pullArg(), but tries not to
|
||||||
|
// invoke notifyCursorLeaves again and does not touch
|
||||||
|
// cur (since the top slice will be deleted
|
||||||
|
// afterwards))
|
||||||
|
MathArray ar = cell(0);
|
||||||
|
LCursor tmpcur = cur;
|
||||||
|
tmpcur.pop();
|
||||||
|
tmpcur.cell().erase(tmpcur.pos());
|
||||||
|
tmpcur.cell().insert(tmpcur.pos(), ar);
|
||||||
|
}
|
||||||
|
|
||||||
//lyxerr << "MathScriptInset::notifyCursorLeaves: 2 " << cur << endl;
|
//lyxerr << "MathScriptInset::notifyCursorLeaves: 2 " << cur << endl;
|
||||||
}
|
}
|
||||||
|
@ -69,6 +69,8 @@ What's new
|
|||||||
|
|
||||||
- Fix lockup when accepting a change in a text inset (bug 2510).
|
- Fix lockup when accepting a change in a text inset (bug 2510).
|
||||||
|
|
||||||
|
- Fix crash when undoing super/subscript deletion (bug 2727).
|
||||||
|
|
||||||
- Fix editing of document while Error List dialog is open (bug 2179).
|
- Fix editing of document while Error List dialog is open (bug 2179).
|
||||||
|
|
||||||
- improve position of cursor after undo.
|
- improve position of cursor after undo.
|
||||||
|
Loading…
Reference in New Issue
Block a user