Backporting fix for #3821.

Allow insertStringAs* to reset the cursor.

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/branches/BRANCH_2_0_X@40015 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Richard Heck 2011-10-26 16:02:30 +00:00
parent b169e4ec22
commit a2705e1474
4 changed files with 12 additions and 7 deletions

View File

@ -1044,6 +1044,7 @@ void pasteClipboardText(Cursor & cur, ErrorList & errorList, bool asParagraphs)
cur.text()->insertStringAsParagraphs(cur, text, cur.current_font); cur.text()->insertStringAsParagraphs(cur, text, cur.current_font);
else else
cur.text()->insertStringAsLines(cur, text, cur.current_font); cur.text()->insertStringAsLines(cur, text, cur.current_font);
cur.setSelection();
} }

View File

@ -756,12 +756,12 @@ void Text::breakParagraph(Cursor & cur, bool inverse_logic)
// needed to insert the selection // needed to insert the selection
void Text::insertStringAsLines(DocIterator const & dit, docstring const & str, void Text::insertStringAsLines(Cursor & cur, docstring const & str,
Font const & font) Font const & font)
{ {
BufferParams const & bparams = owner_->buffer().params(); BufferParams const & bparams = owner_->buffer().params();
pit_type pit = dit.pit(); pit_type pit = cur.pit();
pos_type pos = dit.pos(); pos_type pos = cur.pos();
// insert the string, don't insert doublespace // insert the string, don't insert doublespace
bool space_inserted = true; bool space_inserted = true;
@ -803,12 +803,13 @@ void Text::insertStringAsLines(DocIterator const & dit, docstring const & str,
space_inserted = (*cit == ' '); space_inserted = (*cit == ' ');
} }
} }
setCursor(cur, pit, pos);
} }
// turn double CR to single CR, others are converted into one // turn double CR to single CR, others are converted into one
// blank. Then insertStringAsLines is called // blank. Then insertStringAsLines is called
void Text::insertStringAsParagraphs(DocIterator const & dit, docstring const & str, void Text::insertStringAsParagraphs(Cursor & cur, docstring const & str,
Font const & font) Font const & font)
{ {
docstring linestr = str; docstring linestr = str;
@ -830,7 +831,7 @@ void Text::insertStringAsParagraphs(DocIterator const & dit, docstring const & s
newline_inserted = false; newline_inserted = false;
} }
} }
insertStringAsLines(dit, linestr, font); insertStringAsLines(cur, linestr, font);
} }

View File

@ -263,10 +263,10 @@ public:
/* these things are for search and replace */ /* these things are for search and replace */
/// needed to insert the selection /// needed to insert the selection
void insertStringAsLines(DocIterator const & dit, docstring const & str, void insertStringAsLines(Cursor & cur, docstring const & str,
Font const & font); Font const & font);
/// needed to insert the selection /// needed to insert the selection
void insertStringAsParagraphs(DocIterator const & dit, docstring const & str, void insertStringAsParagraphs(Cursor & cur, docstring const & str,
Font const & font); Font const & font);
/// access to our paragraphs /// access to our paragraphs

View File

@ -193,6 +193,9 @@ What's new
- Improved scrolling in large tables with vertical alignment (bug 7662). - Improved scrolling in large tables with vertical alignment (bug 7662).
- Make cursor position after paste independent of where the pasted material
comes from (bug 3821).
* ADVANCED FIND AND REPLACE * ADVANCED FIND AND REPLACE