aboutsummaryrefslogtreecommitdiff
path: root/include/wlr
diff options
context:
space:
mode:
authoremersion <contact@emersion.fr>2018-12-07 15:50:51 +0100
committeremersion <contact@emersion.fr>2018-12-30 02:48:03 +0100
commit99d879c8878f774aac66e39d7bf4b92f3ae7f0ed (patch)
tree047d62880316a2df2f762f8387760f3c6d22f0ff /include/wlr
parent84c904752f10e24f052beaf12eb3cc529f1bb38d (diff)
data-control-v1: initial protocol implementation
Diffstat (limited to 'include/wlr')
-rw-r--r--include/wlr/types/meson.build3
-rw-r--r--include/wlr/types/wlr_data_control_v1.h47
2 files changed, 49 insertions, 1 deletions
diff --git a/include/wlr/types/meson.build b/include/wlr/types/meson.build
index 752c0dea..5e05c5e5 100644
--- a/include/wlr/types/meson.build
+++ b/include/wlr/types/meson.build
@@ -3,6 +3,7 @@ install_headers(
'wlr_buffer.h',
'wlr_compositor.h',
'wlr_cursor.h',
+ 'wlr_data_control_v1.h',
'wlr_data_device.h',
'wlr_export_dmabuf_v1.h',
'wlr_foreign_toplevel_management_v1.h',
@@ -22,8 +23,8 @@ install_headers(
'wlr_output_damage.h',
'wlr_output_layout.h',
'wlr_output.h',
- 'wlr_pointer.h',
'wlr_pointer_constraints_v1.h',
+ 'wlr_pointer.h',
'wlr_presentation_time.h',
'wlr_primary_selection.h',
'wlr_region.h',
diff --git a/include/wlr/types/wlr_data_control_v1.h b/include/wlr/types/wlr_data_control_v1.h
new file mode 100644
index 00000000..69d7281b
--- /dev/null
+++ b/include/wlr/types/wlr_data_control_v1.h
@@ -0,0 +1,47 @@
+/*
+ * This an unstable interface of wlroots. No guarantees are made regarding the
+ * future consistency of this API.
+ */
+#ifndef WLR_USE_UNSTABLE
+#error "Add -DWLR_USE_UNSTABLE to enable unstable wlroots features"
+#endif
+
+#ifndef WLR_TYPES_WLR_DATA_CONTROL_V1_H
+#define WLR_TYPES_WLR_DATA_CONTROL_V1_H
+
+#include <wayland-server.h>
+#include <wlr/types/wlr_seat.h>
+
+struct wlr_data_control_manager_v1 {
+ struct wl_global *global;
+ struct wl_list resources; // wl_resource_get_link
+ struct wl_list controls; // wlr_data_control_v1::link
+
+ struct {
+ struct wl_signal destroy;
+ struct wl_signal new_control; // wlr_data_control_v1
+ } events;
+
+ struct wl_listener display_destroy;
+};
+
+struct wlr_data_control_v1 {
+ struct wl_resource *resource;
+ struct wlr_data_control_manager_v1 *manager;
+ struct wl_list link; // wlr_data_control_manager_v1::controls
+
+ struct wlr_seat *seat;
+ struct wl_resource *selection_offer_resource; // current selection offer
+
+ struct wl_listener seat_destroy;
+ struct wl_listener seat_selection;
+};
+
+struct wlr_data_control_manager_v1 *wlr_data_control_manager_v1_create(
+ struct wl_display *display);
+void wlr_data_control_manager_v1_destroy(
+ struct wlr_data_control_manager_v1 *manager);
+
+void wlr_data_control_v1_destroy(struct wlr_data_control_v1 *control);
+
+#endif