mirror of
https://gitee.com/vnotex/vnote.git
synced 2025-07-05 13:59:52 +08:00
bug-fix: Vim mode Paste action
Move cursor to the right position after paste.
This commit is contained in:
parent
78bb2d5c41
commit
8b1d7e9841
@ -345,6 +345,7 @@ static void insertChangeBlockAfterDeletion(QTextCursor &p_cursor, int p_deletion
|
||||
p_cursor.insertBlock();
|
||||
} else {
|
||||
// Insert a new block above.
|
||||
p_cursor.movePosition(QTextCursor::StartOfBlock);
|
||||
p_cursor.insertBlock();
|
||||
p_cursor.movePosition(QTextCursor::PreviousBlock);
|
||||
}
|
||||
@ -3824,6 +3825,16 @@ void VVim::processPasteAction(QList<Token> &p_tokens, bool p_pasteBefore)
|
||||
QString value = reg.read();
|
||||
bool isBlock = reg.isBlock();
|
||||
if (value.isEmpty()) {
|
||||
if (checkMode(VimMode::Visual) || checkMode(VimMode::VisualLine)) {
|
||||
setMode(VimMode::Normal);
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
if (!(checkMode(VimMode::Normal)
|
||||
|| checkMode(VimMode::Visual)
|
||||
|| checkMode(VimMode::VisualLine))) {
|
||||
return;
|
||||
}
|
||||
|
||||
@ -3833,67 +3844,101 @@ void VVim::processPasteAction(QList<Token> &p_tokens, bool p_pasteBefore)
|
||||
text.append(value);
|
||||
}
|
||||
|
||||
bool changed = false;
|
||||
int nrBlock = 0;
|
||||
int restorePos = -1;
|
||||
QTextCursor cursor = m_editor->textCursor();
|
||||
cursor.beginEditBlock();
|
||||
|
||||
// Different from Vim:
|
||||
// In visual mode, by default vim select the current char, so paste operation will replace
|
||||
// current char, but here it is strange to follow this specification
|
||||
bool hasSelection = cursor.hasSelection();
|
||||
// current char, but here it is strange to follow this specification.
|
||||
bool isVisualLine = checkMode(VimMode::VisualLine);
|
||||
if (hasSelection) {
|
||||
if (!checkMode(VimMode::Normal)) {
|
||||
// Visual or VisualLine mode.
|
||||
if (cursor.hasSelection()) {
|
||||
int pos = cursor.selectionStart();
|
||||
deleteSelectedText(cursor, false);
|
||||
if (isBlock && !isVisualLine) {
|
||||
deleteSelectedText(cursor, isVisualLine);
|
||||
if (isVisualLine) {
|
||||
// Insert a new block for insertion.
|
||||
insertChangeBlockAfterDeletion(cursor, pos);
|
||||
}
|
||||
|
||||
restorePos = cursor.position();
|
||||
|
||||
if (isBlock) {
|
||||
if (!isVisualLine) {
|
||||
cursor.movePosition(QTextCursor::EndOfBlock);
|
||||
cursor.insertBlock();
|
||||
}
|
||||
|
||||
int nrBlock = text.count('\n');
|
||||
if (nrBlock > 0) {
|
||||
message(tr("%1 more %2").arg(nrBlock).arg(nrBlock > 1 ? tr("lines")
|
||||
: tr("line")));
|
||||
}
|
||||
// inserBlock() already insert a new line, so eliminate one here.
|
||||
nrBlock = text.count('\n');
|
||||
// insertChangeBlockAfterDeletion() already insert a new line, so eliminate one here.
|
||||
text = text.left(text.size() - 1);
|
||||
}
|
||||
cursor.insertText(text);
|
||||
} else { // no selection
|
||||
} else if (isBlock) {
|
||||
// Insert new block right at current cursor.
|
||||
nrBlock = text.count('\n');
|
||||
cursor.insertBlock();
|
||||
restorePos = cursor.position();
|
||||
} else if (text.count('\n') > 0) {
|
||||
restorePos = cursor.position();
|
||||
}
|
||||
|
||||
changed = true;
|
||||
}
|
||||
|
||||
setMode(VimMode::Normal);
|
||||
} else {
|
||||
// Normal mode.
|
||||
if (isBlock) {
|
||||
if (p_pasteBefore) {
|
||||
cursor.movePosition(QTextCursor::StartOfBlock);
|
||||
cursor.insertBlock();
|
||||
cursor.movePosition(QTextCursor::PreviousBlock);
|
||||
} else if (!isVisualLine) {
|
||||
} else {
|
||||
cursor.movePosition(QTextCursor::EndOfBlock);
|
||||
cursor.insertBlock();
|
||||
}
|
||||
|
||||
int nrBlock = text.count('\n');
|
||||
if (nrBlock > 0) {
|
||||
message(tr("%1 more %2").arg(nrBlock).arg(nrBlock > 1 ? tr("lines")
|
||||
: tr("line")));
|
||||
}
|
||||
restorePos = cursor.position();
|
||||
|
||||
nrBlock = text.count('\n');
|
||||
|
||||
// inserBlock() already insert a new line, so eliminate one here.
|
||||
text = text.left(text.size() - 1);
|
||||
} else { // not a block
|
||||
} else {
|
||||
// Not a block.
|
||||
if (!p_pasteBefore && !cursor.atBlockEnd()) {
|
||||
// Insert behind current cursor.
|
||||
cursor.movePosition(QTextCursor::Right);
|
||||
}
|
||||
|
||||
if (text.count('\n') > 0) {
|
||||
restorePos = cursor.position();
|
||||
}
|
||||
}
|
||||
|
||||
changed = true;
|
||||
}
|
||||
|
||||
if (changed) {
|
||||
cursor.insertText(text);
|
||||
|
||||
if (restorePos == -1) {
|
||||
// Move cursor one character left.
|
||||
cursor.movePosition(QTextCursor::Left);
|
||||
} else {
|
||||
// Move cursor at the right position.
|
||||
cursor.setPosition(restorePos);
|
||||
}
|
||||
|
||||
if (nrBlock > 0) {
|
||||
message(tr("%1 more %2").arg(nrBlock).arg(nrBlock > 1 ? tr("lines")
|
||||
: tr("line")));
|
||||
}
|
||||
}
|
||||
|
||||
cursor.endEditBlock();
|
||||
m_editor->setTextCursor(cursor);
|
||||
|
||||
setMode(VimMode::Normal);
|
||||
if (changed) {
|
||||
m_editor->setTextCursor(cursor);
|
||||
}
|
||||
|
||||
qDebug() << "text pasted" << text;
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user