mirror of
https://github.com/microsoft/vcpkg.git
synced 2024-11-29 15:21:59 +08:00
commit
c3f4c15bf4
113
ports/angle/001-fix-uwp.patch
Normal file
113
ports/angle/001-fix-uwp.patch
Normal file
@ -0,0 +1,113 @@
|
|||||||
|
diff --git "a//src/libANGLE/renderer/d3d/d3d11/winrt/CoreWindowNativeWindow.cpp" "b/src/libANGLE/renderer/d3d/d3d11/winrt/CoreWindowNativeWindow.cpp"
|
||||||
|
index dd37ace8..9116b9e6 100644
|
||||||
|
--- "a/src/libANGLE/renderer/d3d/d3d11/winrt/CoreWindowNativeWindow.cpp"
|
||||||
|
+++ "b/src/libANGLE/renderer/d3d/d3d11/winrt/CoreWindowNativeWindow.cpp"
|
||||||
|
@@ -141,6 +141,7 @@ HRESULT CoreWindowNativeWindow::createSwapChain(ID3D11Device *device,
|
||||||
|
unsigned int width,
|
||||||
|
unsigned int height,
|
||||||
|
bool containsAlpha,
|
||||||
|
+ unsigned int samples,
|
||||||
|
IDXGISwapChain1 **swapChain)
|
||||||
|
{
|
||||||
|
if (device == nullptr || factory == nullptr || swapChain == nullptr || width == 0 ||
|
||||||
|
@@ -154,7 +155,7 @@ HRESULT CoreWindowNativeWindow::createSwapChain(ID3D11Device *device,
|
||||||
|
swapChainDesc.Height = height;
|
||||||
|
swapChainDesc.Format = format;
|
||||||
|
swapChainDesc.Stereo = FALSE;
|
||||||
|
- swapChainDesc.SampleDesc.Count = 1;
|
||||||
|
+ swapChainDesc.SampleDesc.Count = samples;
|
||||||
|
swapChainDesc.SampleDesc.Quality = 0;
|
||||||
|
swapChainDesc.BufferUsage =
|
||||||
|
DXGI_USAGE_SHADER_INPUT | DXGI_USAGE_RENDER_TARGET_OUTPUT | DXGI_USAGE_BACK_BUFFER;
|
||||||
|
diff --git "a/src/libANGLE/renderer/d3d/d3d11/winrt/CoreWindowNativeWindow.h" "b/src/libANGLE/renderer/d3d/d3d11/winrt/CoreWindowNativeWindow.h"
|
||||||
|
index d43bf0ba..77b4ae95 100644
|
||||||
|
--- "a/src/libANGLE/renderer/d3d/d3d11/winrt/CoreWindowNativeWindow.h"
|
||||||
|
+++ "b/src/libANGLE/renderer/d3d/d3d11/winrt/CoreWindowNativeWindow.h"
|
||||||
|
@@ -32,7 +32,8 @@ class CoreWindowNativeWindow : public InspectableNativeWindow, public std::enabl
|
||||||
|
DXGI_FORMAT format,
|
||||||
|
unsigned int width,
|
||||||
|
unsigned int height,
|
||||||
|
- bool containsAlpha,
|
||||||
|
+ bool containsAlpha,
|
||||||
|
+ unsigned int samples,
|
||||||
|
IDXGISwapChain1 **swapChain) override;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
diff --git "a/src/libANGLE/renderer/d3d/d3d11/winrt/InspectableNativeWindow.h" "b/src/libANGLE/renderer/d3d/d3d11/winrt/InspectableNativeWindow.h"
|
||||||
|
index 3e67269f..a66935ce 100644
|
||||||
|
--- "a/src/libANGLE/renderer/d3d/d3d11/winrt/InspectableNativeWindow.h"
|
||||||
|
+++ "b/src/libANGLE/renderer/d3d/d3d11/winrt/InspectableNativeWindow.h"
|
||||||
|
@@ -53,6 +53,7 @@ class InspectableNativeWindow
|
||||||
|
unsigned int width,
|
||||||
|
unsigned int height,
|
||||||
|
bool containsAlpha,
|
||||||
|
+ unsigned int samples,
|
||||||
|
IDXGISwapChain1 **swapChain) = 0;
|
||||||
|
|
||||||
|
bool getClientRect(RECT *rect)
|
||||||
|
diff --git "a/src/libANGLE/renderer/d3d/d3d11/winrt/NativeWindow11WinRT.cpp" "b/src/libANGLE/renderer/d3d/d3d11/winrt/NativeWindow11WinRT.cpp"
|
||||||
|
index 2ef2235c..284fccbb 100644
|
||||||
|
--- "a/src/libANGLE/renderer/d3d/d3d11/winrt/NativeWindow11WinRT.cpp"
|
||||||
|
+++ "b/src/libANGLE/renderer/d3d/d3d11/winrt/NativeWindow11WinRT.cpp"
|
||||||
|
@@ -89,6 +89,7 @@ HRESULT NativeWindow11WinRT::createSwapChain(ID3D11Device *device,
|
||||||
|
DXGI_FORMAT format,
|
||||||
|
UINT width,
|
||||||
|
UINT height,
|
||||||
|
+ UINT samples,
|
||||||
|
IDXGISwapChain **swapChain)
|
||||||
|
{
|
||||||
|
if (mImpl)
|
||||||
|
@@ -96,7 +97,7 @@ HRESULT NativeWindow11WinRT::createSwapChain(ID3D11Device *device,
|
||||||
|
IDXGIFactory2 *factory2 = d3d11::DynamicCastComObject<IDXGIFactory2>(factory);
|
||||||
|
IDXGISwapChain1 *swapChain1 = nullptr;
|
||||||
|
HRESULT result =
|
||||||
|
- mImpl->createSwapChain(device, factory2, format, width, height, mHasAlpha, &swapChain1);
|
||||||
|
+ mImpl->createSwapChain(device, factory2, format, width, height, mHasAlpha, samples, &swapChain1);
|
||||||
|
SafeRelease(factory2);
|
||||||
|
*swapChain = static_cast<IDXGISwapChain *>(swapChain1);
|
||||||
|
return result;
|
||||||
|
diff --git "a/src/libANGLE/renderer/d3d/d3d11/winrt/NativeWindow11WinRT.h" "b/src/libANGLE/renderer/d3d/d3d11/winrt/NativeWindow11WinRT.h"
|
||||||
|
index 996fd3a1..97a2c2c4 100644
|
||||||
|
--- "a/src/libANGLE/renderer/d3d/d3d11/winrt/NativeWindow11WinRT.h"
|
||||||
|
+++ "b/src/libANGLE/renderer/d3d/d3d11/winrt/NativeWindow11WinRT.h"
|
||||||
|
@@ -34,6 +34,7 @@ class NativeWindow11WinRT : public NativeWindow11
|
||||||
|
DXGI_FORMAT format,
|
||||||
|
UINT width,
|
||||||
|
UINT height,
|
||||||
|
+ UINT samples,
|
||||||
|
IDXGISwapChain **swapChain) override;
|
||||||
|
|
||||||
|
void commitChange() override;
|
||||||
|
diff --git "a/src/libANGLE/renderer/d3d/d3d11/winrt/SwapChainPanelNativeWindow.cpp" "b/src/libANGLE/renderer/d3d/d3d11/winrt/SwapChainPanelNativeWindow.cpp"
|
||||||
|
index c6d07fc8..89d9f870 100644
|
||||||
|
--- "a/src/libANGLE/renderer/d3d/d3d11/winrt/SwapChainPanelNativeWindow.cpp"
|
||||||
|
+++ "b/src/libANGLE/renderer/d3d/d3d11/winrt/SwapChainPanelNativeWindow.cpp"
|
||||||
|
@@ -246,6 +246,7 @@ HRESULT SwapChainPanelNativeWindow::createSwapChain(ID3D11Device *device,
|
||||||
|
unsigned int width,
|
||||||
|
unsigned int height,
|
||||||
|
bool containsAlpha,
|
||||||
|
+ unsigned int samples,
|
||||||
|
IDXGISwapChain1 **swapChain)
|
||||||
|
{
|
||||||
|
if (device == nullptr || factory == nullptr || swapChain == nullptr || width == 0 ||
|
||||||
|
@@ -259,7 +260,7 @@ HRESULT SwapChainPanelNativeWindow::createSwapChain(ID3D11Device *device,
|
||||||
|
swapChainDesc.Height = height;
|
||||||
|
swapChainDesc.Format = format;
|
||||||
|
swapChainDesc.Stereo = FALSE;
|
||||||
|
- swapChainDesc.SampleDesc.Count = 1;
|
||||||
|
+ swapChainDesc.SampleDesc.Count = samples;
|
||||||
|
swapChainDesc.SampleDesc.Quality = 0;
|
||||||
|
swapChainDesc.BufferUsage =
|
||||||
|
DXGI_USAGE_SHADER_INPUT | DXGI_USAGE_RENDER_TARGET_OUTPUT | DXGI_USAGE_BACK_BUFFER;
|
||||||
|
diff --git "a/src/libANGLE/renderer/d3d/d3d11/winrt/SwapChainPanelNativeWindow.h" "b/src/libANGLE/renderer/d3d/d3d11/winrt/SwapChainPanelNativeWindow.h"
|
||||||
|
index f9a2fc0e..dc5c804e 100644
|
||||||
|
--- "a/src/libANGLE/renderer/d3d/d3d11/winrt/SwapChainPanelNativeWindow.h"
|
||||||
|
+++ "b/src/libANGLE/renderer/d3d/d3d11/winrt/SwapChainPanelNativeWindow.h"
|
||||||
|
@@ -27,6 +27,7 @@ class SwapChainPanelNativeWindow : public InspectableNativeWindow, public std::e
|
||||||
|
unsigned int width,
|
||||||
|
unsigned int height,
|
||||||
|
bool containsAlpha,
|
||||||
|
+ unsigned int samples,
|
||||||
|
IDXGISwapChain1 **swapChain) override;
|
||||||
|
|
||||||
|
protected:
|
@ -1,37 +1,44 @@
|
|||||||
cmake_minimum_required(VERSION 3.8)
|
cmake_minimum_required(VERSION 3.8)
|
||||||
project(angle)
|
project(angle CXX)
|
||||||
|
|
||||||
add_compile_options(/d2guard4 /Wv:18 /WX)
|
if(WIN32 AND NOT WINDOWS_STORE)
|
||||||
|
set(WINDOWS_DESKTOP 1)
|
||||||
|
else()
|
||||||
|
set(WINDOWS_DESKTOP 0)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
add_compile_options(/d2guard4 /Wv:18)
|
||||||
set(CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} /guard:cf")
|
set(CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} /guard:cf")
|
||||||
|
|
||||||
add_definitions(-D_CRT_SECURE_NO_DEPRECATE -D_SCL_SECURE_NO_WARNINGS -D_HAS_EXCEPTIONS=0 -DNOMINMAX -DANGLE_STANDALONE_BUILD -DANGLE_ENABLE_DEBUG_ANNOTATIONS)
|
add_definitions(
|
||||||
|
-D_CRT_SECURE_NO_DEPRECATE
|
||||||
file(WRITE "${CMAKE_CURRENT_BINARY_DIR}/include/id/commit.h" "#define ANGLE_COMMIT_HASH \"invalid-hash\"\n#define ANGLE_COMMIT_HASH_SIZE 12\n#define ANGLE_COMMIT_DATE \"invalid-date\"\n")
|
-D_SCL_SECURE_NO_WARNINGS
|
||||||
|
-D_HAS_EXCEPTIONS=0
|
||||||
|
-DNOMINMAX
|
||||||
|
-DANGLE_STANDALONE_BUILD
|
||||||
|
-DANGLE_ENABLE_DEBUG_ANNOTATIONS
|
||||||
|
)
|
||||||
|
|
||||||
|
configure_file(commit.h include/id/commit.h COPYONLY)
|
||||||
include_directories(include src ${CMAKE_CURRENT_BINARY_DIR}/include)
|
include_directories(include src ${CMAKE_CURRENT_BINARY_DIR}/include)
|
||||||
|
|
||||||
##########
|
##########
|
||||||
# anglebase
|
# angle::common
|
||||||
add_library(anglebase INTERFACE)
|
file(GLOB ANGLE_COMMON_SOURCES "src/common/*.h" "src/common/*.inl" "src/common/*.cpp" "src/common/third_party/base/*.h")
|
||||||
file(GLOB_RECURSE anglebase_SOURCES "src/common/third_party/base/*.h")
|
|
||||||
target_sources(anglebase INTERFACE ${anglebase_SOURCES})
|
|
||||||
target_include_directories(anglebase INTERFACE src/common/third_party/base)
|
|
||||||
|
|
||||||
##########
|
|
||||||
# angle_common
|
|
||||||
file(GLOB ANGLE_COMMON_SOURCES "src/common/*.h" "src/common/*.inl" "src/common/*.cpp")
|
|
||||||
list(FILTER ANGLE_COMMON_SOURCES EXCLUDE REGEX "_unittest|event_tracer|_linux|_mac")
|
list(FILTER ANGLE_COMMON_SOURCES EXCLUDE REGEX "_unittest|event_tracer|_linux|_mac")
|
||||||
add_library(angle_common STATIC ${ANGLE_COMMON_SOURCES})
|
add_library(angle_common STATIC ${ANGLE_COMMON_SOURCES})
|
||||||
target_link_libraries(angle_common PUBLIC anglebase)
|
target_include_directories(angle_common PUBLIC src/common/third_party/base)
|
||||||
|
add_library(angle::common ALIAS angle_common)
|
||||||
|
|
||||||
##########
|
##########
|
||||||
# angle_image_util
|
# angle::image_util
|
||||||
file(GLOB ANGLE_IMAGE_UTIL_SOURCES "src/image_util/*.h" "src/image_util/*.inl" "src/image_util/*.cpp")
|
file(GLOB ANGLE_IMAGE_UTIL_SOURCES "src/image_util/*.h" "src/image_util/*.inl" "src/image_util/*.cpp")
|
||||||
add_library(angle_image_util STATIC ${ANGLE_IMAGE_UTIL_SOURCES})
|
add_library(angle_image_util STATIC ${ANGLE_IMAGE_UTIL_SOURCES})
|
||||||
target_link_libraries(angle_image_util PRIVATE angle_common)
|
target_link_libraries(angle_image_util PRIVATE angle::common)
|
||||||
|
add_library(angle::image_util ALIAS angle_image_util)
|
||||||
|
|
||||||
##########
|
##########
|
||||||
# translator
|
# angle::translator
|
||||||
file(GLOB TRANSLATOR_SOURCES
|
file(GLOB TRANSLATOR_SOURCES
|
||||||
"src/compiler/translator/glslang.l"
|
"src/compiler/translator/glslang.l"
|
||||||
"src/compiler/translator/glslang.y"
|
"src/compiler/translator/glslang.y"
|
||||||
@ -39,25 +46,89 @@ file(GLOB TRANSLATOR_SOURCES
|
|||||||
"src/compiler/translator/*.cpp"
|
"src/compiler/translator/*.cpp"
|
||||||
"src/third_party/compiler/ArrayBoundsClamper.cpp"
|
"src/third_party/compiler/ArrayBoundsClamper.cpp"
|
||||||
)
|
)
|
||||||
add_library(translator STATIC ${TRANSLATOR_SOURCES})
|
add_library(angle_translator STATIC ${TRANSLATOR_SOURCES})
|
||||||
target_compile_definitions(translator PUBLIC
|
target_compile_definitions(angle_translator PUBLIC
|
||||||
-DANGLE_ENABLE_ESSL
|
-DANGLE_ENABLE_ESSL
|
||||||
-DANGLE_ENABLE_GLSL
|
-DANGLE_ENABLE_GLSL
|
||||||
-DANGLE_ENABLE_HLSL
|
-DANGLE_ENABLE_HLSL
|
||||||
)
|
)
|
||||||
target_link_libraries(translator PRIVATE angle_common)
|
target_link_libraries(angle_translator PRIVATE angle::common)
|
||||||
|
add_library(angle::translator ALIAS angle_translator)
|
||||||
|
|
||||||
##########
|
##########
|
||||||
# preprocessor
|
# angle::preprocessor
|
||||||
file(GLOB PREPROCESSOR_SOURCES
|
file(GLOB PREPROCESSOR_SOURCES
|
||||||
"src/compiler/preprocessor/*.h"
|
"src/compiler/preprocessor/*.h"
|
||||||
"src/compiler/preprocessor/*.cpp"
|
"src/compiler/preprocessor/*.cpp"
|
||||||
)
|
)
|
||||||
add_library(preprocessor STATIC ${PREPROCESSOR_SOURCES})
|
add_library(angle_preprocessor STATIC ${PREPROCESSOR_SOURCES})
|
||||||
target_link_libraries(preprocessor PRIVATE angle_common)
|
target_link_libraries(angle_preprocessor PRIVATE angle::common)
|
||||||
|
add_library(angle::preprocessor ALIAS angle_preprocessor)
|
||||||
|
|
||||||
##########
|
##########
|
||||||
# libANGLE
|
# libANGLE
|
||||||
|
|
||||||
|
## OpenGL Renderer
|
||||||
|
if(WINDOWS_DESKTOP)
|
||||||
|
file(GLOB LIBANGLE_GL_SOURCES
|
||||||
|
"src/libANGLE/renderer/gl/*.cpp"
|
||||||
|
"src/libANGLE/renderer/gl/*.inl"
|
||||||
|
"src/libANGLE/renderer/gl/*.h"
|
||||||
|
|
||||||
|
"src/libANGLE/renderer/gl/wgl/*.cpp"
|
||||||
|
"src/libANGLE/renderer/gl/wgl/*.inl"
|
||||||
|
"src/libANGLE/renderer/gl/wgl/*.h"
|
||||||
|
)
|
||||||
|
list(FILTER LIBANGLE_GL_SOURCES EXCLUDE REGEX "_unittest")
|
||||||
|
add_library(angle_renderer_opengl INTERFACE)
|
||||||
|
target_sources(angle_renderer_opengl INTERFACE ${LIBANGLE_GL_SOURCES})
|
||||||
|
target_compile_definitions(angle_renderer_opengl INTERFACE -DANGLE_ENABLE_OPENGL)
|
||||||
|
add_library(angle::renderer::opengl ALIAS angle_renderer_opengl)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
## All D3D Sources
|
||||||
|
file(GLOB_RECURSE LIBANGLE_D3D_SOURCES
|
||||||
|
"src/libANGLE/renderer/d3d/*.cpp"
|
||||||
|
"src/libANGLE/renderer/d3d/*.inl"
|
||||||
|
"src/libANGLE/renderer/d3d/*.h"
|
||||||
|
)
|
||||||
|
list(FILTER LIBANGLE_D3D_SOURCES EXCLUDE REGEX "_unittest")
|
||||||
|
|
||||||
|
## WinRT D3D Renderer
|
||||||
|
if(WINDOWS_STORE)
|
||||||
|
set(LIBANGLE_D3D_WINRT_SOURCES ${LIBANGLE_D3D_SOURCES})
|
||||||
|
list(FILTER LIBANGLE_D3D_WINRT_SOURCES INCLUDE REGEX "winrt")
|
||||||
|
add_library(angle_renderer_winrt INTERFACE)
|
||||||
|
target_sources(angle_renderer_winrt INTERFACE ${LIBANGLE_D3D_WINRT_SOURCES})
|
||||||
|
add_library(angle::renderer::winrt ALIAS angle_renderer_winrt)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
## Win32/d3d9 D3D Renderer
|
||||||
|
if(WINDOWS_DESKTOP)
|
||||||
|
set(LIBANGLE_D3D_DESKTOP_SOURCES ${LIBANGLE_D3D_SOURCES})
|
||||||
|
list(FILTER LIBANGLE_D3D_DESKTOP_SOURCES INCLUDE REGEX "d3d9|win32")
|
||||||
|
find_library(D3D9_LIB NAMES d3d9)
|
||||||
|
add_library(angle_renderer_win32 INTERFACE)
|
||||||
|
target_sources(angle_renderer_win32 INTERFACE ${LIBANGLE_D3D_DESKTOP_SOURCES})
|
||||||
|
target_compile_definitions(angle_renderer_win32 INTERFACE -DANGLE_ENABLE_D3D9)
|
||||||
|
target_link_libraries(angle_renderer_win32 INTERFACE ${D3D9_LIB})
|
||||||
|
add_library(angle::renderer::win32 ALIAS angle_renderer_win32)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
## D3D11 Base renderer
|
||||||
|
list(FILTER LIBANGLE_D3D_SOURCES EXCLUDE REGEX "winrt|d3d9|win32")
|
||||||
|
find_library(DXGUID_LIB NAMES dxguid)
|
||||||
|
find_library(D3D11_LIB NAMES d3d11)
|
||||||
|
add_library(angle_renderer_d3d INTERFACE)
|
||||||
|
target_sources(angle_renderer_d3d INTERFACE ${LIBANGLE_D3D_SOURCES})
|
||||||
|
target_compile_definitions(angle_renderer_d3d INTERFACE
|
||||||
|
-DANGLE_ENABLE_D3D11
|
||||||
|
"-DANGLE_PRELOADED_D3DCOMPILER_MODULE_NAMES={ \"d3dcompiler_47.dll\", \"d3dcompiler_46.dll\", \"d3dcompiler_43.dll\" }"
|
||||||
|
)
|
||||||
|
target_link_libraries(angle_renderer_d3d INTERFACE ${D3D11_LIB} ${DXGUID_LIB})
|
||||||
|
add_library(angle::renderer::d3d ALIAS angle_renderer_d3d)
|
||||||
|
|
||||||
|
## Core libANGLE library
|
||||||
file(GLOB LIBANGLE_SOURCES
|
file(GLOB LIBANGLE_SOURCES
|
||||||
"src/third_party/systeminfo/SystemInfo.cpp"
|
"src/third_party/systeminfo/SystemInfo.cpp"
|
||||||
"src/common/third_party/murmurhash/MurmurHash3.cpp"
|
"src/common/third_party/murmurhash/MurmurHash3.cpp"
|
||||||
@ -71,65 +142,52 @@ file(GLOB LIBANGLE_SOURCES
|
|||||||
"src/libANGLE/renderer/*.inl"
|
"src/libANGLE/renderer/*.inl"
|
||||||
"src/libANGLE/renderer/*.h"
|
"src/libANGLE/renderer/*.h"
|
||||||
|
|
||||||
"src/libANGLE/renderer/gl/*.cpp"
|
|
||||||
"src/libANGLE/renderer/gl/*.inl"
|
|
||||||
"src/libANGLE/renderer/gl/*.h"
|
|
||||||
|
|
||||||
"src/libANGLE/renderer/gl/wgl/*.cpp"
|
|
||||||
"src/libANGLE/renderer/gl/wgl/*.inl"
|
|
||||||
"src/libANGLE/renderer/gl/wgl/*.h"
|
|
||||||
|
|
||||||
# "src/libANGLE/renderer/vulkan/*.cpp"
|
|
||||||
# "src/libANGLE/renderer/vulkan/*.inl"
|
|
||||||
# "src/libANGLE/renderer/vulkan/*.h"
|
|
||||||
|
|
||||||
"src/libANGLE/renderer/null/*.cpp"
|
"src/libANGLE/renderer/null/*.cpp"
|
||||||
"src/libANGLE/renderer/null/*.inl"
|
"src/libANGLE/renderer/null/*.inl"
|
||||||
"src/libANGLE/renderer/null/*.h"
|
"src/libANGLE/renderer/null/*.h"
|
||||||
)
|
)
|
||||||
file(GLOB_RECURSE LIBANGLE_D3D_SOURCES "src/libANGLE/renderer/d3d/*.h" "src/libANGLE/renderer/d3d/*.cpp" "src/libANGLE/renderer/d3d/*.inl")
|
|
||||||
list(FILTER LIBANGLE_SOURCES EXCLUDE REGEX "_unittest")
|
list(FILTER LIBANGLE_SOURCES EXCLUDE REGEX "_unittest")
|
||||||
list(FILTER LIBANGLE_D3D_SOURCES EXCLUDE REGEX "_unittest|winrt")
|
|
||||||
add_library(libANGLE STATIC ${LIBANGLE_SOURCES} ${LIBANGLE_D3D_SOURCES})
|
add_library(libANGLE STATIC ${LIBANGLE_SOURCES})
|
||||||
find_library(D3D9_LIB NAMES d3d9)
|
target_link_libraries(libANGLE PRIVATE
|
||||||
find_library(DXGUID_LIB NAMES dxguid)
|
angle::common
|
||||||
target_link_libraries(libANGLE PRIVATE angle_common angle_image_util translator ${D3D9_LIB} ${DXGUID_LIB} preprocessor)
|
angle::image_util
|
||||||
target_include_directories(libANGLE PRIVATE "src/third_party/khronos")
|
angle::translator
|
||||||
target_compile_definitions(libANGLE PUBLIC
|
angle::preprocessor
|
||||||
-DANGLE_ENABLE_D3D9
|
angle::renderer::d3d
|
||||||
-DANGLE_ENABLE_D3D11
|
$<$<BOOL:${WINDOWS_STORE}>:angle::renderer::winrt>
|
||||||
-DANGLE_ENABLE_OPENGL
|
$<$<BOOL:${WINDOWS_DESKTOP}>:angle::renderer::win32>
|
||||||
# -DANGLE_ENABLE_VULKAN
|
$<$<BOOL:${WINDOWS_DESKTOP}>:angle::renderer::opengl>
|
||||||
-DANGLE_ENABLE_NULL
|
|
||||||
)
|
)
|
||||||
target_compile_definitions(libANGLE PRIVATE -DLIBANGLE_IMPLEMENTATION)
|
target_include_directories(libANGLE PRIVATE "src/third_party/khronos")
|
||||||
|
target_compile_definitions(libANGLE
|
||||||
|
PRIVATE -DANGLE_ENABLE_NULL
|
||||||
|
PUBLIC -DLIBANGLE_IMPLEMENTATION
|
||||||
|
)
|
||||||
|
add_library(angle::libANGLE ALIAS libANGLE)
|
||||||
|
|
||||||
##########
|
##########
|
||||||
# libGLESv2
|
# libGLESv2
|
||||||
file(GLOB LIBGLESV2_SOURCES "src/libGLESv2/*.h" "src/libGLESv2/*.cpp" "src/libGLESv2/libGLESv2.def")
|
file(GLOB LIBGLESV2_SOURCES "src/libGLESv2/*.h" "src/libGLESv2/*.cpp" "src/libGLESv2/libGLESv2.def")
|
||||||
add_library(libGLESv2 ${LIBGLESV2_SOURCES})
|
add_library(libGLESv2 ${LIBGLESV2_SOURCES})
|
||||||
target_link_libraries(libGLESv2 PRIVATE angle_common libANGLE)
|
target_link_libraries(libGLESv2 PRIVATE angle::common angle::libANGLE)
|
||||||
target_compile_definitions(libGLESv2 PRIVATE
|
target_compile_definitions(libGLESv2
|
||||||
-DLIBGLESV2_IMPLEMENTATION
|
PRIVATE -DLIBGLESV2_IMPLEMENTATION
|
||||||
-DLIBANGLE_IMPLEMENTATION
|
PUBLIC
|
||||||
-DGL_GLEXT_PROTOTYPES
|
-DGL_GLEXT_PROTOTYPES
|
||||||
"-DANGLE_PRELOADED_D3DCOMPILER_MODULE_NAMES={ \"d3dcompiler_47.dll\", \"d3dcompiler_46.dll\", \"d3dcompiler_43.dll\" }"
|
|
||||||
-DGL_APICALL=
|
-DGL_APICALL=
|
||||||
-DEGLAPI=
|
-DEGLAPI=
|
||||||
)
|
)
|
||||||
|
|
||||||
##########
|
##########
|
||||||
# libEGL
|
# libEGL
|
||||||
add_library(libEGL "src/libEGL/libEGL.def" "src/libEGL/libEGL.cpp" "src/libEGL/libEGL.rc" "src/libEGL/resource.h")
|
add_library(libEGL
|
||||||
target_link_libraries(libEGL PRIVATE angle_common libANGLE libGLESv2)
|
"src/libEGL/libEGL.def"
|
||||||
target_compile_definitions(libEGL PRIVATE
|
"src/libEGL/libEGL.cpp"
|
||||||
-DLIBANGLE_IMPLEMENTATION
|
"src/libEGL/libEGL.rc"
|
||||||
-DGL_GLEXT_PROTOTYPES
|
"src/libEGL/resource.h"
|
||||||
"-DANGLE_PRELOADED_D3DCOMPILER_MODULE_NAMES={ \"d3dcompiler_47.dll\", \"d3dcompiler_46.dll\", \"d3dcompiler_43.dll\" }"
|
|
||||||
-DGL_APICALL=
|
|
||||||
-DEGLAPI=
|
|
||||||
)
|
)
|
||||||
|
target_link_libraries(libEGL PRIVATE angle::common angle::libANGLE libGLESv2)
|
||||||
|
|
||||||
install(TARGETS libEGL libGLESv2
|
install(TARGETS libEGL libGLESv2
|
||||||
RUNTIME DESTINATION bin
|
RUNTIME DESTINATION bin
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
Source: angle
|
Source: angle
|
||||||
Version: 2017-06-14-8d471f
|
Version: 2017-06-14-8d471f-1
|
||||||
Description: A conformant OpenGL ES implementation for Windows, Mac and Linux.
|
Description: A conformant OpenGL ES implementation for Windows, Mac and Linux.
|
||||||
The goal of ANGLE is to allow users of multiple operating systems to seamlessly run WebGL and other OpenGL ES content by translating OpenGL ES API calls to one of the hardware-supported APIs available for that platform. ANGLE currently provides translation from OpenGL ES 2.0 and 3.0 to desktop OpenGL, OpenGL ES, Direct3D 9, and Direct3D 11. Support for translation from OpenGL ES to Vulkan is underway, and future plans include compute shader support (ES 3.1) and MacOS support.
|
The goal of ANGLE is to allow users of multiple operating systems to seamlessly run WebGL and other OpenGL ES content by translating OpenGL ES API calls to one of the hardware-supported APIs available for that platform. ANGLE currently provides translation from OpenGL ES 2.0 and 3.0 to desktop OpenGL, OpenGL ES, Direct3D 9, and Direct3D 11. Support for translation from OpenGL ES to Vulkan is underway, and future plans include compute shader support (ES 3.1) and MacOS support.
|
||||||
|
3
ports/angle/commit.h
Normal file
3
ports/angle/commit.h
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
#define ANGLE_COMMIT_HASH "invalid-hash"
|
||||||
|
#define ANGLE_COMMIT_HASH_SIZE 12
|
||||||
|
#define ANGLE_COMMIT_DATE "invalid-date"
|
@ -5,6 +5,10 @@ if(VCPKG_LIBRARY_LINKAGE STREQUAL static)
|
|||||||
set(VCPKG_LIBRARY_LINKAGE dynamic)
|
set(VCPKG_LIBRARY_LINKAGE dynamic)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(VCPKG_CMAKE_SYSTEM_NAME STREQUAL "WindowsStore")
|
||||||
|
message(FATAL_ERROR "ANGLE currently only supports being built for desktop")
|
||||||
|
endif()
|
||||||
|
|
||||||
vcpkg_from_github(
|
vcpkg_from_github(
|
||||||
OUT_SOURCE_PATH SOURCE_PATH
|
OUT_SOURCE_PATH SOURCE_PATH
|
||||||
REPO google/angle
|
REPO google/angle
|
||||||
@ -12,8 +16,13 @@ vcpkg_from_github(
|
|||||||
SHA512 b9235d2a98330bc8533c3fe871129e7235c680420eac16610eae4ca7224c5284313ab6377f30ddfb8a2da39b69f3ef0d16023fe1e7cec3fc2198f4eb4bdccb26
|
SHA512 b9235d2a98330bc8533c3fe871129e7235c680420eac16610eae4ca7224c5284313ab6377f30ddfb8a2da39b69f3ef0d16023fe1e7cec3fc2198f4eb4bdccb26
|
||||||
HEAD_REF master
|
HEAD_REF master
|
||||||
)
|
)
|
||||||
|
vcpkg_apply_patches(
|
||||||
|
SOURCE_PATH ${SOURCE_PATH}
|
||||||
|
PATCHES ${CMAKE_CURRENT_LIST_DIR}/001-fix-uwp.patch
|
||||||
|
)
|
||||||
|
|
||||||
file(COPY ${CMAKE_CURRENT_LIST_DIR}/CMakeLists.txt DESTINATION ${SOURCE_PATH})
|
file(COPY ${CMAKE_CURRENT_LIST_DIR}/CMakeLists.txt DESTINATION ${SOURCE_PATH})
|
||||||
|
file(COPY ${CMAKE_CURRENT_LIST_DIR}/commit.h DESTINATION ${SOURCE_PATH})
|
||||||
|
|
||||||
vcpkg_configure_cmake(
|
vcpkg_configure_cmake(
|
||||||
SOURCE_PATH ${SOURCE_PATH}
|
SOURCE_PATH ${SOURCE_PATH}
|
||||||
|
@ -140,3 +140,10 @@ if(NOT VCPKG_TOOLCHAIN)
|
|||||||
|
|
||||||
set(VCPKG_TOOLCHAIN ON)
|
set(VCPKG_TOOLCHAIN ON)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
set(_UNUSED ${CMAKE_TOOLCHAIN_FILE})
|
||||||
|
set(_UNUSED ${CMAKE_ERROR_ON_ABSOLUTE_INSTALL_DESTINATION})
|
||||||
|
set(_UNUSED ${CMAKE_EXPORT_NO_PACKAGE_REGISTRY})
|
||||||
|
set(_UNUSED ${CMAKE_FIND_PACKAGE_NO_PACKAGE_REGISTRY})
|
||||||
|
set(_UNUSED ${CMAKE_FIND_PACKAGE_NO_SYSTEM_PACKAGE_REGISTRY})
|
||||||
|
set(_UNUSED ${CMAKE_INSTALL_SYSTEM_RUNTIME_LIBS_SKIP})
|
||||||
|
Loading…
Reference in New Issue
Block a user