mirror of
https://github.com/microsoft/vcpkg.git
synced 2025-01-15 05:08:02 +08:00
[wxwidgets] Use vcpkg gtk3 for linux et al., fix mingw cross builds (#27087)
* Minor port corrections * Use vcpkg gtk3 for linux et al. * Update versions * Update cmake-user * Use vcpkg sdl2 cmake config * Update versions * Add direct cairo dependency * Declare maybe-unused variables * Fix mingw cross builds * Update versions
This commit is contained in:
parent
b0956f6170
commit
2909a549a9
@ -11,31 +11,16 @@ vcpkg_from_github(
|
|||||||
fix-libs-export.patch
|
fix-libs-export.patch
|
||||||
fix-pcre2.patch
|
fix-pcre2.patch
|
||||||
gtk3-link-libraries.patch
|
gtk3-link-libraries.patch
|
||||||
|
sdl2.patch
|
||||||
)
|
)
|
||||||
|
|
||||||
if(VCPKG_TARGET_IS_LINUX)
|
|
||||||
message(WARNING [[
|
|
||||||
Port wxwidgets currently requires the following packages from the system package manager:
|
|
||||||
pkg-config
|
|
||||||
GTK 3
|
|
||||||
libsecret
|
|
||||||
libgcrypt
|
|
||||||
libsystemd
|
|
||||||
These development packages can be installed on Ubuntu systems via
|
|
||||||
sudo apt-get install pkg-config libgtk-3-dev libsecret-1-dev libgcrypt20-dev libsystemd-dev
|
|
||||||
]])
|
|
||||||
foreach(conflicting_port IN ITEMS freetype glib)
|
|
||||||
if(EXISTS "${CURRENT_INSTALLED_DIR}/share/${conflicting_port}/copyright")
|
|
||||||
message(FATAL_ERROR "Port ${conflicting_port} must not be installed when building ${PORT}:${TARGET_TRIPLET}.")
|
|
||||||
endif()
|
|
||||||
endforeach()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
vcpkg_check_features(
|
vcpkg_check_features(
|
||||||
OUT_FEATURE_OPTIONS FEATURE_OPTIONS
|
OUT_FEATURE_OPTIONS FEATURE_OPTIONS
|
||||||
FEATURES
|
FEATURES
|
||||||
sound wxUSE_SOUND
|
|
||||||
fonts wxUSE_PRIVATE_FONTS
|
fonts wxUSE_PRIVATE_FONTS
|
||||||
|
media wxUSE_MEDIACTRL
|
||||||
|
sound wxUSE_SOUND
|
||||||
|
webview wxUSE_WEBVIEW
|
||||||
webview wxUSE_WEBVIEW_EDGE
|
webview wxUSE_WEBVIEW_EDGE
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -58,19 +43,6 @@ else()
|
|||||||
list(APPEND OPTIONS -DwxUSE_WEBREQUEST_CURL=ON)
|
list(APPEND OPTIONS -DwxUSE_WEBREQUEST_CURL=ON)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(DEFINED ENV{PKG_CONFIG})
|
|
||||||
set(PKGCONFIG "$ENV{PKG_CONFIG}")
|
|
||||||
elseif(VCPKG_TARGET_IS_LINUX AND NOT VCPKG_CROSSCOMPILING)
|
|
||||||
# wxWidgets on Linux currently needs to find the system's `gtk+-3.0.pc`.
|
|
||||||
# vcpkg's port pkgconf would prevent this lookup.
|
|
||||||
find_program(system_pkg_config NAMES pkg-config)
|
|
||||||
if(system_pkg_config)
|
|
||||||
set(PKGCONFIG "${system_pkg_config}")
|
|
||||||
endif()
|
|
||||||
if(VCPKG_LIBRARY_LINKAGE STREQUAL "static")
|
|
||||||
list(APPEND OPTIONS -DPKG_CONFIG_ARGN=--static)
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
vcpkg_find_acquire_program(PKGCONFIG)
|
vcpkg_find_acquire_program(PKGCONFIG)
|
||||||
|
|
||||||
# This may be set to ON by users in a custom triplet.
|
# This may be set to ON by users in a custom triplet.
|
||||||
@ -95,9 +67,14 @@ vcpkg_cmake_configure(
|
|||||||
-DwxUSE_LIBPNG=sys
|
-DwxUSE_LIBPNG=sys
|
||||||
-DwxUSE_LIBTIFF=sys
|
-DwxUSE_LIBTIFF=sys
|
||||||
-DwxUSE_NANOSVG=sys
|
-DwxUSE_NANOSVG=sys
|
||||||
-DwxUSE_SECRETSTORE=FALSE
|
-DwxUSE_LIBGNOMEVFS=OFF
|
||||||
|
-DwxUSE_LIBNOTIFY=OFF
|
||||||
|
-DwxUSE_SECRETSTORE=OFF
|
||||||
-DwxUSE_STL=${WXWIDGETS_USE_STL}
|
-DwxUSE_STL=${WXWIDGETS_USE_STL}
|
||||||
-DwxUSE_STD_CONTAINERS=${WXWIDGETS_USE_STD_CONTAINERS}
|
-DwxUSE_STD_CONTAINERS=${WXWIDGETS_USE_STD_CONTAINERS}
|
||||||
|
-DwxUSE_UIACTIONSIMULATOR=OFF
|
||||||
|
-DCMAKE_DISABLE_FIND_PACKAGE_GSPELL=ON
|
||||||
|
-DCMAKE_DISABLE_FIND_PACKAGE_MSPACK=ON
|
||||||
${OPTIONS}
|
${OPTIONS}
|
||||||
"-DPKG_CONFIG_EXECUTABLE=${PKGCONFIG}"
|
"-DPKG_CONFIG_EXECUTABLE=${PKGCONFIG}"
|
||||||
# The minimum cmake version requirement for Cotire is 2.8.12.
|
# The minimum cmake version requirement for Cotire is 2.8.12.
|
||||||
@ -105,6 +82,9 @@ vcpkg_cmake_configure(
|
|||||||
-DPKG_CONFIG_USE_CMAKE_PREFIX_PATH=ON
|
-DPKG_CONFIG_USE_CMAKE_PREFIX_PATH=ON
|
||||||
OPTIONS_RELEASE
|
OPTIONS_RELEASE
|
||||||
${OPTIONS_RELEASE}
|
${OPTIONS_RELEASE}
|
||||||
|
MAYBE_UNUSED_VARIABLES
|
||||||
|
CMAKE_DISABLE_FIND_PACKAGE_GSPELL
|
||||||
|
CMAKE_DISABLE_FIND_PACKAGE_MSPACK
|
||||||
)
|
)
|
||||||
|
|
||||||
vcpkg_cmake_install()
|
vcpkg_cmake_install()
|
||||||
@ -117,7 +97,7 @@ file(REMOVE_RECURSE
|
|||||||
)
|
)
|
||||||
|
|
||||||
set(tools wxrc)
|
set(tools wxrc)
|
||||||
if(NOT VCPKG_TARGET_IS_WINDOWS OR NOT VCPKG_HOST_IS_WINDOWS)
|
if(NOT VCPKG_TARGET_IS_WINDOWS)
|
||||||
list(APPEND tools wxrc-3.2)
|
list(APPEND tools wxrc-3.2)
|
||||||
file(MAKE_DIRECTORY "${CURRENT_PACKAGES_DIR}/tools/${PORT}")
|
file(MAKE_DIRECTORY "${CURRENT_PACKAGES_DIR}/tools/${PORT}")
|
||||||
file(RENAME "${CURRENT_PACKAGES_DIR}/bin/wx-config" "${CURRENT_PACKAGES_DIR}/tools/${PORT}/wx-config")
|
file(RENAME "${CURRENT_PACKAGES_DIR}/bin/wx-config" "${CURRENT_PACKAGES_DIR}/tools/${PORT}/wx-config")
|
||||||
@ -189,7 +169,7 @@ if(EXISTS "${CURRENT_PACKAGES_DIR}/debug/lib/mswud/wx/setup.h")
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(NOT "debug-support" IN_LIST FEATURES)
|
if(NOT "debug-support" IN_LIST FEATURES)
|
||||||
if(VCPKG_TARGET_IS_WINDOWS AND VCPKG_HOST_IS_WINDOWS)
|
if(VCPKG_TARGET_IS_WINDOWS)
|
||||||
vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/include/wx/debug.h" "#define wxDEBUG_LEVEL 1" "#define wxDEBUG_LEVEL 0")
|
vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/include/wx/debug.h" "#define wxDEBUG_LEVEL 1" "#define wxDEBUG_LEVEL 0")
|
||||||
else()
|
else()
|
||||||
vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/include/wx-3.2/wx/debug.h" "#define wxDEBUG_LEVEL 1" "#define wxDEBUG_LEVEL 0")
|
vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/include/wx-3.2/wx/debug.h" "#define wxDEBUG_LEVEL 1" "#define wxDEBUG_LEVEL 0")
|
||||||
|
29
ports/wxwidgets/sdl2.patch
Normal file
29
ports/wxwidgets/sdl2.patch
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
diff --git a/build/cmake/init.cmake b/build/cmake/init.cmake
|
||||||
|
index 7bd00d3..d903584 100644
|
||||||
|
--- a/build/cmake/init.cmake
|
||||||
|
+++ b/build/cmake/init.cmake
|
||||||
|
@@ -493,7 +493,9 @@ if(wxUSE_GUI)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(wxUSE_SOUND AND wxUSE_LIBSDL AND UNIX AND NOT APPLE)
|
||||||
|
- find_package(SDL2)
|
||||||
|
+ find_package(SDL2 CONFIG REQUIRED)
|
||||||
|
+ set(SDL2_INCLUDE_DIR "" CACHE INTERNAL "")
|
||||||
|
+ set(SDL2_LIBRARY SDL2::SDL2 CACHE INTERNAL "")
|
||||||
|
if(NOT SDL2_FOUND)
|
||||||
|
find_package(SDL)
|
||||||
|
endif()
|
||||||
|
diff --git a/build/cmake/wxWidgetsConfig.cmake.in b/build/cmake/wxWidgetsConfig.cmake.in
|
||||||
|
index 248a701..f617dc4 100644
|
||||||
|
--- a/build/cmake/wxWidgetsConfig.cmake.in
|
||||||
|
+++ b/build/cmake/wxWidgetsConfig.cmake.in
|
||||||
|
@@ -2,6 +2,9 @@
|
||||||
|
|
||||||
|
include(CMakeFindDependencyMacro)
|
||||||
|
find_dependency(unofficial-nanosvg CONFIG)
|
||||||
|
+if("@wxUSE_LIBSDL@")
|
||||||
|
+ find_dependency(SDL2 CONFIG)
|
||||||
|
+endif()
|
||||||
|
|
||||||
|
# determine target from compiler, platform and library type
|
||||||
|
if(WIN32 AND NOT CYGWIN AND NOT MSYS)
|
@ -7,7 +7,7 @@ set(wxWidgets_ROOT_DIR "${_vcpkg_wx_root}" CACHE INTERNAL "")
|
|||||||
set(WX_ROOT_DIR "${_vcpkg_wx_root}" CACHE INTERNAL "")
|
set(WX_ROOT_DIR "${_vcpkg_wx_root}" CACHE INTERNAL "")
|
||||||
unset(_vcpkg_wx_root)
|
unset(_vcpkg_wx_root)
|
||||||
|
|
||||||
if(WIN32 AND CMAKE_HOST_WIN32)
|
if(WIN32)
|
||||||
# Find all libs with "32" infix which is unknown to FindwxWidgets.cmake
|
# Find all libs with "32" infix which is unknown to FindwxWidgets.cmake
|
||||||
function(z_vcpkg_wxwidgets_find_base_library BASENAME)
|
function(z_vcpkg_wxwidgets_find_base_library BASENAME)
|
||||||
find_library(WX_${BASENAME}d wx${BASENAME}32ud NAMES wx${BASENAME}d PATHS "${wxWidgets_ROOT_DIR}/debug/lib" NO_DEFAULT_PATH)
|
find_library(WX_${BASENAME}d wx${BASENAME}32ud NAMES wx${BASENAME}d PATHS "${wxWidgets_ROOT_DIR}/debug/lib" NO_DEFAULT_PATH)
|
||||||
@ -31,11 +31,6 @@ if(WIN32 AND CMAKE_HOST_WIN32)
|
|||||||
set(wxWidgets_LIB_DIR "${wxWidgets_ROOT_DIR}/lib" CACHE INTERNAL "")
|
set(wxWidgets_LIB_DIR "${wxWidgets_ROOT_DIR}/lib" CACHE INTERNAL "")
|
||||||
else()
|
else()
|
||||||
# FindwxWidgets.cmake unix mode, single-config
|
# FindwxWidgets.cmake unix mode, single-config
|
||||||
if(MINGW)
|
|
||||||
# Force FindwxWidgets.cmake unix mode for mingw cross builds
|
|
||||||
set(_vcpkg_wxwidgets_backup_crosscompiling "${CMAKE_CROSSCOMPILING}")
|
|
||||||
set(CMAKE_CROSSCOMPILING 1)
|
|
||||||
endif()
|
|
||||||
set(_vcpkg_wxconfig "")
|
set(_vcpkg_wxconfig "")
|
||||||
if(CMAKE_BUILD_TYPE STREQUAL "Debug" OR "Debug" IN_LIST MAP_IMPORTED_CONFIG_${CMAKE_BUILD_TYPE})
|
if(CMAKE_BUILD_TYPE STREQUAL "Debug" OR "Debug" IN_LIST MAP_IMPORTED_CONFIG_${CMAKE_BUILD_TYPE})
|
||||||
# Debug
|
# Debug
|
||||||
@ -59,7 +54,7 @@ if(DEFINED _vcpkg_wxwidgets_backup_crosscompiling)
|
|||||||
unset(_vcpkg_wxwidgets_backup_crosscompiling)
|
unset(_vcpkg_wxwidgets_backup_crosscompiling)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(WIN32 AND CMAKE_HOST_WIN32 AND "@VCPKG_LIBRARY_LINKAGE@" STREQUAL "static" AND NOT "wx::core" IN_LIST wxWidgets_LIBRARIES)
|
if(WIN32 AND "@VCPKG_LIBRARY_LINKAGE@" STREQUAL "static" AND NOT "wx::core" IN_LIST wxWidgets_LIBRARIES)
|
||||||
find_package(EXPAT QUIET)
|
find_package(EXPAT QUIET)
|
||||||
find_package(JPEG QUIET)
|
find_package(JPEG QUIET)
|
||||||
find_package(PNG QUIET)
|
find_package(PNG QUIET)
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "wxwidgets",
|
"name": "wxwidgets",
|
||||||
"version": "3.2.1",
|
"version": "3.2.1",
|
||||||
|
"port-version": 1,
|
||||||
"description": [
|
"description": [
|
||||||
"Widget toolkit and tools library for creating graphical user interfaces (GUIs) for cross-platform applications. ",
|
"Widget toolkit and tools library for creating graphical user interfaces (GUIs) for cross-platform applications. ",
|
||||||
"Set WXWIDGETS_USE_STL in a custom triplet to build with the wxUSE_STL build option.",
|
"Set WXWIDGETS_USE_STL in a custom triplet to build with the wxUSE_STL build option.",
|
||||||
@ -10,12 +11,25 @@
|
|||||||
"license": "LGPL-2.0-or-later WITH WxWindows-exception-3.1",
|
"license": "LGPL-2.0-or-later WITH WxWindows-exception-3.1",
|
||||||
"supports": "!uwp",
|
"supports": "!uwp",
|
||||||
"dependencies": [
|
"dependencies": [
|
||||||
|
{
|
||||||
|
"name": "cairo",
|
||||||
|
"default-features": false,
|
||||||
|
"platform": "!windows & !osx & !ios"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "curl",
|
"name": "curl",
|
||||||
"default-features": false,
|
"default-features": false,
|
||||||
"platform": "!windows & !osx"
|
"platform": "!windows & !osx"
|
||||||
},
|
},
|
||||||
"expat",
|
"expat",
|
||||||
|
{
|
||||||
|
"name": "gtk3",
|
||||||
|
"platform": "!windows & !osx & !ios"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "libiconv",
|
||||||
|
"platform": "!windows"
|
||||||
|
},
|
||||||
"libjpeg-turbo",
|
"libjpeg-turbo",
|
||||||
"libpng",
|
"libpng",
|
||||||
"nanosvg",
|
"nanosvg",
|
||||||
@ -55,13 +69,23 @@
|
|||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
"media": {
|
||||||
|
"description": "Build wxMediaCtrl support",
|
||||||
|
"dependencies": [
|
||||||
|
{
|
||||||
|
"name": "gstreamer",
|
||||||
|
"default-features": false,
|
||||||
|
"platform": "!windows & !osx & !ios"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
"sound": {
|
"sound": {
|
||||||
"description": "Build wxSound support",
|
"description": "Build wxSound support",
|
||||||
"dependencies": [
|
"dependencies": [
|
||||||
{
|
{
|
||||||
"name": "sdl2",
|
"name": "sdl2",
|
||||||
"default-features": false,
|
"default-features": false,
|
||||||
"platform": "!windows & !osx"
|
"platform": "!windows & !osx & !ios"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
@ -1176,7 +1176,6 @@ wpilib:arm64-windows=fail
|
|||||||
wpilib:x64-osx=fail
|
wpilib:x64-osx=fail
|
||||||
wincrypt:arm64-windows=skip # https://github.com/microsoft/vcpkg-tool/pull/599
|
wincrypt:arm64-windows=skip # https://github.com/microsoft/vcpkg-tool/pull/599
|
||||||
wxchartdir:x64-osx=fail
|
wxchartdir:x64-osx=fail
|
||||||
wxwidgets:x64-linux=fail
|
|
||||||
x265:arm64-windows=fail
|
x265:arm64-windows=fail
|
||||||
x265:arm-uwp=fail
|
x265:arm-uwp=fail
|
||||||
x265:x64-uwp=fail
|
x265:x64-uwp=fail
|
||||||
@ -1293,6 +1292,7 @@ vcpkg-ci-paraview:x64-windows-static=pass
|
|||||||
vcpkg-ci-paraview:x64-windows=pass
|
vcpkg-ci-paraview:x64-windows=pass
|
||||||
vcpkg-ci-paraview:x86-windows=pass
|
vcpkg-ci-paraview:x86-windows=pass
|
||||||
vcpkg-ci-wxwidgets:arm64-windows=pass
|
vcpkg-ci-wxwidgets:arm64-windows=pass
|
||||||
|
vcpkg-ci-wxwidgets:x64-linux=pass
|
||||||
vcpkg-ci-wxwidgets:x64-osx=pass
|
vcpkg-ci-wxwidgets:x64-osx=pass
|
||||||
vcpkg-ci-wxwidgets:x64-windows-static-md=pass
|
vcpkg-ci-wxwidgets:x64-windows-static-md=pass
|
||||||
vcpkg-ci-wxwidgets:x64-windows-static=pass
|
vcpkg-ci-wxwidgets:x64-windows-static=pass
|
||||||
|
@ -122,7 +122,7 @@
|
|||||||
"$package": "wxWidgets",
|
"$package": "wxWidgets",
|
||||||
"name": "wxwidgets",
|
"name": "wxwidgets",
|
||||||
"default-features": false,
|
"default-features": false,
|
||||||
"platform": "!linux & !uwp"
|
"platform": "!uwp"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"$package": "ZLIB",
|
"$package": "ZLIB",
|
||||||
|
@ -7894,7 +7894,7 @@
|
|||||||
},
|
},
|
||||||
"wxwidgets": {
|
"wxwidgets": {
|
||||||
"baseline": "3.2.1",
|
"baseline": "3.2.1",
|
||||||
"port-version": 0
|
"port-version": 1
|
||||||
},
|
},
|
||||||
"x-plane": {
|
"x-plane": {
|
||||||
"baseline": "3.0.3",
|
"baseline": "3.0.3",
|
||||||
|
@ -1,5 +1,10 @@
|
|||||||
{
|
{
|
||||||
"versions": [
|
"versions": [
|
||||||
|
{
|
||||||
|
"git-tree": "3a640144a98d7909a92ba363114f95bcaff554e5",
|
||||||
|
"version": "3.2.1",
|
||||||
|
"port-version": 1
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"git-tree": "a113e248e95bf2305a91b4d7c2a93579cc911b15",
|
"git-tree": "a113e248e95bf2305a91b4d7c2a93579cc911b15",
|
||||||
"version": "3.2.1",
|
"version": "3.2.1",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user