aboutsummaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2018-03-31 10:13:43 -0400
committerGitHub <noreply@github.com>2018-03-31 10:13:43 -0400
commit96c6091f802c803ccd6c7acd3e1165f6a8d4da2d (patch)
treee7e8bc3fef7a367c687ce63d35fcd647f413a35f /include
parent937362b5521fe501d3fb060c5c73e6ae18cc0826 (diff)
parent5111f7df84cea46e1e30cc5b460568e5d46e584a (diff)
Merge pull request #786 from emersion/x11-backend-multiple-outputs
backend/x11: add support for multiple outputs
Diffstat (limited to 'include')
-rw-r--r--include/backend/x11.h27
-rw-r--r--include/wlr/backend/x11.h1
2 files changed, 26 insertions, 2 deletions
diff --git a/include/backend/x11.h b/include/backend/x11.h
index 72710f6c..0426e481 100644
--- a/include/backend/x11.h
+++ b/include/backend/x11.h
@@ -3,29 +3,40 @@
#include <stdbool.h>
#include <wayland-server.h>
+#include <wlr/backend/x11.h>
+#include <wlr/interfaces/wlr_input_device.h>
+#include <wlr/interfaces/wlr_output.h>
#include <wlr/render/egl.h>
#include <X11/Xlib-xcb.h>
#include <xcb/xcb.h>
+#define XCB_EVENT_RESPONSE_TYPE_MASK 0x7f
+
struct wlr_x11_backend;
struct wlr_x11_output {
struct wlr_output wlr_output;
struct wlr_x11_backend *x11;
+ struct wl_list link; // wlr_x11_backend::outputs
xcb_window_t win;
EGLSurface surf;
+
+ struct wl_event_source *frame_timer;
+ int frame_delay;
};
struct wlr_x11_backend {
struct wlr_backend backend;
struct wl_display *wl_display;
+ bool started;
Display *xlib_conn;
xcb_connection_t *xcb_conn;
xcb_screen_t *screen;
- struct wlr_x11_output output;
+ size_t requested_outputs;
+ struct wl_list outputs; // wlr_x11_output::link
struct wlr_keyboard keyboard;
struct wlr_input_device keyboard_dev;
@@ -36,7 +47,6 @@ struct wlr_x11_backend {
struct wlr_egl egl;
struct wlr_renderer *renderer;
struct wl_event_source *event_source;
- struct wl_event_source *frame_timer;
struct {
xcb_atom_t wm_protocols;
@@ -57,4 +67,17 @@ struct wlr_x11_backend {
struct wl_listener display_destroy;
};
+struct wlr_x11_output *x11_output_from_window_id(struct wlr_x11_backend *x11,
+ xcb_window_t window);
+void x11_output_layout_get_box(struct wlr_x11_backend *backend,
+ struct wlr_box *box);
+
+const struct wlr_input_device_impl input_device_impl;
+
+bool x11_handle_input_event(struct wlr_x11_backend *x11,
+ xcb_generic_event_t *event);
+
+void x11_output_handle_configure_notify(struct wlr_x11_output *output,
+ xcb_configure_notify_event_t *event);
+
#endif
diff --git a/include/wlr/backend/x11.h b/include/wlr/backend/x11.h
index b22d7f68..7bc1f891 100644
--- a/include/wlr/backend/x11.h
+++ b/include/wlr/backend/x11.h
@@ -9,6 +9,7 @@
struct wlr_backend *wlr_x11_backend_create(struct wl_display *display,
const char *x11_display);
+struct wlr_output *wlr_x11_output_create(struct wlr_backend *backend);
bool wlr_backend_is_x11(struct wlr_backend *backend);
bool wlr_input_device_is_x11(struct wlr_input_device *device);