diff options
-rw-r--r-- | src/fe-text/gui-entry.c | 19 | ||||
-rw-r--r-- | src/fe-text/gui-entry.h | 1 | ||||
-rw-r--r-- | src/fe-text/gui-readline.c | 3 |
3 files changed, 21 insertions, 2 deletions
diff --git a/src/fe-text/gui-entry.c b/src/fe-text/gui-entry.c index c045de83..d9744cd0 100644 --- a/src/fe-text/gui-entry.c +++ b/src/fe-text/gui-entry.c @@ -561,6 +561,25 @@ void gui_entry_erase(GUI_ENTRY_REC *entry, int size, int update_cutbuffer) gui_entry_draw(entry); } +void gui_entry_erase_cell(GUI_ENTRY_REC *entry) +{ + int size = 1; + + g_return_if_fail(entry != NULL); + + if (entry->utf8) + while (entry->pos+size < entry->text_len && + mk_wcwidth(entry->text[entry->pos+size]) == 0) size++; + + g_memmove(entry->text + entry->pos, entry->text + entry->pos + size, + (entry->text_len-entry->pos-size+1) * sizeof(unichar)); + + entry->text_len -= size; + + gui_entry_redraw_from(entry, entry->pos); + gui_entry_draw(entry); +} + void gui_entry_erase_word(GUI_ENTRY_REC *entry, int to_space) { int to; diff --git a/src/fe-text/gui-entry.h b/src/fe-text/gui-entry.h index e5ab672a..29d8dea2 100644 --- a/src/fe-text/gui-entry.h +++ b/src/fe-text/gui-entry.h @@ -42,6 +42,7 @@ void gui_entry_insert_char(GUI_ENTRY_REC *entry, unichar chr); char *gui_entry_get_cutbuffer(GUI_ENTRY_REC *entry); void gui_entry_erase_to(GUI_ENTRY_REC *entry, int pos, int update_cutbuffer); void gui_entry_erase(GUI_ENTRY_REC *entry, int size, int update_cutbuffer); +void gui_entry_erase_cell(GUI_ENTRY_REC *entry); void gui_entry_erase_word(GUI_ENTRY_REC *entry, int to_space); void gui_entry_erase_next_word(GUI_ENTRY_REC *entry, int to_space); diff --git a/src/fe-text/gui-readline.c b/src/fe-text/gui-readline.c index 06f61e4b..78ebd351 100644 --- a/src/fe-text/gui-readline.c +++ b/src/fe-text/gui-readline.c @@ -697,8 +697,7 @@ static void key_upcase_word(void) static void key_delete_character(void) { if (gui_entry_get_pos(active_entry) < active_entry->text_len) { - gui_entry_move_pos(active_entry, 1); - gui_entry_erase(active_entry, 1, FALSE); + gui_entry_erase_cell(active_entry); } } |