19 #ifndef MIRAL_WAYLAND_EXTENSIONS_H 20 #define MIRAL_WAYLAND_EXTENSIONS_H 33 namespace mir {
class Server; }
86 virtual auto display()
const -> wl_display* = 0;
112 using Filter = std::function<bool(Application const& app, char const* protocol)>;
146 static auto recommended() -> std::set<std::string>;
152 static auto supported() -> std::set<std::string>;
166 std::shared_ptr<Self>
self;
189 #endif //MIRAL_WAYLAND_EXTENSIONS_H Definition: splash_session.h:24
static auto recommended_extensions() -> std::string
Default for extensions to enabled recommended by Mir (colon separated list)
A Builder creates and registers an extension protocol.
Definition: wayland_extensions.h:98
std::string name
Name of the protocol extension.
Definition: wayland_extensions.h:101
void set_filter(Filter const &extension_filter)
Set an extension filter callback to control the extensions available to specific clients.
virtual void run_on_wayland_mainloop(std::function< void()> &&work) const =0
std::function< bool(Application const &app, char const *protocol)> Filter
Definition: wayland_extensions.h:112
auto supported_extensions() const -> std::string
All Wayland extensions currently supported (colon separated list). This includes both the recommended...
Context information useful for implementing Wayland extensions.
Definition: wayland_extensions.h:83
auto operator=(WaylandExtensions const &) -> WaylandExtensions &
auto enable(std::string name) -> WaylandExtensions &
Enable a Wayland extension Throws a std::runtime_error if the extension is not supported.
void operator()(mir::Server &server) const
WaylandExtensions()
Default to enabling the extensions recommended by Mir.
auto window_for(wl_resource *surface) -> Window
Get the MirAL Window for a Wayland Surface, XdgSurface, etc. Note that there may not be a correspondi...
Enable configuration of the Wayland extensions enabled at runtime.
Definition: wayland_extensions.h:48
Handle class to manage a Mir surface. It may be null (e.g. default initialized)
Definition: window.h:37
std::shared_ptr< mir::scene::Session > Application
Definition: application.h:34
Context & operator=(Context const &)=delete
virtual auto display() const -> wl_display *=0
std::function< std::shared_ptr< void >Context const *context)> build
Functor that creates and registers an extension protocol.
Definition: wayland_extensions.h:108
virtual ~Context()=default
void add_extension_disabled_by_default(Builder const &builder)
Add a bespoke Wayland extension both to "supported" but not "enabled by default". ...
char const * name
Definition: client_types.h:177
static char const *const zwlr_layer_shell_v1
Supported wayland extensions that are not enabled by default.
Definition: wayland_extensions.h:128
static char const *const zxdg_output_manager_v1
Allows clients to retrieve additional information about outputs.
Definition: wayland_extensions.h:132
auto disable(std::string name) -> WaylandExtensions &
Disable a Wayand extension Throws a std::runtime_error if the extension is not supported.
static auto recommended() -> std::set< std::string >
The set of Wayland extensions that Mir recommends. Also the set that is enabled by default upon const...
auto application_for(wl_client *client) -> Application
Get the MirAL application for a wl_client.
static auto supported() -> std::set< std::string >
The set of Wayland extensions that core Mir supports. Does not include bespoke extensions A superset ...
void add_extension(Builder const &builder)
Add a bespoke Wayland extension both to "supported" and "enabled by default".
Mir Abstraction Layer.
Definition: floating_window_manager.h:29