diff --git a/docs/reference/gtk/meson.build b/docs/reference/gtk/meson.build
index 0ee718a1c5..4091c704e3 100644
--- a/docs/reference/gtk/meson.build
+++ b/docs/reference/gtk/meson.build
@@ -97,7 +97,6 @@ private_headers = [
'gtkcsswidgetnodeprivate.h',
'gtkcsswin32sizevalueprivate.h',
'gtkdialogprivate.h',
- 'gtkdndprivate.h',
'gtkentryprivate.h',
'gtkeventcontrollerlegacyprivate.h',
'gtkeventcontrollerprivate.h',
diff --git a/gtk/gtkdnd.c b/gtk/gtkdnd.c
deleted file mode 100644
index 5bb5b45190..0000000000
--- a/gtk/gtkdnd.c
+++ /dev/null
@@ -1,141 +0,0 @@
-/* GTK - The GIMP Toolkit
- * Copyright (C) 1995-1999 Peter Mattis, Spencer Kimball and Josh MacDonald
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library. If not, see .
- */
-
-/*
- * Modified by the GTK+ Team and others 1997-2000. See the AUTHORS
- * file for a list of people on the GTK+ Team. See the ChangeLog
- * files for a list of changes. These files are distributed with
- * GTK+ at ftp://ftp.gtk.org/pub/gtk/.
- */
-
-#include "config.h"
-
-#include "gtkdndprivate.h"
-
-#include "gtkdragdestprivate.h"
-#include "gtkimageprivate.h"
-#include "gtkintl.h"
-#include "gtkmain.h"
-#include "gtkpicture.h"
-#include "gtkselectionprivate.h"
-#include "gtksettingsprivate.h"
-#include "gtkstylecontext.h"
-#include "gtktooltipprivate.h"
-#include "gtkwidgetprivate.h"
-#include "gtkwindowgroup.h"
-#include "gtkwindowprivate.h"
-#include "gtknative.h"
-#include "gtkdragiconprivate.h"
-
-#include "gdk/gdkcontentformatsprivate.h"
-#include "gdk/gdktextureprivate.h"
-
-#include
-#include
-#include
-
-
-/**
- * SECTION:gtkdnd
- * @Short_description: Functions for controlling drag and drop handling
- * @Title: Drag and Drop
- *
- * GTK+ has a rich set of functions for doing inter-process communication
- * via the drag-and-drop metaphor.
- *
- * As well as the functions listed here, applications may need to use some
- * facilities provided for [Selections][gtk3-Selections]. Also, the Drag and
- * Drop API makes use of signals in the #GtkWidget class.
- */
-
-/*
- * gtk_drag_dest_handle_event:
- * @toplevel: Toplevel widget that received the event
- * @event: the event to handle
- *
- * Called from widget event handling code on Drag events
- * for destinations. For drag-motion and drop-start events,
- * this function is only called if no event handler has
- * handled the event.
- */
-void
-gtk_drag_dest_handle_event (GtkWidget *toplevel,
- GdkEvent *event)
-{
- GtkDropTarget *dest;
- GdkDrop *drop;
- GdkEventType event_type;
-
- g_return_if_fail (toplevel != NULL);
- g_return_if_fail (event != NULL);
-
- event_type = gdk_event_get_event_type (event);
- drop = gdk_event_get_drop (event);
-
- /* Find the widget for the event */
- switch ((guint) event_type)
- {
- case GDK_DRAG_ENTER:
- break;
-
- case GDK_DRAG_LEAVE:
- dest = gtk_drop_get_current_dest (drop);
- if (dest)
- {
- gtk_drop_target_emit_drag_leave (dest, drop);
- gtk_drop_set_current_dest (drop, NULL);
- }
- break;
-
- case GDK_DRAG_MOTION:
- case GDK_DROP_START:
- gdk_drop_status (drop, 0);
- break;
-
- default:
- g_assert_not_reached ();
- }
-}
-
-static void
-clear_current_dest (gpointer data, GObject *former_object)
-{
- g_object_set_data (G_OBJECT (data), "current-dest", NULL);
-}
-
-void
-gtk_drop_set_current_dest (GdkDrop *drop,
- GtkDropTarget *dest)
-{
- GtkDropTarget *old_dest;
-
- old_dest = g_object_get_data (G_OBJECT (drop), "current-dest");
-
- if (old_dest)
- g_object_weak_unref (G_OBJECT (old_dest), clear_current_dest, drop);
-
- g_object_set_data (G_OBJECT (drop), "current-dest", dest);
-
- if (dest)
- g_object_weak_ref (G_OBJECT (dest), clear_current_dest, drop);
-}
-
-GtkDropTarget *
-gtk_drop_get_current_dest (GdkDrop *drop)
-{
- return g_object_get_data (G_OBJECT (drop), "current-dest");
-}
diff --git a/gtk/gtkdndprivate.h b/gtk/gtkdndprivate.h
deleted file mode 100644
index 4de9a173d5..0000000000
--- a/gtk/gtkdndprivate.h
+++ /dev/null
@@ -1,37 +0,0 @@
-/* -*- Mode: C; c-file-style: "gnu"; tab-width: 8 -*- */
-/* GTK - The GIMP Toolkit
- * Copyright (C) 2015 Red Hat, Inc.
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library. If not, see .
- */
-
-#ifndef __GTK_DND_PRIVATE_H__
-#define __GTK_DND_PRIVATE_H__
-
-#include "gtkwidget.h"
-#include "gtkdragdest.h"
-
-
-G_BEGIN_DECLS
-
-void gtk_drag_dest_handle_event (GtkWidget *toplevel,
- GdkEvent *event);
-
-void gtk_drop_set_current_dest (GdkDrop *drop,
- GtkDropTarget *dest);
-GtkDropTarget *gtk_drop_get_current_dest (GdkDrop *drop);
-
-G_END_DECLS
-
-#endif /* __GTK_DND_PRIVATE_H__ */
diff --git a/gtk/gtkdragdest.c b/gtk/gtkdragdest.c
index 9c2e802076..adf7edfa16 100644
--- a/gtk/gtkdragdest.c
+++ b/gtk/gtkdragdest.c
@@ -27,7 +27,6 @@
#include "gtkdragdest.h"
#include "gtkdragdestprivate.h"
-#include "gtkdndprivate.h"
#include "gtkintl.h"
#include "gtknative.h"
#include "gtktypebuiltins.h"
@@ -102,6 +101,10 @@ static void gtk_drop_target_set_widget (GtkEventController *controller,
GtkWidget *widget);
static void gtk_drop_target_unset_widget (GtkEventController *controller);
+static gboolean gtk_drop_target_get_armed (GtkDropTarget *dest);
+static void gtk_drop_target_set_armed (GtkDropTarget *dest,
+ gboolean armed);
+
G_DEFINE_TYPE (GtkDropTarget, gtk_drop_target, GTK_TYPE_EVENT_CONTROLLER);
static void
@@ -439,12 +442,6 @@ gtk_drag_dest_hierarchy_changed (GtkWidget *widget,
gdk_surface_register_dnd (gtk_native_get_surface (native));
}
-GtkDropTarget *
-gtk_drop_target_get (GtkWidget *widget)
-{
- return g_object_get_data (G_OBJECT (widget), I_("gtk-drag-dest"));
-}
-
/**
* gtk_drop_target_get_target:
* @dest: a #GtkDropTarget
@@ -477,7 +474,7 @@ gtk_drop_target_get_drop (GtkDropTarget *dest)
return dest->drop;
}
-const char *
+static const char *
gtk_drop_target_match (GtkDropTarget *dest,
GdkDrop *drop)
{
@@ -557,7 +554,7 @@ set_drop (GtkDropTarget *dest,
g_object_add_weak_pointer (G_OBJECT (dest->drop), (gpointer *)&dest->drop);
}
-void
+static void
gtk_drop_target_emit_drag_leave (GtkDropTarget *dest,
GdkDrop *drop)
{
@@ -567,7 +564,7 @@ gtk_drop_target_emit_drag_leave (GtkDropTarget *dest,
gtk_drop_target_set_armed (dest, FALSE);
}
-gboolean
+static gboolean
gtk_drop_target_emit_drag_motion (GtkDropTarget *dest,
GdkDrop *drop,
int x,
@@ -586,7 +583,7 @@ gtk_drop_target_emit_drag_motion (GtkDropTarget *dest,
return result;
}
-gboolean
+static gboolean
gtk_drop_target_emit_drag_drop (GtkDropTarget *dest,
GdkDrop *drop,
int x,
@@ -600,7 +597,7 @@ gtk_drop_target_emit_drag_drop (GtkDropTarget *dest,
return result;
}
-void
+static void
gtk_drop_target_set_armed (GtkDropTarget *dest,
gboolean armed)
{
@@ -623,7 +620,7 @@ gtk_drop_target_set_armed (GtkDropTarget *dest,
g_object_notify_by_pspec (G_OBJECT (dest), properties[PROP_ARMED]);
}
-gboolean
+static gboolean
gtk_drop_target_get_armed (GtkDropTarget *dest)
{
return dest->armed;
@@ -647,6 +644,35 @@ gtk_drop_target_filter_event (GtkEventController *controller,
return TRUE;
}
+static void
+clear_current_dest (gpointer data, GObject *former_object)
+{
+ g_object_set_data (G_OBJECT (data), "current-dest", NULL);
+}
+
+static void
+gtk_drop_set_current_dest (GdkDrop *drop,
+ GtkDropTarget *dest)
+{
+ GtkDropTarget *old_dest;
+
+ old_dest = g_object_get_data (G_OBJECT (drop), "current-dest");
+
+ if (old_dest)
+ g_object_weak_unref (G_OBJECT (old_dest), clear_current_dest, drop);
+
+ g_object_set_data (G_OBJECT (drop), "current-dest", dest);
+
+ if (dest)
+ g_object_weak_ref (G_OBJECT (dest), clear_current_dest, drop);
+}
+
+static GtkDropTarget *
+gtk_drop_get_current_dest (GdkDrop *drop)
+{
+ return g_object_get_data (G_OBJECT (drop), "current-dest");
+}
+
static gboolean
gtk_drop_target_handle_event (GtkEventController *controller,
const GdkEvent *event)
@@ -699,6 +725,48 @@ gtk_drop_target_handle_event (GtkEventController *controller,
return found;
}
+/*
+ * This function is called if none of the event
+ * controllers has handled a drag event.
+ */
+void
+gtk_drag_dest_handle_event (GtkWidget *toplevel,
+ GdkEvent *event)
+{
+ GtkDropTarget *dest;
+ GdkDrop *drop;
+ GdkEventType event_type;
+
+ g_return_if_fail (toplevel != NULL);
+ g_return_if_fail (event != NULL);
+
+ event_type = gdk_event_get_event_type (event);
+ drop = gdk_event_get_drop (event);
+
+ switch ((guint) event_type)
+ {
+ case GDK_DRAG_ENTER:
+ break;
+
+ case GDK_DRAG_LEAVE:
+ dest = gtk_drop_get_current_dest (drop);
+ if (dest)
+ {
+ gtk_drop_target_emit_drag_leave (dest, drop);
+ gtk_drop_set_current_dest (drop, NULL);
+ }
+ break;
+
+ case GDK_DRAG_MOTION:
+ case GDK_DROP_START:
+ gdk_drop_status (drop, 0);
+ break;
+
+ default:
+ g_assert_not_reached ();
+ }
+}
+
static void
gtk_drop_target_set_widget (GtkEventController *controller,
GtkWidget *widget)
diff --git a/gtk/gtkdragdestprivate.h b/gtk/gtkdragdestprivate.h
index cb1c031208..0113f98709 100644
--- a/gtk/gtkdragdestprivate.h
+++ b/gtk/gtkdragdestprivate.h
@@ -23,27 +23,9 @@
G_BEGIN_DECLS
-void gtk_drop_target_emit_drag_data_received (GtkDropTarget *dest,
- GdkDrop *drop,
- GtkSelectionData *sdata);
-void gtk_drop_target_emit_drag_leave (GtkDropTarget *dest,
- GdkDrop *drop);
-gboolean gtk_drop_target_emit_drag_motion (GtkDropTarget *dest,
- GdkDrop *drop,
- int x,
- int y);
-gboolean gtk_drop_target_emit_drag_drop (GtkDropTarget *dest,
- GdkDrop *drop,
- int x,
- int y);
-const char * gtk_drop_target_match (GtkDropTarget *dest,
- GdkDrop *drop);
-void gtk_drop_target_set_armed (GtkDropTarget *dest,
- gboolean armed);
-gboolean gtk_drop_target_get_armed (GtkDropTarget *dest);
-
-GtkDropTarget *gtk_drop_target_get (GtkWidget *widget);
+void gtk_drag_dest_handle_event (GtkWidget *toplevel,
+ GdkEvent *event);
G_END_DECLS
diff --git a/gtk/gtkdragsource.c b/gtk/gtkdragsource.c
index 7c3b249a33..53c80774d3 100644
--- a/gtk/gtkdragsource.c
+++ b/gtk/gtkdragsource.c
@@ -26,7 +26,6 @@
#include "gtkdragsource.h"
-#include "gtkdndprivate.h"
#include "gtkgesturedrag.h"
#include "gtkgesturesingleprivate.h"
#include "gtkimagedefinitionprivate.h"
diff --git a/gtk/gtkentry.c b/gtk/gtkentry.c
index db33c193aa..1b249b2fb6 100644
--- a/gtk/gtkentry.c
+++ b/gtk/gtkentry.c
@@ -38,7 +38,6 @@
#include "gtkcelllayout.h"
#include "gtkcssnodeprivate.h"
#include "gtkdebug.h"
-#include "gtkdndprivate.h"
#include "gtkeditable.h"
#include "gtkemojichooser.h"
#include "gtkemojicompletion.h"
diff --git a/gtk/gtkmain.c b/gtk/gtkmain.c
index 504fe53382..3cfaf57396 100644
--- a/gtk/gtkmain.c
+++ b/gtk/gtkmain.c
@@ -116,7 +116,7 @@
#include "gtkaccelmapprivate.h"
#include "gtkbox.h"
#include "gtkdebug.h"
-#include "gtkdndprivate.h"
+#include "gtkdragdestprivate.h"
#include "gtkmain.h"
#include "gtkmediafileprivate.h"
#include "gtkmodulesprivate.h"
diff --git a/gtk/gtktext.c b/gtk/gtktext.c
index 27916ada67..72cf662fc6 100644
--- a/gtk/gtktext.c
+++ b/gtk/gtktext.c
@@ -30,7 +30,6 @@
#include "gtkbutton.h"
#include "gtkcssnodeprivate.h"
#include "gtkdebug.h"
-#include "gtkdndprivate.h"
#include "gtkeditable.h"
#include "gtkemojichooser.h"
#include "gtkemojicompletion.h"
diff --git a/gtk/meson.build b/gtk/meson.build
index 40ae032cfd..cf032943ad 100644
--- a/gtk/meson.build
+++ b/gtk/meson.build
@@ -214,7 +214,6 @@ gtk_public_sources = files([
'gtkcontainer.c',
'gtkcssprovider.c',
'gtkdialog.c',
- 'gtkdnd.c',
'gtkdragdest.c',
'gtkdragsource.c',
'gtkdrawingarea.c',