|  |  |  | GTK+ Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | ||||
#include <gtk/gtk.h>
                    GtkTargetEntry;
                    GtkTargetList;
                    GtkTargetPair;
GtkTargetList *     gtk_target_list_new                 (const GtkTargetEntry *targets,
                                                         guint ntargets);
GtkTargetList *     gtk_target_list_ref                 (GtkTargetList *list);
void                gtk_target_list_unref               (GtkTargetList *list);
void                gtk_target_list_add                 (GtkTargetList *list,
                                                         GdkAtom target,
                                                         guint flags,
                                                         guint info);
void                gtk_target_list_add_table           (GtkTargetList *list,
                                                         const GtkTargetEntry *targets,
                                                         guint ntargets);
void                gtk_target_list_add_text_targets    (GtkTargetList *list,
                                                         guint info);
void                gtk_target_list_add_image_targets   (GtkTargetList *list,
                                                         guint info,
                                                         gboolean writable);
void                gtk_target_list_add_uri_targets     (GtkTargetList *list,
                                                         guint info);
void                gtk_target_list_add_rich_text_targets
                                                        (GtkTargetList *list,
                                                         guint info,
                                                         gboolean deserializable,
                                                         GtkTextBuffer *buffer);
void                gtk_target_list_remove              (GtkTargetList *list,
                                                         GdkAtom target);
gboolean            gtk_target_list_find                (GtkTargetList *list,
                                                         GdkAtom target,
                                                         guint *info);
void                gtk_target_table_free               (GtkTargetEntry *targets,
                                                         gint n_targets);
GtkTargetEntry *    gtk_target_table_new_from_list      (GtkTargetList *list,
                                                         gint *n_targets);
gboolean            gtk_selection_owner_set             (GtkWidget *widget,
                                                         GdkAtom selection,
                                                         guint32 time_);
gboolean            gtk_selection_owner_set_for_display (GdkDisplay *display,
                                                         GtkWidget *widget,
                                                         GdkAtom selection,
                                                         guint32 time_);
void                gtk_selection_add_target            (GtkWidget *widget,
                                                         GdkAtom selection,
                                                         GdkAtom target,
                                                         guint info);
void                gtk_selection_add_targets           (GtkWidget *widget,
                                                         GdkAtom selection,
                                                         const GtkTargetEntry *targets,
                                                         guint ntargets);
void                gtk_selection_clear_targets         (GtkWidget *widget,
                                                         GdkAtom selection);
gboolean            gtk_selection_convert               (GtkWidget *widget,
                                                         GdkAtom selection,
                                                         GdkAtom target,
                                                         guint32 time_);
void                gtk_selection_data_set              (GtkSelectionData *selection_data,
                                                         GdkAtom type,
                                                         gint format,
                                                         const guchar *data,
                                                         gint length);
gboolean            gtk_selection_data_set_text         (GtkSelectionData *selection_data,
                                                         const gchar *str,
                                                         gint len);
guchar *            gtk_selection_data_get_text         (GtkSelectionData *selection_data);
gboolean            gtk_selection_data_set_pixbuf       (GtkSelectionData *selection_data,
                                                         GdkPixbuf *pixbuf);
GdkPixbuf *         gtk_selection_data_get_pixbuf       (GtkSelectionData *selection_data);
gboolean            gtk_selection_data_set_uris         (GtkSelectionData *selection_data,
                                                         gchar **uris);
gchar **            gtk_selection_data_get_uris         (GtkSelectionData *selection_data);
gboolean            gtk_selection_data_get_targets      (GtkSelectionData *selection_data,
                                                         GdkAtom **targets,
                                                         gint *n_atoms);
gboolean            gtk_selection_data_targets_include_image
                                                        (GtkSelectionData *selection_data,
                                                         gboolean writable);
gboolean            gtk_selection_data_targets_include_text
                                                        (GtkSelectionData *selection_data);
gboolean            gtk_selection_data_targets_include_uri
                                                        (GtkSelectionData *selection_data);
gboolean            gtk_selection_data_targets_include_rich_text
                                                        (GtkSelectionData *selection_data,
                                                         GtkTextBuffer *buffer);
GdkAtom             gtk_selection_data_get_selection    (GtkSelectionData *selection_data);
const guchar *      gtk_selection_data_get_data         (GtkSelectionData *selection_data);
gint                gtk_selection_data_get_length       (GtkSelectionData *selection_data);
GdkAtom             gtk_selection_data_get_data_type    (GtkSelectionData *selection_data);
GdkDisplay *        gtk_selection_data_get_display      (GtkSelectionData *selection_data);
gint                gtk_selection_data_get_format       (GtkSelectionData *selection_data);
GdkAtom             gtk_selection_data_get_target       (GtkSelectionData *selection_data);
gboolean            gtk_targets_include_image           (GdkAtom *targets,
                                                         gint n_targets,
                                                         gboolean writable);
gboolean            gtk_targets_include_text            (GdkAtom *targets,
                                                         gint n_targets);
gboolean            gtk_targets_include_uri             (GdkAtom *targets,
                                                         gint n_targets);
gboolean            gtk_targets_include_rich_text       (GdkAtom *targets,
                                                         gint n_targets,
                                                         GtkTextBuffer *buffer);
void                gtk_selection_remove_all            (GtkWidget *widget);
GtkSelectionData *  gtk_selection_data_copy             (GtkSelectionData *data);
void                gtk_selection_data_free             (GtkSelectionData *data);
The selection mechanism provides the basis for different types of communication between processes. In particular, drag and drop and GtkClipboard work via selections. You will very seldom or never need to use most of the functions in this section directly; GtkClipboard provides a nicer interface to the same functionality.
Some of the datatypes defined this section are used in the GtkClipboard and drag-and-drop API's as well. The GtkTargetEntry structure and GtkTargetList objects represent lists of data types that are supported when sending or receiving data. The GtkSelectionData object is used to store a chunk of data along with the data type and other associated information.
typedef struct {
  gchar *target;
  guint  flags;
  guint  info;
} GtkTargetEntry;
A GtkTargetEntry structure represents a single type of data than can be supplied for by a widget for a selection or for supplied or received during drag-and-drop. It contains a string representing the drag type, a flags field (used only for drag and drop - see GtkTargetFlags), and an application assigned integer ID. The integer ID will later be passed as a signal parameter for signals like "selection_get". It allows the application to identify the target type without extensive string compares.
typedef struct {
  GList *list;
  guint ref_count;
} GtkTargetList;
A GtkTargetList structure is a reference counted list of GtkTargetPair. It is used to represent the same information as a table of GtkTargetEntry, but in an efficient form. This structure should be treated as opaque.
typedef struct {
  GdkAtom   target;
  guint     flags;
  guint     info;
} GtkTargetPair;
Internally used structure in the drag-and-drop and selection handling code.
GtkTargetList * gtk_target_list_new (const GtkTargetEntry *targets,guint ntargets);
Creates a new GtkTargetList from an array of GtkTargetEntry.
| 
 | Pointer to an array of GtkTargetEntry | 
| 
 | number of entries in targets. | 
| Returns : | the new GtkTargetList. | 
GtkTargetList *     gtk_target_list_ref                 (GtkTargetList *list);
Increases the reference count of a GtkTargetList by one.
| 
 | a GtkTargetList | 
| Returns : | the passed in GtkTargetList. | 
void                gtk_target_list_unref               (GtkTargetList *list);
Decreases the reference count of a GtkTargetList by one. If the resulting reference count is zero, frees the list.
| 
 | a GtkTargetList | 
void gtk_target_list_add (GtkTargetList *list,GdkAtom target,guint flags,guint info);
Appends another target to a GtkTargetList.
| 
 | a GtkTargetList | 
| 
 | the interned atom representing the target | 
| 
 | the flags for this target | 
| 
 | an ID that will be passed back to the application | 
void gtk_target_list_add_table (GtkTargetList *list,const GtkTargetEntry *targets,guint ntargets);
Prepends a table of GtkTargetEntry to a target list.
| 
 | a GtkTargetList | 
| 
 | the table of GtkTargetEntry | 
| 
 | number of targets in the table | 
void gtk_target_list_add_text_targets (GtkTargetList *list,guint info);
Appends the text targets supported by GtkSelection to
the target list. All targets are added with the same info.
| 
 | a GtkTargetList | 
| 
 | an ID that will be passed back to the application | 
Since 2.6
void gtk_target_list_add_image_targets (GtkTargetList *list,guint info,gboolean writable);
Appends the image targets supported by GtkSelection to
the target list. All targets are added with the same info.
| 
 | a GtkTargetList | 
| 
 | an ID that will be passed back to the application | 
| 
 | whether to add only targets for which GTK+ knows how to convert a pixbuf into the format | 
Since 2.6
void gtk_target_list_add_uri_targets (GtkTargetList *list,guint info);
Appends the URI targets supported by GtkSelection to
the target list. All targets are added with the same info.
| 
 | a GtkTargetList | 
| 
 | an ID that will be passed back to the application | 
Since 2.6
void gtk_target_list_add_rich_text_targets (GtkTargetList *list,guint info,gboolean deserializable,GtkTextBuffer *buffer);
Appends the rich text targets registered with
gtk_text_buffer_register_serialize_format() or
gtk_text_buffer_register_deserialize_format() to the target list. All
targets are added with the same info.
| 
 | a GtkTargetList | 
| 
 | an ID that will be passed back to the application | 
| 
 | if TRUE, then deserializable rich text formats
                 will be added, serializable formats otherwise. | 
| 
 | a GtkTextBuffer. | 
Since 2.10
void gtk_target_list_remove (GtkTargetList *list,GdkAtom target);
Removes a target from a target list.
| 
 | a GtkTargetList | 
| 
 | the interned atom representing the target | 
gboolean gtk_target_list_find (GtkTargetList *list,GdkAtom target,guint *info);
Looks up a given target in a GtkTargetList.
| 
 | a GtkTargetList | 
| 
 | an interned atom representing the target to search for | 
| 
 | a pointer to the location to store application info for target,
       or NULL | 
| Returns : | TRUEif the target was found, otherwiseFALSE | 
void gtk_target_table_free (GtkTargetEntry *targets,gint n_targets);
This function frees a target table as returned by
gtk_target_table_new_from_list()
| 
 | a GtkTargetEntry array | 
| 
 | the number of entries in the array | 
Since 2.10
GtkTargetEntry * gtk_target_table_new_from_list (GtkTargetList *list,gint *n_targets);
This function creates an GtkTargetEntry array that contains the
same targets as the passed list. The returned table is newly
allocated and should be freed using gtk_target_table_free() when no
longer needed.
| 
 | a GtkTargetList | 
| 
 | return location for the number ot targets in the table | 
| Returns : | the new table. | 
Since 2.10
gboolean gtk_selection_owner_set (GtkWidget *widget,GdkAtom selection,guint32 time_);
Claims ownership of a given selection for a particular widget,
or, if widget is NULL, release ownership of the selection.
gboolean gtk_selection_owner_set_for_display (GdkDisplay *display,GtkWidget *widget,GdkAtom selection,guint32 time_);
Claim ownership of a given selection for a particular widget, or,
if widget is NULL, release ownership of the selection.
| 
 | the Gdkdisplay where the selection is set | 
| 
 | new selection owner (a GdkWidget), or NULL. [allow-none] | 
| 
 | an interned atom representing the selection to claim. | 
| 
 | timestamp with which to claim the selection | 
| Returns : | TRUE if the operation succeeded | 
Since 2.2
void gtk_selection_add_target (GtkWidget *widget,GdkAtom selection,GdkAtom target,guint info);
Appends a specified target to the list of supported targets for a given widget and selection.
| 
 | a GtkTarget | 
| 
 | the selection | 
| 
 | target to add. | 
| 
 | A unsigned integer which will be passed back to the application. | 
void gtk_selection_add_targets (GtkWidget *widget,GdkAtom selection,const GtkTargetEntry *targets,guint ntargets);
Prepends a table of targets to the list of supported targets for a given widget and selection.
| 
 | a GtkWidget | 
| 
 | the selection | 
| 
 | a table of targets to add | 
| 
 | number of entries in targets | 
void gtk_selection_clear_targets (GtkWidget *widget,GdkAtom selection);
Remove all targets registered for the given selection for the widget.
| 
 | a GtkWidget | 
| 
 | an atom representing a selection | 
gboolean gtk_selection_convert (GtkWidget *widget,GdkAtom selection,GdkAtom target,guint32 time_);
Requests the contents of a selection. When received, a "selection-received" signal will be generated.
| 
 | The widget which acts as requestor | 
| 
 | Which selection to get | 
| 
 | Form of information desired (e.g., STRING) | 
| 
 | Time of request (usually of triggering event) In emergency, you could use GDK_CURRENT_TIME | 
| Returns : | TRUEif requested succeeded.FALSEif we could not process
         request. (e.g., there was already a request in process for
         this widget). | 
void gtk_selection_data_set (GtkSelectionData *selection_data,GdkAtom type,gint format,const guchar *data,gint length);
Stores new data into a GtkSelectionData object. Should only be called from a selection handler callback. Zero-terminates the stored data.
| 
 | a pointer to a GtkSelectionData structure. | 
| 
 | the type of selection data | 
| 
 | format (number of bits in a unit) | 
| 
 | pointer to the data (will be copied) | 
| 
 | length of the data | 
gboolean gtk_selection_data_set_text (GtkSelectionData *selection_data,const gchar *str,gint len);
Sets the contents of the selection from a UTF-8 encoded string.
The string is converted to the form determined by
selection_data->target.
| 
 | a GtkSelectionData | 
| 
 | a UTF-8 string | 
| 
 | the length of str, or -1 ifstris nul-terminated. | 
| Returns : | TRUEif the selection was successfully set,
  otherwiseFALSE. | 
guchar *            gtk_selection_data_get_text         (GtkSelectionData *selection_data);
Gets the contents of the selection data as a UTF-8 string.
| 
 | a GtkSelectionData | 
| Returns : | if the selection data contained a recognized
  text type and it could be converted to UTF-8, a newly allocated
  string containing the converted text, otherwise NULL.
  If the result is non-NULLit must be freed withg_free(). | 
gboolean gtk_selection_data_set_pixbuf (GtkSelectionData *selection_data,GdkPixbuf *pixbuf);
Sets the contents of the selection from a GdkPixbuf
The pixbuf is converted to the form determined by
selection_data->target.
| 
 | a GtkSelectionData | 
| 
 | a GdkPixbuf | 
| Returns : | TRUEif the selection was successfully set,
  otherwiseFALSE. | 
Since 2.6
GdkPixbuf *         gtk_selection_data_get_pixbuf       (GtkSelectionData *selection_data);
Gets the contents of the selection data as a GdkPixbuf.
| 
 | a GtkSelectionData | 
| Returns : | if the selection data contained a recognized
  image type and it could be converted to a GdkPixbuf, a 
  newly allocated pixbuf is returned, otherwise NULL.
  If the result is non-NULLit must be freed withg_object_unref(). | 
Since 2.6
gboolean gtk_selection_data_set_uris (GtkSelectionData *selection_data,gchar **uris);
Sets the contents of the selection from a list of URIs.
The string is converted to the form determined by
selection_data->target.
| 
 | a GtkSelectionData | 
| 
 | a NULL-terminated array of strings holding URIs | 
| Returns : | TRUEif the selection was successfully set,
  otherwiseFALSE. | 
Since 2.6
gchar **            gtk_selection_data_get_uris         (GtkSelectionData *selection_data);
Gets the contents of the selection data as array of URIs.
| 
 | a GtkSelectionData | 
| Returns : | if
  the selection data contains a list of
  URIs, a newly allocated NULL-terminated string array
  containing the URIs, otherwiseNULL. If the result is
  non-NULLit must be freed withg_strfreev(). [array zero-terminated=1][element-type utf8][transfer full utf8] | 
Since 2.6
gboolean gtk_selection_data_get_targets (GtkSelectionData *selection_data,GdkAtom **targets,gint *n_atoms);
Gets the contents of selection_data as an array of targets.
This can be used to interpret the results of getting
the standard TARGETS target that is always supplied for
any selection.
| 
 | a GtkSelectionData object | 
| 
 | location to store an array of targets. The result
          stored here must be freed with g_free(). | 
| 
 | location to store number of items in targets. | 
| Returns : | TRUEifselection_datacontains a valid
   array of targets, otherwiseFALSE. | 
gboolean gtk_selection_data_targets_include_image (GtkSelectionData *selection_data,gboolean writable);
Given a GtkSelectionData object holding a list of targets,
determines if any of the targets in targets can be used to
provide a GdkPixbuf.
| 
 | a GtkSelectionData object | 
| 
 | whether to accept only targets for which GTK+ knows how to convert a pixbuf into the format | 
| Returns : | TRUEifselection_dataholds a list of targets,
  and a suitable target for images is included, otherwiseFALSE. | 
Since 2.6
gboolean            gtk_selection_data_targets_include_text
                                                        (GtkSelectionData *selection_data);
Given a GtkSelectionData object holding a list of targets,
determines if any of the targets in targets can be used to
provide text.
| 
 | a GtkSelectionData object | 
| Returns : | TRUEifselection_dataholds a list of targets,
  and a suitable target for text is included, otherwiseFALSE. | 
gboolean            gtk_selection_data_targets_include_uri
                                                        (GtkSelectionData *selection_data);
Given a GtkSelectionData object holding a list of targets,
determines if any of the targets in targets can be used to
provide a list or URIs.
| 
 | a GtkSelectionData object | 
| Returns : | TRUEifselection_dataholds a list of targets,
  and a suitable target for URI lists is included, otherwiseFALSE. | 
Since 2.10
gboolean gtk_selection_data_targets_include_rich_text (GtkSelectionData *selection_data,GtkTextBuffer *buffer);
Given a GtkSelectionData object holding a list of targets,
determines if any of the targets in targets can be used to
provide rich text.
| 
 | a GtkSelectionData object | 
| 
 | a GtkTextBuffer | 
| Returns : | TRUEifselection_dataholds a list of targets,
              and a suitable target for rich text is included,
              otherwiseFALSE. | 
Since 2.10
GdkAtom             gtk_selection_data_get_selection    (GtkSelectionData *selection_data);
Retrieves the selection GdkAtom of the selection data.
| 
 | a pointer to a GtkSelectionData structure. | 
| Returns : | the selection GdkAtom of the selection data. | 
Since 2.16
const guchar *      gtk_selection_data_get_data         (GtkSelectionData *selection_data);
Retrieves the raw data of the selection.
| 
 | a pointer to a GtkSelectionData structure. | 
| Returns : | the raw data of the selection. | 
Since 2.14
gint                gtk_selection_data_get_length       (GtkSelectionData *selection_data);
Retrieves the length of the raw data of the selection.
| 
 | a pointer to a GtkSelectionData structure. | 
| Returns : | the length of the data of the selection. | 
Since 2.14
GdkAtom             gtk_selection_data_get_data_type    (GtkSelectionData *selection_data);
Retrieves the data type of the selection.
| 
 | a pointer to a GtkSelectionData structure. | 
| Returns : | the data type of the selection. | 
Since 2.14
GdkDisplay *        gtk_selection_data_get_display      (GtkSelectionData *selection_data);
Retrieves the display of the selection.
| 
 | a pointer to a GtkSelectionData structure. | 
| Returns : | the display of the selection. | 
Since 2.14
gint                gtk_selection_data_get_format       (GtkSelectionData *selection_data);
Retrieves the format of the selection.
| 
 | a pointer to a GtkSelectionData structure. | 
| Returns : | the format of the selection. | 
Since 2.14
GdkAtom             gtk_selection_data_get_target       (GtkSelectionData *selection_data);
Retrieves the target of the selection.
| 
 | a pointer to a GtkSelectionData structure. | 
| Returns : | the target of the selection. | 
Since 2.14
gboolean gtk_targets_include_image (GdkAtom *targets,gint n_targets,gboolean writable);
Determines if any of the targets in targets can be used to
provide a GdkPixbuf.
| 
 | an array of GdkAtoms | 
| 
 | the length of targets | 
| 
 | whether to accept only targets for which GTK+ knows how to convert a pixbuf into the format | 
| Returns : | TRUEiftargetsinclude a suitable target for images,
  otherwiseFALSE. | 
Since 2.10
gboolean gtk_targets_include_text (GdkAtom *targets,gint n_targets);
Determines if any of the targets in targets can be used to
provide text.
| 
 | an array of GdkAtoms | 
| 
 | the length of targets | 
| Returns : | TRUEiftargetsinclude a suitable target for text,
  otherwiseFALSE. | 
Since 2.10
gboolean gtk_targets_include_uri (GdkAtom *targets,gint n_targets);
Determines if any of the targets in targets can be used to
provide an uri list.
| 
 | an array of GdkAtoms | 
| 
 | the length of targets | 
| Returns : | TRUEiftargetsinclude a suitable target for uri lists,
  otherwiseFALSE. | 
Since 2.10
gboolean gtk_targets_include_rich_text (GdkAtom *targets,gint n_targets,GtkTextBuffer *buffer);
Determines if any of the targets in targets can be used to
provide rich text.
| 
 | an array of GdkAtoms | 
| 
 | the length of targets | 
| 
 | a GtkTextBuffer | 
| Returns : | TRUEiftargetsinclude a suitable target for rich text,
              otherwiseFALSE. | 
Since 2.10
void                gtk_selection_remove_all            (GtkWidget *widget);
Removes all handlers and unsets ownership of all selections for a widget. Called when widget is being destroyed. This function will not generally be called by applications.
| 
 | a GtkWidget | 
GtkSelectionData *  gtk_selection_data_copy             (GtkSelectionData *data);
Makes a copy of a GtkSelectionData structure and its data.
| 
 | a pointer to a GtkSelectionData structure. | 
| Returns : | a pointer to a copy of data. | 
void                gtk_selection_data_free             (GtkSelectionData *data);
Frees a GtkSelectionData structure returned from
gtk_selection_data_copy().
| 
 | a pointer to a GtkSelectionData structure. |