mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-12 03:23:12 +00:00
Fix bug 2393 (from Dov Feldstern)
* src/lyxtext.h * src/text.C (LyXText::charsTranspose): New method for transposing characters * src/text.C (LyXText::dispatch): Call charsTranspose for LFUN_CHARS_TRANSPOSE git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@15951 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
8b9ccb51bf
commit
1c3755244f
@ -251,6 +251,8 @@ public:
|
|||||||
};
|
};
|
||||||
/// Change the case of the word at cursor position.
|
/// Change the case of the word at cursor position.
|
||||||
void changeCase(LCursor & cur, TextCase action);
|
void changeCase(LCursor & cur, TextCase action);
|
||||||
|
/// Transposes the character at the cursor with the one before it
|
||||||
|
void charsTranspose(LCursor & cur);
|
||||||
|
|
||||||
/** the DTP switches for paragraphs. LyX will store the top settings
|
/** the DTP switches for paragraphs. LyX will store the top settings
|
||||||
always in the first physical paragraph, the bottom settings in the
|
always in the first physical paragraph, the bottom settings in the
|
||||||
|
57
src/text.C
57
src/text.C
@ -2528,4 +2528,61 @@ bool LyXText::setCursorFromCoordinates(LCursor & cur, int const x, int const y)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void LyXText::charsTranspose(LCursor & cur)
|
||||||
|
{
|
||||||
|
BOOST_ASSERT(this == cur.text());
|
||||||
|
|
||||||
|
pos_type pos = cur.pos();
|
||||||
|
|
||||||
|
// If cursor is at beginning or end of paragraph, do nothing.
|
||||||
|
if (pos == cur.lastpos() || pos == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
Paragraph & par = cur.paragraph();
|
||||||
|
|
||||||
|
// Get the positions of the characters to be transposed.
|
||||||
|
pos_type pos1 = pos - 1;
|
||||||
|
pos_type pos2 = pos;
|
||||||
|
|
||||||
|
// In change tracking mode, ignore deleted characters.
|
||||||
|
while (pos2 < cur.lastpos() && par.isDeleted(pos2))
|
||||||
|
++pos2;
|
||||||
|
if (pos2 == cur.lastpos())
|
||||||
|
return;
|
||||||
|
|
||||||
|
while (pos1 >= 0 && par.isDeleted(pos1))
|
||||||
|
--pos1;
|
||||||
|
if (pos1 < 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Don't do anything if one of the "characters" is not regular text.
|
||||||
|
if (par.isInset(pos1) || par.isInset(pos2))
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Store the characters to be transposed (including font information).
|
||||||
|
char_type char1 = par.getChar(pos1);
|
||||||
|
LyXFont const font1 =
|
||||||
|
par.getFontSettings(cur.buffer().params(), pos1);
|
||||||
|
|
||||||
|
char_type char2 = par.getChar(pos2);
|
||||||
|
LyXFont const font2 =
|
||||||
|
par.getFontSettings(cur.buffer().params(), pos2);
|
||||||
|
|
||||||
|
// And finally, we are ready to perform the transposition.
|
||||||
|
// Track the changes if Change Tracking is enabled.
|
||||||
|
bool const trackChanges = cur.buffer().params().trackChanges;
|
||||||
|
|
||||||
|
recordUndo(cur);
|
||||||
|
|
||||||
|
par.eraseChar(pos2, trackChanges);
|
||||||
|
par.eraseChar(pos1, trackChanges);
|
||||||
|
par.insertChar(pos1, char2, font2, trackChanges);
|
||||||
|
par.insertChar(pos2, char1, font1, trackChanges);
|
||||||
|
|
||||||
|
// After the transposition, move cursor to after the transposition.
|
||||||
|
setCursor(cur, cur.pit(), pos2);
|
||||||
|
cur.forwardPos();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
} // namespace lyx
|
} // namespace lyx
|
||||||
|
@ -748,7 +748,7 @@ void LyXText::dispatch(LCursor & cur, FuncRequest & cmd)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_CHARS_TRANSPOSE:
|
case LFUN_CHARS_TRANSPOSE:
|
||||||
recordUndo(cur);
|
charsTranspose(cur);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_PASTE:
|
case LFUN_PASTE:
|
||||||
|
Loading…
Reference in New Issue
Block a user