mirror of
https://github.com/hyprwm/wlroots-hyprland.git
synced 2025-01-10 17:59:48 +01:00
ce3f4c3fe1
The backend doesn't need to handle transform changes, since everything is done in software. In fact, all of the implementations were all identical and just set the transform. We could add support for hardware transforms, but: - This would require a different field (something like hardware_transform) - Not all combinations are possible because there often are hardware limitations - The Wayland protocol isn't ready for this (in particular xdg-output, see [1]) This belongs to a different patch series anyway. [1]: https://patchwork.freedesktop.org/series/52324/
51 lines
2.1 KiB
C
51 lines
2.1 KiB
C
/*
|
|
* 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_INTERFACES_WLR_OUTPUT_H
|
|
#define WLR_INTERFACES_WLR_OUTPUT_H
|
|
|
|
#include <stdbool.h>
|
|
#include <wlr/backend.h>
|
|
#include <wlr/types/wlr_box.h>
|
|
#include <wlr/types/wlr_output.h>
|
|
|
|
struct wlr_output_impl {
|
|
bool (*enable)(struct wlr_output *output, bool enable);
|
|
bool (*set_mode)(struct wlr_output *output, struct wlr_output_mode *mode);
|
|
bool (*set_custom_mode)(struct wlr_output *output, int32_t width,
|
|
int32_t height, int32_t refresh);
|
|
bool (*set_cursor)(struct wlr_output *output, struct wlr_texture *texture,
|
|
int32_t scale, enum wl_output_transform transform,
|
|
int32_t hotspot_x, int32_t hotspot_y, bool update_texture);
|
|
bool (*move_cursor)(struct wlr_output *output, int x, int y);
|
|
void (*destroy)(struct wlr_output *output);
|
|
bool (*attach_render)(struct wlr_output *output, int *buffer_age);
|
|
bool (*commit)(struct wlr_output *output);
|
|
bool (*set_gamma)(struct wlr_output *output, size_t size,
|
|
const uint16_t *r, const uint16_t *g, const uint16_t *b);
|
|
size_t (*get_gamma_size)(struct wlr_output *output);
|
|
bool (*export_dmabuf)(struct wlr_output *output,
|
|
struct wlr_dmabuf_attributes *attribs);
|
|
bool (*schedule_frame)(struct wlr_output *output);
|
|
bool (*attach_buffer)(struct wlr_output *output, struct wlr_buffer *buffer);
|
|
};
|
|
|
|
void wlr_output_init(struct wlr_output *output, struct wlr_backend *backend,
|
|
const struct wlr_output_impl *impl, struct wl_display *display);
|
|
void wlr_output_update_mode(struct wlr_output *output,
|
|
struct wlr_output_mode *mode);
|
|
void wlr_output_update_custom_mode(struct wlr_output *output, int32_t width,
|
|
int32_t height, int32_t refresh);
|
|
void wlr_output_update_enabled(struct wlr_output *output, bool enabled);
|
|
void wlr_output_update_needs_frame(struct wlr_output *output);
|
|
void wlr_output_damage_whole(struct wlr_output *output);
|
|
void wlr_output_send_frame(struct wlr_output *output);
|
|
void wlr_output_send_present(struct wlr_output *output,
|
|
struct wlr_output_event_present *event);
|
|
|
|
#endif
|