diff options
author | Timo Sirainen <cras@irssi.org> | 2003-11-16 22:56:26 +0000 |
---|---|---|
committer | cras <cras@dbcabf3a-b0e7-0310-adc4-f8d773084564> | 2003-11-16 22:56:26 +0000 |
commit | 130030c5060ea2f3899242379824759037625986 (patch) | |
tree | b5deb8a0027d1f97dbe8c9593908175878b5b6e0 /src/fe-text/gui-readline.c | |
parent | 093f2c44de104cc54a9f5dba5c0bc830cc2014f4 (diff) | |
download | irssi-130030c5060ea2f3899242379824759037625986.zip |
pasting fixes
git-svn-id: http://svn.irssi.org/repos/irssi/trunk@3158 dbcabf3a-b0e7-0310-adc4-f8d773084564
Diffstat (limited to 'src/fe-text/gui-readline.c')
-rw-r--r-- | src/fe-text/gui-readline.c | 44 |
1 files changed, 33 insertions, 11 deletions
diff --git a/src/fe-text/gui-readline.c b/src/fe-text/gui-readline.c index e969e164..316d76a8 100644 --- a/src/fe-text/gui-readline.c +++ b/src/fe-text/gui-readline.c @@ -148,17 +148,39 @@ static void window_next_page(void) gui_window_scroll(active_win, get_scroll_count()); } -static void paste_send(const char *utf8_start, GArray *buf) +static void paste_send(void) { unichar *arr; GString *str; char out[10]; unsigned int i; + int lf; - str = g_string_new(utf8_start); + arr = (unichar *) paste_buffer->data; + lf = FALSE; - arr = (unichar *) buf->data; - for (i = 0; i < buf->len; i++) { + /* first line has to be kludged kind of to get pasting in the + middle of line right.. */ + for (i = 0; i < paste_buffer->len; i++) { + if (arr[i] == '\r' || arr[i] == '\n') { + i++; lf = TRUE; + break; + } + + gui_entry_insert_char(active_entry, arr[i]); + } + + if (!lf) { + /* not a multiline paste */ + return; + } + + signal_emit("send text", 3, gui_entry_get_text(active_entry), + active_win->active_server, active_win->active); + + /* rest of the lines */ + str = g_string_new(NULL); + for (; i < paste_buffer->len; i++) { if (arr[i] == '\r' || arr[i] == '\n') { signal_emit("send text", 3, str->str, active_win->active_server, @@ -177,7 +199,7 @@ static void paste_send(const char *utf8_start, GArray *buf) static void paste_flush(int send) { if (send) - paste_send(paste_entry, paste_buffer); + paste_send(); else { /* revert back to pre-paste state */ gui_entry_set_text(active_entry, paste_entry); @@ -201,7 +223,7 @@ static gboolean paste_timeout(gpointer data) GTimeVal now; int diff; - if (paste_line_count == 0) { + if (paste_state == 0) { /* gone already */ return FALSE; } @@ -256,6 +278,8 @@ static int check_pasting(unichar key, int diff) } else if (paste_state > 0 && diff > paste_detect_time && paste_line_count == 0) { /* reset paste state */ + if (paste_state == paste_detect_keycount) + paste_flush(TRUE); paste_state = 0; return FALSE; } @@ -274,11 +298,7 @@ static int check_pasting(unichar key, int diff) return FALSE; } - if (paste_line_count++ == 0) { - /* end of first line - see how many lines - we'll get */ - g_timeout_add(200, paste_timeout, NULL); - } + paste_line_count++; } if (paste_verify_line_count > 0) g_array_append_val(paste_buffer, key); @@ -307,6 +327,8 @@ static int check_pasting(unichar key, int diff) g_array_index(paste_buffer, unichar, i)); } g_array_set_size(paste_buffer, 0); + } else { + g_timeout_add(100, paste_timeout, NULL); } return TRUE; } |