mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-03 08:28:25 +00:00
Fix the line-delete-forward bug?
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@779 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
e9af311f5f
commit
aa25dde22d
12
ChangeLog
12
ChangeLog
@ -1,3 +1,15 @@
|
|||||||
|
2000-05-30 Jean-Marc Lasgouttes <Jean-Marc.Lasgouttes@inria.fr>
|
||||||
|
|
||||||
|
* src/text.C (DeleteLineForward): set selection to true to avoid
|
||||||
|
that DeleteEmptyParagraphMechanism does some magic. This is how it
|
||||||
|
is done in all other functions, and seems reasonable.
|
||||||
|
(DeleteWordForward): do not jump over non-word stuff, since
|
||||||
|
CursorRightOneWord() already does it.
|
||||||
|
|
||||||
|
Remove the CHECK tag from DeleteLineForward, DeleteWordForward and
|
||||||
|
DeleteWordBackward, since they seem safe to me (since selection is
|
||||||
|
set to "true") DeleteEmptyParagraphMechanism does nothing.
|
||||||
|
|
||||||
2000-05-29 Jean-Marc Lasgouttes <Jean-Marc.Lasgouttes@inria.fr>
|
2000-05-29 Jean-Marc Lasgouttes <Jean-Marc.Lasgouttes@inria.fr>
|
||||||
|
|
||||||
* src/lyx_main.C (easyParse): simplify the code by factoring the
|
* src/lyx_main.C (easyParse): simplify the code by factoring the
|
||||||
|
@ -529,6 +529,7 @@ private:
|
|||||||
float & fill_hfill,
|
float & fill_hfill,
|
||||||
float & fill_label_hfill,
|
float & fill_label_hfill,
|
||||||
bool bidi = true) const;
|
bool bidi = true) const;
|
||||||
|
|
||||||
///
|
///
|
||||||
void DeleteEmptyParagraphMechanism(LyXCursor const & old_cursor) const;
|
void DeleteEmptyParagraphMechanism(LyXCursor const & old_cursor) const;
|
||||||
|
|
||||||
|
@ -183,8 +183,8 @@ string CleanupPath(string const & path) ;
|
|||||||
*/
|
*/
|
||||||
string ReplaceEnvironmentPath(string const & path);
|
string ReplaceEnvironmentPath(string const & path);
|
||||||
|
|
||||||
/* Set Link to the path File Points to as a symbolic link.
|
/* Set Link to the path file points to as a symbolic link.
|
||||||
Return True if succesfull, False other wise */
|
Returns true if successful */
|
||||||
bool LyXReadLink(string const & file, string & Link);
|
bool LyXReadLink(string const & file, string & Link);
|
||||||
|
|
||||||
/* Uses kpsewhich to find tex files */
|
/* Uses kpsewhich to find tex files */
|
||||||
|
25
src/text.C
25
src/text.C
@ -3155,20 +3155,11 @@ void LyXText::SelectSelectedWord()
|
|||||||
/* -------> Delete from cursor up to the end of the current or next word. */
|
/* -------> Delete from cursor up to the end of the current or next word. */
|
||||||
void LyXText::DeleteWordForward()
|
void LyXText::DeleteWordForward()
|
||||||
{
|
{
|
||||||
LyXCursor tmpcursor = cursor;
|
|
||||||
|
|
||||||
if (!cursor.par->Last())
|
if (!cursor.par->Last())
|
||||||
CursorRight();
|
CursorRight();
|
||||||
// CHECK See comment on top of text.C
|
|
||||||
else {
|
else {
|
||||||
/* -------> Skip initial non-word stuff. */
|
LyXCursor tmpcursor = cursor;
|
||||||
while ( cursor.pos < cursor.par->Last()
|
selection = true; // to avoid deletion
|
||||||
&& (cursor.par->IsSeparator(cursor.pos)
|
|
||||||
|| cursor.par->IsKomma(cursor.pos)) )
|
|
||||||
cursor.pos++;
|
|
||||||
|
|
||||||
SetCursorIntern(cursor.par, cursor.pos);
|
|
||||||
selection = True; // to avoid deletion
|
|
||||||
CursorRightOneWord();
|
CursorRightOneWord();
|
||||||
sel_cursor = cursor;
|
sel_cursor = cursor;
|
||||||
cursor = tmpcursor;
|
cursor = tmpcursor;
|
||||||
@ -3183,11 +3174,10 @@ void LyXText::DeleteWordForward()
|
|||||||
/* -------> Delete from cursor to start of current or prior word. */
|
/* -------> Delete from cursor to start of current or prior word. */
|
||||||
void LyXText::DeleteWordBackward()
|
void LyXText::DeleteWordBackward()
|
||||||
{
|
{
|
||||||
LyXCursor tmpcursor = cursor;
|
|
||||||
if (!cursor.par->Last())
|
if (!cursor.par->Last())
|
||||||
CursorLeft();
|
CursorLeft();
|
||||||
// CHECK See comment on top of text.C
|
else {
|
||||||
else{
|
LyXCursor tmpcursor = cursor;
|
||||||
selection = true; // to avoid deletion
|
selection = true; // to avoid deletion
|
||||||
CursorLeftOneWord();
|
CursorLeftOneWord();
|
||||||
sel_cursor = cursor;
|
sel_cursor = cursor;
|
||||||
@ -3201,19 +3191,18 @@ void LyXText::DeleteWordBackward()
|
|||||||
/* -------> Kill to end of line. */
|
/* -------> Kill to end of line. */
|
||||||
void LyXText::DeleteLineForward()
|
void LyXText::DeleteLineForward()
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
||||||
if (!cursor.par->Last())
|
if (!cursor.par->Last())
|
||||||
// Paragraph is empty, so we just go to the right
|
// Paragraph is empty, so we just go to the right
|
||||||
CursorRight();
|
CursorRight();
|
||||||
else {
|
else {
|
||||||
// CHECK See comment on top of text.C
|
|
||||||
LyXCursor tmpcursor = cursor;
|
LyXCursor tmpcursor = cursor;
|
||||||
|
selection = true; // to avoid deletion
|
||||||
CursorEnd();
|
CursorEnd();
|
||||||
sel_cursor = cursor;
|
sel_cursor = cursor;
|
||||||
cursor = tmpcursor;
|
cursor = tmpcursor;
|
||||||
SetSelection();
|
SetSelection();
|
||||||
if (selection == false) {
|
// What is this test for ??? (JMarc)
|
||||||
|
if (!selection) {
|
||||||
DeleteWordForward();
|
DeleteWordForward();
|
||||||
} else {
|
} else {
|
||||||
CutSelection();
|
CutSelection();
|
||||||
|
@ -3542,7 +3542,6 @@ void LyXText::CursorDownParagraph() const
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void LyXText::DeleteEmptyParagraphMechanism(LyXCursor const & old_cursor) const
|
void LyXText::DeleteEmptyParagraphMechanism(LyXCursor const & old_cursor) const
|
||||||
{
|
{
|
||||||
// Would be wrong to delete anything if we have a selection.
|
// Would be wrong to delete anything if we have a selection.
|
||||||
@ -3886,14 +3885,14 @@ bool LyXText::TextHandleUndo(Undo * undo)
|
|||||||
void LyXText::FinishUndo()
|
void LyXText::FinishUndo()
|
||||||
{
|
{
|
||||||
// makes sure the next operation will be stored
|
// makes sure the next operation will be stored
|
||||||
undo_finished = True;
|
undo_finished = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void LyXText::FreezeUndo()
|
void LyXText::FreezeUndo()
|
||||||
{
|
{
|
||||||
// this is dangerous and for internal use only
|
// this is dangerous and for internal use only
|
||||||
undo_frozen = True;
|
undo_frozen = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user