From 271df559dd30e4bc5ec6af02d017ac0aaabd63a7 Mon Sep 17 00:00:00 2001 From: outfoxxed Date: Wed, 1 Jan 2025 04:27:54 -0800 Subject: [PATCH] protocols: add hyprland-surface-v1 (#11) --- README.md | 1 + meson.build | 1 + protocols/hyprland-surface-v1.xml | 100 ++++++++++++++++++++++++++++++ 3 files changed, 102 insertions(+) create mode 100644 protocols/hyprland-surface-v1.xml diff --git a/README.md b/README.md index 9d4df04..b5b5a44 100644 --- a/README.md +++ b/README.md @@ -12,6 +12,7 @@ hyprland-exclusive plumbing protocols anyways. - `hyprland_global_keybindings` -> for managing global keybinds via D-Bus. - `hyprland_focus_grab` -> for grabbing input focus, primarily for complex context menus. - `hyprland_ctm_control` -> for managing CTMs of displays. See [hyprsunset](https://github.com/hyprwm/hyprsunset) +- `hyprland_surface` -> for setting hyprland specific wl_surface properties. # Contributing Adding new protocols is *discouraged*. If the protocol has a good reason to be, and you have an impl ready, feel free to make a PR. diff --git a/meson.build b/meson.build index 1b9ed09..c44ce23 100644 --- a/meson.build +++ b/meson.build @@ -12,6 +12,7 @@ protocols = { 'hyprland-global-shortcuts': ['v1'], 'hyprland-focus-grab': ['v1'], 'hyprland-ctm-control': ['v1'], + 'hyprland-surface': ['v1'], } protocol_files = [] diff --git a/protocols/hyprland-surface-v1.xml b/protocols/hyprland-surface-v1.xml new file mode 100644 index 0000000..2f68336 --- /dev/null +++ b/protocols/hyprland-surface-v1.xml @@ -0,0 +1,100 @@ + + + + Copyright © 2025 outfoxxed + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + + 1. Redistributions of source code must retain the above copyright notice, this + list of conditions and the following disclaimer. + + 2. Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. + + 3. Neither the name of the copyright holder nor the names of its + contributors may be used to endorse or promote products derived from + this software without specific prior written permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE + FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR + SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER + CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, + OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + + + + This protocol exposes hyprland-specific wl_surface properties. + + + + + This interface allows a client to create hyprland surface objects. + + + + + Create a hyprland surface object for the given wayland surface. + + If the wl_surface already has an associated hyprland_surface_v1 object, + even from a different manager, creation is a protocol error. + + + + + + + + + Destroy the surface manager. + This does not destroy existing surface objects. + + + + + + + + + + + This interface allows access to hyprland-specific properties of a wl_surface. + + Once the wl_surface has been destroyed, the hyprland surface object must be + destroyed as well. All other operations are a protocol error. + + + + + Sets a multiplier for the overall opacity of the surface. + This multiplier applies to visual effects such as blur behind the surface + in addition to the surface's content. + + The default value is 1.0. + Setting a value outside of the range 0.0 - 1.0 (inclusive) is a protocol error. + Does not take effect until wl_surface.commit is called. + + + + + + + + Destroy the hyprland surface object, resetting properties provided + by this interface to their default values on the next wl_surface.commit. + + + + + + + + +