rearrange the mark-handling code in do_replace_loop() a bit, and add one

more miscellaneous fix


git-svn-id: svn://svn.savannah.gnu.org/nano/trunk/nano@1997 35c25a1d-7b9e-4130-9fde-d3aeb78583b8
master
David Lawrence Ramsey 2004-10-18 02:06:53 +00:00
parent 381d483986
commit 2cc2a57dea
2 changed files with 28 additions and 21 deletions

View File

@ -1420,9 +1420,9 @@ bool do_int_spell_fix(const char *word)
{ {
char *save_search; char *save_search;
char *save_replace; char *save_replace;
size_t current_x_save = current_x; size_t current_x_save = current_x, pww_save = placewewant;
filestruct *current_save = current;
filestruct *edittop_save = edittop; filestruct *edittop_save = edittop;
filestruct *current_save = current;
/* Save where we are. */ /* Save where we are. */
bool accepted = TRUE; bool accepted = TRUE;
/* The return value. */ /* The return value. */
@ -1463,8 +1463,10 @@ bool do_int_spell_fix(const char *word)
last_replace = mallocstrcpy(NULL, word); last_replace = mallocstrcpy(NULL, word);
/* Start from the top of the file. */ /* Start from the top of the file. */
edittop = fileage;
current = fileage; current = fileage;
current_x = -1; current_x = -1;
placewewant = 0;
search_last_line = FALSE; search_last_line = FALSE;
@ -1500,9 +1502,10 @@ bool do_int_spell_fix(const char *word)
last_replace = save_replace; last_replace = save_replace;
/* Restore where we were. */ /* Restore where we were. */
edittop = edittop_save;
current = current_save; current = current_save;
current_x = current_x_save; current_x = current_x_save;
edittop = edittop_save; placewewant = pww_save;
/* Restore case sensitivity setting. */ /* Restore case sensitivity setting. */
if (!case_sens_set) if (!case_sens_set)

View File

@ -299,7 +299,7 @@ bool findnextstr(bool can_display_wrap, bool wholeword, bool
break; break;
} }
/* Finished processing file, get out. */ /* We've finished processing the file, so get out. */
if (search_last_line) { if (search_last_line) {
if (can_display_wrap) if (can_display_wrap)
not_found_msg(needle); not_found_msg(needle);
@ -318,7 +318,7 @@ bool findnextstr(bool can_display_wrap, bool wholeword, bool
} }
#endif #endif
/* Start or end of buffer reached; wrap around. */ /* Start or end of buffer reached, so wrap around. */
if (fileptr == NULL) { if (fileptr == NULL) {
if (!can_display_wrap) if (!can_display_wrap)
return FALSE; return FALSE;
@ -626,7 +626,14 @@ int do_replace_loop(const char *needle, filestruct *real_current, size_t
if (old_mark_set) { if (old_mark_set) {
/* Save the locations where the mark begins and ends. */ /* Save the locations where the mark begins and ends. */
filestruct *old_current = current;
size_t old_current_x = current_x;
current = real_current;
current_x = *real_current_x;
mark_order(&top, &top_x, &bot, &bot_x); mark_order(&top, &top_x, &bot, &bot_x);
current = old_current;
current_x = old_current_x;
UNSET(MARK_ISSET); UNSET(MARK_ISSET);
edit_refresh(); edit_refresh();
@ -747,22 +754,6 @@ int do_replace_loop(const char *needle, filestruct *real_current, size_t
*real_current_x += length_change; *real_current_x += length_change;
} }
#ifndef NANO_SMALL
/* Since the locations where the mark begins and ends may
* have changed, keep our saved locations in sync with
* them. */
if (old_mark_set) {
filestruct *old_current = current;
size_t old_current_x = current_x;
current = real_current;
current_x = *real_current_x;
mark_order(&top, &top_x, &bot, &bot_x);
current = old_current;
current_x = old_current_x;
}
#endif
/* Set the cursor at the last character of the replacement /* Set the cursor at the last character of the replacement
* text, so searching will resume after the replacement * text, so searching will resume after the replacement
* text. Note that current_x might be set to -1 here. */ * text. Note that current_x might be set to -1 here. */
@ -788,6 +779,19 @@ int do_replace_loop(const char *needle, filestruct *real_current, size_t
set_modified(); set_modified();
numreplaced++; numreplaced++;
} }
/* Save the locations where the mark begins and ends again,
* since they may have changed. */
if (old_mark_set) {
filestruct *old_current = current;
size_t old_current_x = current_x;
current = real_current;
current_x = *real_current_x;
mark_order(&top, &top_x, &bot, &bot_x);
current = old_current;
current_x = old_current_x;
}
} }
/* If text has been added to the magicline, make a new magicline. */ /* If text has been added to the magicline, make a new magicline. */