diff --git a/gdk/x11/gdkdrop-x11.c b/gdk/x11/gdkdrop-x11.c index 3f7566d88d..05b07ca990 100644 --- a/gdk/x11/gdkdrop-x11.c +++ b/gdk/x11/gdkdrop-x11.c @@ -769,22 +769,18 @@ gdk_x11_drop_status (GdkDrop *drop, possible_actions = actions & gdk_drop_get_actions (drop); - if (drop_x11->suggested_action != 0) + if (preferred & possible_actions) + suggested_action = preferred; + else if (drop_x11->suggested_action & possible_actions) suggested_action = drop_x11->suggested_action; + else if (possible_actions & GDK_ACTION_COPY) + suggested_action = GDK_ACTION_COPY; + else if (possible_actions & GDK_ACTION_MOVE) + suggested_action = GDK_ACTION_MOVE; + else if (possible_actions & GDK_ACTION_ASK) + suggested_action = GDK_ACTION_ASK; else - suggested_action = preferred & possible_actions; - - if (suggested_action == 0 && possible_actions != 0) - { - if (possible_actions & GDK_ACTION_COPY) - suggested_action = GDK_ACTION_COPY; - else if (possible_actions & GDK_ACTION_MOVE) - suggested_action = GDK_ACTION_MOVE; - else if (possible_actions & GDK_ACTION_ASK) - suggested_action = GDK_ACTION_ASK; - else - suggested_action = 0; - } + suggested_action = 0; xev.xclient.type = ClientMessage; xev.xclient.message_type = gdk_x11_get_xatom_by_name_for_display (display, "XdndStatus");