summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTimo Sirainen <cras@irssi.org>2003-11-21 18:15:11 +0000
committercras <cras@dbcabf3a-b0e7-0310-adc4-f8d773084564>2003-11-21 18:15:11 +0000
commit776529044793cdbe9a307a16e97e0c27dc92eebb (patch)
treeccc028176fcf1d093f360fdf3d88768bd6328005
parentdbc8fd9a1a43cc5beba54471232ba49af300a740 (diff)
downloadirssi-776529044793cdbe9a307a16e97e0c27dc92eebb.zip
pasting fixes. changed key to ^K from ^O since ^O is working strangely in
some systems.. git-svn-id: http://svn.irssi.org/repos/irssi/trunk@3180 dbcabf3a-b0e7-0310-adc4-f8d773084564
-rw-r--r--src/fe-text/gui-readline.c115
-rw-r--r--src/fe-text/module-formats.c4
2 files changed, 43 insertions, 76 deletions
diff --git a/src/fe-text/gui-readline.c b/src/fe-text/gui-readline.c
index 65e9be44..3d87640e 100644
--- a/src/fe-text/gui-readline.c
+++ b/src/fe-text/gui-readline.c
@@ -154,34 +154,31 @@ static void paste_send(void)
const char *signal_name;
char out[10], *text;
unsigned int i;
- int lf;
arr = (unichar *) paste_buffer->data;
- lf = FALSE;
+ signal_name = active_win->active == NULL ?
+ "send command" : "send text";
- /* 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;
- }
+ if (active_entry->text_len == 0)
+ i = 0;
+ else {
+ /* 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++;
+ break;
+ }
- gui_entry_insert_char(active_entry, arr[i]);
- }
+ gui_entry_insert_char(active_entry, arr[i]);
+ }
- if (!lf) {
- /* not a multiline paste */
- return;
+ text = gui_entry_get_text(active_entry);
+ signal_emit(signal_name, 3, text,
+ active_win->active_server, active_win->active);
+ g_free(text);
}
- signal_name = active_win->active == NULL ? "send command" : "send text";
-
- text = gui_entry_get_text(active_entry);
- signal_emit(signal_name, 3, text,
- active_win->active_server, active_win->active);
- g_free(text);
-
/* rest of the lines */
str = g_string_new(NULL);
for (; i < paste_buffer->len; i++) {
@@ -190,9 +187,11 @@ static void paste_send(void)
active_win->active_server,
active_win->active);
g_string_truncate(str, 0);
- } else {
+ } else if (active_entry->utf8) {
out[utf16_char_to_utf8(arr[i], out)] = '\0';
g_string_append(str, out);
+ } else {
+ g_string_append_c(str, arr[i]);
}
}
@@ -202,13 +201,11 @@ static void paste_send(void)
static void paste_flush(int send)
{
+ gui_entry_set_text(active_entry, paste_entry);
+ gui_entry_set_pos(active_entry, paste_entry_pos);
+
if (send)
paste_send();
- else {
- /* revert back to pre-paste state */
- gui_entry_set_text(active_entry, paste_entry);
- gui_entry_set_pos(active_entry, paste_entry_pos);
- }
g_array_set_size(paste_buffer, 0);
gui_entry_set_prompt(active_entry,
@@ -264,13 +261,8 @@ static gboolean paste_timeout(gpointer data)
return TRUE;
}
-#define IS_PASTE_SKIP_KEY(c) \
- ((c) == '\r' || (c) == '\n')
-
static int check_pasting(unichar key, int diff)
{
- unsigned int i;
-
if (paste_state < 0)
return FALSE;
@@ -286,67 +278,42 @@ static int check_pasting(unichar key, int diff)
paste_state++;
paste_line_count = 0;
g_array_set_size(paste_buffer, 0);
- if (!IS_PASTE_SKIP_KEY(prev_key))
+ if (prev_key != '\r' && prev_key != '\n')
g_array_append_val(paste_buffer, prev_key);
} 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;
}
/* continuing quick hits */
- if (paste_state == paste_detect_keycount) {
- /* pasting.. */
- if ((key == 15 || key == 3) && paste_prompt) {
- paste_flush(key == 15);
- return TRUE;
- }
-
- if (IS_PASTE_SKIP_KEY(key)) {
- if (paste_verify_line_count <= 0) {
- /* handle CR/LF the normal way */
- return FALSE;
- }
-
- paste_line_count++;
- }
- if (paste_verify_line_count > 0)
- g_array_append_val(paste_buffer, key);
- else
- gui_entry_insert_char(active_entry, key);
+ if ((key == 11 || key == 3) && paste_prompt) {
+ paste_flush(key == 11);
return TRUE;
}
- if (IS_PASTE_SKIP_KEY(key)) {
- /* we might be pasting, but we can't go back from executed
- commands.. */
- paste_state++;
- g_array_set_size(paste_buffer, 0);
- return FALSE;
- }
-
- paste_state++;
g_array_append_val(paste_buffer, key);
- if (paste_state == paste_detect_keycount) {
- /* ok, we started pasting. */
- gui_entry_set_text(active_entry, paste_entry);
- gui_entry_set_pos(active_entry, paste_entry_pos);
+ if (key == '\r' || key == '\n') {
+ /* newline - assume this line was pasted */
+ if (paste_state == 1) {
+ paste_state = 2;
+ gui_entry_set_text(active_entry, paste_entry);
+ gui_entry_set_pos(active_entry, paste_entry_pos);
+ if (paste_verify_line_count > 0)
+ g_timeout_add(100, paste_timeout, NULL);
+ }
+
if (paste_verify_line_count <= 0) {
- for (i = 0; i < paste_buffer->len; i++) {
- gui_entry_insert_char(active_entry,
- g_array_index(paste_buffer, unichar, i));
- }
+ /* paste previous line */
+ paste_send();
g_array_set_size(paste_buffer, 0);
} else {
- g_timeout_add(100, paste_timeout, NULL);
+ paste_line_count++;
}
- return TRUE;
}
- return FALSE;
+ return paste_state == 2;
}
static void sig_gui_key_pressed(gpointer keyp)
diff --git a/src/fe-text/module-formats.c b/src/fe-text/module-formats.c
index 39bb984b..f627a2d9 100644
--- a/src/fe-text/module-formats.c
+++ b/src/fe-text/module-formats.c
@@ -74,8 +74,8 @@ FORMAT_REC gui_text_formats[] =
/* ---- */
{ NULL, "Pasting", 0 },
- { "paste_warning", "Pasting $0 lines to $1. Press Ctrl-O if you wish to do this or Ctrl-C to cancel.", 2, { 1, 0 } },
- { "paste_prompt", "Hit Ctrl-O to paste, Ctrl-C to abort?", 0 },
+ { "paste_warning", "Pasting $0 lines to $1. Press Ctrl-K if you wish to do this or Ctrl-C to cancel.", 2, { 1, 0 } },
+ { "paste_prompt", "Hit Ctrl-K to paste, Ctrl-C to abort?", 0 },
{ NULL, NULL, 0 }
};