diff options
| author | Drew DeVault <sir@cmpwn.com> | 2018-03-31 10:13:43 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-03-31 10:13:43 -0400 | 
| commit | 96c6091f802c803ccd6c7acd3e1165f6a8d4da2d (patch) | |
| tree | e7e8bc3fef7a367c687ce63d35fcd647f413a35f /include | |
| parent | 937362b5521fe501d3fb060c5c73e6ae18cc0826 (diff) | |
| parent | 5111f7df84cea46e1e30cc5b460568e5d46e584a (diff) | |
| download | wlroots-96c6091f802c803ccd6c7acd3e1165f6a8d4da2d.tar.xz | |
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.h | 27 | ||||
| -rw-r--r-- | include/wlr/backend/x11.h | 1 | 
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); | 
