diff options
author | Sebastien Helleu <flashcode@flashtux.org> | 2010-08-12 18:24:52 +0200 |
---|---|---|
committer | Sebastien Helleu <flashcode@flashtux.org> | 2010-08-12 18:24:52 +0200 |
commit | 3950a60e87dbd9dd29896132a64c03df1a64e3c3 (patch) | |
tree | 8c8e6c346a63fb2783627af41288c6c2403cfd0e | |
parent | 94acf64f8cd35162d04fcb4ad63c5dfa34f8d432 (diff) | |
download | weechat-3950a60e87dbd9dd29896132a64c03df1a64e3c3.zip |
Use window pointers instead of buffer pointers in gui-input.c
-rw-r--r-- | src/core/wee-command.c | 50 | ||||
-rw-r--r-- | src/gui/gui-input.c | 494 | ||||
-rw-r--r-- | src/gui/gui-input.h | 46 | ||||
-rw-r--r-- | src/gui/gui-window.c | 4 |
4 files changed, 300 insertions, 294 deletions
diff --git a/src/core/wee-command.c b/src/core/wee-command.c index 2c33bcd07..e9b8bd23b 100644 --- a/src/core/wee-command.c +++ b/src/core/wee-command.c @@ -1889,44 +1889,44 @@ command_input (void *data, struct t_gui_buffer *buffer, if (argc > 1) { - if (string_strcasecmp (argv[1], "return") == 0) + if (string_strcasecmp (argv[1], "clipboard_paste") == 0) + gui_input_clipboard_paste (gui_current_window); + else if (string_strcasecmp (argv[1], "return") == 0) gui_input_return (gui_current_window); else if (string_strcasecmp (argv[1], "complete_next") == 0) - gui_input_complete_next (gui_current_window->buffer); + gui_input_complete_next (gui_current_window); else if (string_strcasecmp (argv[1], "complete_previous") == 0) - gui_input_complete_previous (gui_current_window->buffer); + gui_input_complete_previous (gui_current_window); else if (string_strcasecmp (argv[1], "search_text") == 0) gui_input_search_text (gui_current_window); else if (string_strcasecmp (argv[1], "delete_previous_char") == 0) - gui_input_delete_previous_char (gui_current_window->buffer); + gui_input_delete_previous_char (gui_current_window); else if (string_strcasecmp (argv[1], "delete_next_char") == 0) - gui_input_delete_next_char (gui_current_window->buffer); + gui_input_delete_next_char (gui_current_window); else if (string_strcasecmp (argv[1], "delete_previous_word") == 0) - gui_input_delete_previous_word (gui_current_window->buffer); + gui_input_delete_previous_word (gui_current_window); else if (string_strcasecmp (argv[1], "delete_next_word") == 0) - gui_input_delete_next_word (gui_current_window->buffer); + gui_input_delete_next_word (gui_current_window); else if (string_strcasecmp (argv[1], "delete_beginning_of_line") == 0) - gui_input_delete_beginning_of_line (gui_current_window->buffer); + gui_input_delete_beginning_of_line (gui_current_window); else if (string_strcasecmp (argv[1], "delete_end_of_line") == 0) - gui_input_delete_end_of_line (gui_current_window->buffer); + gui_input_delete_end_of_line (gui_current_window); else if (string_strcasecmp (argv[1], "delete_line") == 0) - gui_input_delete_line (gui_current_window->buffer); - else if (string_strcasecmp (argv[1], "clipboard_paste") == 0) - gui_input_clipboard_paste (gui_current_window->buffer); + gui_input_delete_line (gui_current_window); else if (string_strcasecmp (argv[1], "transpose_chars") == 0) - gui_input_transpose_chars (gui_current_window->buffer); + gui_input_transpose_chars (gui_current_window); else if (string_strcasecmp (argv[1], "move_beginning_of_line") == 0) - gui_input_move_beginning_of_line (gui_current_window->buffer); + gui_input_move_beginning_of_line (gui_current_window); else if (string_strcasecmp (argv[1], "move_end_of_line") == 0) - gui_input_move_end_of_line (gui_current_window->buffer); + gui_input_move_end_of_line (gui_current_window); else if (string_strcasecmp (argv[1], "move_previous_char") == 0) - gui_input_move_previous_char (gui_current_window->buffer); + gui_input_move_previous_char (gui_current_window); else if (string_strcasecmp (argv[1], "move_next_char") == 0) - gui_input_move_next_char (gui_current_window->buffer); + gui_input_move_next_char (gui_current_window); else if (string_strcasecmp (argv[1], "move_previous_word") == 0) - gui_input_move_previous_word (gui_current_window->buffer); + gui_input_move_previous_word (gui_current_window); else if (string_strcasecmp (argv[1], "move_next_word") == 0) - gui_input_move_next_word (gui_current_window->buffer); + gui_input_move_next_word (gui_current_window); else if (string_strcasecmp (argv[1], "history_previous") == 0) gui_input_history_local_previous (gui_current_window); else if (string_strcasecmp (argv[1], "history_next") == 0) @@ -1946,15 +1946,15 @@ command_input (void *data, struct t_gui_buffer *buffer, else if (string_strcasecmp (argv[1], "hotlist_clear") == 0) gui_input_hotlist_clear (gui_current_window); else if (string_strcasecmp (argv[1], "grab_key") == 0) - gui_input_grab_key (gui_current_window->buffer); + gui_input_grab_key (gui_current_window); else if (string_strcasecmp (argv[1], "grab_key_command") == 0) - gui_input_grab_key_command (gui_current_window->buffer); + gui_input_grab_key_command (gui_current_window); else if (string_strcasecmp (argv[1], "scroll_unread") == 0) gui_input_scroll_unread (gui_current_window); else if (string_strcasecmp (argv[1], "set_unread") == 0) gui_input_set_unread (); else if (string_strcasecmp (argv[1], "set_unread_current_buffer") == 0) - gui_input_set_unread_buffer (gui_current_window->buffer); + gui_input_set_unread_current (gui_current_window); else if (string_strcasecmp (argv[1], "switch_active_buffer") == 0) gui_input_switch_active_buffer (gui_current_window); else if (string_strcasecmp (argv[1], "switch_active_buffer_previous") == 0) @@ -1962,12 +1962,12 @@ command_input (void *data, struct t_gui_buffer *buffer, else if (string_strcasecmp (argv[1], "insert") == 0) { if (argc > 2) - gui_input_insert (gui_current_window->buffer, argv_eol[2]); + gui_input_insert (gui_current_window, argv_eol[2]); } else if (string_strcasecmp (argv[1], "undo") == 0) - gui_input_undo (gui_current_window->buffer); + gui_input_undo (gui_current_window); else if (string_strcasecmp (argv[1], "redo") == 0) - gui_input_redo (gui_current_window->buffer); + gui_input_redo (gui_current_window); } return WEECHAT_RC_OK; diff --git a/src/gui/gui-input.c b/src/gui/gui-input.c index 5bbdda9a6..cea9c5f56 100644 --- a/src/gui/gui-input.c +++ b/src/gui/gui-input.c @@ -263,19 +263,20 @@ gui_input_clipboard_copy (const char *buffer, int size) /* * gui_action_clipboard_paste: paste clipboard at cursor pos in input line + * (default key: ctrl-y) */ void -gui_input_clipboard_paste (struct t_gui_buffer *buffer) +gui_input_clipboard_paste (struct t_gui_window *window) { - if (buffer->input && gui_input_clipboard) + if (window->buffer->input && gui_input_clipboard) { - gui_buffer_undo_snap (buffer); - gui_input_insert_string (buffer, + gui_buffer_undo_snap (window->buffer); + gui_input_insert_string (window->buffer, gui_input_clipboard, -1); - gui_completion_stop (buffer->completion, 1); + gui_completion_stop (window->buffer->completion, 1); - gui_input_text_changed_modifier_and_signal (buffer, 1); + gui_input_text_changed_modifier_and_signal (window->buffer, 1); } } @@ -326,76 +327,76 @@ gui_input_return (struct t_gui_window *window) */ void -gui_input_complete (struct t_gui_buffer *buffer) +gui_input_complete (struct t_gui_window *window) { int i; - if (!buffer->completion) + if (!window->buffer->completion) return; - if (buffer->completion->word_found) + if (window->buffer->completion->word_found) { /* replace word with new completed word into input buffer */ - if (buffer->completion->diff_size > 0) + if (window->buffer->completion->diff_size > 0) { - buffer->input_buffer_size += - buffer->completion->diff_size; - buffer->input_buffer_length += - buffer->completion->diff_length; - gui_input_optimize_size (buffer); - buffer->input_buffer[buffer->input_buffer_size] = '\0'; - for (i = buffer->input_buffer_size - 1; - i >= buffer->completion->position_replace + - (int)strlen (buffer->completion->word_found); i--) + window->buffer->input_buffer_size += + window->buffer->completion->diff_size; + window->buffer->input_buffer_length += + window->buffer->completion->diff_length; + gui_input_optimize_size (window->buffer); + window->buffer->input_buffer[window->buffer->input_buffer_size] = '\0'; + for (i = window->buffer->input_buffer_size - 1; + i >= window->buffer->completion->position_replace + + (int)strlen (window->buffer->completion->word_found); i--) { - buffer->input_buffer[i] = - buffer->input_buffer[i - buffer->completion->diff_size]; + window->buffer->input_buffer[i] = + window->buffer->input_buffer[i - window->buffer->completion->diff_size]; } } else { - for (i = buffer->completion->position_replace + - strlen (buffer->completion->word_found); - i < buffer->input_buffer_size; i++) + for (i = window->buffer->completion->position_replace + + strlen (window->buffer->completion->word_found); + i < window->buffer->input_buffer_size; i++) { - buffer->input_buffer[i] = - buffer->input_buffer[i - buffer->completion->diff_size]; + window->buffer->input_buffer[i] = + window->buffer->input_buffer[i - window->buffer->completion->diff_size]; } - buffer->input_buffer_size += buffer->completion->diff_size; - buffer->input_buffer_length += buffer->completion->diff_length; - gui_input_optimize_size (buffer); - buffer->input_buffer[buffer->input_buffer_size] = '\0'; + window->buffer->input_buffer_size += window->buffer->completion->diff_size; + window->buffer->input_buffer_length += window->buffer->completion->diff_length; + gui_input_optimize_size (window->buffer); + window->buffer->input_buffer[window->buffer->input_buffer_size] = '\0'; } - strncpy (buffer->input_buffer + buffer->completion->position_replace, - buffer->completion->word_found, - strlen (buffer->completion->word_found)); - buffer->input_buffer_pos = - utf8_pos (buffer->input_buffer, - buffer->completion->position_replace) + - utf8_strlen (buffer->completion->word_found); + strncpy (window->buffer->input_buffer + window->buffer->completion->position_replace, + window->buffer->completion->word_found, + strlen (window->buffer->completion->word_found)); + window->buffer->input_buffer_pos = + utf8_pos (window->buffer->input_buffer, + window->buffer->completion->position_replace) + + utf8_strlen (window->buffer->completion->word_found); /* * position is < 0 this means only one word was found to complete, * so reinit to stop completion */ - if (buffer->completion->position >= 0) - buffer->completion->position = utf8_real_pos (buffer->input_buffer, - buffer->input_buffer_pos); + if (window->buffer->completion->position >= 0) + window->buffer->completion->position = utf8_real_pos (window->buffer->input_buffer, + window->buffer->input_buffer_pos); /* add space if needed after completion */ - if (buffer->completion->add_space) + if (window->buffer->completion->add_space) { - if (buffer->input_buffer[utf8_real_pos (buffer->input_buffer, - buffer->input_buffer_pos)] != ' ') + if (window->buffer->input_buffer[utf8_real_pos (window->buffer->input_buffer, + window->buffer->input_buffer_pos)] != ' ') { - gui_input_insert_string (buffer, " ", - buffer->input_buffer_pos); + gui_input_insert_string (window->buffer, " ", + window->buffer->input_buffer_pos); } else - buffer->input_buffer_pos++; - if (buffer->completion->position >= 0) - buffer->completion->position++; + window->buffer->input_buffer_pos++; + if (window->buffer->completion->position >= 0) + window->buffer->completion->position++; } } } @@ -405,19 +406,20 @@ gui_input_complete (struct t_gui_buffer *buffer) */ void -gui_input_complete_next (struct t_gui_buffer *buffer) +gui_input_complete_next (struct t_gui_window *window) { - if (buffer->input && (buffer->text_search == GUI_TEXT_SEARCH_DISABLED)) + if (window->buffer->input + && (window->buffer->text_search == GUI_TEXT_SEARCH_DISABLED)) { - gui_buffer_undo_snap (buffer); - gui_completion_search (buffer->completion, + gui_buffer_undo_snap (window->buffer); + gui_completion_search (window->buffer->completion, 1, - buffer->input_buffer, - buffer->input_buffer_size, - utf8_real_pos (buffer->input_buffer, - buffer->input_buffer_pos)); - gui_input_complete (buffer); - gui_input_text_changed_modifier_and_signal (buffer, 1); + window->buffer->input_buffer, + window->buffer->input_buffer_size, + utf8_real_pos (window->buffer->input_buffer, + window->buffer->input_buffer_pos)); + gui_input_complete (window); + gui_input_text_changed_modifier_and_signal (window->buffer, 1); } } @@ -426,19 +428,20 @@ gui_input_complete_next (struct t_gui_buffer *buffer) */ void -gui_input_complete_previous (struct t_gui_buffer *buffer) +gui_input_complete_previous (struct t_gui_window *window) { - if (buffer->input && (buffer->text_search == GUI_TEXT_SEARCH_DISABLED)) + if (window->buffer->input + && (window->buffer->text_search == GUI_TEXT_SEARCH_DISABLED)) { - gui_buffer_undo_snap (buffer); - gui_completion_search (buffer->completion, + gui_buffer_undo_snap (window->buffer); + gui_completion_search (window->buffer->completion, -1, - buffer->input_buffer, - buffer->input_buffer_size, - utf8_real_pos (buffer->input_buffer, - buffer->input_buffer_pos)); - gui_input_complete (buffer); - gui_input_text_changed_modifier_and_signal (buffer, 1); + window->buffer->input_buffer, + window->buffer->input_buffer_size, + utf8_real_pos (window->buffer->input_buffer, + window->buffer->input_buffer_pos)); + gui_input_complete (window); + gui_input_text_changed_modifier_and_signal (window->buffer, 1); } } @@ -468,27 +471,27 @@ gui_input_search_text (struct t_gui_window *window) */ void -gui_input_delete_previous_char (struct t_gui_buffer *buffer) +gui_input_delete_previous_char (struct t_gui_window *window) { char *pos, *pos_last; int char_size, size_to_move; - if (buffer->input && (buffer->input_buffer_pos > 0)) + if (window->buffer->input && (window->buffer->input_buffer_pos > 0)) { - gui_buffer_undo_snap (buffer); - pos = utf8_add_offset (buffer->input_buffer, - buffer->input_buffer_pos); - pos_last = utf8_prev_char (buffer->input_buffer, pos); + gui_buffer_undo_snap (window->buffer); + pos = utf8_add_offset (window->buffer->input_buffer, + window->buffer->input_buffer_pos); + pos_last = utf8_prev_char (window->buffer->input_buffer, pos); char_size = pos - pos_last; size_to_move = strlen (pos); - gui_input_move (buffer, pos_last, pos, size_to_move); - buffer->input_buffer_size -= char_size; - buffer->input_buffer_length--; - buffer->input_buffer_pos--; - buffer->input_buffer[buffer->input_buffer_size] = '\0'; - gui_input_optimize_size (buffer); - gui_completion_stop (buffer->completion, 1); - gui_input_text_changed_modifier_and_signal (buffer, 1); + gui_input_move (window->buffer, pos_last, pos, size_to_move); + window->buffer->input_buffer_size -= char_size; + window->buffer->input_buffer_length--; + window->buffer->input_buffer_pos--; + window->buffer->input_buffer[window->buffer->input_buffer_size] = '\0'; + gui_input_optimize_size (window->buffer); + gui_completion_stop (window->buffer->completion, 1); + gui_input_text_changed_modifier_and_signal (window->buffer, 1); } } @@ -497,27 +500,27 @@ gui_input_delete_previous_char (struct t_gui_buffer *buffer) */ void -gui_input_delete_next_char (struct t_gui_buffer *buffer) +gui_input_delete_next_char (struct t_gui_window *window) { char *pos, *pos_next; int char_size, size_to_move; - if (buffer->input - && (buffer->input_buffer_pos < buffer->input_buffer_length)) + if (window->buffer->input + && (window->buffer->input_buffer_pos < window->buffer->input_buffer_length)) { - gui_buffer_undo_snap (buffer); - pos = utf8_add_offset (buffer->input_buffer, - buffer->input_buffer_pos); + gui_buffer_undo_snap (window->buffer); + pos = utf8_add_offset (window->buffer->input_buffer, + window->buffer->input_buffer_pos); pos_next = utf8_next_char (pos); char_size = pos_next - pos; size_to_move = strlen (pos_next); - gui_input_move (buffer, pos, pos_next, size_to_move); - buffer->input_buffer_size -= char_size; - buffer->input_buffer_length--; - buffer->input_buffer[buffer->input_buffer_size] = '\0'; - gui_input_optimize_size (buffer); - gui_completion_stop (buffer->completion, 1); - gui_input_text_changed_modifier_and_signal (buffer, 1); + gui_input_move (window->buffer, pos, pos_next, size_to_move); + window->buffer->input_buffer_size -= char_size; + window->buffer->input_buffer_length--; + window->buffer->input_buffer[window->buffer->input_buffer_size] = '\0'; + gui_input_optimize_size (window->buffer); + gui_completion_stop (window->buffer->completion, 1); + gui_input_text_changed_modifier_and_signal (window->buffer, 1); } } @@ -526,32 +529,32 @@ gui_input_delete_next_char (struct t_gui_buffer *buffer) */ void -gui_input_delete_previous_word (struct t_gui_buffer *buffer) +gui_input_delete_previous_word (struct t_gui_window *window) { int length_deleted, size_deleted; char *start, *string; - if (buffer->input && (buffer->input_buffer_pos > 0)) + if (window->buffer->input && (window->buffer->input_buffer_pos > 0)) { - gui_buffer_undo_snap (buffer); - start = utf8_add_offset (buffer->input_buffer, - buffer->input_buffer_pos - 1); + gui_buffer_undo_snap (window->buffer); + start = utf8_add_offset (window->buffer->input_buffer, + window->buffer->input_buffer_pos - 1); string = start; while (string && (string[0] == ' ')) { - string = utf8_prev_char (buffer->input_buffer, string); + string = utf8_prev_char (window->buffer->input_buffer, string); } if (string) { while (string && (string[0] != ' ')) { - string = utf8_prev_char (buffer->input_buffer, string); + string = utf8_prev_char (window->buffer->input_buffer, string); } if (string) { while (string && (string[0] == ' ')) { - string = utf8_prev_char (buffer->input_buffer, string); + string = utf8_prev_char (window->buffer->input_buffer, string); } } } @@ -559,23 +562,23 @@ gui_input_delete_previous_word (struct t_gui_buffer *buffer) if (string) string = utf8_next_char (utf8_next_char (string)); else - string = buffer->input_buffer; + string = window->buffer->input_buffer; size_deleted = utf8_next_char (start) - string; length_deleted = utf8_strnlen (string, size_deleted); gui_input_clipboard_copy (string, size_deleted); - gui_input_move (buffer, string, string + size_deleted, + gui_input_move (window->buffer, string, string + size_deleted, strlen (string + size_deleted)); - buffer->input_buffer_size -= size_deleted; - buffer->input_buffer_length -= length_deleted; - buffer->input_buffer[buffer->input_buffer_size] = '\0'; - buffer->input_buffer_pos -= length_deleted; - gui_input_optimize_size (buffer); - gui_completion_stop (buffer->completion, 1); - gui_input_text_changed_modifier_and_signal (buffer, 1); + window->buffer->input_buffer_size -= size_deleted; + window->buffer->input_buffer_length -= length_deleted; + window->buffer->input_buffer[window->buffer->input_buffer_size] = '\0'; + window->buffer->input_buffer_pos -= length_deleted; + gui_input_optimize_size (window->buffer); + gui_completion_stop (window->buffer->completion, 1); + gui_input_text_changed_modifier_and_signal (window->buffer, 1); } } @@ -584,16 +587,16 @@ gui_input_delete_previous_word (struct t_gui_buffer *buffer) */ void -gui_input_delete_next_word (struct t_gui_buffer *buffer) +gui_input_delete_next_word (struct t_gui_window *window) { int size_deleted, length_deleted; char *start, *string; - if (buffer->input) + if (window->buffer->input) { - gui_buffer_undo_snap (buffer); - start = utf8_add_offset (buffer->input_buffer, - buffer->input_buffer_pos); + gui_buffer_undo_snap (window->buffer); + start = utf8_add_offset (window->buffer->input_buffer, + window->buffer->input_buffer_pos); string = start; length_deleted = 0; while (string[0]) @@ -607,14 +610,14 @@ gui_input_delete_next_word (struct t_gui_buffer *buffer) gui_input_clipboard_copy (start, size_deleted); - gui_input_move (buffer, start, string, strlen (string)); + gui_input_move (window->buffer, start, string, strlen (string)); - buffer->input_buffer_size -= size_deleted; - buffer->input_buffer_length -= length_deleted; - buffer->input_buffer[buffer->input_buffer_size] = '\0'; - gui_input_optimize_size (buffer); - gui_completion_stop (buffer->completion, 1); - gui_input_text_changed_modifier_and_signal (buffer, 1); + window->buffer->input_buffer_size -= size_deleted; + window->buffer->input_buffer_length -= length_deleted; + window->buffer->input_buffer[window->buffer->input_buffer_size] = '\0'; + gui_input_optimize_size (window->buffer); + gui_completion_stop (window->buffer->completion, 1); + gui_input_text_changed_modifier_and_signal (window->buffer, 1); } } @@ -625,31 +628,32 @@ gui_input_delete_next_word (struct t_gui_buffer *buffer) */ void -gui_input_delete_beginning_of_line (struct t_gui_buffer *buffer) +gui_input_delete_beginning_of_line (struct t_gui_window *window) { int length_deleted, size_deleted, pos_start; char *start; - if (buffer->input && (buffer->input_buffer_pos > 0)) + if (window->buffer->input && (window->buffer->input_buffer_pos > 0)) { - gui_buffer_undo_snap (buffer); - start = utf8_add_offset (buffer->input_buffer, - buffer->input_buffer_pos); - pos_start = start - buffer->input_buffer; - size_deleted = start - buffer->input_buffer; - length_deleted = utf8_strnlen (buffer->input_buffer, size_deleted); - gui_input_clipboard_copy (buffer->input_buffer, - start - buffer->input_buffer); + gui_buffer_undo_snap (window->buffer); + start = utf8_add_offset (window->buffer->input_buffer, + window->buffer->input_buffer_pos); + pos_start = start - window->buffer->input_buffer; + size_deleted = start - window->buffer->input_buffer; + length_deleted = utf8_strnlen (window->buffer->input_buffer, size_deleted); + gui_input_clipboard_copy (window->buffer->input_buffer, + start - window->buffer->input_buffer); - gui_input_move (buffer, buffer->input_buffer, start, strlen (start)); + gui_input_move (window->buffer, window->buffer->input_buffer, + start, strlen (start)); - buffer->input_buffer_size -= size_deleted; - buffer->input_buffer_length -= length_deleted; - buffer->input_buffer[buffer->input_buffer_size] = '\0'; - buffer->input_buffer_pos = 0; - gui_input_optimize_size (buffer); - gui_completion_stop (buffer->completion, 1); - gui_input_text_changed_modifier_and_signal (buffer, 1); + window->buffer->input_buffer_size -= size_deleted; + window->buffer->input_buffer_length -= length_deleted; + window->buffer->input_buffer[window->buffer->input_buffer_size] = '\0'; + window->buffer->input_buffer_pos = 0; + gui_input_optimize_size (window->buffer); + gui_completion_stop (window->buffer->completion, 1); + gui_input_text_changed_modifier_and_signal (window->buffer, 1); } } @@ -659,26 +663,26 @@ gui_input_delete_beginning_of_line (struct t_gui_buffer *buffer) */ void -gui_input_delete_end_of_line (struct t_gui_buffer *buffer) +gui_input_delete_end_of_line (struct t_gui_window *window) { char *start; int size_deleted, length_deleted, pos_start; - if (buffer->input) + if (window->buffer->input) { - gui_buffer_undo_snap (buffer); - start = utf8_add_offset (buffer->input_buffer, - buffer->input_buffer_pos); - pos_start = start - buffer->input_buffer; + gui_buffer_undo_snap (window->buffer); + start = utf8_add_offset (window->buffer->input_buffer, + window->buffer->input_buffer_pos); + pos_start = start - window->buffer->input_buffer; size_deleted = strlen (start); length_deleted = utf8_strlen (start); gui_input_clipboard_copy (start, size_deleted); start[0] = '\0'; - buffer->input_buffer_size = strlen (buffer->input_buffer); - buffer->input_buffer_length = utf8_strlen (buffer->input_buffer); - gui_input_optimize_size (buffer); - gui_completion_stop (buffer->completion, 1); - gui_input_text_changed_modifier_and_signal (buffer, 1); + window->buffer->input_buffer_size = strlen (window->buffer->input_buffer); + window->buffer->input_buffer_length = utf8_strlen (window->buffer->input_buffer); + gui_input_optimize_size (window->buffer); + gui_completion_stop (window->buffer->completion, 1); + gui_input_text_changed_modifier_and_signal (window->buffer, 1); } } @@ -687,18 +691,18 @@ gui_input_delete_end_of_line (struct t_gui_buffer *buffer) */ void -gui_input_delete_line (struct t_gui_buffer *buffer) +gui_input_delete_line (struct t_gui_window *window) { - if (buffer->input) + if (window->buffer->input) { - gui_buffer_undo_snap (buffer); - buffer->input_buffer[0] = '\0'; - buffer->input_buffer_size = 0; - buffer->input_buffer_length = 0; - buffer->input_buffer_pos = 0; - gui_input_optimize_size (buffer); - gui_completion_stop (buffer->completion, 1); - gui_input_text_changed_modifier_and_signal (buffer, 1); + gui_buffer_undo_snap (window->buffer); + window->buffer->input_buffer[0] = '\0'; + window->buffer->input_buffer_size = 0; + window->buffer->input_buffer_length = 0; + window->buffer->input_buffer_pos = 0; + gui_input_optimize_size (window->buffer); + gui_completion_stop (window->buffer->completion, 1); + gui_input_text_changed_modifier_and_signal (window->buffer, 1); } } @@ -708,25 +712,25 @@ gui_input_delete_line (struct t_gui_buffer *buffer) */ void -gui_input_transpose_chars (struct t_gui_buffer *buffer) +gui_input_transpose_chars (struct t_gui_window *window) { char *start, *prev_char, saved_char[5]; int size_prev_char, size_start_char; int pos_prev_char, pos_start; - if (buffer->input && (buffer->input_buffer_pos > 0) - && (buffer->input_buffer_length > 1)) + if (window->buffer->input && (window->buffer->input_buffer_pos > 0) + && (window->buffer->input_buffer_length > 1)) { - gui_buffer_undo_snap (buffer); + gui_buffer_undo_snap (window->buffer); - if (buffer->input_buffer_pos == buffer->input_buffer_length) - buffer->input_buffer_pos--; + if (window->buffer->input_buffer_pos == window->buffer->input_buffer_length) + window->buffer->input_buffer_pos--; - start = utf8_add_offset (buffer->input_buffer, - buffer->input_buffer_pos); - pos_start = start - buffer->input_buffer; - prev_char = utf8_prev_char (buffer->input_buffer, start); - pos_prev_char = prev_char - buffer->input_buffer; + start = utf8_add_offset (window->buffer->input_buffer, + window->buffer->input_buffer_pos); + pos_start = start - window->buffer->input_buffer; + prev_char = utf8_prev_char (window->buffer->input_buffer, start); + pos_prev_char = prev_char - window->buffer->input_buffer; size_prev_char = start - prev_char; size_start_char = utf8_char_size (start); @@ -734,11 +738,11 @@ gui_input_transpose_chars (struct t_gui_buffer *buffer) memcpy (prev_char, start, size_start_char); memcpy (prev_char + size_start_char, saved_char, size_prev_char); - buffer->input_buffer_pos++; + window->buffer->input_buffer_pos++; - gui_completion_stop (buffer->completion, 1); + gui_completion_stop (window->buffer->completion, 1); - gui_input_text_changed_modifier_and_signal (buffer, 1); + gui_input_text_changed_modifier_and_signal (window->buffer, 1); } } @@ -747,14 +751,13 @@ gui_input_transpose_chars (struct t_gui_buffer *buffer) */ void -gui_input_move_beginning_of_line (struct t_gui_buffer *buffer) +gui_input_move_beginning_of_line (struct t_gui_window *window) { - if (buffer->input) + if (window->buffer->input) { - if (buffer->input_buffer_pos > 0) + if (window->buffer->input_buffer_pos > 0) { - buffer->input_buffer_pos = 0; - + window->buffer->input_buffer_pos = 0; gui_input_text_cursor_moved_signal (); } } @@ -765,14 +768,13 @@ gui_input_move_beginning_of_line (struct t_gui_buffer *buffer) */ void -gui_input_move_end_of_line (struct t_gui_buffer *buffer) +gui_input_move_end_of_line (struct t_gui_window *window) { - if (buffer->input) + if (window->buffer->input) { - if (buffer->input_buffer_pos < buffer->input_buffer_length) + if (window->buffer->input_buffer_pos < window->buffer->input_buffer_length) { - buffer->input_buffer_pos = buffer->input_buffer_length; - + window->buffer->input_buffer_pos = window->buffer->input_buffer_length; gui_input_text_cursor_moved_signal (); } } @@ -783,14 +785,13 @@ gui_input_move_end_of_line (struct t_gui_buffer *buffer) */ void -gui_input_move_previous_char (struct t_gui_buffer *buffer) +gui_input_move_previous_char (struct t_gui_window *window) { - if (buffer->input) + if (window->buffer->input) { - if (buffer->input_buffer_pos > 0) + if (window->buffer->input_buffer_pos > 0) { - buffer->input_buffer_pos--; - + window->buffer->input_buffer_pos--; gui_input_text_cursor_moved_signal (); } } @@ -801,14 +802,13 @@ gui_input_move_previous_char (struct t_gui_buffer *buffer) */ void -gui_input_move_next_char (struct t_gui_buffer *buffer) +gui_input_move_next_char (struct t_gui_window *window) { - if (buffer->input) + if (window->buffer->input) { - if (buffer->input_buffer_pos < buffer->input_buffer_length) + if (window->buffer->input_buffer_pos < window->buffer->input_buffer_length) { - buffer->input_buffer_pos++; - + window->buffer->input_buffer_pos++; gui_input_text_cursor_moved_signal (); } } @@ -820,35 +820,35 @@ gui_input_move_next_char (struct t_gui_buffer *buffer) */ void -gui_input_move_previous_word (struct t_gui_buffer *buffer) +gui_input_move_previous_word (struct t_gui_window *window) { char *pos; - if (buffer->input) + if (window->buffer->input) { - if (buffer->input_buffer_pos > 0) + if (window->buffer->input_buffer_pos > 0) { - pos = utf8_add_offset (buffer->input_buffer, - buffer->input_buffer_pos - 1); + pos = utf8_add_offset (window->buffer->input_buffer, + window->buffer->input_buffer_pos - 1); while (pos && (pos[0] == ' ')) { - pos = utf8_prev_char (buffer->input_buffer, pos); + pos = utf8_prev_char (window->buffer->input_buffer, pos); } if (pos) { while (pos && (pos[0] != ' ')) { - pos = utf8_prev_char (buffer->input_buffer, pos); + pos = utf8_prev_char (window->buffer->input_buffer, pos); } if (pos) pos = utf8_next_char (pos); else - pos = buffer->input_buffer; - buffer->input_buffer_pos = utf8_pos (buffer->input_buffer, - pos - buffer->input_buffer); + pos = window->buffer->input_buffer; + window->buffer->input_buffer_pos = utf8_pos (window->buffer->input_buffer, + pos - window->buffer->input_buffer); } else - buffer->input_buffer_pos = 0; + window->buffer->input_buffer_pos = 0; gui_input_text_cursor_moved_signal (); } @@ -861,16 +861,16 @@ gui_input_move_previous_word (struct t_gui_buffer *buffer) */ void -gui_input_move_next_word (struct t_gui_buffer *buffer) +gui_input_move_next_word (struct t_gui_window *window) { char *pos; - if (buffer->input) + if (window->buffer->input) { - if (buffer->input_buffer_pos < buffer->input_buffer_length) + if (window->buffer->input_buffer_pos < window->buffer->input_buffer_length) { - pos = utf8_add_offset (buffer->input_buffer, - buffer->input_buffer_pos); + pos = utf8_add_offset (window->buffer->input_buffer, + window->buffer->input_buffer_pos); while (pos[0] && (pos[0] == ' ')) { pos = utf8_next_char (pos); @@ -882,16 +882,20 @@ gui_input_move_next_word (struct t_gui_buffer *buffer) pos = utf8_next_char (pos); } if (pos[0]) - buffer->input_buffer_pos = - utf8_pos (buffer->input_buffer, - pos - buffer->input_buffer); + { + window->buffer->input_buffer_pos = + utf8_pos (window->buffer->input_buffer, + pos - window->buffer->input_buffer); + } else - buffer->input_buffer_pos = buffer->input_buffer_length; + window->buffer->input_buffer_pos = window->buffer->input_buffer_length; } else - buffer->input_buffer_pos = - utf8_pos (buffer->input_buffer, - utf8_prev_char (buffer->input_buffer, pos) - buffer->input_buffer); + { + window->buffer->input_buffer_pos = + utf8_pos (window->buffer->input_buffer, + utf8_prev_char (window->buffer->input_buffer, pos) - window->buffer->input_buffer); + } gui_input_text_cursor_moved_signal (); } @@ -1218,9 +1222,9 @@ gui_input_hotlist_clear (struct t_gui_window *window) */ void -gui_input_grab_key (struct t_gui_buffer *buffer) +gui_input_grab_key (struct t_gui_window *window) { - if (buffer->input) + if (window->buffer->input) gui_keyboard_grab_init (0); } @@ -1230,9 +1234,9 @@ gui_input_grab_key (struct t_gui_buffer *buffer) */ void -gui_input_grab_key_command (struct t_gui_buffer *buffer) +gui_input_grab_key_command (struct t_gui_window *window) { - if (buffer->input) + if (window->buffer->input) gui_keyboard_grab_init (1); } @@ -1293,9 +1297,9 @@ gui_input_set_unread () */ void -gui_input_set_unread_buffer (struct t_gui_buffer *buffer) +gui_input_set_unread_current (struct t_gui_window *window) { - gui_buffer_set_unread (buffer); + gui_buffer_set_unread (window->buffer); } /* @@ -1341,16 +1345,16 @@ gui_input_switch_active_buffer_previous (struct t_gui_window *window) */ void -gui_input_insert (struct t_gui_buffer *buffer, const char *args) +gui_input_insert (struct t_gui_window *window, const char *args) { char *args2; if (args) { - gui_buffer_undo_snap (buffer); + gui_buffer_undo_snap (window->buffer); args2 = string_convert_hex_chars (args); - gui_input_insert_string (buffer, (args2) ? args2 : args, -1); - gui_input_text_changed_modifier_and_signal (buffer, 1); + gui_input_insert_string (window->buffer, (args2) ? args2 : args, -1); + gui_input_text_changed_modifier_and_signal (window->buffer, 1); if (args2) free (args2); } @@ -1376,27 +1380,28 @@ gui_input_undo_use (struct t_gui_buffer *buffer, struct t_gui_input_undo *undo) */ void -gui_input_undo (struct t_gui_buffer *buffer) +gui_input_undo (struct t_gui_window *window) { - if (buffer->ptr_input_undo) + if (window->buffer->ptr_input_undo) { /* * if we are doing undo and that undo pointer is to the end of list * (for example first time undo is used), then save current input * content in undo list */ - if ((buffer->ptr_input_undo == buffer->last_input_undo) - && (buffer->ptr_input_undo)->data - && (strcmp (buffer->input_buffer, (buffer->ptr_input_undo)->data) != 0)) + if ((window->buffer->ptr_input_undo == window->buffer->last_input_undo) + && (window->buffer->ptr_input_undo)->data + && (strcmp (window->buffer->input_buffer, (window->buffer->ptr_input_undo)->data) != 0)) { - gui_buffer_undo_snap_free (buffer); - gui_buffer_undo_add (buffer); + gui_buffer_undo_snap_free (window->buffer); + gui_buffer_undo_add (window->buffer); } - if (buffer->ptr_input_undo && (buffer->ptr_input_undo)->prev_undo) + if (window->buffer->ptr_input_undo + && (window->buffer->ptr_input_undo)->prev_undo) { - buffer->ptr_input_undo = (buffer->ptr_input_undo)->prev_undo; - gui_input_undo_use (buffer, buffer->ptr_input_undo); + window->buffer->ptr_input_undo = (window->buffer->ptr_input_undo)->prev_undo; + gui_input_undo_use (window->buffer, window->buffer->ptr_input_undo); } } } @@ -1406,11 +1411,12 @@ gui_input_undo (struct t_gui_buffer *buffer) */ void -gui_input_redo (struct t_gui_buffer *buffer) +gui_input_redo (struct t_gui_window *window) { - if (buffer->ptr_input_undo && (buffer->ptr_input_undo)->next_undo) + if (window->buffer->ptr_input_undo + && (window->buffer->ptr_input_undo)->next_undo) { - buffer->ptr_input_undo = (buffer->ptr_input_undo)->next_undo; - gui_input_undo_use (buffer, buffer->ptr_input_undo); + window->buffer->ptr_input_undo = (window->buffer->ptr_input_undo)->next_undo; + gui_input_undo_use (window->buffer, window->buffer->ptr_input_undo); } } diff --git a/src/gui/gui-input.h b/src/gui/gui-input.h index cd0ac33eb..c5421b8e7 100644 --- a/src/gui/gui-input.h +++ b/src/gui/gui-input.h @@ -39,25 +39,25 @@ extern void gui_input_move (struct t_gui_buffer *buffer, char *target, extern void gui_input_set_pos (struct t_gui_buffer *buffer, int pos); extern int gui_input_insert_string (struct t_gui_buffer *buffer, const char *string, int pos); -extern void gui_input_clipboard_paste (struct t_gui_buffer *buffer); +extern void gui_input_clipboard_paste (struct t_gui_window *window); extern void gui_input_return (struct t_gui_window *window); -extern void gui_input_complete_next (struct t_gui_buffer *buffer); -extern void gui_input_complete_previous (struct t_gui_buffer *buffer); +extern void gui_input_complete_next (struct t_gui_window *window); +extern void gui_input_complete_previous (struct t_gui_window *window); extern void gui_input_search_text (struct t_gui_window *window); -extern void gui_input_delete_previous_char (struct t_gui_buffer *buffer); -extern void gui_input_delete_next_char (struct t_gui_buffer *buffer); -extern void gui_input_delete_previous_word (struct t_gui_buffer *buffer); -extern void gui_input_delete_next_word (struct t_gui_buffer *buffer); -extern void gui_input_delete_beginning_of_line (struct t_gui_buffer *buffer); -extern void gui_input_delete_end_of_line (struct t_gui_buffer *buffer); -extern void gui_input_delete_line (struct t_gui_buffer *buffer); -extern void gui_input_transpose_chars (struct t_gui_buffer *buffer); -extern void gui_input_move_beginning_of_line (struct t_gui_buffer *buffer); -extern void gui_input_move_end_of_line (struct t_gui_buffer *buffer); -extern void gui_input_move_previous_char (struct t_gui_buffer *buffer); -extern void gui_input_move_next_char (struct t_gui_buffer *buffer); -extern void gui_input_move_previous_word (struct t_gui_buffer *buffer); -extern void gui_input_move_next_word (struct t_gui_buffer *buffer); +extern void gui_input_delete_previous_char (struct t_gui_window *window); +extern void gui_input_delete_next_char (struct t_gui_window *window); +extern void gui_input_delete_previous_word (struct t_gui_window *window); +extern void gui_input_delete_next_word (struct t_gui_window *window); +extern void gui_input_delete_beginning_of_line (struct t_gui_window *window); +extern void gui_input_delete_end_of_line (struct t_gui_window *window); +extern void gui_input_delete_line (struct t_gui_window *window); +extern void gui_input_transpose_chars (struct t_gui_window *window); +extern void gui_input_move_beginning_of_line (struct t_gui_window *window); +extern void gui_input_move_end_of_line (struct t_gui_window *window); +extern void gui_input_move_previous_char (struct t_gui_window *window); +extern void gui_input_move_next_char (struct t_gui_window *window); +extern void gui_input_move_previous_word (struct t_gui_window *window); +extern void gui_input_move_next_word (struct t_gui_window *window); extern void gui_input_history_local_previous (struct t_gui_window *window); extern void gui_input_history_local_next (struct t_gui_window *window); extern void gui_input_history_global_previous (struct t_gui_window *window); @@ -67,15 +67,15 @@ extern void gui_input_jump_last_buffer (struct t_gui_window *window); extern void gui_input_jump_previously_visited_buffer (struct t_gui_window *window); extern void gui_input_jump_next_visited_buffer (struct t_gui_window *window); extern void gui_input_hotlist_clear (struct t_gui_window *window); -extern void gui_input_grab_key (struct t_gui_buffer *buffer); -extern void gui_input_grab_key_command (struct t_gui_buffer *buffer); +extern void gui_input_grab_key (struct t_gui_window *window); +extern void gui_input_grab_key_command (struct t_gui_window *window); extern void gui_input_scroll_unread (struct t_gui_window *window); extern void gui_input_set_unread (); -extern void gui_input_set_unread_buffer (struct t_gui_buffer *buffer); +extern void gui_input_set_unread_current (struct t_gui_window *window); extern void gui_input_switch_active_buffer (struct t_gui_window *window); extern void gui_input_switch_active_buffer_previous (struct t_gui_window *window); -extern void gui_input_insert (struct t_gui_buffer *buffer, const char *args); -extern void gui_input_undo (struct t_gui_buffer *buffer); -extern void gui_input_redo (struct t_gui_buffer *buffer); +extern void gui_input_insert (struct t_gui_window *window, const char *args); +extern void gui_input_undo (struct t_gui_window *window); +extern void gui_input_redo (struct t_gui_window *window); #endif /* __WEECHAT_GUI_INPUT_H */ diff --git a/src/gui/gui-window.c b/src/gui/gui-window.c index ced9a0d30..72d1ecc0d 100644 --- a/src/gui/gui-window.c +++ b/src/gui/gui-window.c @@ -879,7 +879,7 @@ gui_window_search_start (struct t_gui_window *window) if (window->buffer->input_buffer && window->buffer->input_buffer[0]) window->buffer->text_search_input = strdup (window->buffer->input_buffer); - gui_input_delete_line (window->buffer); + gui_input_delete_line (window); } /* @@ -916,7 +916,7 @@ gui_window_search_stop (struct t_gui_window *window) { window->buffer->text_search = GUI_TEXT_SEARCH_DISABLED; window->buffer->text_search = 0; - gui_input_delete_line (window->buffer); + gui_input_delete_line (window); if (window->buffer->text_search_input) { gui_input_insert_string (window->buffer, |