X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/1fe91d709854883a7e38f9b6aad709b98cebe030..345ff9c65b3ef17709785708b224dfcbf5135583:/src/gtk/dnd.cpp diff --git a/src/gtk/dnd.cpp b/src/gtk/dnd.cpp index 45ab7ced5a..db30dd5c47 100644 --- a/src/gtk/dnd.cpp +++ b/src/gtk/dnd.cpp @@ -36,12 +36,10 @@ extern bool g_blockEventsOnDrag; // the flags used for the last DoDragDrop() static long gs_flagsForDrag = 0; -#ifdef __WXDEBUG__ // the trace mask we use with wxLogTrace() - call // wxLog::AddTraceMask(TRACE_DND) to enable the trace messages from here // (there are quite a few of them, so don't enable this by default) -static const wxChar *TRACE_DND = _T("dnd"); -#endif +#define TRACE_DND "dnd" // global variables because GTK+ DnD want to have the // mouse event that caused it @@ -239,7 +237,7 @@ static gboolean target_drag_motion( GtkWidget *WXUNUSED(widget), else if (drop_target->GetDefaultAction() == wxDragMove && (context->actions & GDK_ACTION_MOVE)) { - + result = wxDragMove; } else @@ -334,9 +332,7 @@ static gboolean target_drag_drop( GtkWidget *widget, if (!ret) { -#ifdef __WXDEBUG__ wxLogTrace(TRACE_DND, wxT( "Drop target: OnDrop returned FALSE") ); -#endif /* cancel the whole thing */ gtk_drag_finish( context, @@ -346,9 +342,7 @@ static gboolean target_drag_drop( GtkWidget *widget, } else { -#ifdef __WXDEBUG__ wxLogTrace(TRACE_DND, wxT( "Drop target: OnDrop returned true") ); -#endif #if wxUSE_THREADS /* disable GUI threads */ @@ -357,7 +351,7 @@ static gboolean target_drag_drop( GtkWidget *widget, GdkAtom format = drop_target->GtkGetMatchingPair(); // this does happen somehow, see bug 555111 - wxCHECK_MSG( format, FALSE, _T("no matching GdkAtom for format?") ); + wxCHECK_MSG( format, FALSE, wxT("no matching GdkAtom for format?") ); /* GdkDragAction action = GDK_ACTION_MOVE; @@ -414,9 +408,7 @@ static void target_drag_data_received( GtkWidget *WXUNUSED(widget), return; } -#ifdef __WXDEBUG__ wxLogTrace(TRACE_DND, wxT( "Drop target: data received event") ); -#endif /* inform the wxDropTarget about the current GtkSelectionData. this is only valid for the duration of this call */ @@ -426,18 +418,14 @@ static void target_drag_data_received( GtkWidget *WXUNUSED(widget), if ( wxIsDragResultOk( drop_target->OnData( x, y, result ) ) ) { -#ifdef __WXDEBUG__ wxLogTrace(TRACE_DND, wxT( "Drop target: OnData returned true") ); -#endif /* tell GTK that data transfer was successful */ gtk_drag_finish( context, TRUE, FALSE, time ); } else { -#ifdef __WXDEBUG__ wxLogTrace(TRACE_DND, wxT( "Drop target: OnData returned FALSE") ); -#endif /* tell GTK that data transfer was not successful */ gtk_drag_finish( context, FALSE, FALSE, time ); @@ -468,13 +456,9 @@ wxDragResult wxDropTarget::OnDragOver( wxCoord WXUNUSED(x), { // GetMatchingPair() checks for m_dataObject too, no need to do it here - // disable the debug message from GetMatchingPair() - there are too many - // of them otherwise -#ifdef __WXDEBUG__ - wxLogNull noLog; -#endif // Debug - - return (GtkGetMatchingPair() != (GdkAtom) 0) ? def : wxDragNone; + // disable the trace message from GetMatchingPair() by passing true to it + // (there are just too many of them otherwise) + return (GtkGetMatchingPair(true) != (GdkAtom) 0) ? def : wxDragNone; } bool wxDropTarget::OnDrop( wxCoord WXUNUSED(x), wxCoord WXUNUSED(y) ) @@ -497,7 +481,13 @@ wxDragResult wxDropTarget::OnData( wxCoord WXUNUSED(x), wxCoord WXUNUSED(y), return GetData() ? def : wxDragNone; } -GdkAtom wxDropTarget::GtkGetMatchingPair() + +wxDataFormat wxDropTarget::GetMatchingPair() +{ + return wxDataFormat( GtkGetMatchingPair() ); +} + +GdkAtom wxDropTarget::GtkGetMatchingPair(bool quiet) { if (!m_dataObject) return (GdkAtom) 0; @@ -511,10 +501,11 @@ GdkAtom wxDropTarget::GtkGetMatchingPair() GdkAtom formatAtom = (GdkAtom)(child->data); wxDataFormat format( formatAtom ); -#ifdef __WXDEBUG__ - wxLogTrace(TRACE_DND, wxT("Drop target: drag has format: %s"), - format.GetId().c_str()); -#endif // Debug + if ( !quiet ) + { + wxLogTrace(TRACE_DND, wxT("Drop target: drag has format: %s"), + format.GetId().c_str()); + } if (m_dataObject->IsSupportedFormat( format )) return formatAtom; @@ -607,10 +598,8 @@ source_drag_data_get (GtkWidget *WXUNUSED(widget), { 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; @@ -618,26 +607,20 @@ source_drag_data_get (GtkWidget *WXUNUSED(widget), if (!data) { -#ifdef __WXDEBUG__ wxLogTrace(TRACE_DND, wxT("Drop source: no data object") ); -#endif - return; + return; } if (!data->IsSupportedFormat(format)) { -#ifdef __WXDEBUG__ wxLogTrace(TRACE_DND, wxT("Drop source: unsupported format") ); -#endif - return; + return; } if (data->GetDataSize(format) == 0) { -#ifdef __WXDEBUG__ wxLogTrace(TRACE_DND, wxT("Drop source: empty data") ); -#endif - return; + return; } size_t size = data->GetDataSize(format); @@ -837,10 +820,9 @@ wxDragResult wxDropSource::DoDragDrop(int flags) for (size_t i = 0; i < count; i++) { GdkAtom atom = array[i]; -#ifdef __WXDEBUG__ - wxLogTrace(TRACE_DND, wxT("Drop source: Supported atom %s"), gdk_atom_name( atom )); -#endif - gtk_target_list_add( target_list, atom, 0, 0 ); + wxLogTrace(TRACE_DND, wxT("Drop source: Supported atom %s"), + gdk_atom_name( atom )); + gtk_target_list_add( target_list, atom, 0, 0 ); } delete[] array;