5706d7e5d2
In this MR we add support to the majority of the interfaces from the color-management protocol. That means that we are able to advertise output's images descriptions to clients, preferred surface images descriptions, and so on. We also support clients that wants to create ICC-based images descriptions and set such descriptions for surfaces. We still don't support the interface to allow clients to create image descriptions from parameters, but that should be addressed in the near future. Signed-off-by: Leandro Ribeiro <leandro.ribeiro@collabora.com>
2720 lines
77 KiB
C
2720 lines
77 KiB
C
/*
|
|
* Copyright © 2008-2011 Kristian Høgsberg
|
|
* Copyright © 2012, 2017, 2018, 2021 Collabora, Ltd.
|
|
* Copyright © 2017, 2018 General Electric Company
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining
|
|
* a copy of this software and associated documentation files (the
|
|
* "Software"), to deal in the Software without restriction, including
|
|
* without limitation the rights to use, copy, modify, merge, publish,
|
|
* distribute, sublicense, and/or sell copies of the Software, and to
|
|
* permit persons to whom the Software is furnished to do so, subject to
|
|
* the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice (including the
|
|
* next paragraph) shall be included in all copies or substantial
|
|
* portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
|
|
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
|
|
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
* SOFTWARE.
|
|
*/
|
|
|
|
#ifndef _WAYLAND_SYSTEM_COMPOSITOR_H_
|
|
#define _WAYLAND_SYSTEM_COMPOSITOR_H_
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#include <stdbool.h>
|
|
#include <stdint.h>
|
|
#include <time.h>
|
|
#include <pixman.h>
|
|
#include <xkbcommon/xkbcommon.h>
|
|
|
|
#define WL_HIDE_DEPRECATED
|
|
#include <wayland-server.h>
|
|
|
|
#include <libweston/matrix.h>
|
|
#include <libweston/zalloc.h>
|
|
|
|
struct weston_log_pacer {
|
|
/** This must be set to zero before first use */
|
|
bool initialized;
|
|
struct timespec burst_start;
|
|
unsigned int event_count;
|
|
unsigned int max_burst;
|
|
unsigned int reset_ms;
|
|
};
|
|
|
|
struct weston_geometry {
|
|
int32_t x, y;
|
|
int32_t width, height;
|
|
};
|
|
|
|
struct weston_size {
|
|
int32_t width, height;
|
|
};
|
|
|
|
struct weston_transform {
|
|
struct weston_matrix matrix;
|
|
struct wl_list link;
|
|
};
|
|
|
|
/** 2D device coordinates normalized to [0, 1] range */
|
|
struct weston_point2d_device_normalized {
|
|
double x;
|
|
double y;
|
|
};
|
|
|
|
struct weston_surface;
|
|
struct weston_buffer;
|
|
struct shell_surface;
|
|
struct weston_seat;
|
|
struct weston_output;
|
|
struct input_method;
|
|
struct weston_pointer;
|
|
struct linux_dmabuf_buffer;
|
|
struct weston_recorder;
|
|
struct weston_pointer_constraint;
|
|
struct ro_anonymous_file;
|
|
struct weston_color_profile;
|
|
struct weston_color_transform;
|
|
struct pixel_format_info;
|
|
struct weston_output_capture_info;
|
|
struct weston_tearing_control;
|
|
|
|
enum weston_keyboard_modifier {
|
|
MODIFIER_CTRL = (1 << 0),
|
|
MODIFIER_ALT = (1 << 1),
|
|
MODIFIER_SUPER = (1 << 2),
|
|
MODIFIER_SHIFT = (1 << 3),
|
|
};
|
|
|
|
enum weston_keyboard_locks {
|
|
WESTON_NUM_LOCK = (1 << 0),
|
|
WESTON_CAPS_LOCK = (1 << 1),
|
|
};
|
|
|
|
enum weston_led {
|
|
LED_NUM_LOCK = (1 << 0),
|
|
LED_CAPS_LOCK = (1 << 1),
|
|
LED_SCROLL_LOCK = (1 << 2),
|
|
};
|
|
|
|
enum weston_mode_aspect_ratio {
|
|
/** The picture aspect ratio values, for the aspect_ratio field of
|
|
* weston_mode. The values here, are taken from
|
|
* DRM_MODE_PICTURE_ASPECT_* from drm_mode.h.
|
|
*/
|
|
WESTON_MODE_PIC_AR_NONE = 0, /* DRM_MODE_PICTURE_ASPECT_NONE */
|
|
WESTON_MODE_PIC_AR_4_3 = 1, /* DRM_MODE_PICTURE_ASPECT_4_3 */
|
|
WESTON_MODE_PIC_AR_16_9 = 2, /* DRM_MODE_PICTURE_ASPECT_16_9 */
|
|
WESTON_MODE_PIC_AR_64_27 = 3, /* DRM_MODE_PICTURE_ASPECT_64_27 */
|
|
WESTON_MODE_PIC_AR_256_135 = 4, /* DRM_MODE_PICTURE_ASPECT_256_135*/
|
|
};
|
|
|
|
enum weston_surface_protection_mode {
|
|
WESTON_SURFACE_PROTECTION_MODE_RELAXED,
|
|
WESTON_SURFACE_PROTECTION_MODE_ENFORCED
|
|
};
|
|
|
|
/** Possible mode of an output
|
|
*
|
|
* \ingroup output
|
|
*/
|
|
struct weston_mode {
|
|
uint32_t flags;
|
|
/** Picture aspect ratio.*/
|
|
enum weston_mode_aspect_ratio aspect_ratio;
|
|
int32_t width; /**< Width in pixels. */
|
|
int32_t height; /**< Height in pixels. */
|
|
uint32_t refresh; /**< Refresh rate in mHz. */
|
|
struct wl_list link; /**< in weston_output::mode_list */
|
|
};
|
|
|
|
struct weston_animation {
|
|
void (*frame)(struct weston_animation *animation,
|
|
struct weston_output *output,
|
|
const struct timespec *time);
|
|
int frame_counter;
|
|
struct wl_list link;
|
|
};
|
|
|
|
enum {
|
|
WESTON_SPRING_OVERSHOOT,
|
|
WESTON_SPRING_CLAMP,
|
|
WESTON_SPRING_BOUNCE
|
|
};
|
|
|
|
struct weston_spring {
|
|
double k;
|
|
double friction;
|
|
double current;
|
|
double target;
|
|
double previous;
|
|
double min, max;
|
|
struct timespec timestamp;
|
|
uint32_t clip;
|
|
};
|
|
|
|
/* bit compatible with drm definitions. */
|
|
enum dpms_enum {
|
|
WESTON_DPMS_ON,
|
|
WESTON_DPMS_STANDBY,
|
|
WESTON_DPMS_SUSPEND,
|
|
WESTON_DPMS_OFF
|
|
};
|
|
|
|
/* enum for content protection requests/status
|
|
*
|
|
* This enum represents the content protection requests and statuses in
|
|
* libweston and its enum values correspond to those of 'type' enum defined in
|
|
* weston-content-protection protocol. The values should exactly match to the
|
|
* values of the 'type' enum of the protocol.
|
|
*/
|
|
|
|
enum weston_hdcp_protection {
|
|
WESTON_HDCP_DISABLE = 0,
|
|
WESTON_HDCP_ENABLE_TYPE_0,
|
|
WESTON_HDCP_ENABLE_TYPE_1
|
|
};
|
|
|
|
/** Weston test suite quirks
|
|
*
|
|
* There are some things that need a specific behavior when we run Weston in the
|
|
* test suite. Tests can use this struct to select for certain behaviors.
|
|
*
|
|
* \sa compositor_setup
|
|
* \ingroup testharness
|
|
*/
|
|
struct weston_testsuite_quirks {
|
|
/** Force GL-renderer to do a full upload of wl_shm buffers. */
|
|
bool gl_force_full_upload;
|
|
/** Ensure GL shadow fb is used, and always repaint it fully. */
|
|
bool gl_force_full_redraw_of_shadow_fb;
|
|
/** Required enum weston_capability bit mask, otherwise skip run. */
|
|
uint32_t required_capabilities;
|
|
};
|
|
|
|
/** Weston test suite data that is given to compositor
|
|
*
|
|
* It contains two members:
|
|
*
|
|
* 1. The struct weston_testsuite_quirks, which can be used by the tests to
|
|
* change certain behavior of Weston when running these tests.
|
|
* 2. The void *test_private_data member which can be used by the testsuite of
|
|
* projects that uses libweston in order to give arbitrary test data to the
|
|
* compositor. Its type should be defined by the testsuite of the project.
|
|
*
|
|
* \sa compositor_setup
|
|
* \ingroup testharness
|
|
*/
|
|
struct weston_testsuite_data {
|
|
struct weston_testsuite_quirks test_quirks;
|
|
void *test_private_data;
|
|
};
|
|
|
|
/** EOTF mode for outputs and heads
|
|
*
|
|
* A list of EOTF modes for driving displays, defined by CTA-861-G for
|
|
* Dynamic Range and Mastering InfoFrame.
|
|
*
|
|
* On heads, a bitmask of one or more entries shows which modes are claimed
|
|
* supported.
|
|
*
|
|
* On outputs, the mode to be used for driving the video sink.
|
|
*
|
|
* For traditional non-HDR sRGB, use WESTON_EOTF_MODE_SDR.
|
|
*/
|
|
enum weston_eotf_mode {
|
|
/** Invalid EOTF mode, or none supported. */
|
|
WESTON_EOTF_MODE_NONE = 0,
|
|
|
|
/** Traditional gamma, SDR luminance range */
|
|
WESTON_EOTF_MODE_SDR = 0x01,
|
|
|
|
/** Traditional gamma, HDR luminance range */
|
|
WESTON_EOTF_MODE_TRADITIONAL_HDR = 0x02,
|
|
|
|
/** Preceptual quantizer, SMPTE ST 2084 */
|
|
WESTON_EOTF_MODE_ST2084 = 0x04,
|
|
|
|
/** Hybrid log-gamma, ITU-R BT.2100 */
|
|
WESTON_EOTF_MODE_HLG = 0x08,
|
|
};
|
|
|
|
/** Bitmask of all defined EOTF modes */
|
|
#define WESTON_EOTF_MODE_ALL_MASK \
|
|
((uint32_t)(WESTON_EOTF_MODE_SDR | WESTON_EOTF_MODE_TRADITIONAL_HDR | \
|
|
WESTON_EOTF_MODE_ST2084 | WESTON_EOTF_MODE_HLG))
|
|
|
|
/** CIE 1931 xy chromaticity coordinates */
|
|
struct weston_CIExy {
|
|
float x;
|
|
float y;
|
|
};
|
|
|
|
enum weston_hdr_metadata_type1_groups {
|
|
/** weston_hdr_metadata_type1::primary is set */
|
|
WESTON_HDR_METADATA_TYPE1_GROUP_PRIMARIES = 0x01,
|
|
|
|
/** weston_hdr_metadata_type1::white is set */
|
|
WESTON_HDR_METADATA_TYPE1_GROUP_WHITE = 0x02,
|
|
|
|
/** weston_hdr_metadata_type1::maxDML is set */
|
|
WESTON_HDR_METADATA_TYPE1_GROUP_MAXDML = 0x04,
|
|
|
|
/** weston_hdr_metadata_type1::minDML is set */
|
|
WESTON_HDR_METADATA_TYPE1_GROUP_MINDML = 0x08,
|
|
|
|
/** weston_hdr_metadata_type1::maxCLL is set */
|
|
WESTON_HDR_METADATA_TYPE1_GROUP_MAXCLL = 0x10,
|
|
|
|
/** weston_hdr_metadata_type1::maxFALL is set */
|
|
WESTON_HDR_METADATA_TYPE1_GROUP_MAXFALL = 0x20,
|
|
|
|
/** all valid bits */
|
|
WESTON_HDR_METADATA_TYPE1_GROUP_ALL_MASK = 0x3f
|
|
};
|
|
|
|
/** HDR static metadata type 1
|
|
*
|
|
* The fields are defined by CTA-861-G except here they use float encoding.
|
|
*
|
|
* In Weston used only with HDR display modes.
|
|
*/
|
|
struct weston_hdr_metadata_type1 {
|
|
/** Which fields are valid
|
|
*
|
|
* A bitmask of values from enum weston_hdr_metadata_type1_groups.
|
|
*/
|
|
uint32_t group_mask;
|
|
|
|
/* EOTF is tracked externally with enum weston_eotf_mode */
|
|
|
|
/** Chromaticities of the primaries, in any order */
|
|
struct weston_CIExy primary[3];
|
|
|
|
/** White point chromaticity */
|
|
struct weston_CIExy white;
|
|
|
|
/** Maximum display mastering luminance, 1 - 65535 cd/m² */
|
|
float maxDML;
|
|
|
|
/** Minimum display mastering luminance, 0.0001 - 6.5535 cd/m² */
|
|
float minDML;
|
|
|
|
/** Maximum content light level, 1 - 65535 cd/m² */
|
|
float maxCLL;
|
|
|
|
/** Maximum frame-average light level, 1 - 65535 cd/m² */
|
|
float maxFALL;
|
|
};
|
|
|
|
enum weston_color_characteristics_groups {
|
|
/** weston_color_characteristics::primary is set */
|
|
WESTON_COLOR_CHARACTERISTICS_GROUP_PRIMARIES = 0x01,
|
|
|
|
/** weston_color_characteristics::white is set */
|
|
WESTON_COLOR_CHARACTERISTICS_GROUP_WHITE = 0x02,
|
|
|
|
/** weston_color_characteristics::max_luminance is set */
|
|
WESTON_COLOR_CHARACTERISTICS_GROUP_MAXL = 0x04,
|
|
|
|
/** weston_color_characteristics::min_luminance is set */
|
|
WESTON_COLOR_CHARACTERISTICS_GROUP_MINL = 0x08,
|
|
|
|
/** weston_color_characteristics::maxFALL is set */
|
|
WESTON_COLOR_CHARACTERISTICS_GROUP_MAXFALL = 0x10,
|
|
|
|
/** all valid bits */
|
|
WESTON_COLOR_CHARACTERISTICS_GROUP_ALL_MASK = 0x1f
|
|
};
|
|
|
|
/** Basic display color characteristics
|
|
*
|
|
* This is a simple description of a display or output (monitor) color
|
|
* characteristics. The parameters can be found in EDID, with caveats. They
|
|
* are particularly useful with HDR monitors.
|
|
*/
|
|
struct weston_color_characteristics {
|
|
/** Which fields are valid
|
|
*
|
|
* A bitmask of values from enum weston_color_characteristics_groups.
|
|
*/
|
|
uint32_t group_mask;
|
|
|
|
/* EOTF is tracked externally with enum weston_eotf_mode */
|
|
|
|
/** Chromaticities of the primaries */
|
|
struct weston_CIExy primary[3];
|
|
|
|
/** White point chromaticity */
|
|
struct weston_CIExy white;
|
|
|
|
/** Display's desired maximum content peak luminance, cd/m² */
|
|
float max_luminance;
|
|
|
|
/** Display's desired minimum content luminance, cd/m² */
|
|
float min_luminance;
|
|
|
|
/** Display's desired maximum frame-average light level, cd/m² */
|
|
float maxFALL;
|
|
};
|
|
|
|
/** Represents a head, usually a display connector
|
|
*
|
|
* \rst
|
|
See :ref:`libweston-head`. \endrst
|
|
*
|
|
* \ingroup head
|
|
*/
|
|
struct weston_head {
|
|
struct weston_compositor *compositor; /**< owning compositor */
|
|
struct weston_backend *backend; /**< owning backend */
|
|
struct wl_list compositor_link; /**< in weston_compositor::head_list */
|
|
struct wl_signal destroy_signal; /**< destroy callbacks */
|
|
|
|
struct weston_output *output; /**< the output driving this head */
|
|
struct wl_list output_link; /**< in weston_output::head_list */
|
|
|
|
struct wl_list resource_list; /**< wl_output protocol objects */
|
|
struct wl_global *global; /**< wl_output global */
|
|
|
|
struct wl_list xdg_output_resource_list; /**< xdg_output protocol objects */
|
|
|
|
int32_t mm_width; /**< physical image width in mm */
|
|
int32_t mm_height; /**< physical image height in mm */
|
|
|
|
/** WL_OUTPUT_TRANSFORM enum to apply to match native orientation */
|
|
uint32_t transform;
|
|
|
|
char *make; /**< monitor manufacturer (PNP ID) */
|
|
char *model; /**< monitor model */
|
|
char *serial_number; /**< monitor serial */
|
|
uint32_t subpixel; /**< enum wl_output_subpixel */
|
|
bool connection_internal; /**< embedded monitor (e.g. laptop) */
|
|
bool device_changed; /**< monitor information has changed */
|
|
|
|
char *name; /**< head name, e.g. connector name */
|
|
bool connected; /**< is physically connected */
|
|
bool non_desktop; /**< non-desktop display, e.g. HMD */
|
|
uint32_t supported_eotf_mask; /**< supported weston_eotf_mode bits */
|
|
|
|
/** Current content protection status */
|
|
enum weston_hdcp_protection current_protection;
|
|
|
|
/* xx_color_manager_v1.get_color_management_output
|
|
*
|
|
* When a client uses this request, we add the wl_resource we create to
|
|
* this list. */
|
|
struct wl_list cm_output_resource_list;
|
|
};
|
|
|
|
/** Output properties derived from its color characteristics and profile
|
|
*
|
|
* These are constructed by a color manager.
|
|
*
|
|
* A weston_output_color_outcome owns (a reference to) everything it contains.
|
|
*
|
|
* \ingroup output
|
|
* \internal
|
|
*/
|
|
struct weston_output_color_outcome {
|
|
/** sRGB to output color space transformation */
|
|
struct weston_color_transform *from_sRGB_to_output;
|
|
|
|
/** sRGB to blending color space transformation */
|
|
struct weston_color_transform *from_sRGB_to_blend;
|
|
|
|
/** Blending to output color space transformation */
|
|
struct weston_color_transform *from_blend_to_output;
|
|
|
|
/** HDR Static Metadata Type 1 for WESTON_EOTF_MODE_ST2084 */
|
|
struct weston_hdr_metadata_type1 hdr_meta;
|
|
};
|
|
|
|
enum weston_output_power_state {
|
|
/** No rendering and dpms off */
|
|
WESTON_OUTPUT_POWER_FORCED_OFF = 0,
|
|
/** Normal rendering and dpms on */
|
|
WESTON_OUTPUT_POWER_NORMAL
|
|
};
|
|
|
|
struct weston_plane {
|
|
struct weston_compositor *compositor;
|
|
int32_t x, y;
|
|
struct wl_list link;
|
|
};
|
|
|
|
/** Content producer for heads
|
|
*
|
|
* \rst
|
|
See :ref:`libweston-output`. \endrst
|
|
*
|
|
* \ingroup output
|
|
*/
|
|
struct weston_output {
|
|
uint32_t id;
|
|
char *name;
|
|
|
|
struct weston_backend *backend;
|
|
|
|
/** Matches the lifetime from the user perspective */
|
|
struct wl_signal user_destroy_signal;
|
|
|
|
void *renderer_state;
|
|
struct weston_plane primary_plane;
|
|
|
|
struct wl_list link;
|
|
struct weston_compositor *compositor;
|
|
|
|
/* struct weston_paint_node::output_link */
|
|
struct wl_list paint_node_list;
|
|
|
|
/** From global to output buffer coordinates. */
|
|
struct weston_matrix matrix;
|
|
/** From output buffer to global coordinates. */
|
|
struct weston_matrix inverse_matrix;
|
|
|
|
struct wl_list animation_list;
|
|
struct weston_coord_global pos;
|
|
int32_t width, height;
|
|
|
|
/** List of paint nodes in z-order, from top to bottom, maybe pruned
|
|
*
|
|
* struct weston_paint_node::z_order_link
|
|
*/
|
|
struct wl_list paint_node_z_order_list;
|
|
|
|
/** Output area in global coordinates, simple rect */
|
|
pixman_region32_t region;
|
|
|
|
/** True if damage has occurred since the last repaint for this output;
|
|
* if set, a repaint will eventually occur. */
|
|
bool repaint_needed;
|
|
|
|
/** True if the entire contents of the output should be redrawn */
|
|
bool full_repaint_needed;
|
|
|
|
/** Used only between repaint_begin and repaint_cancel. */
|
|
bool repainted;
|
|
|
|
/** State of the repaint loop */
|
|
enum {
|
|
REPAINT_NOT_SCHEDULED = 0, /**< idle; no repaint will occur */
|
|
REPAINT_BEGIN_FROM_IDLE, /**< start_repaint_loop scheduled */
|
|
REPAINT_SCHEDULED, /**< repaint is scheduled to occur */
|
|
REPAINT_AWAITING_COMPLETION, /**< last repaint not yet finished */
|
|
} repaint_status;
|
|
|
|
/** If repaint_status is REPAINT_SCHEDULED, contains the time the
|
|
* next repaint should be run */
|
|
struct timespec next_repaint;
|
|
|
|
/** For cancelling the idle_repaint callback on output destruction. */
|
|
struct wl_event_source *idle_repaint_source;
|
|
|
|
struct wl_signal frame_signal;
|
|
struct wl_signal destroy_signal; /**< sent when disabled */
|
|
struct weston_coord_global move;
|
|
struct timespec frame_time; /* presentation timestamp */
|
|
uint64_t msc; /* media stream counter */
|
|
int disable_planes;
|
|
int destroying;
|
|
struct wl_list feedback_list;
|
|
struct weston_output_capture_info *capture_info;
|
|
|
|
uint32_t transform;
|
|
int32_t native_scale;
|
|
int32_t current_scale;
|
|
int32_t original_scale;
|
|
|
|
struct weston_mode *native_mode;
|
|
struct weston_mode *current_mode;
|
|
struct weston_mode *original_mode;
|
|
struct wl_list mode_list;
|
|
|
|
struct wl_list head_list; /**< List of driven weston_heads */
|
|
|
|
enum weston_hdcp_protection desired_protection;
|
|
enum weston_hdcp_protection current_protection;
|
|
bool allow_protection;
|
|
|
|
enum weston_output_power_state power_state;
|
|
|
|
struct weston_log_pacer repaint_delay_pacer;
|
|
struct weston_log_pacer pixman_overdraw_pacer;
|
|
|
|
int (*start_repaint_loop)(struct weston_output *output);
|
|
int (*repaint)(struct weston_output *output);
|
|
void (*destroy)(struct weston_output *output);
|
|
void (*assign_planes)(struct weston_output *output);
|
|
int (*switch_mode)(struct weston_output *output, struct weston_mode *mode);
|
|
|
|
/* backlight values are on 0-255 range, where higher is brighter */
|
|
int32_t backlight_current;
|
|
void (*set_backlight)(struct weston_output *output, uint32_t value);
|
|
void (*set_dpms)(struct weston_output *output, enum dpms_enum level);
|
|
|
|
uint16_t gamma_size;
|
|
void (*set_gamma)(struct weston_output *output,
|
|
uint16_t size,
|
|
uint16_t *r,
|
|
uint16_t *g,
|
|
uint16_t *b);
|
|
|
|
bool enabled; /**< is in the output_list, not pending list */
|
|
int scale;
|
|
|
|
struct weston_color_profile *color_profile;
|
|
bool from_blend_to_output_by_backend;
|
|
enum weston_eotf_mode eotf_mode;
|
|
struct weston_color_characteristics color_characteristics;
|
|
|
|
struct weston_output_color_outcome *color_outcome;
|
|
uint64_t color_outcome_serial;
|
|
|
|
int (*enable)(struct weston_output *output);
|
|
int (*disable)(struct weston_output *output);
|
|
|
|
/** Attach a head in the backend
|
|
*
|
|
* @param output The output to attach to.
|
|
* @param head The head to attach.
|
|
* @return 0 on success, -1 on failure.
|
|
*
|
|
* Do anything necessary to account for a new head being attached to
|
|
* the output, and check any conditions possible. On failure, both
|
|
* the head and the output must be left as before the call.
|
|
*
|
|
* Libweston core will add the head to the head_list after a successful
|
|
* call.
|
|
*/
|
|
int (*attach_head)(struct weston_output *output,
|
|
struct weston_head *head);
|
|
|
|
/** Detach a head in the backend
|
|
*
|
|
* @param output The output to detach from.
|
|
* @param head The head to detach.
|
|
*
|
|
* Do any clean-up necessary to detach this head from the output.
|
|
* The head has already been removed from the output's head_list.
|
|
*/
|
|
void (*detach_head)(struct weston_output *output,
|
|
struct weston_head *head);
|
|
};
|
|
|
|
enum weston_pointer_motion_mask {
|
|
WESTON_POINTER_MOTION_ABS = 1 << 0,
|
|
WESTON_POINTER_MOTION_REL = 1 << 1,
|
|
WESTON_POINTER_MOTION_REL_UNACCEL = 1 << 2,
|
|
};
|
|
|
|
struct weston_pointer_motion_event {
|
|
uint32_t mask;
|
|
struct timespec time;
|
|
struct weston_coord_global abs;
|
|
struct weston_coord rel;
|
|
struct weston_coord rel_unaccel;
|
|
};
|
|
|
|
struct weston_pointer_axis_event {
|
|
uint32_t axis;
|
|
double value;
|
|
bool has_discrete;
|
|
int32_t discrete;
|
|
};
|
|
|
|
struct weston_pointer_grab;
|
|
struct weston_pointer_grab_interface {
|
|
void (*focus)(struct weston_pointer_grab *grab);
|
|
void (*motion)(struct weston_pointer_grab *grab,
|
|
const struct timespec *time,
|
|
struct weston_pointer_motion_event *event);
|
|
void (*button)(struct weston_pointer_grab *grab,
|
|
const struct timespec *time,
|
|
uint32_t button, uint32_t state);
|
|
void (*axis)(struct weston_pointer_grab *grab,
|
|
const struct timespec *time,
|
|
struct weston_pointer_axis_event *event);
|
|
void (*axis_source)(struct weston_pointer_grab *grab, uint32_t source);
|
|
void (*frame)(struct weston_pointer_grab *grab);
|
|
void (*cancel)(struct weston_pointer_grab *grab);
|
|
};
|
|
|
|
struct weston_pointer_grab {
|
|
const struct weston_pointer_grab_interface *interface;
|
|
struct weston_pointer *pointer;
|
|
};
|
|
|
|
struct weston_keyboard_grab;
|
|
struct weston_keyboard_grab_interface {
|
|
void (*key)(struct weston_keyboard_grab *grab,
|
|
const struct timespec *time, uint32_t key, uint32_t state);
|
|
void (*modifiers)(struct weston_keyboard_grab *grab, uint32_t serial,
|
|
uint32_t mods_depressed, uint32_t mods_latched,
|
|
uint32_t mods_locked, uint32_t group);
|
|
void (*cancel)(struct weston_keyboard_grab *grab);
|
|
};
|
|
|
|
struct weston_keyboard_grab {
|
|
const struct weston_keyboard_grab_interface *interface;
|
|
struct weston_keyboard *keyboard;
|
|
};
|
|
|
|
struct weston_touch_grab;
|
|
struct weston_touch_grab_interface {
|
|
void (*down)(struct weston_touch_grab *grab,
|
|
const struct timespec *time,
|
|
int touch_id,
|
|
struct weston_coord_global c);
|
|
void (*up)(struct weston_touch_grab *grab,
|
|
const struct timespec *time,
|
|
int touch_id);
|
|
void (*motion)(struct weston_touch_grab *grab,
|
|
const struct timespec *time,
|
|
int touch_id,
|
|
struct weston_coord_global c);
|
|
void (*frame)(struct weston_touch_grab *grab);
|
|
void (*cancel)(struct weston_touch_grab *grab);
|
|
};
|
|
|
|
struct weston_touch_grab {
|
|
const struct weston_touch_grab_interface *interface;
|
|
struct weston_touch *touch;
|
|
};
|
|
|
|
struct weston_tablet;
|
|
struct weston_tablet_tool;
|
|
struct weston_tablet_tool_grab;
|
|
struct weston_tablet_tool_grab_interface {
|
|
void (*proximity_in)(struct weston_tablet_tool_grab *grab,
|
|
const struct timespec *time,
|
|
struct weston_tablet *tablet);
|
|
void (*proximity_out)(struct weston_tablet_tool_grab *grab,
|
|
const struct timespec *time);
|
|
void (*motion)(struct weston_tablet_tool_grab *grab,
|
|
const struct timespec *time,
|
|
struct weston_coord_global pos);
|
|
void (*down)(struct weston_tablet_tool_grab *grab,
|
|
const struct timespec *time);
|
|
void (*up)(struct weston_tablet_tool_grab *grab,
|
|
const struct timespec *time);
|
|
void (*pressure)(struct weston_tablet_tool_grab *grab,
|
|
const struct timespec *time,
|
|
uint32_t pressure);
|
|
void (*distance)(struct weston_tablet_tool_grab *grab,
|
|
const struct timespec *time,
|
|
uint32_t distance);
|
|
void (*tilt)(struct weston_tablet_tool_grab *grab,
|
|
const struct timespec *time,
|
|
wl_fixed_t tilt_x,
|
|
wl_fixed_t tilt_y);
|
|
void (*button)(struct weston_tablet_tool_grab *grab,
|
|
const struct timespec *time,
|
|
uint32_t button,
|
|
uint32_t state);
|
|
void (*frame)(struct weston_tablet_tool_grab *grab,
|
|
const struct timespec *time);
|
|
void (*cancel)(struct weston_tablet_tool_grab *grab);
|
|
};
|
|
|
|
struct weston_tablet_tool_grab {
|
|
const struct weston_tablet_tool_grab_interface *interface;
|
|
struct weston_tablet_tool *tool;
|
|
};
|
|
|
|
struct weston_data_offer {
|
|
struct wl_resource *resource;
|
|
struct weston_data_source *source;
|
|
struct wl_listener source_destroy_listener;
|
|
uint32_t dnd_actions;
|
|
enum wl_data_device_manager_dnd_action preferred_dnd_action;
|
|
bool in_ask;
|
|
};
|
|
|
|
struct weston_data_source {
|
|
struct wl_resource *resource;
|
|
struct wl_signal destroy_signal;
|
|
struct wl_array mime_types;
|
|
struct weston_data_offer *offer;
|
|
struct weston_seat *seat;
|
|
bool accepted;
|
|
bool actions_set;
|
|
bool set_selection;
|
|
uint32_t dnd_actions;
|
|
enum wl_data_device_manager_dnd_action current_dnd_action;
|
|
enum wl_data_device_manager_dnd_action compositor_action;
|
|
|
|
void (*accept)(struct weston_data_source *source,
|
|
uint32_t serial, const char *mime_type);
|
|
void (*send)(struct weston_data_source *source,
|
|
const char *mime_type, int32_t fd);
|
|
void (*cancel)(struct weston_data_source *source);
|
|
};
|
|
|
|
struct weston_pointer_client {
|
|
struct wl_list link;
|
|
struct wl_client *client;
|
|
struct wl_list pointer_resources;
|
|
struct wl_list relative_pointer_resources;
|
|
};
|
|
|
|
struct weston_pointer {
|
|
struct weston_seat *seat;
|
|
|
|
struct wl_list pointer_clients;
|
|
|
|
struct weston_view *focus;
|
|
struct weston_pointer_client *focus_client;
|
|
uint32_t focus_serial;
|
|
struct wl_listener focus_view_listener;
|
|
struct wl_listener focus_resource_listener;
|
|
struct wl_signal focus_signal;
|
|
struct wl_signal motion_signal;
|
|
struct wl_signal destroy_signal;
|
|
|
|
struct weston_view *sprite;
|
|
struct wl_listener sprite_destroy_listener;
|
|
struct weston_coord_surface hotspot;
|
|
|
|
struct weston_pointer_grab *grab;
|
|
struct weston_pointer_grab default_grab;
|
|
struct weston_coord_global grab_pos;
|
|
uint32_t grab_button;
|
|
uint32_t grab_serial;
|
|
struct timespec grab_time;
|
|
|
|
struct weston_coord_global pos;
|
|
wl_fixed_t sx, sy;
|
|
uint32_t button_count;
|
|
|
|
struct wl_listener output_destroy_listener;
|
|
|
|
struct wl_list timestamps_list;
|
|
};
|
|
|
|
/** libinput style calibration matrix
|
|
*
|
|
* See https://wayland.freedesktop.org/libinput/doc/latest/absolute_axes.html
|
|
* and libinput_device_config_calibration_set_matrix().
|
|
*/
|
|
struct weston_touch_device_matrix {
|
|
float m[6];
|
|
};
|
|
|
|
struct weston_touch_device;
|
|
|
|
/** Operations for a calibratable touchscreen */
|
|
struct weston_touch_device_ops {
|
|
/** Get the associated output if existing. */
|
|
struct weston_output *(*get_output)(struct weston_touch_device *device);
|
|
|
|
/** Get the name of the associated head if existing. */
|
|
const char *
|
|
(*get_calibration_head_name)(struct weston_touch_device *device);
|
|
|
|
/** Retrieve the current calibration matrix. */
|
|
void (*get_calibration)(struct weston_touch_device *device,
|
|
struct weston_touch_device_matrix *cal);
|
|
|
|
/** Set a new calibration matrix. */
|
|
void (*set_calibration)(struct weston_touch_device *device,
|
|
const struct weston_touch_device_matrix *cal);
|
|
};
|
|
|
|
enum weston_touch_mode {
|
|
/** Normal touch event handling */
|
|
WESTON_TOUCH_MODE_NORMAL,
|
|
|
|
/** Prepare moving to WESTON_TOUCH_MODE_CALIB.
|
|
*
|
|
* Move to WESTON_TOUCH_MODE_CALIB as soon as no touches are down on
|
|
* any seat. Until then, all touch events are routed normally.
|
|
*/
|
|
WESTON_TOUCH_MODE_PREP_CALIB,
|
|
|
|
/** Calibration mode
|
|
*
|
|
* Only a single weston_touch_device forwards events to the calibrator
|
|
* all other touch device cause a calibrator "wrong device" event to
|
|
* be sent.
|
|
*/
|
|
WESTON_TOUCH_MODE_CALIB,
|
|
|
|
/** Prepare moving to WESTON_TOUCH_MODE_NORMAL.
|
|
*
|
|
* Move to WESTON_TOUCH_MODE_NORMAL as soon as no touches are down on
|
|
* any seat. Until then, touch events are routed as in
|
|
* WESTON_TOUCH_MODE_CALIB except "wrong device" events are not sent.
|
|
*/
|
|
WESTON_TOUCH_MODE_PREP_NORMAL
|
|
};
|
|
|
|
/** Represents a physical touchscreen input device */
|
|
struct weston_touch_device {
|
|
char *syspath; /**< unique name */
|
|
|
|
struct weston_touch *aggregate; /**< weston_touch this is part of */
|
|
struct wl_list link; /**< in weston_touch::device_list */
|
|
struct wl_signal destroy_signal; /**< destroy notifier */
|
|
|
|
void *backend_data; /**< backend-specific private */
|
|
|
|
const struct weston_touch_device_ops *ops;
|
|
struct weston_touch_device_matrix saved_calibration;
|
|
};
|
|
|
|
/** Represents a set of touchscreen devices aggregated under a seat */
|
|
struct weston_touch {
|
|
struct weston_seat *seat;
|
|
|
|
struct wl_list device_list; /* struct weston_touch_device::link */
|
|
|
|
struct wl_list resource_list;
|
|
struct wl_list focus_resource_list;
|
|
struct weston_view *focus;
|
|
struct wl_listener focus_view_listener;
|
|
struct wl_listener focus_resource_listener;
|
|
uint32_t focus_serial;
|
|
struct wl_signal focus_signal;
|
|
bool pending_focus_reset;
|
|
|
|
uint32_t num_tp;
|
|
|
|
struct weston_touch_grab *grab;
|
|
struct weston_touch_grab default_grab;
|
|
int grab_touch_id;
|
|
struct weston_coord_global grab_pos;
|
|
uint32_t grab_serial;
|
|
struct timespec grab_time;
|
|
|
|
struct wl_list timestamps_list;
|
|
};
|
|
|
|
struct weston_tablet_tool {
|
|
struct weston_seat *seat;
|
|
uint32_t type;
|
|
struct weston_tablet *current_tablet;
|
|
|
|
struct wl_list resource_list;
|
|
struct wl_list focus_resource_list;
|
|
struct weston_view *focus;
|
|
struct wl_listener focus_view_listener;
|
|
struct wl_listener focus_resource_listener;
|
|
uint32_t focus_serial;
|
|
uint32_t grab_serial;
|
|
|
|
struct wl_list link;
|
|
|
|
uint64_t serial;
|
|
uint64_t hwid;
|
|
uint32_t capabilities;
|
|
|
|
struct weston_tablet_tool_grab *grab;
|
|
struct weston_tablet_tool_grab default_grab;
|
|
|
|
int button_count;
|
|
bool tip_is_down;
|
|
|
|
struct timespec frame_time;
|
|
|
|
struct weston_view *sprite;
|
|
struct weston_coord_surface hotspot;
|
|
struct wl_listener sprite_destroy_listener;
|
|
|
|
struct weston_coord_global pos;
|
|
struct weston_coord_global grab_pos;
|
|
|
|
struct wl_signal focus_signal;
|
|
struct wl_signal removed_signal;
|
|
};
|
|
|
|
struct weston_tablet {
|
|
struct weston_seat *seat;
|
|
|
|
struct wl_list resource_list;
|
|
struct wl_list tool_list;
|
|
|
|
struct wl_list link;
|
|
|
|
char *name;
|
|
uint32_t vid;
|
|
uint32_t pid;
|
|
const char *path;
|
|
};
|
|
|
|
struct weston_coord_global
|
|
weston_pointer_motion_to_abs(struct weston_pointer *pointer,
|
|
struct weston_pointer_motion_event *event);
|
|
|
|
void
|
|
weston_pointer_send_motion(struct weston_pointer *pointer,
|
|
const struct timespec *time,
|
|
struct weston_pointer_motion_event *event);
|
|
bool
|
|
weston_pointer_has_focus_resource(struct weston_pointer *pointer);
|
|
void
|
|
weston_pointer_send_button(struct weston_pointer *pointer,
|
|
const struct timespec *time,
|
|
uint32_t button,
|
|
enum wl_pointer_button_state state);
|
|
void
|
|
weston_pointer_send_axis(struct weston_pointer *pointer,
|
|
const struct timespec *time,
|
|
struct weston_pointer_axis_event *event);
|
|
void
|
|
weston_pointer_send_axis_source(struct weston_pointer *pointer,
|
|
enum wl_pointer_axis_source source);
|
|
void
|
|
weston_pointer_send_frame(struct weston_pointer *pointer);
|
|
|
|
void
|
|
weston_pointer_set_focus(struct weston_pointer *pointer,
|
|
struct weston_view *view);
|
|
|
|
void
|
|
weston_pointer_clear_focus(struct weston_pointer *pointer);
|
|
void
|
|
weston_pointer_start_grab(struct weston_pointer *pointer,
|
|
struct weston_pointer_grab *grab);
|
|
void
|
|
weston_pointer_end_grab(struct weston_pointer *pointer);
|
|
void
|
|
weston_pointer_move(struct weston_pointer *pointer,
|
|
struct weston_pointer_motion_event *event);
|
|
void
|
|
weston_keyboard_set_focus(struct weston_keyboard *keyboard,
|
|
struct weston_surface *surface);
|
|
void
|
|
weston_keyboard_start_grab(struct weston_keyboard *device,
|
|
struct weston_keyboard_grab *grab);
|
|
void
|
|
weston_keyboard_end_grab(struct weston_keyboard *keyboard);
|
|
int
|
|
/*
|
|
* 'mask' and 'value' should be a bitwise mask of one or more
|
|
* valued of the weston_keyboard_locks enum.
|
|
*/
|
|
weston_keyboard_set_locks(struct weston_keyboard *keyboard,
|
|
uint32_t mask, uint32_t value);
|
|
|
|
void
|
|
weston_keyboard_send_key(struct weston_keyboard *keyboard,
|
|
const struct timespec *time, uint32_t key,
|
|
enum wl_keyboard_key_state state);
|
|
void
|
|
weston_keyboard_send_modifiers(struct weston_keyboard *keyboard,
|
|
uint32_t serial, uint32_t mods_depressed,
|
|
uint32_t mods_latched,
|
|
uint32_t mods_locked, uint32_t group);
|
|
|
|
void
|
|
weston_touch_set_focus(struct weston_touch *touch,
|
|
struct weston_view *view);
|
|
void
|
|
weston_touch_start_grab(struct weston_touch *touch,
|
|
struct weston_touch_grab *grab);
|
|
void
|
|
weston_touch_end_grab(struct weston_touch *touch);
|
|
|
|
void
|
|
weston_touch_send_down(struct weston_touch *touch, const struct timespec *time,
|
|
int touch_id, struct weston_coord_global pos);
|
|
void
|
|
weston_touch_send_up(struct weston_touch *touch, const struct timespec *time,
|
|
int touch_id);
|
|
void
|
|
weston_touch_send_motion(struct weston_touch *touch,
|
|
const struct timespec *time, int touch_id,
|
|
struct weston_coord_global pos);
|
|
void
|
|
weston_touch_send_frame(struct weston_touch *touch);
|
|
|
|
|
|
void
|
|
weston_tablet_tool_set_focus(struct weston_tablet_tool *tool,
|
|
struct weston_view *view,
|
|
const struct timespec *time);
|
|
|
|
void
|
|
weston_tablet_tool_start_grab(struct weston_tablet_tool *tool,
|
|
struct weston_tablet_tool_grab *grab);
|
|
|
|
void
|
|
weston_tablet_tool_end_grab(struct weston_tablet_tool *tool);
|
|
|
|
void
|
|
weston_tablet_tool_send_proximity_out(struct weston_tablet_tool *tool,
|
|
const struct timespec *time);
|
|
|
|
void
|
|
weston_tablet_tool_send_motion(struct weston_tablet_tool *tool,
|
|
const struct timespec *time,
|
|
struct weston_coord_global pos);
|
|
|
|
void
|
|
weston_tablet_tool_send_down(struct weston_tablet_tool *tool,
|
|
const struct timespec *time);
|
|
|
|
void
|
|
weston_tablet_tool_send_up(struct weston_tablet_tool *tool,
|
|
const struct timespec *time);
|
|
|
|
void
|
|
weston_tablet_tool_send_pressure(struct weston_tablet_tool *tool,
|
|
const struct timespec *time,
|
|
uint32_t pressure);
|
|
|
|
void
|
|
weston_tablet_tool_send_distance(struct weston_tablet_tool *tool,
|
|
const struct timespec *time,
|
|
uint32_t distance);
|
|
|
|
void
|
|
weston_tablet_tool_send_tilt(struct weston_tablet_tool *tool,
|
|
const struct timespec *time,
|
|
wl_fixed_t tilt_x, wl_fixed_t tilt_y);
|
|
|
|
void
|
|
weston_tablet_tool_send_button(struct weston_tablet_tool *tool,
|
|
const struct timespec *time,
|
|
uint32_t button, uint32_t state);
|
|
|
|
void
|
|
weston_tablet_tool_send_frame(struct weston_tablet_tool *tool,
|
|
const struct timespec *time);
|
|
|
|
void
|
|
weston_tablet_tool_cursor_move(struct weston_tablet_tool *tool,
|
|
struct weston_coord_global pos);
|
|
|
|
|
|
void
|
|
weston_seat_set_selection(struct weston_seat *seat,
|
|
struct weston_data_source *source, uint32_t serial);
|
|
|
|
int
|
|
weston_pointer_start_drag(struct weston_pointer *pointer,
|
|
struct weston_data_source *source,
|
|
struct weston_surface *icon,
|
|
struct wl_client *client);
|
|
struct weston_xkb_info {
|
|
struct xkb_keymap *keymap;
|
|
struct ro_anonymous_file *keymap_rofile;
|
|
int32_t ref_count;
|
|
xkb_mod_index_t shift_mod;
|
|
xkb_mod_index_t caps_mod;
|
|
xkb_mod_index_t ctrl_mod;
|
|
xkb_mod_index_t alt_mod;
|
|
xkb_mod_index_t mod2_mod;
|
|
xkb_mod_index_t mod3_mod;
|
|
xkb_mod_index_t super_mod;
|
|
xkb_mod_index_t mod5_mod;
|
|
xkb_led_index_t num_led;
|
|
xkb_led_index_t caps_led;
|
|
xkb_led_index_t scroll_led;
|
|
};
|
|
|
|
struct weston_keyboard {
|
|
struct weston_seat *seat;
|
|
|
|
struct wl_list resource_list;
|
|
struct wl_list focus_resource_list;
|
|
struct weston_surface *focus;
|
|
struct wl_listener focus_resource_listener;
|
|
uint32_t focus_serial;
|
|
struct wl_signal focus_signal;
|
|
|
|
struct weston_keyboard_grab *grab;
|
|
struct weston_keyboard_grab default_grab;
|
|
uint32_t grab_key;
|
|
uint32_t grab_serial;
|
|
struct timespec grab_time;
|
|
|
|
struct wl_array keys;
|
|
|
|
struct {
|
|
uint32_t mods_depressed;
|
|
uint32_t mods_latched;
|
|
uint32_t mods_locked;
|
|
uint32_t group;
|
|
} modifiers;
|
|
|
|
struct weston_keyboard_grab input_method_grab;
|
|
struct wl_resource *input_method_resource;
|
|
|
|
struct weston_xkb_info *xkb_info;
|
|
struct {
|
|
struct xkb_state *state;
|
|
enum weston_led leds;
|
|
} xkb_state;
|
|
struct xkb_keymap *pending_keymap;
|
|
|
|
struct wl_list timestamps_list;
|
|
};
|
|
|
|
struct weston_seat {
|
|
struct wl_list base_resource_list;
|
|
|
|
struct wl_global *global;
|
|
struct weston_pointer *pointer_state;
|
|
struct weston_keyboard *keyboard_state;
|
|
struct weston_touch *touch_state;
|
|
int pointer_device_count;
|
|
int keyboard_device_count;
|
|
int touch_device_count;
|
|
|
|
struct weston_output *output; /* constraint */
|
|
|
|
struct wl_signal destroy_signal;
|
|
struct wl_signal updated_caps_signal;
|
|
|
|
struct weston_compositor *compositor;
|
|
struct wl_list link;
|
|
enum weston_keyboard_modifier modifier_state;
|
|
struct weston_surface *saved_kbd_focus;
|
|
struct wl_listener saved_kbd_focus_listener;
|
|
bool use_saved_kbd_focus;
|
|
struct wl_list drag_resource_list;
|
|
|
|
uint32_t selection_serial;
|
|
struct weston_data_source *selection_data_source;
|
|
struct wl_listener selection_data_source_listener;
|
|
struct wl_signal selection_signal;
|
|
|
|
void (*led_update)(struct weston_seat *ws, enum weston_led leds);
|
|
|
|
struct input_method *input_method;
|
|
char *seat_name;
|
|
|
|
struct wl_list tablet_list;
|
|
struct wl_list tablet_tool_list;
|
|
struct wl_list tablet_seat_resource_list;
|
|
struct wl_signal tablet_tool_added_signal;
|
|
};
|
|
|
|
enum {
|
|
WESTON_COMPOSITOR_ACTIVE, /* normal rendering and events */
|
|
WESTON_COMPOSITOR_IDLE, /* shell->unlock called on activity */
|
|
WESTON_COMPOSITOR_OFFSCREEN, /* no rendering, no frame events */
|
|
WESTON_COMPOSITOR_SLEEPING /* same as offscreen, but also set dpms
|
|
* to off */
|
|
};
|
|
|
|
struct weston_layer_entry {
|
|
struct wl_list link;
|
|
struct weston_layer *layer;
|
|
};
|
|
|
|
/**
|
|
* Higher value means higher in the stack.
|
|
*
|
|
* These values are based on well-known concepts in a classic desktop
|
|
* environment. Third-party modules based on libweston are encouraged to use
|
|
* them to integrate better with other projects.
|
|
*
|
|
* A fully integrated environment can use any value, based on these or not,
|
|
* at their discretion.
|
|
*/
|
|
enum weston_layer_position {
|
|
/* Special value to indicate an invalid layer position. */
|
|
WESTON_LAYER_POSITION_NONE = -1,
|
|
|
|
/*
|
|
* Special value to make the layer invisible and still rendered.
|
|
* This is used by compositors wanting e.g. minimized surfaces to still
|
|
* receive frame callbacks.
|
|
*/
|
|
WESTON_LAYER_POSITION_HIDDEN = 0x00000000,
|
|
|
|
/*
|
|
* There should always be a background layer with a surface covering
|
|
* the visible area.
|
|
*
|
|
* If the compositor handles the background itself, it should use
|
|
* BACKGROUND.
|
|
*
|
|
* If the compositor supports runtime-loadable modules to set the
|
|
* background, it should put a solid color surface at (BACKGROUND - 1)
|
|
* and modules must use BACKGROUND.
|
|
*/
|
|
WESTON_LAYER_POSITION_BACKGROUND = 0x00000002,
|
|
|
|
/* For "desktop widgets" and applications like conky. */
|
|
WESTON_LAYER_POSITION_BOTTOM_UI = 0x30000000,
|
|
|
|
/* For regular applications, only one layer should have this value
|
|
* to ensure proper stacking control. */
|
|
WESTON_LAYER_POSITION_NORMAL = 0x50000000,
|
|
|
|
/* For desktop UI, like panels. */
|
|
WESTON_LAYER_POSITION_UI = 0x80000000,
|
|
|
|
/* For fullscreen applications that should cover UI. */
|
|
WESTON_LAYER_POSITION_FULLSCREEN = 0xb0000000,
|
|
|
|
/* For special UI like on-screen keyboard that fullscreen applications
|
|
* will need. */
|
|
WESTON_LAYER_POSITION_TOP_UI = 0xe0000000,
|
|
|
|
/* For the lock surface. */
|
|
WESTON_LAYER_POSITION_LOCK = 0xffff0000,
|
|
|
|
/* Values reserved for libweston internal usage */
|
|
WESTON_LAYER_POSITION_CURSOR = 0xfffffffe,
|
|
WESTON_LAYER_POSITION_FADE = 0xffffffff,
|
|
};
|
|
|
|
struct weston_layer {
|
|
struct weston_compositor *compositor;
|
|
struct wl_list link; /* weston_compositor::layer_list */
|
|
enum weston_layer_position position;
|
|
pixman_box32_t mask;
|
|
struct weston_layer_entry view_list;
|
|
};
|
|
|
|
struct weston_drm_format_array;
|
|
|
|
enum weston_capability {
|
|
/* backend/renderer supports arbitrary rotation */
|
|
WESTON_CAP_ROTATION_ANY = 0x0001,
|
|
|
|
/* screencaptures need to be y-flipped */
|
|
WESTON_CAP_CAPTURE_YFLIP = 0x0002,
|
|
|
|
/* backend/renderer has a separate cursor plane */
|
|
WESTON_CAP_CURSOR_PLANE = 0x0004,
|
|
|
|
/* backend supports setting arbitrary resolutions */
|
|
WESTON_CAP_ARBITRARY_MODES = 0x0008,
|
|
|
|
/* renderer supports weston_view_set_mask() clipping */
|
|
WESTON_CAP_VIEW_CLIP_MASK = 0x0010,
|
|
|
|
/* renderer supports explicit synchronization */
|
|
WESTON_CAP_EXPLICIT_SYNC = 0x0020,
|
|
|
|
/* renderer supports color management operations */
|
|
WESTON_CAP_COLOR_OPS = 0x0040,
|
|
};
|
|
|
|
/* Configuration struct for a backend.
|
|
*
|
|
* This struct carries the configuration for a backend, and it's
|
|
* passed to the backend's init entry point. The backend will
|
|
* likely want to subclass this in order to handle backend specific
|
|
* data.
|
|
*
|
|
* \rststar
|
|
* .. note:
|
|
*
|
|
* Alternate designs were proposed (Feb 2016) for using opaque structures[1]
|
|
* and for section+key/value getter/setters[2]. The rationale for selecting
|
|
* the transparent structure design is based on several assumptions[3] which
|
|
* may require re-evaluating the design choice if they fail to hold.
|
|
*
|
|
* 1. https://lists.freedesktop.org/archives/wayland-devel/2016-February/026989.html
|
|
* 2. https://lists.freedesktop.org/archives/wayland-devel/2016-February/026929.html
|
|
* 3. https://lists.freedesktop.org/archives/wayland-devel/2016-February/027228.html
|
|
*
|
|
* \endrststar
|
|
*/
|
|
struct weston_backend_config {
|
|
/** Major version for the backend-specific config struct
|
|
*
|
|
* This version must match exactly what the backend expects, otherwise
|
|
* the struct is incompatible.
|
|
*/
|
|
uint32_t struct_version;
|
|
|
|
/** Minor version of the backend-specific config struct
|
|
*
|
|
* This must be set to sizeof(struct backend-specific config).
|
|
* If the value here is smaller than what the backend expects, the
|
|
* extra config members will assume their default values.
|
|
*
|
|
* A value greater than what the backend expects is incompatible.
|
|
*/
|
|
size_t struct_size;
|
|
};
|
|
|
|
struct weston_backend;
|
|
|
|
/** Callback for saving calibration
|
|
*
|
|
* \param compositor The compositor.
|
|
* \param device The physical touch device to save for.
|
|
* \param calibration The new calibration from a client.
|
|
* \return -1 on failure, 0 on success.
|
|
*
|
|
* Failure will prevent taking the new calibration into use.
|
|
*/
|
|
typedef int (*weston_touch_calibration_save_func)(
|
|
struct weston_compositor *compositor,
|
|
struct weston_touch_device *device,
|
|
const struct weston_touch_device_matrix *calibration);
|
|
struct weston_touch_calibrator;
|
|
|
|
struct weston_desktop_xwayland;
|
|
struct weston_desktop_xwayland_interface;
|
|
struct weston_debug_compositor;
|
|
struct weston_color_manager;
|
|
struct weston_dmabuf_feedback;
|
|
struct weston_dmabuf_feedback_format_table;
|
|
struct weston_renderer;
|
|
|
|
/** Main object, container-like structure which aggregates all other objects.
|
|
*
|
|
* \ingroup compositor
|
|
*/
|
|
struct weston_compositor {
|
|
struct wl_signal destroy_signal;
|
|
bool shutting_down;
|
|
|
|
struct wl_display *wl_display;
|
|
struct weston_desktop_xwayland *xwayland;
|
|
const struct weston_desktop_xwayland_interface *xwayland_interface;
|
|
|
|
/* surface signals */
|
|
struct wl_signal create_surface_signal;
|
|
struct wl_signal activate_signal;
|
|
struct wl_signal transform_signal;
|
|
|
|
struct wl_signal kill_signal;
|
|
struct wl_signal idle_signal;
|
|
struct wl_signal wake_signal;
|
|
|
|
struct wl_signal show_input_panel_signal;
|
|
struct wl_signal hide_input_panel_signal;
|
|
struct wl_signal update_input_panel_signal;
|
|
|
|
struct wl_signal seat_created_signal;
|
|
struct wl_signal output_created_signal;
|
|
struct wl_signal output_destroyed_signal;
|
|
struct wl_signal output_moved_signal;
|
|
struct wl_signal output_resized_signal; /* callback argument: resized output */
|
|
|
|
/* Signal for output changes triggered by configuration from frontend
|
|
* or head state changes from backend.
|
|
*/
|
|
struct wl_signal output_heads_changed_signal; /* arg: weston_output */
|
|
|
|
struct wl_signal session_signal;
|
|
bool session_active;
|
|
|
|
struct weston_layer fade_layer;
|
|
struct weston_layer cursor_layer;
|
|
|
|
struct wl_list pending_output_list;
|
|
struct wl_list output_list;
|
|
struct wl_list head_list; /* struct weston_head::compositor_link */
|
|
struct wl_list seat_list;
|
|
struct wl_list layer_list; /* struct weston_layer::link */
|
|
struct wl_list view_list; /* struct weston_view::link */
|
|
struct wl_list plane_list;
|
|
struct wl_list key_binding_list;
|
|
struct wl_list modifier_binding_list;
|
|
struct wl_list button_binding_list;
|
|
struct wl_list touch_binding_list;
|
|
struct wl_list tablet_tool_binding_list;
|
|
struct wl_list axis_binding_list;
|
|
struct wl_list debug_binding_list;
|
|
|
|
bool view_list_needs_rebuild;
|
|
|
|
uint32_t state;
|
|
struct wl_event_source *idle_source;
|
|
uint32_t idle_inhibit;
|
|
int idle_time; /* timeout, s */
|
|
struct wl_event_source *repaint_timer;
|
|
|
|
const struct weston_pointer_grab_interface *default_pointer_grab;
|
|
|
|
/* Repaint state. */
|
|
uint32_t capabilities; /* combination of enum weston_capability */
|
|
|
|
struct weston_color_manager *color_manager;
|
|
struct weston_idalloc *color_profile_id_generator;
|
|
|
|
struct weston_renderer *renderer;
|
|
const struct pixel_format_info *read_format;
|
|
|
|
/* Pointer to the first backend on backend_list */
|
|
struct weston_backend *primary_backend;
|
|
struct wl_list backend_list;
|
|
|
|
struct weston_launcher *launcher;
|
|
|
|
struct weston_dmabuf_feedback *default_dmabuf_feedback;
|
|
struct weston_dmabuf_feedback_format_table *dmabuf_feedback_format_table;
|
|
|
|
struct wl_list plugin_api_list; /* struct weston_plugin_api::link */
|
|
|
|
uint32_t output_id_pool;
|
|
bool output_flow_dirty;
|
|
|
|
struct xkb_rule_names xkb_names;
|
|
struct xkb_context *xkb_context;
|
|
struct weston_xkb_info *xkb_info;
|
|
|
|
int32_t kb_repeat_rate;
|
|
int32_t kb_repeat_delay;
|
|
|
|
bool vt_switching;
|
|
|
|
clockid_t presentation_clock;
|
|
int32_t repaint_msec;
|
|
struct timespec last_repaint_start;
|
|
|
|
unsigned int activate_serial;
|
|
|
|
struct wl_global *pointer_constraints;
|
|
|
|
int exit_code;
|
|
|
|
void *user_data;
|
|
void (*exit)(struct weston_compositor *c);
|
|
|
|
struct wl_global *tablet_manager;
|
|
struct wl_list tablet_manager_resource_list;
|
|
|
|
/* Whether to let the compositor run without any input device. */
|
|
bool require_input;
|
|
|
|
/* Whether to load multiple backends. */
|
|
bool multi_backend;
|
|
|
|
/* Test suite data */
|
|
struct weston_testsuite_data test_data;
|
|
|
|
/* Signal for a backend to inform a frontend about possible changes
|
|
* in head status.
|
|
*/
|
|
struct wl_signal heads_changed_signal;
|
|
struct wl_event_source *heads_changed_source;
|
|
|
|
/* Touchscreen calibrator support: */
|
|
enum weston_touch_mode touch_mode;
|
|
struct wl_global *touch_calibration;
|
|
weston_touch_calibration_save_func touch_calibration_save;
|
|
struct weston_layer calibrator_layer;
|
|
struct weston_touch_calibrator *touch_calibrator;
|
|
|
|
struct weston_log_context *weston_log_ctx;
|
|
struct weston_log_scope *debug_scene;
|
|
struct weston_log_scope *timeline;
|
|
struct weston_log_scope *libseat_debug;
|
|
|
|
struct content_protection *content_protection;
|
|
|
|
struct weston_log_pacer unmapped_surface_or_view_pacer;
|
|
struct weston_log_pacer presentation_clock_failure_pacer;
|
|
|
|
/** Screenshooting global state, see output-capture.c */
|
|
struct {
|
|
struct wl_global *weston_capture_v1;
|
|
struct wl_signal ask_auth;
|
|
} output_capture;
|
|
};
|
|
|
|
struct weston_solid_buffer_values {
|
|
float r, g, b, a;
|
|
};
|
|
|
|
struct weston_buffer {
|
|
struct wl_resource *resource;
|
|
struct wl_signal destroy_signal;
|
|
struct wl_listener destroy_listener;
|
|
|
|
enum {
|
|
WESTON_BUFFER_SHM,
|
|
WESTON_BUFFER_DMABUF,
|
|
WESTON_BUFFER_RENDERER_OPAQUE,
|
|
WESTON_BUFFER_SOLID,
|
|
} type;
|
|
|
|
union {
|
|
struct wl_shm_buffer *shm_buffer;
|
|
void *dmabuf;
|
|
void *legacy_buffer;
|
|
struct weston_solid_buffer_values solid;
|
|
};
|
|
|
|
int32_t width, height;
|
|
uint32_t busy_count;
|
|
uint32_t passive_count;
|
|
enum {
|
|
ORIGIN_TOP_LEFT, /* buffer content starts at (0,0) */
|
|
ORIGIN_BOTTOM_LEFT, /* buffer content starts at (0, height) */
|
|
} buffer_origin;
|
|
bool direct_display;
|
|
|
|
void *renderer_private;
|
|
void *backend_private;
|
|
|
|
const struct pixel_format_info *pixel_format;
|
|
uint64_t format_modifier;
|
|
};
|
|
|
|
enum weston_buffer_reference_type {
|
|
BUFFER_REF_NONE,
|
|
BUFFER_MAY_BE_ACCESSED,
|
|
BUFFER_WILL_NOT_BE_ACCESSED,
|
|
};
|
|
|
|
struct weston_buffer_reference {
|
|
struct weston_buffer *buffer;
|
|
enum weston_buffer_reference_type type;
|
|
};
|
|
|
|
struct weston_buffer_viewport {
|
|
struct {
|
|
/* wl_surface.set_buffer_transform */
|
|
uint32_t transform;
|
|
|
|
/* wl_surface.set_scaling_factor */
|
|
int32_t scale;
|
|
|
|
/*
|
|
* If src_width != wl_fixed_from_int(-1),
|
|
* then and only then src_* are used.
|
|
*/
|
|
wl_fixed_t src_x, src_y;
|
|
wl_fixed_t src_width, src_height;
|
|
} buffer;
|
|
|
|
struct {
|
|
/*
|
|
* If width == -1, the size is inferred from the buffer.
|
|
*/
|
|
int32_t width, height;
|
|
} surface;
|
|
};
|
|
|
|
struct weston_buffer_release {
|
|
/* The associated zwp_linux_buffer_release_v1 resource. */
|
|
struct wl_resource *resource;
|
|
/* How many weston_buffer_release_reference objects point to this
|
|
* object. */
|
|
uint32_t ref_count;
|
|
/* The fence fd, if any, associated with this release. If the fence fd
|
|
* is -1 then this is considered an immediate release. */
|
|
int fence_fd;
|
|
};
|
|
|
|
struct weston_buffer_release_reference {
|
|
struct weston_buffer_release *buffer_release;
|
|
/* Listener for the destruction of the wl_resource associated with the
|
|
* referenced buffer_release object. */
|
|
struct wl_listener destroy_listener;
|
|
};
|
|
|
|
struct weston_region {
|
|
struct wl_resource *resource;
|
|
pixman_region32_t region;
|
|
};
|
|
|
|
/* Using weston_view transformations
|
|
*
|
|
* To add a transformation to a view, create a struct weston_transform, and
|
|
* add it to the list view->geometry.transformation_list. Whenever you
|
|
* change the list, anything under view->geometry, or anything in the
|
|
* weston_transforms linked into the list, you must call
|
|
* weston_view_geometry_dirty().
|
|
*
|
|
* The order in the list defines the order of transformations. Let the list
|
|
* contain the transformation matrices M1, ..., Mn as head to tail. The
|
|
* transformation is applied to view-local coordinate vector p as
|
|
* P = Mn * ... * M2 * M1 * p
|
|
* to produce the global coordinate vector P. The total transform
|
|
* Mn * ... * M2 * M1
|
|
* is cached in view->transform.matrix, and the inverse of it in
|
|
* view->transform.inverse.
|
|
*
|
|
* The list always contains view->transform.position transformation, which
|
|
* is the translation by view->geometry.x and y.
|
|
*
|
|
* If you want to apply a transformation in local coordinates, add your
|
|
* weston_transform to the head of the list. If you want to apply a
|
|
* transformation in global coordinates, add it to the tail of the list.
|
|
*
|
|
* If view->geometry.parent is set, the total transformation of this
|
|
* view will be the parent's total transformation and this transformation
|
|
* combined:
|
|
* Mparent * Mn * ... * M2 * M1
|
|
*/
|
|
|
|
struct weston_view {
|
|
struct weston_surface *surface;
|
|
struct wl_list surface_link;
|
|
struct wl_signal destroy_signal;
|
|
struct wl_signal map_signal;
|
|
struct wl_signal unmap_signal;
|
|
|
|
/* struct weston_paint_node::view_link */
|
|
struct wl_list paint_node_list;
|
|
|
|
struct wl_list link; /* weston_compositor::view_list */
|
|
struct weston_layer_entry layer_link; /* part of geometry */
|
|
|
|
/* For weston_layer inheritance from another view */
|
|
struct weston_view *parent_view;
|
|
|
|
unsigned int click_to_activate_serial;
|
|
|
|
pixman_region32_t visible; /* Unoccluded region in global space */
|
|
float alpha; /* part of geometry, see below */
|
|
|
|
/* Surface geometry state, mutable.
|
|
* If you change anything, call weston_surface_geometry_dirty().
|
|
* That includes the transformations referenced from the list.
|
|
*/
|
|
struct {
|
|
/* pos_offset is the surface's position in the global space
|
|
* if parent is NULL, or its offset in its parent's surface
|
|
* space if parent is set.
|
|
*/
|
|
struct weston_coord pos_offset;
|
|
|
|
/* struct weston_transform */
|
|
struct wl_list transformation_list;
|
|
|
|
/* managed by weston_view_set_transform_parent() */
|
|
struct weston_view *parent;
|
|
struct wl_listener parent_destroy_listener;
|
|
struct wl_list child_list; /* geometry.parent_link */
|
|
struct wl_list parent_link;
|
|
|
|
/* managed by weston_view_set_mask() */
|
|
bool scissor_enabled;
|
|
pixman_region32_t scissor; /* always a simple rect */
|
|
} geometry;
|
|
|
|
/* State derived from geometry state, read-only.
|
|
* This is updated by weston_view_update_transform().
|
|
*/
|
|
struct {
|
|
int dirty;
|
|
|
|
/* Approximations in global coordinates:
|
|
* - boundingbox is guaranteed to include the whole view in
|
|
* the smallest possible single rectangle.
|
|
* - opaque is guaranteed to be fully opaque, though not
|
|
* necessarily include all opaque areas.
|
|
*/
|
|
pixman_region32_t boundingbox;
|
|
pixman_region32_t opaque;
|
|
|
|
/* Regardless of enabled status, matrix and inverse are
|
|
* updated by weston_view_update_transform(), and are
|
|
* used for coordinate conversion between the view
|
|
* and global spaces.
|
|
*/
|
|
int enabled;
|
|
struct weston_matrix matrix;
|
|
struct weston_matrix inverse;
|
|
|
|
struct weston_transform position; /* matrix from x, y */
|
|
} transform;
|
|
|
|
/*
|
|
* The primary output for this view.
|
|
* Used for picking the output for driving internal animations on the
|
|
* view, inheriting the primary output for related views in shells, etc.
|
|
*/
|
|
struct weston_output *output;
|
|
struct wl_listener output_destroy_listener;
|
|
|
|
/*
|
|
* A more complete representation of all outputs this surface is
|
|
* displayed on.
|
|
*/
|
|
uint32_t output_mask;
|
|
|
|
/* Per-surface Presentation feedback flags, controlled by backend. */
|
|
uint32_t psf_flags;
|
|
|
|
bool is_mapped;
|
|
struct weston_log_pacer subsurface_parent_log_pacer;
|
|
};
|
|
|
|
enum weston_surface_status {
|
|
/** nothing has changed */
|
|
WESTON_SURFACE_CLEAN = 0,
|
|
/** a new buffer has been attached, but is like-for-like with the
|
|
* previous */
|
|
WESTON_SURFACE_DIRTY_BUFFER = 1 << 0,
|
|
/** surface has been resized */
|
|
WESTON_SURFACE_DIRTY_SIZE = 1 << 1,
|
|
/** x/y position has changed */
|
|
WESTON_SURFACE_DIRTY_POS = 1 << 2,
|
|
/** buffer parameters have changed in a way which impacts the
|
|
* processing pipeline, e.g. format/opacity */
|
|
WESTON_SURFACE_DIRTY_BUFFER_PARAMS = 1 << 3,
|
|
/** input region has changed */
|
|
WESTON_SURFACE_DIRTY_INPUT = 1 << 4,
|
|
/** subsurfaces have been added, removed, or restacked */
|
|
WESTON_SURFACE_DIRTY_SUBSURFACE_CONFIG = 1 << 5,
|
|
};
|
|
|
|
struct weston_surface_state {
|
|
enum weston_surface_status status;
|
|
|
|
/* wl_surface.attach */
|
|
struct weston_buffer *buffer;
|
|
struct wl_listener buffer_destroy_listener;
|
|
|
|
struct weston_coord_surface buf_offset;
|
|
|
|
/* wl_surface.damage */
|
|
pixman_region32_t damage_surface;
|
|
/* wl_surface.damage_buffer */
|
|
pixman_region32_t damage_buffer;
|
|
|
|
/* wl_surface.set_opaque_region */
|
|
pixman_region32_t opaque;
|
|
|
|
/* wl_surface.set_input_region */
|
|
pixman_region32_t input;
|
|
|
|
/* wl_surface.frame */
|
|
struct wl_list frame_callback_list;
|
|
|
|
/* presentation.feedback */
|
|
struct wl_list feedback_list;
|
|
|
|
/* wl_surface.set_buffer_transform */
|
|
/* wl_surface.set_scaling_factor */
|
|
/* wp_viewport.set_source */
|
|
/* wp_viewport.set_destination */
|
|
struct weston_buffer_viewport buffer_viewport;
|
|
|
|
/* zwp_surface_synchronization_v1.set_acquire_fence */
|
|
int acquire_fence_fd;
|
|
|
|
/* zwp_surface_synchronization_v1.get_release */
|
|
struct weston_buffer_release_reference buffer_release_ref;
|
|
|
|
/* weston_protected_surface.set_type */
|
|
enum weston_hdcp_protection desired_protection;
|
|
|
|
/* weston_protected_surface.enforced/relaxed */
|
|
enum weston_surface_protection_mode protection_mode;
|
|
|
|
/* color_management_surface_v1_interface.set_image_description or
|
|
* color_management_surface_v1_interface.unset_image_description */
|
|
struct weston_color_profile *color_profile;
|
|
const struct weston_render_intent_info *render_intent;
|
|
};
|
|
|
|
struct weston_surface_activation_data {
|
|
struct weston_view *view;
|
|
struct weston_seat *seat;
|
|
uint32_t flags;
|
|
};
|
|
|
|
struct weston_pointer_constraint {
|
|
struct wl_list link;
|
|
|
|
struct weston_surface *surface;
|
|
struct weston_view *view;
|
|
struct wl_resource *resource;
|
|
struct weston_pointer_grab grab;
|
|
struct weston_pointer *pointer;
|
|
uint32_t lifetime;
|
|
|
|
pixman_region32_t region;
|
|
pixman_region32_t region_pending;
|
|
bool region_is_pending;
|
|
|
|
struct weston_coord_surface hint;
|
|
struct weston_coord_surface hint_pending;
|
|
bool hint_is_pending;
|
|
|
|
struct wl_listener pointer_destroy_listener;
|
|
struct wl_listener view_unmap_listener;
|
|
struct wl_listener surface_commit_listener;
|
|
struct wl_listener surface_activate_listener;
|
|
};
|
|
|
|
struct weston_surface {
|
|
struct wl_resource *resource;
|
|
struct wl_signal destroy_signal; /* callback argument: this surface */
|
|
struct weston_compositor *compositor;
|
|
struct wl_signal commit_signal;
|
|
|
|
/* struct weston_paint_node::surface_link */
|
|
struct wl_list paint_node_list;
|
|
|
|
/** Damage in local coordinates from the client, for tex upload. */
|
|
pixman_region32_t damage;
|
|
|
|
pixman_region32_t opaque; /* part of geometry, see below */
|
|
pixman_region32_t input;
|
|
int32_t width, height;
|
|
int32_t ref_count;
|
|
|
|
/* Not for long-term storage. This exists for book-keeping while
|
|
* iterating over surfaces and views
|
|
*/
|
|
bool touched;
|
|
|
|
void *renderer_state;
|
|
|
|
struct wl_list views;
|
|
|
|
/*
|
|
* Which output to vsync this surface to.
|
|
* Used to determine whether to send or queue frame events, and for
|
|
* other client-visible syncing/throttling tied to the output
|
|
* repaint cycle.
|
|
*/
|
|
struct weston_output *output;
|
|
|
|
/*
|
|
* A more complete representation of all outputs this surface is
|
|
* displayed on.
|
|
*/
|
|
uint32_t output_mask;
|
|
|
|
struct wl_list frame_callback_list;
|
|
struct wl_list feedback_list;
|
|
|
|
struct weston_buffer_reference buffer_ref;
|
|
struct weston_buffer_viewport buffer_viewport;
|
|
int32_t width_from_buffer; /* before applying viewport */
|
|
int32_t height_from_buffer;
|
|
bool keep_buffer; /* for backends to prevent early release */
|
|
|
|
/* wp_viewport resource for this surface */
|
|
struct wl_resource *viewport_resource;
|
|
|
|
/* All the pending state, that wl_surface.commit will apply. */
|
|
struct weston_surface_state pending;
|
|
|
|
/* Matrices representing of the full transformation between
|
|
* buffer and surface coordinates. These matrices are updated
|
|
* using the weston_surface_build_buffer_matrix function. */
|
|
struct weston_matrix buffer_to_surface_matrix;
|
|
struct weston_matrix surface_to_buffer_matrix;
|
|
|
|
/*
|
|
* If non-NULL, this function will be called on
|
|
* wl_surface::commit after a new buffer has been set up for
|
|
* this surface. The coordinate holds the buffer offset parameters
|
|
* supplied to wl_surface::attach or wl_surface::offset.
|
|
*/
|
|
void (*committed)(struct weston_surface *es,
|
|
struct weston_coord_surface new_origin);
|
|
void *committed_private;
|
|
int (*get_label)(struct weston_surface *surface, char *buf, size_t len);
|
|
|
|
/*
|
|
* Sent when the surface has been mapped and unmapped, respectively.
|
|
* The data argument is the weston_surface.
|
|
*/
|
|
struct wl_signal map_signal;
|
|
struct wl_signal unmap_signal;
|
|
|
|
/* Parent's list of its sub-surfaces, weston_subsurface:parent_link.
|
|
* Contains also the parent itself as a dummy weston_subsurface,
|
|
* if the list is not empty.
|
|
*/
|
|
struct wl_list subsurface_list; /* weston_subsurface::parent_link */
|
|
struct wl_list subsurface_list_pending; /* ...::parent_link_pending */
|
|
|
|
/*
|
|
* For tracking protocol role assignments. Different roles may
|
|
* have the same configure hook, e.g. in shell.c. Configure hook
|
|
* may get reset, this will not.
|
|
* XXX: map configure functions 1:1 to roles, and never reset it,
|
|
* and replace role_name with configure.
|
|
*/
|
|
const char *role_name;
|
|
|
|
bool is_mapped, is_unmapping, is_mapping;
|
|
bool is_opaque;
|
|
|
|
/* An list of per seat pointer constraints. */
|
|
struct wl_list pointer_constraints;
|
|
|
|
/* zwp_surface_synchronization_v1 resource for this surface */
|
|
struct wl_resource *synchronization_resource;
|
|
int acquire_fence_fd;
|
|
struct weston_buffer_release_reference buffer_release_ref;
|
|
|
|
struct weston_dmabuf_feedback *dmabuf_feedback;
|
|
|
|
enum weston_hdcp_protection desired_protection;
|
|
enum weston_hdcp_protection current_protection;
|
|
enum weston_surface_protection_mode protection_mode;
|
|
|
|
struct weston_tearing_control *tear_control;
|
|
|
|
struct weston_color_profile *color_profile;
|
|
struct weston_color_profile *preferred_color_profile;
|
|
const struct weston_render_intent_info *render_intent;
|
|
|
|
/* xx_color_manager_v1.get_color_management_surface
|
|
*
|
|
* When a client uses this request, we add the wl_resource we create to
|
|
* this list. */
|
|
struct wl_list cm_surface_resource_list;
|
|
};
|
|
|
|
struct weston_subsurface {
|
|
struct wl_resource *resource;
|
|
|
|
/* guaranteed to be valid and non-NULL */
|
|
struct weston_surface *surface;
|
|
struct wl_listener surface_destroy_listener;
|
|
|
|
/* can be NULL */
|
|
struct weston_surface *parent;
|
|
struct wl_listener parent_destroy_listener;
|
|
struct wl_list parent_link;
|
|
struct wl_list parent_link_pending;
|
|
|
|
struct {
|
|
struct weston_coord_surface offset;
|
|
bool changed;
|
|
} position;
|
|
|
|
int has_cached_data;
|
|
struct weston_surface_state cached;
|
|
struct weston_buffer_reference cached_buffer_ref;
|
|
|
|
/* Sub-surface has been reordered; need to apply damage. */
|
|
bool reordered;
|
|
|
|
int synchronized;
|
|
|
|
/* Used for constructing the view tree */
|
|
struct wl_list unused_views;
|
|
|
|
struct weston_log_pacer subsurface_offset_pacer;
|
|
};
|
|
|
|
struct protected_surface {
|
|
struct weston_surface *surface;
|
|
struct wl_listener surface_destroy_listener;
|
|
struct wl_list link;
|
|
struct wl_resource *protection_resource;
|
|
struct content_protection *cp_backptr;
|
|
};
|
|
|
|
struct content_protection {
|
|
struct weston_compositor *compositor;
|
|
struct wl_listener destroy_listener;
|
|
struct weston_log_scope *debug;
|
|
struct wl_list protected_list;
|
|
struct wl_event_source *surface_protection_update;
|
|
};
|
|
|
|
|
|
enum weston_key_state_update {
|
|
STATE_UPDATE_AUTOMATIC,
|
|
STATE_UPDATE_NONE,
|
|
};
|
|
|
|
enum weston_activate_flag {
|
|
WESTON_ACTIVATE_FLAG_NONE = 0,
|
|
WESTON_ACTIVATE_FLAG_CONFIGURE = 1 << 0,
|
|
WESTON_ACTIVATE_FLAG_CLICKED = 1 << 1,
|
|
WESTON_ACTIVATE_FLAG_FULLSCREEN = 1 << 2,
|
|
};
|
|
|
|
void
|
|
weston_version(int *major, int *minor, int *micro);
|
|
|
|
void
|
|
weston_view_set_output(struct weston_view *view, struct weston_output *output);
|
|
|
|
void
|
|
weston_view_update_transform(struct weston_view *view);
|
|
|
|
void
|
|
weston_view_geometry_dirty(struct weston_view *view);
|
|
|
|
void
|
|
weston_view_add_transform(struct weston_view *view,
|
|
struct wl_list *pos,
|
|
struct weston_transform *transform);
|
|
|
|
void
|
|
weston_view_remove_transform(struct weston_view *view,
|
|
struct weston_transform *transform);
|
|
|
|
struct weston_coord_global __attribute__ ((warn_unused_result))
|
|
weston_coord_surface_to_global(const struct weston_view *view,
|
|
struct weston_coord_surface coord);
|
|
|
|
struct weston_coord_surface __attribute__ ((warn_unused_result))
|
|
weston_coord_global_to_surface(const struct weston_view *view,
|
|
struct weston_coord_global coord);
|
|
|
|
struct weston_coord_buffer __attribute__ ((warn_unused_result))
|
|
weston_coord_surface_to_buffer(const struct weston_surface *surface,
|
|
struct weston_coord_surface coord);
|
|
|
|
struct weston_coord_global __attribute__ ((warn_unused_result))
|
|
weston_coord_global_clamp_for_output(struct weston_coord_global pos,
|
|
const struct weston_output *output);
|
|
|
|
void
|
|
weston_view_activate_input(struct weston_view *view,
|
|
struct weston_seat *seat,
|
|
uint32_t flags);
|
|
|
|
void
|
|
notify_modifiers(struct weston_seat *seat, uint32_t serial);
|
|
|
|
void
|
|
weston_view_set_alpha(struct weston_view *view, float alpha);
|
|
|
|
void
|
|
weston_view_move_to_layer(struct weston_view *view,
|
|
struct weston_layer_entry *layer);
|
|
|
|
void
|
|
weston_layer_entry_insert(struct weston_layer_entry *list,
|
|
struct weston_layer_entry *entry);
|
|
void
|
|
weston_layer_entry_remove(struct weston_layer_entry *entry);
|
|
void
|
|
weston_layer_init(struct weston_layer *layer,
|
|
struct weston_compositor *compositor);
|
|
void
|
|
weston_layer_fini(struct weston_layer *layer);
|
|
void
|
|
weston_layer_set_position(struct weston_layer *layer,
|
|
enum weston_layer_position position);
|
|
void
|
|
weston_layer_unset_position(struct weston_layer *layer);
|
|
|
|
void
|
|
weston_layer_set_mask(struct weston_layer *layer, int x, int y, int width, int height);
|
|
|
|
void
|
|
weston_layer_set_mask_infinite(struct weston_layer *layer);
|
|
|
|
bool
|
|
weston_layer_mask_is_infinite(struct weston_layer *layer);
|
|
|
|
/* An invalid flag in presented_flags to catch logic errors. */
|
|
#define WP_PRESENTATION_FEEDBACK_INVALID (1U << 31)
|
|
/* Steal another bit from presented_flags for tearing */
|
|
#define WESTON_FINISH_FRAME_TEARING (1U << 30)
|
|
|
|
void
|
|
weston_output_schedule_repaint(struct weston_output *output);
|
|
void
|
|
weston_compositor_schedule_repaint(struct weston_compositor *compositor);
|
|
void
|
|
weston_compositor_damage_all(struct weston_compositor *compositor);
|
|
void
|
|
weston_compositor_wake(struct weston_compositor *compositor);
|
|
void
|
|
weston_compositor_sleep(struct weston_compositor *compositor);
|
|
struct weston_view *
|
|
weston_compositor_pick_view(struct weston_compositor *compositor,
|
|
struct weston_coord_global pos);
|
|
|
|
struct weston_binding;
|
|
typedef void (*weston_key_binding_handler_t)(struct weston_keyboard *keyboard,
|
|
const struct timespec *time,
|
|
uint32_t key,
|
|
void *data);
|
|
struct weston_binding *
|
|
weston_compositor_add_key_binding(struct weston_compositor *compositor,
|
|
uint32_t key,
|
|
enum weston_keyboard_modifier modifier,
|
|
weston_key_binding_handler_t binding,
|
|
void *data);
|
|
struct weston_binding *
|
|
weston_compositor_add_debug_binding(struct weston_compositor *compositor,
|
|
uint32_t key,
|
|
weston_key_binding_handler_t binding,
|
|
void *data);
|
|
|
|
typedef void (*weston_modifier_binding_handler_t)(struct weston_keyboard *keyboard,
|
|
enum weston_keyboard_modifier modifier,
|
|
void *data);
|
|
struct weston_binding *
|
|
weston_compositor_add_modifier_binding(struct weston_compositor *compositor,
|
|
enum weston_keyboard_modifier modifier,
|
|
weston_modifier_binding_handler_t binding,
|
|
void *data);
|
|
|
|
typedef void (*weston_button_binding_handler_t)(struct weston_pointer *pointer,
|
|
const struct timespec *time,
|
|
uint32_t button,
|
|
void *data);
|
|
struct weston_binding *
|
|
weston_compositor_add_button_binding(struct weston_compositor *compositor,
|
|
uint32_t button,
|
|
enum weston_keyboard_modifier modifier,
|
|
weston_button_binding_handler_t binding,
|
|
void *data);
|
|
|
|
typedef void (*weston_touch_binding_handler_t)(struct weston_touch *touch,
|
|
const struct timespec *time,
|
|
void *data);
|
|
struct weston_binding *
|
|
weston_compositor_add_touch_binding(struct weston_compositor *compositor,
|
|
enum weston_keyboard_modifier modifier,
|
|
weston_touch_binding_handler_t binding,
|
|
void *data);
|
|
|
|
typedef void (*weston_tablet_tool_binding_handler_t)(struct weston_tablet_tool *tool,
|
|
uint32_t button,
|
|
void *data);
|
|
struct weston_binding *
|
|
weston_compositor_add_tablet_tool_binding(struct weston_compositor *compositor,
|
|
uint32_t button,
|
|
enum weston_keyboard_modifier modifier,
|
|
weston_tablet_tool_binding_handler_t binding,
|
|
void *data);
|
|
|
|
typedef void (*weston_axis_binding_handler_t)(struct weston_pointer *pointer,
|
|
const struct timespec *time,
|
|
struct weston_pointer_axis_event *event,
|
|
void *data);
|
|
struct weston_binding *
|
|
weston_compositor_add_axis_binding(struct weston_compositor *compositor,
|
|
uint32_t axis,
|
|
enum weston_keyboard_modifier modifier,
|
|
weston_axis_binding_handler_t binding,
|
|
void *data);
|
|
|
|
void
|
|
weston_binding_destroy(struct weston_binding *binding);
|
|
|
|
void
|
|
weston_install_debug_key_binding(struct weston_compositor *compositor,
|
|
uint32_t mod);
|
|
|
|
void
|
|
weston_compositor_set_default_pointer_grab(struct weston_compositor *compositor,
|
|
const struct weston_pointer_grab_interface *interface);
|
|
|
|
struct weston_surface *
|
|
weston_surface_create(struct weston_compositor *compositor);
|
|
|
|
void
|
|
weston_surface_set_color_profile(struct weston_surface *surface,
|
|
struct weston_color_profile *cprof,
|
|
const struct weston_render_intent_info *intent_info);
|
|
|
|
struct weston_view *
|
|
weston_view_create(struct weston_surface *surface);
|
|
|
|
struct weston_buffer_reference *
|
|
weston_buffer_create_solid_rgba(struct weston_compositor *compositor,
|
|
float r, float g, float b, float a);
|
|
|
|
void
|
|
weston_surface_attach_solid(struct weston_surface *surface,
|
|
struct weston_buffer_reference *buffer_ref,
|
|
int w, int h);
|
|
|
|
void
|
|
weston_buffer_destroy_solid(struct weston_buffer_reference *buffer_ref);
|
|
|
|
bool
|
|
weston_surface_has_content(struct weston_surface *surface);
|
|
|
|
void
|
|
weston_view_destroy(struct weston_view *view);
|
|
|
|
void
|
|
weston_view_set_rel_position(struct weston_view *view,
|
|
struct weston_coord_surface offset);
|
|
|
|
void
|
|
weston_view_set_position(struct weston_view *view,
|
|
struct weston_coord_global pos);
|
|
|
|
void
|
|
weston_view_set_position_with_offset(struct weston_view *view,
|
|
struct weston_coord_global pos,
|
|
struct weston_coord_surface offset);
|
|
|
|
struct weston_coord_surface
|
|
weston_view_get_pos_offset_rel(struct weston_view *view);
|
|
|
|
struct weston_coord_global
|
|
weston_view_get_pos_offset_global(struct weston_view *view);
|
|
|
|
void
|
|
weston_view_set_transform_parent(struct weston_view *view,
|
|
struct weston_view *parent);
|
|
|
|
void
|
|
weston_view_set_mask(struct weston_view *view,
|
|
int x, int y, int width, int height);
|
|
|
|
void
|
|
weston_view_set_mask_infinite(struct weston_view *view);
|
|
|
|
bool
|
|
weston_view_is_mapped(struct weston_view *view);
|
|
|
|
void
|
|
weston_view_schedule_repaint(struct weston_view *view);
|
|
|
|
bool
|
|
weston_surface_is_mapped(struct weston_surface *surface);
|
|
|
|
bool
|
|
weston_surface_is_mapping(struct weston_surface *surface);
|
|
|
|
bool
|
|
weston_surface_is_unmapping(struct weston_surface *surface);
|
|
|
|
void
|
|
weston_surface_set_size(struct weston_surface *surface,
|
|
int32_t width, int32_t height);
|
|
|
|
void
|
|
weston_surface_damage(struct weston_surface *surface);
|
|
|
|
void
|
|
weston_view_damage_below(struct weston_view *view);
|
|
|
|
void
|
|
weston_view_unmap(struct weston_view *view);
|
|
|
|
void
|
|
weston_surface_map(struct weston_surface *surface);
|
|
|
|
void
|
|
weston_surface_unmap(struct weston_surface *surface);
|
|
|
|
struct weston_surface *
|
|
weston_surface_get_main_surface(struct weston_surface *surface);
|
|
|
|
int
|
|
weston_surface_set_role(struct weston_surface *surface,
|
|
const char *role_name,
|
|
struct wl_resource *error_resource,
|
|
uint32_t error_code);
|
|
const char *
|
|
weston_surface_get_role(struct weston_surface *surface);
|
|
|
|
void
|
|
weston_surface_set_label_func(struct weston_surface *surface,
|
|
int (*desc)(struct weston_surface *,
|
|
char *, size_t));
|
|
|
|
void
|
|
weston_surface_get_content_size(struct weston_surface *surface,
|
|
int *width, int *height);
|
|
|
|
struct weston_geometry
|
|
weston_surface_get_bounding_box(struct weston_surface *surface);
|
|
|
|
int
|
|
weston_surface_copy_content(struct weston_surface *surface,
|
|
void *target, size_t size,
|
|
int src_x, int src_y,
|
|
int width, int height);
|
|
|
|
struct weston_buffer *
|
|
weston_buffer_from_resource(struct weston_compositor *ec,
|
|
struct wl_resource *resource);
|
|
|
|
void
|
|
weston_compositor_get_time(struct timespec *time);
|
|
|
|
void
|
|
weston_compositor_destroy(struct weston_compositor *ec);
|
|
|
|
struct weston_compositor *
|
|
weston_compositor_create(struct wl_display *display,
|
|
struct weston_log_context *log_ctx, void *user_data,
|
|
const struct weston_testsuite_data *test_data);
|
|
|
|
void *
|
|
weston_compositor_get_test_data(struct weston_compositor *ec);
|
|
|
|
bool
|
|
weston_compositor_add_destroy_listener_once(struct weston_compositor *compositor,
|
|
struct wl_listener *listener,
|
|
wl_notify_func_t destroy_handler);
|
|
|
|
enum weston_compositor_backend {
|
|
WESTON_BACKEND_DRM,
|
|
WESTON_BACKEND_HEADLESS,
|
|
WESTON_BACKEND_PIPEWIRE,
|
|
WESTON_BACKEND_RDP,
|
|
WESTON_BACKEND_VNC,
|
|
WESTON_BACKEND_WAYLAND,
|
|
WESTON_BACKEND_X11,
|
|
};
|
|
|
|
enum weston_renderer_type {
|
|
WESTON_RENDERER_AUTO = 0,
|
|
WESTON_RENDERER_NOOP = 1,
|
|
WESTON_RENDERER_PIXMAN = 2,
|
|
WESTON_RENDERER_GL = 3,
|
|
};
|
|
|
|
struct weston_backend *
|
|
weston_compositor_load_backend(struct weston_compositor *compositor,
|
|
enum weston_compositor_backend backend,
|
|
struct weston_backend_config *config_base);
|
|
void
|
|
weston_compositor_exit(struct weston_compositor *ec);
|
|
void *
|
|
weston_compositor_get_user_data(struct weston_compositor *compositor);
|
|
void
|
|
weston_compositor_exit_with_code(struct weston_compositor *compositor,
|
|
int exit_code);
|
|
void
|
|
weston_output_add_destroy_listener(struct weston_output *output,
|
|
struct wl_listener *listener);
|
|
struct wl_listener *
|
|
weston_output_get_destroy_listener(struct weston_output *output,
|
|
wl_notify_func_t notify);
|
|
int
|
|
weston_compositor_set_xkb_rule_names(struct weston_compositor *ec,
|
|
struct xkb_rule_names *names);
|
|
|
|
/* String literal of spaces, the same width as the timestamp. */
|
|
#define STAMP_SPACE " "
|
|
|
|
/**
|
|
* \ingroup wlog
|
|
*/
|
|
typedef int (*log_func_t)(const char *fmt, va_list ap);
|
|
void
|
|
weston_log_set_handler(log_func_t log, log_func_t cont);
|
|
int
|
|
weston_log(const char *fmt, ...)
|
|
__attribute__ ((format (printf, 1, 2)));
|
|
int
|
|
weston_log_continue(const char *fmt, ...)
|
|
__attribute__ ((format (printf, 1, 2)));
|
|
|
|
void
|
|
weston_log_paced(struct weston_log_pacer *pacer, unsigned int max_burst,
|
|
unsigned int reset_ms, const char *fmt, ...)
|
|
__attribute__ ((format (printf, 4, 5)));
|
|
|
|
enum weston_screenshooter_outcome {
|
|
WESTON_SCREENSHOOTER_SUCCESS,
|
|
WESTON_SCREENSHOOTER_NO_MEMORY,
|
|
WESTON_SCREENSHOOTER_BAD_BUFFER
|
|
};
|
|
|
|
typedef void (*weston_screenshooter_done_func_t)(void *data,
|
|
enum weston_screenshooter_outcome outcome);
|
|
int
|
|
weston_screenshooter_shoot(struct weston_output *output, struct weston_buffer *buffer,
|
|
weston_screenshooter_done_func_t done, void *data) WL_DEPRECATED;
|
|
struct weston_recorder *
|
|
weston_recorder_start(struct weston_output *output, const char *filename);
|
|
void
|
|
weston_recorder_stop(struct weston_recorder *recorder);
|
|
|
|
struct weston_view_animation;
|
|
typedef void (*weston_view_animation_done_func_t)(struct weston_view_animation *animation, void *data);
|
|
|
|
void
|
|
weston_view_animation_destroy(struct weston_view_animation *animation);
|
|
|
|
struct weston_view_animation *
|
|
weston_zoom_run(struct weston_view *view, float start, float stop,
|
|
weston_view_animation_done_func_t done, void *data);
|
|
|
|
struct weston_view_animation *
|
|
weston_fade_run(struct weston_view *view, float start, float end,
|
|
weston_view_animation_done_func_t done, void *data);
|
|
|
|
struct weston_view_animation *
|
|
weston_move_scale_run(struct weston_view *view, int dx, int dy,
|
|
float start, float end, bool reverse,
|
|
weston_view_animation_done_func_t done, void *data);
|
|
|
|
struct weston_view_animation *
|
|
weston_move_run(struct weston_view *view, int dx, int dy,
|
|
float start, float end, bool reverse,
|
|
weston_view_animation_done_func_t done, void *data);
|
|
|
|
void
|
|
weston_fade_update(struct weston_view_animation *fade, float target);
|
|
|
|
struct weston_view_animation *
|
|
weston_stable_fade_run(struct weston_view *front_view, float start,
|
|
struct weston_view *back_view, float end,
|
|
weston_view_animation_done_func_t done, void *data);
|
|
|
|
struct weston_view_animation *
|
|
weston_slide_run(struct weston_view *view, float start, float stop,
|
|
weston_view_animation_done_func_t done, void *data);
|
|
|
|
struct weston_surface *
|
|
weston_surface_ref(struct weston_surface *surface);
|
|
|
|
void
|
|
weston_surface_unref(struct weston_surface *surface);
|
|
|
|
int
|
|
weston_output_mode_switch_to_temporary(struct weston_output *output,
|
|
struct weston_mode *mode,
|
|
int32_t scale);
|
|
int
|
|
weston_output_mode_switch_to_native(struct weston_output *output);
|
|
|
|
int
|
|
weston_backend_init(struct weston_compositor *c,
|
|
struct weston_backend_config *config_base);
|
|
int
|
|
weston_module_init(struct weston_compositor *compositor);
|
|
|
|
void *
|
|
weston_load_module(const char *name, const char *entrypoint, const char *module_dir);
|
|
|
|
size_t
|
|
weston_module_path_from_env(const char *name, char *path, size_t path_len);
|
|
|
|
int
|
|
weston_parse_transform(const char *transform, uint32_t *out);
|
|
|
|
const char *
|
|
weston_transform_to_string(uint32_t output_transform);
|
|
|
|
struct weston_keyboard *
|
|
weston_seat_get_keyboard(struct weston_seat *seat);
|
|
|
|
struct weston_pointer *
|
|
weston_seat_get_pointer(struct weston_seat *seat);
|
|
|
|
struct weston_touch *
|
|
weston_seat_get_touch(struct weston_seat *seat);
|
|
|
|
void
|
|
weston_seat_set_keyboard_focus(struct weston_seat *seat,
|
|
struct weston_surface *surface);
|
|
|
|
void
|
|
weston_keyboard_send_keymap(struct weston_keyboard *kbd,
|
|
struct wl_resource *resource);
|
|
|
|
int
|
|
weston_compositor_load_xwayland(struct weston_compositor *compositor);
|
|
|
|
int
|
|
weston_compositor_load_color_manager(struct weston_compositor *compositor);
|
|
|
|
bool
|
|
weston_head_is_connected(struct weston_head *head);
|
|
|
|
bool
|
|
weston_head_is_enabled(struct weston_head *head);
|
|
|
|
bool
|
|
weston_head_is_device_changed(struct weston_head *head);
|
|
|
|
bool
|
|
weston_head_is_non_desktop(struct weston_head *head);
|
|
|
|
void
|
|
weston_head_set_device_changed(struct weston_head *head);
|
|
|
|
void
|
|
weston_head_reset_device_changed(struct weston_head *head);
|
|
|
|
const char *
|
|
weston_head_get_name(struct weston_head *head);
|
|
|
|
struct weston_output *
|
|
weston_head_get_output(struct weston_head *head);
|
|
|
|
uint32_t
|
|
weston_head_get_transform(struct weston_head *head);
|
|
|
|
void
|
|
weston_head_detach(struct weston_head *head);
|
|
|
|
void
|
|
weston_head_add_destroy_listener(struct weston_head *head,
|
|
struct wl_listener *listener);
|
|
|
|
struct wl_listener *
|
|
weston_head_get_destroy_listener(struct weston_head *head,
|
|
wl_notify_func_t notify);
|
|
|
|
void
|
|
weston_head_set_content_protection_status(struct weston_head *head,
|
|
enum weston_hdcp_protection status);
|
|
|
|
struct weston_head *
|
|
weston_compositor_iterate_heads(struct weston_compositor *compositor,
|
|
struct weston_head *iter);
|
|
|
|
void
|
|
weston_compositor_add_heads_changed_listener(struct weston_compositor *compositor,
|
|
struct wl_listener *listener);
|
|
|
|
struct weston_output *
|
|
weston_compositor_find_output_by_name(struct weston_compositor *compositor,
|
|
const char *name);
|
|
|
|
struct weston_output *
|
|
weston_compositor_create_output(struct weston_compositor *compositor,
|
|
struct weston_head *head, const char *name);
|
|
|
|
void
|
|
weston_output_destroy(struct weston_output *output);
|
|
|
|
int
|
|
weston_output_attach_head(struct weston_output *output,
|
|
struct weston_head *head);
|
|
|
|
struct weston_head *
|
|
weston_output_iterate_heads(struct weston_output *output,
|
|
struct weston_head *iter);
|
|
|
|
void
|
|
weston_output_set_scale(struct weston_output *output,
|
|
int32_t scale);
|
|
|
|
void
|
|
weston_output_set_transform(struct weston_output *output,
|
|
uint32_t transform);
|
|
|
|
bool
|
|
weston_output_set_color_profile(struct weston_output *output,
|
|
struct weston_color_profile *cprof);
|
|
|
|
void
|
|
weston_output_set_eotf_mode(struct weston_output *output,
|
|
enum weston_eotf_mode eotf_mode);
|
|
|
|
enum weston_eotf_mode
|
|
weston_output_get_eotf_mode(const struct weston_output *output);
|
|
|
|
void
|
|
weston_output_set_color_characteristics(struct weston_output *output,
|
|
const struct weston_color_characteristics *cc);
|
|
|
|
const struct weston_color_characteristics *
|
|
weston_output_get_color_characteristics(struct weston_output *output);
|
|
|
|
void
|
|
weston_output_init(struct weston_output *output,
|
|
struct weston_compositor *compositor,
|
|
const char *name);
|
|
|
|
void
|
|
weston_output_move(struct weston_output *output,
|
|
struct weston_coord_global pos);
|
|
|
|
int
|
|
weston_output_enable(struct weston_output *output);
|
|
|
|
void
|
|
weston_output_disable(struct weston_output *output);
|
|
|
|
uint32_t
|
|
weston_output_get_supported_eotf_modes(struct weston_output *output);
|
|
|
|
void
|
|
weston_output_power_off(struct weston_output *output);
|
|
|
|
void
|
|
weston_output_power_on(struct weston_output *output);
|
|
|
|
void
|
|
weston_compositor_flush_heads_changed(struct weston_compositor *compositor);
|
|
|
|
struct weston_head *
|
|
weston_head_from_resource(struct wl_resource *resource);
|
|
|
|
struct weston_head *
|
|
weston_output_get_first_head(struct weston_output *output);
|
|
|
|
void
|
|
weston_output_allow_protection(struct weston_output *output,
|
|
bool allow_protection);
|
|
|
|
bool
|
|
weston_output_contains_coord(struct weston_output *output,
|
|
struct weston_coord_global pos);
|
|
|
|
int
|
|
weston_compositor_enable_touch_calibrator(struct weston_compositor *compositor,
|
|
weston_touch_calibration_save_func save);
|
|
|
|
struct weston_log_context *
|
|
weston_log_ctx_create(void);
|
|
|
|
void
|
|
weston_log_ctx_destroy(struct weston_log_context *log_ctx);
|
|
|
|
int
|
|
weston_compositor_enable_content_protection(struct weston_compositor *compositor);
|
|
|
|
void
|
|
weston_timeline_refresh_subscription_objects(struct weston_compositor *wc,
|
|
void *object);
|
|
|
|
struct weston_color_profile *
|
|
weston_color_profile_ref(struct weston_color_profile *cprof);
|
|
|
|
void
|
|
weston_color_profile_unref(struct weston_color_profile *cprof);
|
|
|
|
const char *
|
|
weston_color_profile_get_description(struct weston_color_profile *cprof);
|
|
|
|
struct weston_color_profile *
|
|
weston_compositor_load_icc_file(struct weston_compositor *compositor,
|
|
const char *path);
|
|
|
|
/** Describes who is trying to capture and which output */
|
|
struct weston_output_capture_client {
|
|
struct wl_client *client;
|
|
struct weston_output *output;
|
|
};
|
|
|
|
/** Arguments asking to authorize a screenshot/capture
|
|
*
|
|
* \sa weston_compositor_add_screenshot_authority
|
|
*/
|
|
struct weston_output_capture_attempt {
|
|
const struct weston_output_capture_client *const who;
|
|
|
|
/** Set to true to authorize the screenshot. */
|
|
bool authorized;
|
|
/** Set to true to deny the screenshot. */
|
|
bool denied;
|
|
};
|
|
|
|
void
|
|
weston_compositor_add_screenshot_authority(struct weston_compositor *compositor,
|
|
struct wl_listener *listener,
|
|
void (*auth)(struct wl_listener *l,
|
|
struct weston_output_capture_attempt *att));
|
|
|
|
int
|
|
weston_compositor_backends_loaded(struct weston_compositor *compositor);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif
|