diff options
author | Richard Hult <richard@imendio.com> | 2008-06-26 13:01:40 +0000 |
---|---|---|
committer | Richard Hult <rhult@src.gnome.org> | 2008-06-26 13:01:40 +0000 |
commit | 2f29e8d9f5c00ec14aa27f4f81b1bf092bcf6b45 (patch) | |
tree | a76cee2580de4536249d9d46e9f77d40c06197b4 /gtk/gtkquartz.c | |
parent | 2e6f82b987aad795e376c635618e67eb3b49f345 (diff) | |
download | gtk+-2f29e8d9f5c00ec14aa27f4f81b1bf092bcf6b45.tar.gz |
Patch from Christian Dywan to clean up selection data setting.
2008-06-26 Richard Hult <richard@imendio.com>
* gtk/gtkclipboard-quartz.c: (gtk_clipboard_wait_for_contents):
* gtk/gtkquartz.c:
(_gtk_quartz_get_selection_data_from_pasteboard),
(_gtk_quartz_set_selection_data_for_pasteboard): Patch from
Christian Dywan to clean up selection data setting.
svn path=/trunk/; revision=20690
Diffstat (limited to 'gtk/gtkquartz.c')
-rw-r--r-- | gtk/gtkquartz.c | 47 |
1 files changed, 26 insertions, 21 deletions
diff --git a/gtk/gtkquartz.c b/gtk/gtkquartz.c index 9a6be3889c..bcecad4e36 100644 --- a/gtk/gtkquartz.c +++ b/gtk/gtkquartz.c @@ -168,10 +168,9 @@ _gtk_quartz_get_selection_data_from_pasteboard (NSPasteboard *pasteboard, { const char *utf8_string = [s UTF8String]; - selection_data->type = target; - selection_data->format = 8; - selection_data->length = strlen (utf8_string); - selection_data->data = (guchar*) g_strdup (utf8_string); + gtk_selection_data_set (selection_data, + target, 8, + (guchar *)utf8_string, strlen (utf8_string)); } } else if (target == gdk_atom_intern_static_string ("application/x-color")) @@ -243,12 +242,9 @@ _gtk_quartz_get_selection_data_from_pasteboard (NSPasteboard *pasteboard, if (data) { - selection_data->type = target; - selection_data->format = 8; - selection_data->length = [data length]; - selection_data->data = g_malloc (selection_data->length + 1); - selection_data->data[selection_data->length] = '\0'; - memcpy(selection_data->data, [data bytes], selection_data->length); + gtk_selection_data_set (selection_data, + target, 8, + [data bytes], [data length]); } } @@ -256,21 +252,30 @@ _gtk_quartz_get_selection_data_from_pasteboard (NSPasteboard *pasteboard, } void -_gtk_quartz_set_selection_data_for_pasteboard (NSPasteboard *pasteboard, +_gtk_quartz_set_selection_data_for_pasteboard (NSPasteboard *pasteboard, GtkSelectionData *selection_data) { NSString *type; - gchar *target = gdk_atom_name (selection_data->target); + gchar *target; + GdkDisplay *display; + gint format; + const guchar *data; + guint length; + + target = gdk_atom_name (gtk_selection_data_get_target (selection_data)); + display = gtk_selection_data_get_display (selection_data); + format = gtk_selection_data_get_format (selection_data); + data = gtk_selection_data_get_data (selection_data, &length); type = target_to_pasteboard_type (target); g_free (target); if ([type isEqualTo:NSStringPboardType]) - [pasteboard setString:[NSString stringWithUTF8String:(const char *)selection_data->data] + [pasteboard setString:[NSString stringWithUTF8String:(const char *)data] forType:type]; else if ([type isEqualTo:NSColorPboardType]) { - guint16 *color = (guint16 *)selection_data->data; + guint16 *color = (guint16 *)data; float red, green, blue, alpha; NSColor *nscolor; @@ -278,7 +283,7 @@ _gtk_quartz_set_selection_data_for_pasteboard (NSPasteboard *pasteboard, green = (float)color[1] / 0xffff; blue = (float)color[2] / 0xffff; alpha = (float)color[3] / 0xffff; - + nscolor = [NSColor colorWithDeviceRed:red green:green blue:blue alpha:alpha]; [nscolor writeToPasteboard:pasteboard]; } @@ -287,11 +292,11 @@ _gtk_quartz_set_selection_data_for_pasteboard (NSPasteboard *pasteboard, gchar **list = NULL; int count; - count = gdk_text_property_to_utf8_list_for_display (selection_data->display, + count = gdk_text_property_to_utf8_list_for_display (display, gdk_atom_intern_static_string ("UTF8_STRING"), - selection_data->format, - selection_data->data, - selection_data->length, + format, + data, + length, &list); if (count > 0) @@ -310,8 +315,8 @@ _gtk_quartz_set_selection_data_for_pasteboard (NSPasteboard *pasteboard, g_strfreev (list); } else - [pasteboard setData:[NSData dataWithBytesNoCopy:selection_data->data - length:selection_data->length + [pasteboard setData:[NSData dataWithBytesNoCopy:data + length:length freeWhenDone:NO] forType:type]; } |