mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 09:12:24 +00:00
Richard Boulton's patch for improved correctness in selection
handling (generally, selection request timestamps should be set to the timestamp on the event that caused them). [originally from svn r3408]
This commit is contained in:
parent
92db92af5a
commit
11c9c018ec
28
unix/pterm.c
28
unix/pterm.c
@ -81,6 +81,7 @@ struct gui_data {
|
|||||||
void *eventlogstuff;
|
void *eventlogstuff;
|
||||||
char *progname, **gtkargvstart;
|
char *progname, **gtkargvstart;
|
||||||
int ngtkargs;
|
int ngtkargs;
|
||||||
|
guint32 input_event_time; /* Timestamp of the most recent input event. */
|
||||||
};
|
};
|
||||||
|
|
||||||
struct draw_ctx {
|
struct draw_ctx {
|
||||||
@ -447,6 +448,9 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
wchar_t ucsoutput[2];
|
wchar_t ucsoutput[2];
|
||||||
int ucsval, start, end, special, use_ucsoutput;
|
int ucsval, start, end, special, use_ucsoutput;
|
||||||
|
|
||||||
|
/* Remember the timestamp. */
|
||||||
|
inst->input_event_time = event->time;
|
||||||
|
|
||||||
/* By default, nothing is generated. */
|
/* By default, nothing is generated. */
|
||||||
end = start = 0;
|
end = start = 0;
|
||||||
special = use_ucsoutput = FALSE;
|
special = use_ucsoutput = FALSE;
|
||||||
@ -1021,6 +1025,9 @@ gint button_event(GtkWidget *widget, GdkEventButton *event, gpointer data)
|
|||||||
struct gui_data *inst = (struct gui_data *)data;
|
struct gui_data *inst = (struct gui_data *)data;
|
||||||
int shift, ctrl, alt, x, y, button, act;
|
int shift, ctrl, alt, x, y, button, act;
|
||||||
|
|
||||||
|
/* Remember the timestamp. */
|
||||||
|
inst->input_event_time = event->time;
|
||||||
|
|
||||||
show_mouseptr(inst, 1);
|
show_mouseptr(inst, 1);
|
||||||
|
|
||||||
if (event->button == 4 && event->type == GDK_BUTTON_PRESS) {
|
if (event->button == 4 && event->type == GDK_BUTTON_PRESS) {
|
||||||
@ -1077,6 +1084,9 @@ gint motion_event(GtkWidget *widget, GdkEventMotion *event, gpointer data)
|
|||||||
struct gui_data *inst = (struct gui_data *)data;
|
struct gui_data *inst = (struct gui_data *)data;
|
||||||
int shift, ctrl, alt, x, y, button;
|
int shift, ctrl, alt, x, y, button;
|
||||||
|
|
||||||
|
/* Remember the timestamp. */
|
||||||
|
inst->input_event_time = event->time;
|
||||||
|
|
||||||
show_mouseptr(inst, 1);
|
show_mouseptr(inst, 1);
|
||||||
|
|
||||||
shift = event->state & GDK_SHIFT_MASK;
|
shift = event->state & GDK_SHIFT_MASK;
|
||||||
@ -1391,7 +1401,7 @@ void write_clip(void *frontend, wchar_t * data, int len, int must_deselect)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (gtk_selection_owner_set(inst->area, GDK_SELECTION_PRIMARY,
|
if (gtk_selection_owner_set(inst->area, GDK_SELECTION_PRIMARY,
|
||||||
GDK_CURRENT_TIME)) {
|
inst->input_event_time)) {
|
||||||
gtk_selection_add_target(inst->area, GDK_SELECTION_PRIMARY,
|
gtk_selection_add_target(inst->area, GDK_SELECTION_PRIMARY,
|
||||||
GDK_SELECTION_TYPE_STRING, 1);
|
GDK_SELECTION_TYPE_STRING, 1);
|
||||||
if (inst->pasteout_data_ctext)
|
if (inst->pasteout_data_ctext)
|
||||||
@ -1427,6 +1437,7 @@ gint selection_clear(GtkWidget *widget, GdkEventSelection *seldata,
|
|||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
struct gui_data *inst = (struct gui_data *)data;
|
struct gui_data *inst = (struct gui_data *)data;
|
||||||
|
|
||||||
term_deselect(inst->term);
|
term_deselect(inst->term);
|
||||||
if (inst->pasteout_data)
|
if (inst->pasteout_data)
|
||||||
sfree(inst->pasteout_data);
|
sfree(inst->pasteout_data);
|
||||||
@ -1461,14 +1472,16 @@ void request_paste(void *frontend)
|
|||||||
* fall back to an ordinary string.
|
* fall back to an ordinary string.
|
||||||
*/
|
*/
|
||||||
gtk_selection_convert(inst->area, GDK_SELECTION_PRIMARY,
|
gtk_selection_convert(inst->area, GDK_SELECTION_PRIMARY,
|
||||||
utf8_string_atom, GDK_CURRENT_TIME);
|
utf8_string_atom,
|
||||||
|
inst->input_event_time);
|
||||||
} else {
|
} else {
|
||||||
/*
|
/*
|
||||||
* If we're in direct-to-font mode, we disable UTF-8
|
* If we're in direct-to-font mode, we disable UTF-8
|
||||||
* pasting, and go straight to ordinary string data.
|
* pasting, and go straight to ordinary string data.
|
||||||
*/
|
*/
|
||||||
gtk_selection_convert(inst->area, GDK_SELECTION_PRIMARY,
|
gtk_selection_convert(inst->area, GDK_SELECTION_PRIMARY,
|
||||||
GDK_SELECTION_TYPE_STRING, GDK_CURRENT_TIME);
|
GDK_SELECTION_TYPE_STRING,
|
||||||
|
inst->input_event_time);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1491,7 +1504,8 @@ void selection_received(GtkWidget *widget, GtkSelectionData *seldata,
|
|||||||
* text next.
|
* text next.
|
||||||
*/
|
*/
|
||||||
gtk_selection_convert(inst->area, GDK_SELECTION_PRIMARY,
|
gtk_selection_convert(inst->area, GDK_SELECTION_PRIMARY,
|
||||||
compound_text_atom, GDK_CURRENT_TIME);
|
compound_text_atom,
|
||||||
|
inst->input_event_time);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1501,7 +1515,8 @@ void selection_received(GtkWidget *widget, GtkSelectionData *seldata,
|
|||||||
* string.
|
* string.
|
||||||
*/
|
*/
|
||||||
gtk_selection_convert(inst->area, GDK_SELECTION_PRIMARY,
|
gtk_selection_convert(inst->area, GDK_SELECTION_PRIMARY,
|
||||||
GDK_SELECTION_TYPE_STRING, GDK_CURRENT_TIME);
|
GDK_SELECTION_TYPE_STRING,
|
||||||
|
inst->input_event_time);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1529,7 +1544,8 @@ void selection_received(GtkWidget *widget, GtkSelectionData *seldata,
|
|||||||
* Compound text failed; fall back to STRING.
|
* Compound text failed; fall back to STRING.
|
||||||
*/
|
*/
|
||||||
gtk_selection_convert(inst->area, GDK_SELECTION_PRIMARY,
|
gtk_selection_convert(inst->area, GDK_SELECTION_PRIMARY,
|
||||||
GDK_SELECTION_TYPE_STRING, GDK_CURRENT_TIME);
|
GDK_SELECTION_TYPE_STRING,
|
||||||
|
inst->input_event_time);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
text = list[0];
|
text = list[0];
|
||||||
|
Loading…
Reference in New Issue
Block a user