Do earlier and better checking for matching actions and data format, hopefully fixes #11201
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@62662 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -41,7 +41,8 @@ public:
|
|||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
|
|
||||||
GdkAtom GtkGetMatchingPair(bool quiet = false);
|
GdkAtom GTKGetMatchingPair(bool quiet = false);
|
||||||
|
wxDragResult GTKFigureOutSuggestedAction();
|
||||||
|
|
||||||
void GtkRegisterWidget( GtkWidget *widget );
|
void GtkRegisterWidget( GtkWidget *widget );
|
||||||
void GtkUnregisterWidget( GtkWidget *widget );
|
void GtkUnregisterWidget( GtkWidget *widget );
|
||||||
@@ -52,10 +53,10 @@ public:
|
|||||||
guint m_dragTime;
|
guint m_dragTime;
|
||||||
bool m_firstMotion; // gdk has no "gdk_drag_enter" event
|
bool m_firstMotion; // gdk has no "gdk_drag_enter" event
|
||||||
|
|
||||||
void GtkSetDragContext( GdkDragContext *dc ) { m_dragContext = dc; }
|
void GTKSetDragContext( GdkDragContext *dc ) { m_dragContext = dc; }
|
||||||
void GtkSetDragWidget( GtkWidget *w ) { m_dragWidget = w; }
|
void GTKSetDragWidget( GtkWidget *w ) { m_dragWidget = w; }
|
||||||
void GtkSetDragData( GtkSelectionData *sd ) { m_dragData = sd; }
|
void GTKSetDragData( GtkSelectionData *sd ) { m_dragData = sd; }
|
||||||
void GtkSetDragTime( guint time ) { m_dragTime = time; }
|
void GTKSetDragTime( guint time ) { m_dragTime = time; }
|
||||||
};
|
};
|
||||||
|
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
|
251
src/gtk/dnd.cpp
251
src/gtk/dnd.cpp
@@ -164,7 +164,7 @@ static void target_drag_leave( GtkWidget *WXUNUSED(widget),
|
|||||||
{
|
{
|
||||||
/* inform the wxDropTarget about the current GdkDragContext.
|
/* inform the wxDropTarget about the current GdkDragContext.
|
||||||
this is only valid for the duration of this call */
|
this is only valid for the duration of this call */
|
||||||
drop_target->GtkSetDragContext( context );
|
drop_target->GTKSetDragContext( context );
|
||||||
|
|
||||||
/* we don't need return values. this event is just for
|
/* we don't need return values. this event is just for
|
||||||
information */
|
information */
|
||||||
@@ -174,7 +174,7 @@ static void target_drag_leave( GtkWidget *WXUNUSED(widget),
|
|||||||
drop_target->m_firstMotion = true;
|
drop_target->m_firstMotion = true;
|
||||||
|
|
||||||
/* after this, invalidate the drop_target's GdkDragContext */
|
/* after this, invalidate the drop_target's GdkDragContext */
|
||||||
drop_target->GtkSetDragContext( NULL );
|
drop_target->GTKSetDragContext( NULL );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -204,81 +204,51 @@ static gboolean target_drag_motion( GtkWidget *WXUNUSED(widget),
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* inform the wxDropTarget about the current GdkDragContext.
|
// Inform the wxDropTarget about the current GdkDragContext.
|
||||||
this is only valid for the duration of this call */
|
// This is only valid for the duration of this call.
|
||||||
drop_target->GtkSetDragContext( context );
|
drop_target->GTKSetDragContext( context );
|
||||||
|
|
||||||
// GTK+ always supposes that we want to copy the data by default while we
|
// Does the source actually accept the data type?
|
||||||
// might want to move it, so examine not only suggested_action - which is
|
if (drop_target->GTKGetMatchingPair() == (GdkAtom) 0)
|
||||||
// only good if we don't have our own preferences - but also the actions
|
|
||||||
// field
|
|
||||||
wxDragResult result;
|
|
||||||
if (drop_target->GetDefaultAction() == wxDragNone)
|
|
||||||
{
|
{
|
||||||
// use default action set by wxDropSource::DoDragDrop()
|
drop_target->GTKSetDragContext( NULL );
|
||||||
if ( (gs_flagsForDrag & wxDrag_DefaultMove) == wxDrag_DefaultMove &&
|
return FALSE;
|
||||||
(context->actions & GDK_ACTION_MOVE ) )
|
|
||||||
{
|
|
||||||
// move is requested by the program and allowed by GTK+ - do it, even
|
|
||||||
// though suggested_action may be currently wxDragCopy
|
|
||||||
result = wxDragMove;
|
|
||||||
}
|
}
|
||||||
else // use whatever GTK+ says we should
|
|
||||||
{
|
|
||||||
result = ConvertFromGTK(context->suggested_action);
|
|
||||||
|
|
||||||
if ( (result == wxDragMove) && !(gs_flagsForDrag & wxDrag_AllowMove) )
|
wxDragResult suggested_action = drop_target->GTKFigureOutSuggestedAction();
|
||||||
{
|
|
||||||
// we're requested to move but we can't
|
|
||||||
result = wxDragCopy;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (drop_target->GetDefaultAction() == wxDragMove &&
|
|
||||||
(context->actions & GDK_ACTION_MOVE))
|
|
||||||
{
|
|
||||||
|
|
||||||
result = wxDragMove;
|
wxDragResult result = wxDragNone;
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (context->actions & GDK_ACTION_COPY)
|
|
||||||
result = wxDragCopy;
|
|
||||||
else if (context->actions & GDK_ACTION_MOVE)
|
|
||||||
result = wxDragMove;
|
|
||||||
else
|
|
||||||
result = wxDragNone;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (drop_target->m_firstMotion)
|
if (drop_target->m_firstMotion)
|
||||||
{
|
{
|
||||||
/* the first "drag_motion" event substitutes a "drag_enter" event */
|
// the first "drag_motion" event substitutes a "drag_enter" event
|
||||||
result = drop_target->OnEnter( x, y, result );
|
result = drop_target->OnEnter( x, y, suggested_action );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* give program a chance to react (i.e. to say no by returning FALSE) */
|
// give program a chance to react (i.e. to say no by returning FALSE)
|
||||||
result = drop_target->OnDragOver( x, y, result );
|
result = drop_target->OnDragOver( x, y, suggested_action );
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ret = wxIsDragResultOk( result );
|
GdkDragAction result_action = GDK_ACTION_DEFAULT;
|
||||||
if (ret)
|
|
||||||
{
|
|
||||||
GdkDragAction action;
|
|
||||||
if (result == wxDragCopy)
|
if (result == wxDragCopy)
|
||||||
action = GDK_ACTION_COPY;
|
result_action = GDK_ACTION_COPY;
|
||||||
else if (result == wxDragLink)
|
else if (result == wxDragLink)
|
||||||
action = GDK_ACTION_LINK;
|
result_action = GDK_ACTION_LINK;
|
||||||
else
|
else
|
||||||
action = GDK_ACTION_MOVE;
|
result_action = GDK_ACTION_MOVE;
|
||||||
|
|
||||||
gdk_drag_status( context, action, time );
|
// is result action actually supported
|
||||||
}
|
bool ret ((result_action != GDK_ACTION_DEFAULT) &&
|
||||||
|
(context->actions & result_action));
|
||||||
|
|
||||||
/* after this, invalidate the drop_target's GdkDragContext */
|
if (ret)
|
||||||
drop_target->GtkSetDragContext( NULL );
|
gdk_drag_status( context, result_action, time );
|
||||||
|
|
||||||
/* this has to be done because GDK has no "drag_enter" event */
|
// after this, invalidate the drop_target's GdkDragContext
|
||||||
|
drop_target->GTKSetDragContext( NULL );
|
||||||
|
|
||||||
|
// this has to be done because GDK has no "drag_enter" event
|
||||||
drop_target->m_firstMotion = false;
|
drop_target->m_firstMotion = false;
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
@@ -302,26 +272,33 @@ static gboolean target_drag_drop( GtkWidget *widget,
|
|||||||
the drop, call gtk_drag_finish() with success == FALSE
|
the drop, call gtk_drag_finish() with success == FALSE
|
||||||
otherwise call gtk_drag_data_get()" */
|
otherwise call gtk_drag_data_get()" */
|
||||||
|
|
||||||
/* this seems to make a difference between not accepting
|
|
||||||
due to wrong target area and due to wrong format. let
|
|
||||||
us hope that this is not required.. */
|
|
||||||
|
|
||||||
/* inform the wxDropTarget about the current GdkDragContext.
|
/* inform the wxDropTarget about the current GdkDragContext.
|
||||||
this is only valid for the duration of this call */
|
this is only valid for the duration of this call */
|
||||||
drop_target->GtkSetDragContext( context );
|
drop_target->GTKSetDragContext( context );
|
||||||
|
|
||||||
|
// Does the source actually accept the data type?
|
||||||
|
if (drop_target->GTKGetMatchingPair() == (GdkAtom) 0)
|
||||||
|
{
|
||||||
|
// cancel the whole thing
|
||||||
|
gtk_drag_finish( context,
|
||||||
|
FALSE, // no success
|
||||||
|
FALSE, // don't delete data on dropping side
|
||||||
|
time );
|
||||||
|
|
||||||
|
drop_target->GTKSetDragContext( NULL );
|
||||||
|
|
||||||
|
drop_target->m_firstMotion = true;
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
/* inform the wxDropTarget about the current drag widget.
|
/* inform the wxDropTarget about the current drag widget.
|
||||||
this is only valid for the duration of this call */
|
this is only valid for the duration of this call */
|
||||||
drop_target->GtkSetDragWidget( widget );
|
drop_target->GTKSetDragWidget( widget );
|
||||||
|
|
||||||
/* inform the wxDropTarget about the current drag time.
|
/* inform the wxDropTarget about the current drag time.
|
||||||
this is only valid for the duration of this call */
|
this is only valid for the duration of this call */
|
||||||
drop_target->GtkSetDragTime( time );
|
drop_target->GTKSetDragTime( time );
|
||||||
|
|
||||||
/*
|
|
||||||
wxDragResult result = wxDragMove;
|
|
||||||
if (context->suggested_action == GDK_ACTION_COPY) result = wxDragCopy;
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* reset the block here as someone might very well
|
/* reset the block here as someone might very well
|
||||||
show a dialog as a reaction to a drop and this
|
show a dialog as a reaction to a drop and this
|
||||||
@@ -344,36 +321,23 @@ static gboolean target_drag_drop( GtkWidget *widget,
|
|||||||
{
|
{
|
||||||
wxLogTrace(TRACE_DND, wxT( "Drop target: OnDrop returned true") );
|
wxLogTrace(TRACE_DND, wxT( "Drop target: OnDrop returned true") );
|
||||||
|
|
||||||
#if wxUSE_THREADS
|
GdkAtom format = drop_target->GTKGetMatchingPair();
|
||||||
/* disable GUI threads */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
GdkAtom format = drop_target->GtkGetMatchingPair();
|
|
||||||
|
|
||||||
// this does happen somehow, see bug 555111
|
// this does happen somehow, see bug 555111
|
||||||
wxCHECK_MSG( format, FALSE, wxT("no matching GdkAtom for format?") );
|
wxCHECK_MSG( format, FALSE, wxT("no matching GdkAtom for format?") );
|
||||||
|
|
||||||
/*
|
|
||||||
GdkDragAction action = GDK_ACTION_MOVE;
|
|
||||||
if (result == wxDragCopy) action == GDK_ACTION_COPY;
|
|
||||||
context->action = action;
|
|
||||||
*/
|
|
||||||
/* this should trigger an "drag_data_received" event */
|
/* this should trigger an "drag_data_received" event */
|
||||||
gtk_drag_get_data( widget,
|
gtk_drag_get_data( widget,
|
||||||
context,
|
context,
|
||||||
format,
|
format,
|
||||||
time );
|
time );
|
||||||
|
|
||||||
#if wxUSE_THREADS
|
|
||||||
/* re-enable GUI threads */
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* after this, invalidate the drop_target's GdkDragContext */
|
/* after this, invalidate the drop_target's GdkDragContext */
|
||||||
drop_target->GtkSetDragContext( NULL );
|
drop_target->GTKSetDragContext( NULL );
|
||||||
|
|
||||||
/* after this, invalidate the drop_target's drag widget */
|
/* after this, invalidate the drop_target's drag widget */
|
||||||
drop_target->GtkSetDragWidget( NULL );
|
drop_target->GTKSetDragWidget( NULL );
|
||||||
|
|
||||||
/* this has to be done because GDK has no "drag_enter" event */
|
/* this has to be done because GDK has no "drag_enter" event */
|
||||||
drop_target->m_firstMotion = true;
|
drop_target->m_firstMotion = true;
|
||||||
@@ -412,7 +376,7 @@ static void target_drag_data_received( GtkWidget *WXUNUSED(widget),
|
|||||||
|
|
||||||
/* inform the wxDropTarget about the current GtkSelectionData.
|
/* inform the wxDropTarget about the current GtkSelectionData.
|
||||||
this is only valid for the duration of this call */
|
this is only valid for the duration of this call */
|
||||||
drop_target->GtkSetDragData( data );
|
drop_target->GTKSetDragData( data );
|
||||||
|
|
||||||
wxDragResult result = ConvertFromGTK(context->action);
|
wxDragResult result = ConvertFromGTK(context->action);
|
||||||
|
|
||||||
@@ -432,7 +396,7 @@ static void target_drag_data_received( GtkWidget *WXUNUSED(widget),
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* after this, invalidate the drop_target's drag data */
|
/* after this, invalidate the drop_target's drag data */
|
||||||
drop_target->GtkSetDragData( NULL );
|
drop_target->GTKSetDragData( NULL );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -454,40 +418,85 @@ wxDragResult wxDropTarget::OnDragOver( wxCoord WXUNUSED(x),
|
|||||||
wxCoord WXUNUSED(y),
|
wxCoord WXUNUSED(y),
|
||||||
wxDragResult def )
|
wxDragResult def )
|
||||||
{
|
{
|
||||||
// GetMatchingPair() checks for m_dataObject too, no need to do it here
|
return def;
|
||||||
|
|
||||||
// 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) )
|
bool wxDropTarget::OnDrop( wxCoord WXUNUSED(x), wxCoord WXUNUSED(y) )
|
||||||
{
|
{
|
||||||
if (!m_dataObject)
|
return true;
|
||||||
return false;
|
|
||||||
|
|
||||||
return (GtkGetMatchingPair() != (GdkAtom) 0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
wxDragResult wxDropTarget::OnData( wxCoord WXUNUSED(x), wxCoord WXUNUSED(y),
|
wxDragResult wxDropTarget::OnData( wxCoord WXUNUSED(x), wxCoord WXUNUSED(y),
|
||||||
wxDragResult def )
|
wxDragResult def )
|
||||||
{
|
{
|
||||||
if (!m_dataObject)
|
|
||||||
return wxDragNone;
|
|
||||||
|
|
||||||
if (GtkGetMatchingPair() == (GdkAtom) 0)
|
|
||||||
return wxDragNone;
|
|
||||||
|
|
||||||
return GetData() ? def : wxDragNone;
|
return GetData() ? def : wxDragNone;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
wxDragResult wxDropTarget::GTKFigureOutSuggestedAction()
|
||||||
|
{
|
||||||
|
if (!m_dragContext)
|
||||||
|
return wxDragError;
|
||||||
|
|
||||||
|
// GTK+ always supposes that we want to copy the data by default while we
|
||||||
|
// might want to move it, so examine not only suggested_action - which is
|
||||||
|
// only good if we don't have our own preferences - but also the actions
|
||||||
|
// field
|
||||||
|
wxDragResult suggested_action = wxDragNone;
|
||||||
|
if (GetDefaultAction() == wxDragNone)
|
||||||
|
{
|
||||||
|
// use default action set by wxDropSource::DoDragDrop()
|
||||||
|
if ( (gs_flagsForDrag & wxDrag_DefaultMove) == wxDrag_DefaultMove &&
|
||||||
|
(m_dragContext->actions & GDK_ACTION_MOVE ) )
|
||||||
|
{
|
||||||
|
// move is requested by the program and allowed by GTK+ - do it, even
|
||||||
|
// though suggested_action may be currently wxDragCopy
|
||||||
|
suggested_action = wxDragMove;
|
||||||
|
}
|
||||||
|
else // use whatever GTK+ says we should
|
||||||
|
{
|
||||||
|
suggested_action = ConvertFromGTK(m_dragContext->suggested_action);
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
// RR: I don't understand the code below: if the drag comes from
|
||||||
|
// a different app, the gs_flagsForDrag is invalid; if it
|
||||||
|
// comes from the same wx app, then GTK+ hopefully won't
|
||||||
|
// suggest something we didn't allow in the frist place
|
||||||
|
// in DoDrop()
|
||||||
|
if ( (suggested_action == wxDragMove) && !(gs_flagsForDrag & wxDrag_AllowMove) )
|
||||||
|
{
|
||||||
|
// we're requested to move but we can't
|
||||||
|
suggested_action = wxDragCopy;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (GetDefaultAction() == wxDragMove &&
|
||||||
|
(m_dragContext->actions & GDK_ACTION_MOVE))
|
||||||
|
{
|
||||||
|
|
||||||
|
suggested_action = wxDragMove;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (m_dragContext->actions & GDK_ACTION_COPY)
|
||||||
|
suggested_action = wxDragCopy;
|
||||||
|
else if (m_dragContext->actions & GDK_ACTION_MOVE)
|
||||||
|
suggested_action = wxDragMove;
|
||||||
|
else if (m_dragContext->actions & GDK_ACTION_LINK)
|
||||||
|
suggested_action = wxDragLink;
|
||||||
|
else
|
||||||
|
suggested_action = wxDragNone;
|
||||||
|
}
|
||||||
|
|
||||||
|
return suggested_action;
|
||||||
|
}
|
||||||
|
|
||||||
wxDataFormat wxDropTarget::GetMatchingPair()
|
wxDataFormat wxDropTarget::GetMatchingPair()
|
||||||
{
|
{
|
||||||
return wxDataFormat( GtkGetMatchingPair() );
|
return wxDataFormat( GTKGetMatchingPair() );
|
||||||
}
|
}
|
||||||
|
|
||||||
GdkAtom wxDropTarget::GtkGetMatchingPair(bool quiet)
|
GdkAtom wxDropTarget::GTKGetMatchingPair(bool quiet)
|
||||||
{
|
{
|
||||||
if (!m_dataObject)
|
if (!m_dataObject)
|
||||||
return (GdkAtom) 0;
|
return (GdkAtom) 0;
|
||||||
@@ -590,7 +599,7 @@ void wxDropTarget::GtkRegisterWidget( GtkWidget *widget )
|
|||||||
extern "C" {
|
extern "C" {
|
||||||
static void
|
static void
|
||||||
source_drag_data_get (GtkWidget *WXUNUSED(widget),
|
source_drag_data_get (GtkWidget *WXUNUSED(widget),
|
||||||
GdkDragContext *WXUNUSED(context),
|
GdkDragContext *context,
|
||||||
GtkSelectionData *selection_data,
|
GtkSelectionData *selection_data,
|
||||||
guint WXUNUSED(info),
|
guint WXUNUSED(info),
|
||||||
guint WXUNUSED(time),
|
guint WXUNUSED(time),
|
||||||
@@ -601,7 +610,7 @@ source_drag_data_get (GtkWidget *WXUNUSED(widget),
|
|||||||
wxLogTrace(TRACE_DND, wxT("Drop source: format requested: %s"),
|
wxLogTrace(TRACE_DND, wxT("Drop source: format requested: %s"),
|
||||||
format.GetId().c_str());
|
format.GetId().c_str());
|
||||||
|
|
||||||
drop_source->m_retValue = wxDragCancel;
|
drop_source->m_retValue = wxDragError;
|
||||||
|
|
||||||
wxDataObject *data = drop_source->GetDataObject();
|
wxDataObject *data = drop_source->GetDataObject();
|
||||||
|
|
||||||
@@ -635,9 +644,7 @@ source_drag_data_get (GtkWidget *WXUNUSED(widget),
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if wxUSE_THREADS
|
drop_source->m_retValue = ConvertFromGTK( context->action );
|
||||||
/* disable GUI threads */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
gtk_selection_data_set( selection_data,
|
gtk_selection_data_set( selection_data,
|
||||||
selection_data->target,
|
selection_data->target,
|
||||||
@@ -645,10 +652,6 @@ source_drag_data_get (GtkWidget *WXUNUSED(widget),
|
|||||||
d,
|
d,
|
||||||
size );
|
size );
|
||||||
|
|
||||||
#if wxUSE_THREADS
|
|
||||||
/* enable GUI threads */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
delete[] d;
|
delete[] d;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -662,8 +665,6 @@ static void source_drag_end( GtkWidget *WXUNUSED(widget),
|
|||||||
GdkDragContext *WXUNUSED(context),
|
GdkDragContext *WXUNUSED(context),
|
||||||
wxDropSource *drop_source )
|
wxDropSource *drop_source )
|
||||||
{
|
{
|
||||||
// printf( "Drag source: drag_end.\n" );
|
|
||||||
|
|
||||||
drop_source->m_waiting = false;
|
drop_source->m_waiting = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -699,7 +700,7 @@ wxDropSource::wxDropSource(wxWindow *win,
|
|||||||
m_widget = win->m_widget;
|
m_widget = win->m_widget;
|
||||||
if (win->m_wxwindow) m_widget = win->m_wxwindow;
|
if (win->m_wxwindow) m_widget = win->m_wxwindow;
|
||||||
|
|
||||||
m_retValue = wxDragCancel;
|
m_retValue = wxDragNone;
|
||||||
|
|
||||||
SetIcons(iconCopy, iconMove, iconNone);
|
SetIcons(iconCopy, iconMove, iconNone);
|
||||||
}
|
}
|
||||||
@@ -720,7 +721,7 @@ wxDropSource::wxDropSource(wxDataObject& data,
|
|||||||
m_widget = win->m_widget;
|
m_widget = win->m_widget;
|
||||||
if (win->m_wxwindow) m_widget = win->m_wxwindow;
|
if (win->m_wxwindow) m_widget = win->m_wxwindow;
|
||||||
|
|
||||||
m_retValue = wxDragCancel;
|
m_retValue = wxDragNone;
|
||||||
|
|
||||||
SetIcons(iconCopy, iconMove, iconNone);
|
SetIcons(iconCopy, iconMove, iconNone);
|
||||||
}
|
}
|
||||||
@@ -826,18 +827,20 @@ wxDragResult wxDropSource::DoDragDrop(int flags)
|
|||||||
}
|
}
|
||||||
delete[] array;
|
delete[] array;
|
||||||
|
|
||||||
int action = GDK_ACTION_COPY;
|
int allowed_actions = GDK_ACTION_COPY;
|
||||||
if ( flags & wxDrag_AllowMove )
|
if ( flags & wxDrag_AllowMove )
|
||||||
action |= GDK_ACTION_MOVE;
|
allowed_actions |= GDK_ACTION_MOVE;
|
||||||
|
|
||||||
// VZ: as we already use g_blockEventsOnDrag it shouldn't be that bad
|
// VZ: as we already use g_blockEventsOnDrag it shouldn't be that bad
|
||||||
// to use a global to pass the flags to the drop target but I'd
|
// to use a global to pass the flags to the drop target but I'd
|
||||||
// surely prefer a better way to do it
|
// surely prefer a better way to do it
|
||||||
gs_flagsForDrag = flags;
|
gs_flagsForDrag = flags;
|
||||||
|
|
||||||
|
m_retValue = wxDragCancel;
|
||||||
|
|
||||||
GdkDragContext *context = gtk_drag_begin( m_widget,
|
GdkDragContext *context = gtk_drag_begin( m_widget,
|
||||||
target_list,
|
target_list,
|
||||||
(GdkDragAction)action,
|
(GdkDragAction)allowed_actions,
|
||||||
g_lastButtonNumber, // number of mouse button which started drag
|
g_lastButtonNumber, // number of mouse button which started drag
|
||||||
(GdkEvent*) g_lastMouseEvent );
|
(GdkEvent*) g_lastMouseEvent );
|
||||||
|
|
||||||
@@ -849,15 +852,11 @@ wxDragResult wxDropSource::DoDragDrop(int flags)
|
|||||||
|
|
||||||
m_dragContext = context;
|
m_dragContext = context;
|
||||||
|
|
||||||
PrepareIcon( action, context );
|
PrepareIcon( allowed_actions, context );
|
||||||
|
|
||||||
while (m_waiting)
|
while (m_waiting)
|
||||||
gtk_main_iteration();
|
gtk_main_iteration();
|
||||||
|
|
||||||
m_retValue = ConvertFromGTK(context->action);
|
|
||||||
if ( m_retValue == wxDragNone )
|
|
||||||
m_retValue = wxDragCancel;
|
|
||||||
|
|
||||||
return m_retValue;
|
return m_retValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user