+//----------------------------------------------------------------------------
+// "drag_data_get"
+//----------------------------------------------------------------------------
+
+extern "C" {
+static void
+source_drag_data_get (GtkWidget *WXUNUSED(widget),
+ GdkDragContext *WXUNUSED(context),
+ GtkSelectionData *selection_data,
+ guint WXUNUSED(info),
+ guint WXUNUSED(time),
+ wxDropSource *drop_source )
+{
+ wxDataFormat format( selection_data->target );
+
+#ifdef __WXDEBUG__
+ wxLogTrace(TRACE_DND, wxT("Drop source: format requested: %s"),
+ format.GetId().c_str());
+#endif
+
+ drop_source->m_retValue = wxDragCancel;
+
+ wxDataObject *data = drop_source->GetDataObject();
+
+ if (!data)
+ {
+#ifdef __WXDEBUG__
+ wxLogTrace(TRACE_DND, wxT("Drop source: no data object") );
+#endif
+ return;
+ }
+
+ if (!data->IsSupportedFormat(format))
+ {
+#ifdef __WXDEBUG__
+ wxLogTrace(TRACE_DND, wxT("Drop source: unsupported format") );
+#endif
+ return;
+ }
+
+ if (data->GetDataSize(format) == 0)
+ {
+#ifdef __WXDEBUG__
+ wxLogTrace(TRACE_DND, wxT("Drop source: empty data") );
+#endif
+ return;
+ }
+
+ size_t size = data->GetDataSize(format);
+
+// printf( "data size: %d.\n", (int)data_size );
+
+ guchar *d = new guchar[size];
+
+ if (!data->GetDataHere( format, (void*)d ))
+ {
+ delete[] d;
+ return;
+ }
+
+#if wxUSE_THREADS
+ /* disable GUI threads */
+#endif
+
+ gtk_selection_data_set( selection_data,
+ selection_data->target,
+ 8, // 8-bit
+ d,
+ size );
+
+#if wxUSE_THREADS
+ /* enable GUI threads */
+#endif
+
+ delete[] d;
+}
+}
+
+//----------------------------------------------------------------------------
+// "drag_end"
+//----------------------------------------------------------------------------
+
+extern "C" {
+static void source_drag_end( GtkWidget *WXUNUSED(widget),
+ GdkDragContext *WXUNUSED(context),
+ wxDropSource *drop_source )
+{
+ // printf( "Drag source: drag_end.\n" );
+
+ drop_source->m_waiting = false;
+}
+}