mirror of
https://git.lyx.org/repos/lyx.git
synced 2024-11-09 18:31:04 +00:00
Respect group integrity when removing stuff from the Undo stack.
Fixes: #9079
This commit is contained in:
parent
b064f09b5a
commit
6bce9abfee
@ -160,13 +160,17 @@ public:
|
||||
/// Push an item on to the stack, deleting the bottom group on
|
||||
/// overflow.
|
||||
void push(UndoElement const & v) {
|
||||
c_.push_front(v);
|
||||
if (c_.size() > limit_) {
|
||||
// Remove some entries if the limit has been reached.
|
||||
// However, if the only group on the stack is the one
|
||||
// we are currently populating, do nothing.
|
||||
if (c_.size() >= limit_
|
||||
&& c_.front().group_id != v.group_id) {
|
||||
// remove a whole group at once.
|
||||
const size_t gid = c_.back().group_id;
|
||||
while (!c_.empty() && c_.back().group_id == gid)
|
||||
c_.pop_back();
|
||||
}
|
||||
c_.push_front(v);
|
||||
}
|
||||
|
||||
/// Mark all the elements of the stack as dirty
|
||||
|
@ -80,6 +80,8 @@ What's new
|
||||
|
||||
- Fix select-by-doubleclick in mathed (bug 8829).
|
||||
|
||||
- Fix undo with many individual changes (e.g. with replace all)
|
||||
(bug #7079).
|
||||
|
||||
|
||||
* INTERNALS
|
||||
|
Loading…
Reference in New Issue
Block a user