for (; pit <= et.pit(); ++pit) {
pos_type left = (pit == it.pit() ? it.pos() : 0);
pos_type right = (pit == et.pit() ? et.pos() : pars_[pit].size());
- pars_[pit].acceptChanges(left, right);
- // merge paragraph if appropriate:
- // if (right >= pars_[pit].size() && pit + 1 < et.pit() &&
- // pars_[pit].isDeleted(pars_[pit].size())) {
- // setCursorIntern(cur, pit + 1, 0);
- // backspacePos0(cur);
- //}
+ // handle imaginary end-of-par character first
+ if (right == pars_[pit].size() && !pars_[pit].isUnchanged(right)) {
+ if (pars_[pit].isInserted(right)) {
+ pars_[pit].setChange(right, Change(Change::UNCHANGED));
+ } else {
+ // if (pit + 1 < et.pit()) {
+ // setCursorIntern(cur, pit + 1, 0);
+ // backspacePos0(cur);
+ // }
+ }
+ }
+
+ pars_[pit].acceptChanges(left, right);
}
finishUndo();
cur.clearSelection();
- setCursorIntern(cur, it.pit(), 0);
+ setCursorIntern(cur, it.pit(), it.pos());
+ cur.updateFlags(Update::Force);
}
for (; pit <= et.pit(); ++pit) {
pos_type left = (pit == it.pit() ? it.pos() : 0);
pos_type right = (pit == et.pit() ? et.pos() : pars_[pit].size());
- pars_[pit].rejectChanges(left, right);
- // merge paragraph if appropriate:
- // if (right >= pars_[pit].size() && pit + 1 < et.pit() &&
- // pars_[pit].isInserted(pars_[pit].size())) {
- // setCursorIntern(cur, pit + 1, 0);
- // backspacePos0(cur);
- //}
+ // handle imaginary end-of-par character first
+ if (right == pars_[pit].size() && !pars_[pit].isUnchanged(right)) {
+ if (pars_[pit].isDeleted(right)) {
+ pars_[pit].setChange(right, Change(Change::UNCHANGED));
+ } else {
+ // if (pit + 1 < et.pit()) {
+ // setCursorIntern(cur, pit + 1, 0);
+ // backspacePos0(cur);
+ // }
+ }
+ }
+
+ pars_[pit].rejectChanges(left, right);
}
finishUndo();
cur.clearSelection();
- setCursorIntern(cur, it.pit(), 0);
+ setCursorIntern(cur, it.pit(), it.pos());
+ cur.updateFlags(Update::Force);
}