distribution/packages/emulators/standalone/cemu-sa/patches/001-revert-vulkan-canvas.patch
2023-07-09 15:49:59 +00:00

794 lines
30 KiB
Diff

diff --git a/CMakeLists.txt b/CMakeLists.txt
index 26d676b..2ce81a0 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -125,16 +125,7 @@ endif()
if (UNIX AND NOT APPLE)
find_package(X11 REQUIRED)
if (ENABLE_WAYLAND)
- find_package(Wayland REQUIRED Client)
- find_package(WaylandScanner REQUIRED)
- find_package(WaylandProtocols 1.15 REQUIRED)
-
- ecm_add_wayland_client_protocol(WAYLAND_PROTOCOL_SRCS
- PROTOCOL "${WaylandProtocols_DATADIR}/stable/viewporter/viewporter.xml"
- BASENAME viewporter)
- add_library(CemuWaylandProtocols STATIC ${WAYLAND_PROTOCOL_SRCS})
- target_include_directories(CemuWaylandProtocols PUBLIC "${CMAKE_CURRENT_BINARY_DIR}")
-
+ find_package(Wayland REQUIRED)
add_compile_definitions(HAS_WAYLAND)
endif()
find_package(GTK3 REQUIRED)
diff --git a/cmake/ECMFindModuleHelpers.cmake b/cmake/ECMFindModuleHelpers.cmake
deleted file mode 100644
index a483740..0000000
--- a/cmake/ECMFindModuleHelpers.cmake
+++ /dev/null
@@ -1,279 +0,0 @@
-# SPDX-FileCopyrightText: 2014 Alex Merry <alex.merry@kde.org>
-#
-# SPDX-License-Identifier: BSD-3-Clause
-
-#[=======================================================================[.rst:
-ECMFindModuleHelpers
---------------------
-
-Helper macros for find modules: ``ecm_find_package_version_check()``,
-``ecm_find_package_parse_components()`` and
-``ecm_find_package_handle_library_components()``.
-
-::
-
- ecm_find_package_version_check(<name>)
-
-Prints warnings if the CMake version or the project's required CMake version
-is older than that required by extra-cmake-modules.
-
-::
-
- ecm_find_package_parse_components(<name>
- RESULT_VAR <variable>
- KNOWN_COMPONENTS <component1> [<component2> [...]]
- [SKIP_DEPENDENCY_HANDLING])
-
-This macro will populate <variable> with a list of components found in
-<name>_FIND_COMPONENTS, after checking that all those components are in the
-list of ``KNOWN_COMPONENTS``; if there are any unknown components, it will print
-an error or warning (depending on the value of <name>_FIND_REQUIRED) and call
-``return()``.
-
-The order of components in <variable> is guaranteed to match the order they
-are listed in the ``KNOWN_COMPONENTS`` argument.
-
-If ``SKIP_DEPENDENCY_HANDLING`` is not set, for each component the variable
-<name>_<component>_component_deps will be checked for dependent components.
-If <component> is listed in <name>_FIND_COMPONENTS, then all its (transitive)
-dependencies will also be added to <variable>.
-
-::
-
- ecm_find_package_handle_library_components(<name>
- COMPONENTS <component> [<component> [...]]
- [SKIP_DEPENDENCY_HANDLING])
- [SKIP_PKG_CONFIG])
-
-Creates an imported library target for each component. The operation of this
-macro depends on the presence of a number of CMake variables.
-
-The <name>_<component>_lib variable should contain the name of this library,
-and <name>_<component>_header variable should contain the name of a header
-file associated with it (whatever relative path is normally passed to
-'#include'). <name>_<component>_header_subdir variable can be used to specify
-which subdirectory of the include path the headers will be found in.
-``ecm_find_package_components()`` will then search for the library
-and include directory (creating appropriate cache variables) and create an
-imported library target named <name>::<component>.
-
-Additional variables can be used to provide additional information:
-
-If ``SKIP_PKG_CONFIG``, the <name>_<component>_pkg_config variable is set, and
-pkg-config is found, the pkg-config module given by
-<name>_<component>_pkg_config will be searched for and used to help locate the
-library and header file. It will also be used to set
-<name>_<component>_VERSION.
-
-Note that if version information is found via pkg-config,
-<name>_<component>_FIND_VERSION can be set to require a particular version
-for each component.
-
-If ``SKIP_DEPENDENCY_HANDLING`` is not set, the ``INTERFACE_LINK_LIBRARIES`` property
-of the imported target for <component> will be set to contain the imported
-targets for the components listed in <name>_<component>_component_deps.
-<component>_FOUND will also be set to ``FALSE`` if any of the components in
-<name>_<component>_component_deps are not found. This requires the components
-in <name>_<component>_component_deps to be listed before <component> in the
-``COMPONENTS`` argument.
-
-The following variables will be set:
-
-``<name>_TARGETS``
- the imported targets
-``<name>_LIBRARIES``
- the found libraries
-``<name>_INCLUDE_DIRS``
- the combined required include directories for the components
-``<name>_DEFINITIONS``
- the "other" CFLAGS provided by pkg-config, if any
-``<name>_VERSION``
- the value of ``<name>_<component>_VERSION`` for the first component that
- has this variable set (note that components are searched for in the order
- they are passed to the macro), although if it is already set, it will not
- be altered
-
-.. note::
- These variables are never cleared, so if
- ``ecm_find_package_handle_library_components()`` is called multiple times with
- different components (typically because of multiple ``find_package()`` calls) then
- ``<name>_TARGETS``, for example, will contain all the targets found in any
- call (although no duplicates).
-
-Since pre-1.0.0.
-#]=======================================================================]
-
-include(CMakeParseArguments)
-
-macro(ecm_find_package_version_check module_name)
- if(CMAKE_VERSION VERSION_LESS 3.16.0)
- message(FATAL_ERROR "CMake 3.16.0 is required by Find${module_name}.cmake")
- endif()
- if(CMAKE_MINIMUM_REQUIRED_VERSION VERSION_LESS 3.16.0)
- message(AUTHOR_WARNING "Your project should require at least CMake 3.16.0 to use Find${module_name}.cmake")
- endif()
-endmacro()
-
-macro(ecm_find_package_parse_components module_name)
- set(ecm_fppc_options SKIP_DEPENDENCY_HANDLING)
- set(ecm_fppc_oneValueArgs RESULT_VAR)
- set(ecm_fppc_multiValueArgs KNOWN_COMPONENTS DEFAULT_COMPONENTS)
- cmake_parse_arguments(ECM_FPPC "${ecm_fppc_options}" "${ecm_fppc_oneValueArgs}" "${ecm_fppc_multiValueArgs}" ${ARGN})
-
- if(ECM_FPPC_UNPARSED_ARGUMENTS)
- message(FATAL_ERROR "Unexpected arguments to ecm_find_package_parse_components: ${ECM_FPPC_UNPARSED_ARGUMENTS}")
- endif()
- if(NOT ECM_FPPC_RESULT_VAR)
- message(FATAL_ERROR "Missing RESULT_VAR argument to ecm_find_package_parse_components")
- endif()
- if(NOT ECM_FPPC_KNOWN_COMPONENTS)
- message(FATAL_ERROR "Missing KNOWN_COMPONENTS argument to ecm_find_package_parse_components")
- endif()
- if(NOT ECM_FPPC_DEFAULT_COMPONENTS)
- set(ECM_FPPC_DEFAULT_COMPONENTS ${ECM_FPPC_KNOWN_COMPONENTS})
- endif()
-
- if(${module_name}_FIND_COMPONENTS)
- set(ecm_fppc_requestedComps ${${module_name}_FIND_COMPONENTS})
-
- if(NOT ECM_FPPC_SKIP_DEPENDENCY_HANDLING)
- # Make sure deps are included
- foreach(ecm_fppc_comp ${ecm_fppc_requestedComps})
- foreach(ecm_fppc_dep_comp ${${module_name}_${ecm_fppc_comp}_component_deps})
- list(FIND ecm_fppc_requestedComps "${ecm_fppc_dep_comp}" ecm_fppc_index)
- if("${ecm_fppc_index}" STREQUAL "-1")
- if(NOT ${module_name}_FIND_QUIETLY)
- message(STATUS "${module_name}: ${ecm_fppc_comp} requires ${${module_name}_${ecm_fppc_comp}_component_deps}")
- endif()
- list(APPEND ecm_fppc_requestedComps "${ecm_fppc_dep_comp}")
- endif()
- endforeach()
- endforeach()
- else()
- message(STATUS "Skipping dependency handling for ${module_name}")
- endif()
- list(REMOVE_DUPLICATES ecm_fppc_requestedComps)
-
- # This makes sure components are listed in the same order as
- # KNOWN_COMPONENTS (potentially important for inter-dependencies)
- set(${ECM_FPPC_RESULT_VAR})
- foreach(ecm_fppc_comp ${ECM_FPPC_KNOWN_COMPONENTS})
- list(FIND ecm_fppc_requestedComps "${ecm_fppc_comp}" ecm_fppc_index)
- if(NOT "${ecm_fppc_index}" STREQUAL "-1")
- list(APPEND ${ECM_FPPC_RESULT_VAR} "${ecm_fppc_comp}")
- list(REMOVE_AT ecm_fppc_requestedComps ${ecm_fppc_index})
- endif()
- endforeach()
- # if there are any left, they are unknown components
- if(ecm_fppc_requestedComps)
- set(ecm_fppc_msgType STATUS)
- if(${module_name}_FIND_REQUIRED)
- set(ecm_fppc_msgType FATAL_ERROR)
- endif()
- if(NOT ${module_name}_FIND_QUIETLY)
- message(${ecm_fppc_msgType} "${module_name}: requested unknown components ${ecm_fppc_requestedComps}")
- endif()
- return()
- endif()
- else()
- set(${ECM_FPPC_RESULT_VAR} ${ECM_FPPC_DEFAULT_COMPONENTS})
- endif()
-endmacro()
-
-macro(ecm_find_package_handle_library_components module_name)
- set(ecm_fpwc_options SKIP_PKG_CONFIG SKIP_DEPENDENCY_HANDLING)
- set(ecm_fpwc_oneValueArgs)
- set(ecm_fpwc_multiValueArgs COMPONENTS)
- cmake_parse_arguments(ECM_FPWC "${ecm_fpwc_options}" "${ecm_fpwc_oneValueArgs}" "${ecm_fpwc_multiValueArgs}" ${ARGN})
-
- if(ECM_FPWC_UNPARSED_ARGUMENTS)
- message(FATAL_ERROR "Unexpected arguments to ecm_find_package_handle_components: ${ECM_FPWC_UNPARSED_ARGUMENTS}")
- endif()
- if(NOT ECM_FPWC_COMPONENTS)
- message(FATAL_ERROR "Missing COMPONENTS argument to ecm_find_package_handle_components")
- endif()
-
- include(FindPackageHandleStandardArgs)
- find_package(PkgConfig QUIET)
- foreach(ecm_fpwc_comp ${ECM_FPWC_COMPONENTS})
- set(ecm_fpwc_dep_vars)
- set(ecm_fpwc_dep_targets)
- if(NOT SKIP_DEPENDENCY_HANDLING)
- foreach(ecm_fpwc_dep ${${module_name}_${ecm_fpwc_comp}_component_deps})
- list(APPEND ecm_fpwc_dep_vars "${module_name}_${ecm_fpwc_dep}_FOUND")
- list(APPEND ecm_fpwc_dep_targets "${module_name}::${ecm_fpwc_dep}")
- endforeach()
- endif()
-
- if(NOT ECM_FPWC_SKIP_PKG_CONFIG AND ${module_name}_${ecm_fpwc_comp}_pkg_config)
- pkg_check_modules(PKG_${module_name}_${ecm_fpwc_comp} QUIET
- ${${module_name}_${ecm_fpwc_comp}_pkg_config})
- endif()
-
- find_path(${module_name}_${ecm_fpwc_comp}_INCLUDE_DIR
- NAMES ${${module_name}_${ecm_fpwc_comp}_header}
- HINTS ${PKG_${module_name}_${ecm_fpwc_comp}_INCLUDE_DIRS}
- PATH_SUFFIXES ${${module_name}_${ecm_fpwc_comp}_header_subdir}
- )
- find_library(${module_name}_${ecm_fpwc_comp}_LIBRARY
- NAMES ${${module_name}_${ecm_fpwc_comp}_lib}
- HINTS ${PKG_${module_name}_${ecm_fpwc_comp}_LIBRARY_DIRS}
- )
-
- set(${module_name}_${ecm_fpwc_comp}_VERSION "${PKG_${module_name}_${ecm_fpwc_comp}_VERSION}")
- if(NOT ${module_name}_VERSION)
- set(${module_name}_VERSION ${${module_name}_${ecm_fpwc_comp}_VERSION})
- endif()
-
- set(FPHSA_NAME_MISMATCHED 1)
- find_package_handle_standard_args(${module_name}_${ecm_fpwc_comp}
- FOUND_VAR
- ${module_name}_${ecm_fpwc_comp}_FOUND
- REQUIRED_VARS
- ${module_name}_${ecm_fpwc_comp}_LIBRARY
- ${module_name}_${ecm_fpwc_comp}_INCLUDE_DIR
- ${ecm_fpwc_dep_vars}
- VERSION_VAR
- ${module_name}_${ecm_fpwc_comp}_VERSION
- )
- unset(FPHSA_NAME_MISMATCHED)
-
- mark_as_advanced(
- ${module_name}_${ecm_fpwc_comp}_LIBRARY
- ${module_name}_${ecm_fpwc_comp}_INCLUDE_DIR
- )
-
- if(${module_name}_${ecm_fpwc_comp}_FOUND)
- list(APPEND ${module_name}_LIBRARIES
- "${${module_name}_${ecm_fpwc_comp}_LIBRARY}")
- list(APPEND ${module_name}_INCLUDE_DIRS
- "${${module_name}_${ecm_fpwc_comp}_INCLUDE_DIR}")
- set(${module_name}_DEFINITIONS
- ${${module_name}_DEFINITIONS}
- ${PKG_${module_name}_${ecm_fpwc_comp}_DEFINITIONS})
- if(NOT TARGET ${module_name}::${ecm_fpwc_comp})
- add_library(${module_name}::${ecm_fpwc_comp} UNKNOWN IMPORTED)
- set_target_properties(${module_name}::${ecm_fpwc_comp} PROPERTIES
- IMPORTED_LOCATION "${${module_name}_${ecm_fpwc_comp}_LIBRARY}"
- INTERFACE_COMPILE_OPTIONS "${PKG_${module_name}_${ecm_fpwc_comp}_DEFINITIONS}"
- INTERFACE_INCLUDE_DIRECTORIES "${${module_name}_${ecm_fpwc_comp}_INCLUDE_DIR}"
- INTERFACE_LINK_LIBRARIES "${ecm_fpwc_dep_targets}"
- )
- endif()
- list(APPEND ${module_name}_TARGETS
- "${module_name}::${ecm_fpwc_comp}")
- endif()
- endforeach()
- if(${module_name}_LIBRARIES)
- list(REMOVE_DUPLICATES ${module_name}_LIBRARIES)
- endif()
- if(${module_name}_INCLUDE_DIRS)
- list(REMOVE_DUPLICATES ${module_name}_INCLUDE_DIRS)
- endif()
- if(${module_name}_DEFINITIONS)
- list(REMOVE_DUPLICATES ${module_name}_DEFINITIONS)
- endif()
- if(${module_name}_TARGETS)
- list(REMOVE_DUPLICATES ${module_name}_TARGETS)
- endif()
-endmacro()
diff --git a/cmake/ECMFindModuleHelpersStub.cmake b/cmake/ECMFindModuleHelpersStub.cmake
deleted file mode 100644
index acc8c80..0000000
--- a/cmake/ECMFindModuleHelpersStub.cmake
+++ /dev/null
@@ -1 +0,0 @@
-include(${CMAKE_CURRENT_LIST_DIR}/ECMFindModuleHelpers.cmake)
diff --git a/cmake/FindWayland.cmake b/cmake/FindWayland.cmake
index 926fd48..813bcf0 100644
--- a/cmake/FindWayland.cmake
+++ b/cmake/FindWayland.cmake
@@ -1,137 +1,14 @@
-# SPDX-FileCopyrightText: 2014 Alex Merry <alex.merry@kde.org>
-# SPDX-FileCopyrightText: 2014 Martin Gräßlin <mgraesslin@kde.org>
-#
-# SPDX-License-Identifier: BSD-3-Clause
+find_package(PkgConfig)
-#[=======================================================================[.rst:
-FindWayland
------------
-
-Try to find Wayland.
-
-This is a component-based find module, which makes use of the COMPONENTS
-and OPTIONAL_COMPONENTS arguments to find_module. The following components
-are available::
-
- Client Server Cursor Egl
-
-If no components are specified, this module will act as though all components
-were passed to OPTIONAL_COMPONENTS.
-
-This module will define the following variables, independently of the
-components searched for or found:
-
-``Wayland_FOUND``
- TRUE if (the requested version of) Wayland is available
-``Wayland_VERSION``
- Found Wayland version
-``Wayland_TARGETS``
- A list of all targets imported by this module (note that there may be more
- than the components that were requested)
-``Wayland_LIBRARIES``
- This can be passed to target_link_libraries() instead of the imported
- targets
-``Wayland_INCLUDE_DIRS``
- This should be passed to target_include_directories() if the targets are
- not used for linking
-``Wayland_DEFINITIONS``
- This should be passed to target_compile_options() if the targets are not
- used for linking
-``Wayland_DATADIR``
- The core wayland protocols data directory
- Since 5.73.0
-
-For each searched-for components, ``Wayland_<component>_FOUND`` will be set to
-TRUE if the corresponding Wayland library was found, and FALSE otherwise. If
-``Wayland_<component>_FOUND`` is TRUE, the imported target
-``Wayland::<component>`` will be defined. This module will also attempt to
-determine ``Wayland_*_VERSION`` variables for each imported target, although
-``Wayland_VERSION`` should normally be sufficient.
-
-In general we recommend using the imported targets, as they are easier to use
-and provide more control. Bear in mind, however, that if any target is in the
-link interface of an exported library, it must be made available by the
-package config file.
-
-Since pre-1.0.0.
-#]=======================================================================]
-
-include(${CMAKE_CURRENT_LIST_DIR}/ECMFindModuleHelpersStub.cmake)
-
-ecm_find_package_version_check(Wayland)
-
-set(Wayland_known_components
- Client
- Server
- Cursor
- Egl
-)
-foreach(_comp ${Wayland_known_components})
- string(TOLOWER "${_comp}" _lc_comp)
- set(Wayland_${_comp}_component_deps)
- set(Wayland_${_comp}_pkg_config "wayland-${_lc_comp}")
- set(Wayland_${_comp}_lib "wayland-${_lc_comp}")
- set(Wayland_${_comp}_header "wayland-${_lc_comp}.h")
-endforeach()
-set(Wayland_Egl_component_deps Client)
-
-ecm_find_package_parse_components(Wayland
- RESULT_VAR Wayland_components
- KNOWN_COMPONENTS ${Wayland_known_components}
-)
-ecm_find_package_handle_library_components(Wayland
- COMPONENTS ${Wayland_components}
-)
-
-# If pkg-config didn't provide us with version information,
-# try to extract it from wayland-version.h
-# (Note that the version from wayland-egl.pc will probably be
-# the Mesa version, rather than the Wayland version, but that
-# version will be ignored as we always find wayland-client.pc
-# first).
-if(NOT Wayland_VERSION)
- find_file(Wayland_VERSION_HEADER
- NAMES wayland-version.h
- HINTS ${Wayland_INCLUDE_DIRS}
- )
- mark_as_advanced(Wayland_VERSION_HEADER)
- if(Wayland_VERSION_HEADER)
- file(READ ${Wayland_VERSION_HEADER} _wayland_version_header_contents)
- string(REGEX REPLACE
- "^.*[ \t]+WAYLAND_VERSION[ \t]+\"([0-9.]*)\".*$"
- "\\1"
- Wayland_VERSION
- "${_wayland_version_header_contents}"
- )
- unset(_wayland_version_header_contents)
- endif()
-endif()
+pkg_search_module(WAYLAND_CLIENT IMPORTED_TARGET wayland-client)
+include(FindPackageHandleStandardArgs)
find_package_handle_standard_args(Wayland
- FOUND_VAR
- Wayland_FOUND
REQUIRED_VARS
- Wayland_LIBRARIES
- VERSION_VAR
- Wayland_VERSION
- HANDLE_COMPONENTS
+ WAYLAND_CLIENT_LIBRARIES
+ VERSION_VAR WAYLAND_CLIENT_VERSION
)
-pkg_get_variable(Wayland_DATADIR wayland-scanner pkgdatadir)
-if (CMAKE_CROSSCOMPILING AND (NOT EXISTS "${Wayland_DATADIR}/wayland.xml"))
- # PKG_CONFIG_SYSROOT_DIR only applies to -I and -L flags, so pkg-config
- # does not prepend CMAKE_SYSROOT when cross-compiling unless you pass
- # --define-prefix explicitly. Therefore we have to manually do prepend
- # it here when cross-compiling.
- # See https://gitlab.kitware.com/cmake/cmake/-/issues/16647#note_844761
- set(Wayland_DATADIR ${CMAKE_SYSROOT}${Wayland_DATADIR})
-endif()
-if (NOT EXISTS "${Wayland_DATADIR}/wayland.xml")
- message(WARNING "Could not find wayland.xml in ${Wayland_DATADIR}")
+if (Wayland_FOUND)
+ add_library(Wayland::client ALIAS PkgConfig::WAYLAND_CLIENT)
endif()
-
-include(FeatureSummary)
-set_package_properties(Wayland PROPERTIES
- URL "https://wayland.freedesktop.org/"
- DESCRIPTION "C library implementation of the Wayland protocol: a protocol for a compositor to talk to its clients"
-)
diff --git a/cmake/FindWaylandProtocols.cmake b/cmake/FindWaylandProtocols.cmake
deleted file mode 100644
index a444988..0000000
--- a/cmake/FindWaylandProtocols.cmake
+++ /dev/null
@@ -1,38 +0,0 @@
-# SPDX-FileCopyrightText: 2019 Vlad Zahorodnii <vlad.zahorodnii@kde.org>
-#
-# SPDX-License-Identifier: BSD-3-Clause
-
-#[=======================================================================[.rst:
-FindWaylandProtocols
---------------------
-
-Try to find wayland-protocols on a Unix system.
-
-This will define the following variables:
-
-``WaylandProtocols_FOUND``
- True if (the requested version of) wayland-protocols is available
-``WaylandProtocols_VERSION``
- The version of wayland-protocols
-``WaylandProtocols_DATADIR``
- The wayland protocols data directory
-#]=======================================================================]
-
-find_package(PkgConfig QUIET)
-pkg_check_modules(PKG_wayland_protocols QUIET wayland-protocols)
-
-set(WaylandProtocols_VERSION ${PKG_wayland_protocols_VERSION})
-pkg_get_variable(WaylandProtocols_DATADIR wayland-protocols pkgdatadir)
-
-include(FindPackageHandleStandardArgs)
-find_package_handle_standard_args(WaylandProtocols
- FOUND_VAR WaylandProtocols_FOUND
- REQUIRED_VARS WaylandProtocols_DATADIR
- VERSION_VAR WaylandProtocols_VERSION
-)
-
-include(FeatureSummary)
-set_package_properties(WaylandProtocols PROPERTIES
- DESCRIPTION "Specifications of extended Wayland protocols"
- URL "https://wayland.freedesktop.org/"
-)
diff --git a/cmake/FindWaylandScanner.cmake b/cmake/FindWaylandScanner.cmake
deleted file mode 100644
index f849580..0000000
--- a/cmake/FindWaylandScanner.cmake
+++ /dev/null
@@ -1,162 +0,0 @@
-# SPDX-FileCopyrightText: 2012-2014 Pier Luigi Fiorini <pierluigi.fiorini@gmail.com>
-#
-# SPDX-License-Identifier: BSD-3-Clause
-
-#[=======================================================================[.rst:
-FindWaylandScanner
-------------------
-
-Try to find wayland-scanner.
-
-If the wayland-scanner executable is not in your PATH, you can provide
-an alternative name or full path location with the ``WaylandScanner_EXECUTABLE``
-variable.
-
-This will define the following variables:
-
-``WaylandScanner_FOUND``
- True if wayland-scanner is available.
-
-``WaylandScanner_EXECUTABLE``
- The wayland-scanner executable.
-
-If ``WaylandScanner_FOUND`` is TRUE, it will also define the following imported
-target:
-
-``Wayland::Scanner``
- The wayland-scanner executable.
-
-This module provides the following functions to generate C protocol
-implementations:
-
- - ``ecm_add_wayland_client_protocol``
- - ``ecm_add_wayland_server_protocol``
-
-::
-
- ecm_add_wayland_client_protocol(<target>
- PROTOCOL <xmlfile>
- BASENAME <basename>)
-
- ecm_add_wayland_client_protocol(<source_files_var>
- PROTOCOL <xmlfile>
- BASENAME <basename>)
-
-Generate Wayland client protocol files from ``<xmlfile>`` XML
-definition for the ``<basename>`` interface and append those files
-to ``<source_files_var>`` or ``<target>``.
-
-::
-
- ecm_add_wayland_server_protocol(<target>
- PROTOCOL <xmlfile>
- BASENAME <basename>)
-
- ecm_add_wayland_server_protocol(<source_files_var>
- PROTOCOL <xmlfile>
- BASENAME <basename>)
-
-Generate Wayland server protocol files from ``<xmlfile>`` XML
-definition for the ``<basename>`` interface and append those files
-to ``<source_files_var>`` or ``<target>``.
-
-Since 1.4.0.
-#]=======================================================================]
-
-include(${CMAKE_CURRENT_LIST_DIR}/ECMFindModuleHelpersStub.cmake)
-
-ecm_find_package_version_check(WaylandScanner)
-
-# Find wayland-scanner
-find_program(WaylandScanner_EXECUTABLE NAMES wayland-scanner)
-
-include(FindPackageHandleStandardArgs)
-find_package_handle_standard_args(WaylandScanner
- FOUND_VAR
- WaylandScanner_FOUND
- REQUIRED_VARS
- WaylandScanner_EXECUTABLE
-)
-
-mark_as_advanced(WaylandScanner_EXECUTABLE)
-
-if(NOT TARGET Wayland::Scanner AND WaylandScanner_FOUND)
- add_executable(Wayland::Scanner IMPORTED)
- set_target_properties(Wayland::Scanner PROPERTIES
- IMPORTED_LOCATION "${WaylandScanner_EXECUTABLE}"
- )
-endif()
-
-include(FeatureSummary)
-set_package_properties(WaylandScanner PROPERTIES
- URL "https://wayland.freedesktop.org/"
- DESCRIPTION "Executable that converts XML protocol files to C code"
-)
-
-
-include(CMakeParseArguments)
-
-function(ecm_add_wayland_client_protocol target_or_sources_var)
- # Parse arguments
- set(oneValueArgs PROTOCOL BASENAME)
- cmake_parse_arguments(ARGS "" "${oneValueArgs}" "" ${ARGN})
-
- if(ARGS_UNPARSED_ARGUMENTS)
- message(FATAL_ERROR "Unknown keywords given to ecm_add_wayland_client_protocol(): \"${ARGS_UNPARSED_ARGUMENTS}\"")
- endif()
-
- get_filename_component(_infile ${ARGS_PROTOCOL} ABSOLUTE)
- set(_client_header "${CMAKE_CURRENT_BINARY_DIR}/wayland-${ARGS_BASENAME}-client-protocol.h")
- set(_code "${CMAKE_CURRENT_BINARY_DIR}/wayland-${ARGS_BASENAME}-protocol.c")
-
- set_source_files_properties(${_client_header} GENERATED)
- set_source_files_properties(${_code} GENERATED)
- set_property(SOURCE ${_client_header} ${_code} PROPERTY SKIP_AUTOMOC ON)
-
- add_custom_command(OUTPUT "${_client_header}"
- COMMAND ${WaylandScanner_EXECUTABLE} client-header ${_infile} ${_client_header}
- DEPENDS ${_infile} VERBATIM)
-
- add_custom_command(OUTPUT "${_code}"
- COMMAND ${WaylandScanner_EXECUTABLE} public-code ${_infile} ${_code}
- DEPENDS ${_infile} ${_client_header} VERBATIM)
-
- if (TARGET ${target_or_sources_var})
- target_sources(${target_or_sources_var} PRIVATE "${_client_header}" "${_code}")
- else()
- list(APPEND ${target_or_sources_var} "${_client_header}" "${_code}")
- set(${target_or_sources_var} ${${target_or_sources_var}} PARENT_SCOPE)
- endif()
-endfunction()
-
-
-function(ecm_add_wayland_server_protocol target_or_sources_var)
- # Parse arguments
- set(oneValueArgs PROTOCOL BASENAME)
- cmake_parse_arguments(ARGS "" "${oneValueArgs}" "" ${ARGN})
-
- if(ARGS_UNPARSED_ARGUMENTS)
- message(FATAL_ERROR "Unknown keywords given to ecm_add_wayland_server_protocol(): \"${ARGS_UNPARSED_ARGUMENTS}\"")
- endif()
-
- ecm_add_wayland_client_protocol(${target_or_sources_var}
- PROTOCOL ${ARGS_PROTOCOL}
- BASENAME ${ARGS_BASENAME})
-
- get_filename_component(_infile ${ARGS_PROTOCOL} ABSOLUTE)
- set(_server_header "${CMAKE_CURRENT_BINARY_DIR}/wayland-${ARGS_BASENAME}-server-protocol.h")
- set(_server_code "${CMAKE_CURRENT_BINARY_DIR}/wayland-${ARGS_BASENAME}-protocol.c")
- set_property(SOURCE ${_server_header} ${_server_code} PROPERTY SKIP_AUTOMOC ON)
- set_source_files_properties(${_server_header} GENERATED)
-
- add_custom_command(OUTPUT "${_server_header}"
- COMMAND ${WaylandScanner_EXECUTABLE} server-header ${_infile} ${_server_header}
- DEPENDS ${_infile} VERBATIM)
-
- if (TARGET ${target_or_sources_var})
- target_sources(${target_or_sources_var} PRIVATE "${_server_header}")
- else()
- list(APPEND ${target_or_sources_var} "${_server_header}")
- set(${target_or_sources_var} ${${target_or_sources_var}} PARENT_SCOPE)
- endif()
-endfunction()
diff --git a/src/Cafe/CMakeLists.txt b/src/Cafe/CMakeLists.txt
index 8da2217..0daffbb 100644
--- a/src/Cafe/CMakeLists.txt
+++ b/src/Cafe/CMakeLists.txt
@@ -505,7 +505,7 @@ target_link_libraries(CemuCafe PRIVATE
if (ENABLE_WAYLAND)
# PUBLIC because wayland-client.h is included in VulkanAPI.h
- target_link_libraries(CemuCafe PUBLIC Wayland::Client)
+ target_link_libraries(CemuCafe PUBLIC Wayland::client)
endif()
if (ENABLE_WXWIDGETS)
diff --git a/src/gui/CMakeLists.txt b/src/gui/CMakeLists.txt
index 90dc91c..74eaf7d 100644
--- a/src/gui/CMakeLists.txt
+++ b/src/gui/CMakeLists.txt
@@ -153,7 +153,7 @@ if(ENABLE_WXWIDGETS AND UNIX AND NOT APPLE)
# PUBLIC because gdk/gdkkeysyms.h is included in guiWrapper.h
target_link_libraries(CemuGui PUBLIC GTK3::gtk)
if (ENABLE_WAYLAND)
- target_link_libraries(CemuGui PRIVATE Wayland::Client CemuWaylandProtocols)
+ target_link_libraries(CemuGui PRIVATE Wayland::client)
endif()
endif()
diff --git a/src/gui/canvas/VulkanCanvas.cpp b/src/gui/canvas/VulkanCanvas.cpp
index ceddeb5..00ebeb2 100644
--- a/src/gui/canvas/VulkanCanvas.cpp
+++ b/src/gui/canvas/VulkanCanvas.cpp
@@ -67,8 +67,9 @@ void VulkanCanvas::OnResize(wxSizeEvent& event)
#if BOOST_OS_LINUX && HAS_WAYLAND
if(m_subsurface)
{
- auto sRect = GetScreenRect();
- m_subsurface->setSize(sRect.GetX(), sRect.GetY(), sRect.GetWidth(), sRect.GetHeight());
+ int32_t x,y;
+ GetScreenPosition(&x,&y);
+ m_subsurface->setPosition(x, y);
}
#endif
const wxSize size = GetSize();
diff --git a/src/gui/helpers/wxWayland.h b/src/gui/helpers/wxWayland.h
index a3b8211..f921783 100644
--- a/src/gui/helpers/wxWayland.h
+++ b/src/gui/helpers/wxWayland.h
@@ -7,22 +7,16 @@
#include <gtk/gtk.h>
#include <wayland-client.h>
#include <wx/wx.h>
-#include "wayland-viewporter-client-protocol.h"
class wxWlSubsurface
{
static void registry_add_object(void* data, struct wl_registry* registry, uint32_t name, const char* interface, uint32_t version)
{
- auto wlSubsurface = static_cast<wxWlSubsurface*>(data);
-
if (!strcmp(interface, wl_subcompositor_interface.name))
{
+ auto wlSubsurface = static_cast<wxWlSubsurface*>(data);
wlSubsurface->m_subcompositor = static_cast<wl_subcompositor*>(wl_registry_bind(registry, name, &wl_subcompositor_interface, 1));
}
- else if (!strcmp(interface, wp_viewporter_interface.name))
- {
- wlSubsurface->m_viewporter = static_cast<wp_viewporter*>(wl_registry_bind(registry, name, &wp_viewporter_interface, 1));
- }
}
static void registry_remove_object(void* /*data*/, struct wl_registry* /*registry*/, uint32_t /*name*/) {}
@@ -30,12 +24,8 @@ class wxWlSubsurface
wl_subcompositor* m_subcompositor;
wl_surface* m_surface;
wl_subsurface* m_subsurface;
- wp_viewporter* m_viewporter = NULL;
- wp_viewport* m_viewport = NULL;
int32_t m_xPos = 0;
int32_t m_yPos = 0;
- int32_t m_width = 0;
- int32_t m_height = 0;
public:
wxWlSubsurface(wxWindow* window)
@@ -51,30 +41,25 @@ public:
wl_registry_add_listener(registry, &m_registry_listener, this);
wl_display_roundtrip(display);
m_surface = wl_compositor_create_surface(compositor);
- if (m_viewporter)
- m_viewport = wp_viewporter_get_viewport(m_viewporter, m_surface);
wl_region* region = wl_compositor_create_region(compositor);
wl_surface_set_input_region(m_surface, region);
m_subsurface = wl_subcompositor_get_subsurface(m_subcompositor, m_surface, surface);
wl_subsurface_set_desync(m_subsurface);
- auto sRect = window->GetScreenRect();
- setSize(sRect.x, sRect.y, sRect.width, sRect.height);
+ window->GetScreenPosition(&m_xPos, &m_yPos);
+ wl_subsurface_set_position(m_subsurface, m_xPos, m_yPos);
+ wl_surface_commit(m_surface);
wl_region_destroy(region);
}
wl_surface* getSurface() const { return m_surface; }
- void setSize(int32_t xPos, int32_t yPos, int32_t width, int32_t height)
+ void setPosition(int32_t xPos, int32_t yPos)
{
- if (xPos != m_xPos || m_yPos != yPos || m_width != width || m_height != height)
+ if (xPos != m_xPos || m_yPos != yPos)
{
m_xPos = xPos;
m_yPos = yPos;
- m_height = height;
- m_width = width;
wl_subsurface_set_position(m_subsurface, m_xPos, m_yPos);
- if (m_viewport)
- wp_viewport_set_destination(m_viewport, m_width, m_height);
wl_surface_commit(m_surface);
}
}