2020-07-01 14:43:36 +00:00
|
|
|
# Copyright (C) 2020 The Khronos Group Inc.
|
|
|
|
#
|
|
|
|
# All rights reserved.
|
|
|
|
#
|
|
|
|
# Redistribution and use in source and binary forms, with or without
|
|
|
|
# modification, are permitted provided that the following conditions
|
|
|
|
# are met:
|
|
|
|
#
|
|
|
|
# Redistributions of source code must retain the above copyright
|
|
|
|
# notice, this list of conditions and the following disclaimer.
|
|
|
|
#
|
|
|
|
# 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.
|
|
|
|
#
|
2020-07-03 11:21:01 +00:00
|
|
|
# Neither the name of The Khronos Group Inc. nor the names of its
|
2020-07-01 14:43:36 +00:00
|
|
|
# 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 HOLDERS 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.
|
|
|
|
|
2020-07-13 18:14:02 +00:00
|
|
|
project(glslang
|
|
|
|
LANGUAGES CXX)
|
|
|
|
|
2017-04-29 08:57:36 +00:00
|
|
|
# increase to 3.1 once all major distributions
|
|
|
|
# include a version of CMake >= 3.1
|
|
|
|
cmake_minimum_required(VERSION 2.8.12)
|
2017-10-10 14:26:31 +00:00
|
|
|
if (POLICY CMP0048)
|
|
|
|
cmake_policy(SET CMP0048 NEW)
|
|
|
|
endif()
|
2016-05-05 18:45:53 +00:00
|
|
|
set_property(GLOBAL PROPERTY USE_FOLDERS ON)
|
2015-06-26 22:29:10 +00:00
|
|
|
|
2019-10-22 04:38:04 +00:00
|
|
|
# Enable compile commands database
|
|
|
|
set(CMAKE_EXPORT_COMPILE_COMMANDS ON)
|
|
|
|
|
2017-04-29 08:57:36 +00:00
|
|
|
# Adhere to GNU filesystem layout conventions
|
|
|
|
include(GNUInstallDirs)
|
|
|
|
|
2019-08-09 14:56:51 +00:00
|
|
|
# Needed for CMAKE_DEPENDENT_OPTION macro
|
|
|
|
include(CMakeDependentOption)
|
|
|
|
|
2018-03-30 14:32:03 +00:00
|
|
|
option(BUILD_SHARED_LIBS "Build Shared Libraries" OFF)
|
2019-10-15 09:00:23 +00:00
|
|
|
option(BUILD_EXTERNAL "Build external dependencies in /External" ON)
|
2018-03-30 14:32:03 +00:00
|
|
|
|
|
|
|
set(LIB_TYPE STATIC)
|
|
|
|
|
|
|
|
if(BUILD_SHARED_LIBS)
|
|
|
|
set(LIB_TYPE SHARED)
|
|
|
|
endif()
|
|
|
|
|
Generate build information from CHANGES.md
This PR significantly reworks the way glslang is versioned.
Instead of committing changes to the `GLSLANG_MINOR_VERSION` define in
`glslang/Public/ShaderLang.h`, and using `make-revision` to generate
`GLSLANG_PATCH_LEVEL` in `glslang/Include/revision.h`, all version
information is now derived from the new `CHANGES.md` file.
`CHANGES.md` acts as the single source of truth for glslang version
information, along with a convenient place to put all release notes for
each notable change made.
`CHANGES.md` is parsed using the new `build_info.py` python script.
This script can read basic template files to produce new source files,
which it does to read the new `build_info.h.tmpl` to generate (at build
time) a glslang private header at
`<build-dir>/include/glslang/build_info.h`.
I've written generators for each of the CMake, Bazel, gn, and
`Android.mk` build scripts.
The new version code conforms to the Semantic Versioning 2.0 spec.
This new version is also used by the CMake rules to produce versioned
shared objects, including a major-versioned SONAME.
New APIs:
---------
* `glslang::GetVersion()` returns a `Version` struct with the version
major, minor, patch and flavor.
Breaking API changes:
---------------------
* The public defines `GLSLANG_MINOR_VERSION` and `GLSLANG_PATCH_LEVEL`
have been entirely removed.
* `glslang/Public/ShaderLang.h` and `glslang/Include/revision.h` have
been deleted.
* Instead, `<build-dir>/include/glslang/build_info.h` is created in
the build directory, and `<build-dir>/include` is a CMake `PUBLIC`
(dependee-inherited) include directory for the glslang targets.
* `<build-dir>/include/glslang/build_info.h` contains the following
new #defines:
`GLSLANG_VERSION_MAJOR`, `GLSLANG_VERSION_MINOR`,
`GLSLANG_VERSION_PATCH`, `GLSLANG_VERSION_FLAVOR`,
`GLSLANG_VERSION_GREATER_THAN(major, minor, patch)`,
`GLSLANG_VERSION_GREATER_OR_EQUAL_TO(major, minor, patch)`,
`GLSLANG_VERSION_LESS_THAN(major, minor, patch)`,
`GLSLANG_VERSION_LESS_OR_EQUAL_TO(major, minor, patch)`
* The CMake install output directory contains a copy of
`build_info.h` at: `include/glslang/build_info.h`
* Python3 is now always required to build glslang (likely always
required for transitive dependency builds).
2020-06-17 10:17:19 +00:00
|
|
|
if ("${CMAKE_BUILD_TYPE}" STREQUAL "")
|
|
|
|
# This logic inside SPIRV-Tools, which can upset build target dependencies
|
|
|
|
# if changed after targets are already defined. To prevent these issues,
|
|
|
|
# ensure CMAKE_BUILD_TYPE is assigned early and at the glslang root scope.
|
|
|
|
message(STATUS "No build type selected, default to Debug")
|
|
|
|
set(CMAKE_BUILD_TYPE "Debug")
|
|
|
|
endif()
|
|
|
|
|
2017-07-04 12:54:57 +00:00
|
|
|
option(SKIP_GLSLANG_INSTALL "Skip installation" ${SKIP_GLSLANG_INSTALL})
|
|
|
|
if(NOT ${SKIP_GLSLANG_INSTALL})
|
|
|
|
set(ENABLE_GLSLANG_INSTALL ON)
|
|
|
|
endif()
|
2018-07-07 21:53:06 +00:00
|
|
|
option(ENABLE_SPVREMAPPER "Enables building of SPVRemapper" ON)
|
2017-07-04 12:54:57 +00:00
|
|
|
|
2016-12-20 00:56:00 +00:00
|
|
|
option(ENABLE_GLSLANG_BINARIES "Builds glslangValidator and spirv-remap" ON)
|
2016-05-05 04:30:44 +00:00
|
|
|
|
2020-02-06 21:36:52 +00:00
|
|
|
option(ENABLE_GLSLANG_JS
|
|
|
|
"If using Emscripten, build glslang.js. Otherwise, builds a sample executable for binary-size testing." OFF)
|
|
|
|
CMAKE_DEPENDENT_OPTION(ENABLE_GLSLANG_WEBMIN
|
|
|
|
"Reduces glslang to minimum needed for web use"
|
|
|
|
OFF "ENABLE_GLSLANG_JS"
|
|
|
|
OFF)
|
|
|
|
CMAKE_DEPENDENT_OPTION(ENABLE_GLSLANG_WEBMIN_DEVEL
|
|
|
|
"For ENABLE_GLSLANG_WEBMIN builds, enables compilation error messages"
|
|
|
|
OFF "ENABLE_GLSLANG_WEBMIN"
|
|
|
|
OFF)
|
|
|
|
CMAKE_DEPENDENT_OPTION(ENABLE_EMSCRIPTEN_SINGLE_FILE
|
|
|
|
"If using Emscripten, enables SINGLE_FILE build"
|
|
|
|
OFF "ENABLE_GLSLANG_JS AND EMSCRIPTEN"
|
|
|
|
OFF)
|
|
|
|
CMAKE_DEPENDENT_OPTION(ENABLE_EMSCRIPTEN_ENVIRONMENT_NODE
|
|
|
|
"If using Emscripten, builds to run on Node instead of Web"
|
|
|
|
OFF "ENABLE_GLSLANG_JS AND EMSCRIPTEN"
|
|
|
|
OFF)
|
|
|
|
|
|
|
|
CMAKE_DEPENDENT_OPTION(ENABLE_HLSL
|
|
|
|
"Enables HLSL input support"
|
|
|
|
ON "NOT ENABLE_GLSLANG_WEBMIN"
|
|
|
|
OFF)
|
2019-08-09 14:56:51 +00:00
|
|
|
|
2020-02-17 17:37:09 +00:00
|
|
|
option(ENABLE_RTTI "Enables RTTI" OFF)
|
2020-05-21 05:55:24 +00:00
|
|
|
option(ENABLE_EXCEPTIONS "Enables Exceptions" OFF)
|
2019-08-09 14:56:51 +00:00
|
|
|
option(ENABLE_OPT "Enables spirv-opt capability if present" ON)
|
2019-10-15 17:28:40 +00:00
|
|
|
option(ENABLE_PCH "Enables Precompiled header" ON)
|
2019-10-25 08:57:11 +00:00
|
|
|
option(ENABLE_CTEST "Enables testing" ON)
|
2019-08-09 14:56:51 +00:00
|
|
|
|
2017-04-29 08:57:36 +00:00
|
|
|
if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT AND WIN32)
|
|
|
|
set(CMAKE_INSTALL_PREFIX "install" CACHE STRING "..." FORCE)
|
|
|
|
endif()
|
2015-06-26 22:29:10 +00:00
|
|
|
|
2018-07-06 18:12:09 +00:00
|
|
|
option(USE_CCACHE "Use ccache" OFF)
|
|
|
|
if(USE_CCACHE)
|
|
|
|
find_program(CCACHE_FOUND ccache)
|
|
|
|
if(CCACHE_FOUND)
|
|
|
|
set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE ccache)
|
|
|
|
endif(CCACHE_FOUND)
|
|
|
|
endif()
|
|
|
|
|
2019-10-25 08:57:11 +00:00
|
|
|
if(ENABLE_CTEST)
|
|
|
|
include(CTest)
|
|
|
|
endif()
|
2017-04-28 20:46:52 +00:00
|
|
|
|
2017-01-09 22:10:14 +00:00
|
|
|
if(ENABLE_HLSL)
|
|
|
|
add_definitions(-DENABLE_HLSL)
|
|
|
|
endif(ENABLE_HLSL)
|
2017-01-09 01:20:25 +00:00
|
|
|
|
2020-02-06 21:36:52 +00:00
|
|
|
if(ENABLE_GLSLANG_WEBMIN)
|
2019-07-28 08:12:10 +00:00
|
|
|
add_definitions(-DGLSLANG_WEB)
|
2020-02-06 21:36:52 +00:00
|
|
|
if(ENABLE_GLSLANG_WEBMIN_DEVEL)
|
2019-09-18 06:08:45 +00:00
|
|
|
add_definitions(-DGLSLANG_WEB_DEVEL)
|
2020-02-06 21:36:52 +00:00
|
|
|
endif(ENABLE_GLSLANG_WEBMIN_DEVEL)
|
|
|
|
endif(ENABLE_GLSLANG_WEBMIN)
|
2019-07-28 08:12:10 +00:00
|
|
|
|
2015-06-26 22:29:10 +00:00
|
|
|
if(WIN32)
|
2019-01-25 17:30:37 +00:00
|
|
|
set(CMAKE_DEBUG_POSTFIX "d")
|
2017-03-12 03:44:55 +00:00
|
|
|
if(MSVC)
|
|
|
|
include(ChooseMSVCCRT.cmake)
|
|
|
|
endif(MSVC)
|
2015-11-16 17:03:28 +00:00
|
|
|
add_definitions(-DGLSLANG_OSINCLUDE_WIN32)
|
2015-06-26 22:29:10 +00:00
|
|
|
elseif(UNIX)
|
2015-11-16 17:03:28 +00:00
|
|
|
add_definitions(-DGLSLANG_OSINCLUDE_UNIX)
|
2015-06-26 22:29:10 +00:00
|
|
|
else(WIN32)
|
2016-04-03 00:17:13 +00:00
|
|
|
message("unknown platform")
|
2015-06-26 22:29:10 +00:00
|
|
|
endif(WIN32)
|
|
|
|
|
2017-04-29 08:57:36 +00:00
|
|
|
if(${CMAKE_CXX_COMPILER_ID} MATCHES "GNU")
|
|
|
|
add_compile_options(-Wall -Wmaybe-uninitialized -Wuninitialized -Wunused -Wunused-local-typedefs
|
2019-10-15 15:17:53 +00:00
|
|
|
-Wunused-parameter -Wunused-value -Wunused-variable -Wunused-but-set-parameter -Wunused-but-set-variable -fno-exceptions)
|
2017-04-29 08:57:36 +00:00
|
|
|
add_compile_options(-Wno-reorder) # disable this from -Wall, since it happens all over.
|
2020-02-17 17:37:09 +00:00
|
|
|
if(NOT ENABLE_RTTI)
|
|
|
|
add_compile_options(-fno-rtti)
|
|
|
|
endif()
|
2020-05-21 05:55:24 +00:00
|
|
|
if(NOT ENABLE_EXCEPTIONS)
|
|
|
|
add_compile_options(-fno-exceptions)
|
|
|
|
endif()
|
2020-01-30 03:39:13 +00:00
|
|
|
if(NOT CMAKE_CXX_COMPILER_VERSION VERSION_LESS "9.0.0")
|
2019-10-18 14:28:53 +00:00
|
|
|
add_compile_options(-Werror=deprecated-copy)
|
|
|
|
endif()
|
2020-06-29 12:46:26 +00:00
|
|
|
|
2020-07-03 14:41:03 +00:00
|
|
|
if(NOT CMAKE_VERSION VERSION_LESS "3.13")
|
|
|
|
# Error if there's symbols that are not found at link time.
|
|
|
|
# add_link_options() was added in CMake 3.13 - if using an earlier
|
|
|
|
# version don't set this - it should be caught by presubmits anyway.
|
|
|
|
add_link_options("-Wl,--no-undefined")
|
|
|
|
endif()
|
2020-04-10 08:39:16 +00:00
|
|
|
elseif(${CMAKE_CXX_COMPILER_ID} MATCHES "Clang" AND NOT MSVC)
|
2017-04-29 08:57:36 +00:00
|
|
|
add_compile_options(-Wall -Wuninitialized -Wunused -Wunused-local-typedefs
|
2019-10-15 15:17:53 +00:00
|
|
|
-Wunused-parameter -Wunused-value -Wunused-variable)
|
2017-04-29 08:57:36 +00:00
|
|
|
add_compile_options(-Wno-reorder) # disable this from -Wall, since it happens all over.
|
2020-02-17 17:37:09 +00:00
|
|
|
if(NOT ENABLE_RTTI)
|
|
|
|
add_compile_options(-fno-rtti)
|
|
|
|
endif()
|
2020-05-21 05:55:24 +00:00
|
|
|
if(NOT ENABLE_EXCEPTIONS)
|
|
|
|
add_compile_options(-fno-exceptions)
|
|
|
|
endif()
|
2020-06-29 12:46:26 +00:00
|
|
|
|
2020-07-03 14:41:03 +00:00
|
|
|
if(NOT CMAKE_VERSION VERSION_LESS "3.13")
|
|
|
|
# Error if there's symbols that are not found at link time.
|
|
|
|
# add_link_options() was added in CMake 3.13 - if using an earlier
|
|
|
|
# version don't set this - it should be caught by presubmits anyway.
|
|
|
|
add_link_options("-Wl,-undefined,error")
|
|
|
|
endif()
|
2020-04-10 08:39:16 +00:00
|
|
|
elseif(MSVC)
|
2020-02-17 17:37:09 +00:00
|
|
|
if(NOT ENABLE_RTTI)
|
2020-06-23 18:57:43 +00:00
|
|
|
string(FIND "${CMAKE_CXX_FLAGS}" "/GR" MSVC_HAS_GR)
|
|
|
|
if(MSVC_HAS_GR)
|
|
|
|
string(REGEX REPLACE /GR /GR- CMAKE_CXX_FLAGS ${CMAKE_CXX_FLAGS})
|
|
|
|
else()
|
|
|
|
add_compile_options(/GR-) # Disable RTTI
|
|
|
|
endif()
|
2020-02-17 17:37:09 +00:00
|
|
|
endif()
|
2020-05-21 05:55:24 +00:00
|
|
|
if(ENABLE_EXCEPTIONS)
|
|
|
|
add_compile_options(/EHsc) # Enable Exceptions
|
|
|
|
endif()
|
2017-04-29 08:57:36 +00:00
|
|
|
endif()
|
|
|
|
|
2020-02-06 21:36:52 +00:00
|
|
|
if(ENABLE_GLSLANG_JS)
|
|
|
|
if(MSVC)
|
|
|
|
add_compile_options(/Os /GR-)
|
|
|
|
else()
|
2020-05-21 05:55:24 +00:00
|
|
|
add_compile_options(-Os -fno-rtti -fno-exceptions)
|
2020-04-10 08:39:16 +00:00
|
|
|
if(${CMAKE_CXX_COMPILER_ID} MATCHES "Clang" AND NOT MSVC)
|
2020-03-23 19:26:53 +00:00
|
|
|
add_compile_options(-Wno-unused-parameter)
|
|
|
|
add_compile_options(-Wno-unused-variable -Wno-unused-const-variable)
|
|
|
|
endif()
|
2020-02-06 21:36:52 +00:00
|
|
|
endif()
|
|
|
|
endif(ENABLE_GLSLANG_JS)
|
2019-08-08 17:50:13 +00:00
|
|
|
|
2017-04-29 08:57:36 +00:00
|
|
|
# Request C++11
|
|
|
|
if(${CMAKE_VERSION} VERSION_LESS 3.1)
|
|
|
|
# CMake versions before 3.1 do not understand CMAKE_CXX_STANDARD
|
|
|
|
# remove this block once CMake >=3.1 has fixated in the ecosystem
|
2020-03-23 19:26:53 +00:00
|
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11")
|
2017-04-29 08:57:36 +00:00
|
|
|
else()
|
|
|
|
set(CMAKE_CXX_STANDARD 11)
|
|
|
|
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
|
|
|
set(CMAKE_CXX_EXTENSIONS OFF)
|
2015-06-26 22:29:10 +00:00
|
|
|
endif()
|
|
|
|
|
2016-06-02 18:37:24 +00:00
|
|
|
function(glslang_set_link_args TARGET)
|
|
|
|
# For MinGW compiles, statically link against the GCC and C++ runtimes.
|
|
|
|
# This avoids the need to ship those runtimes as DLLs.
|
2017-04-29 08:57:36 +00:00
|
|
|
if(WIN32 AND ${CMAKE_CXX_COMPILER_ID} MATCHES "GNU")
|
|
|
|
set_target_properties(${TARGET} PROPERTIES
|
|
|
|
LINK_FLAGS "-static -static-libgcc -static-libstdc++")
|
|
|
|
endif()
|
2016-06-02 18:37:24 +00:00
|
|
|
endfunction(glslang_set_link_args)
|
|
|
|
|
2019-05-09 09:43:26 +00:00
|
|
|
# CMake needs to find the right version of python, right from the beginning,
|
|
|
|
# otherwise, it will find the wrong version and fail later
|
Generate build information from CHANGES.md
This PR significantly reworks the way glslang is versioned.
Instead of committing changes to the `GLSLANG_MINOR_VERSION` define in
`glslang/Public/ShaderLang.h`, and using `make-revision` to generate
`GLSLANG_PATCH_LEVEL` in `glslang/Include/revision.h`, all version
information is now derived from the new `CHANGES.md` file.
`CHANGES.md` acts as the single source of truth for glslang version
information, along with a convenient place to put all release notes for
each notable change made.
`CHANGES.md` is parsed using the new `build_info.py` python script.
This script can read basic template files to produce new source files,
which it does to read the new `build_info.h.tmpl` to generate (at build
time) a glslang private header at
`<build-dir>/include/glslang/build_info.h`.
I've written generators for each of the CMake, Bazel, gn, and
`Android.mk` build scripts.
The new version code conforms to the Semantic Versioning 2.0 spec.
This new version is also used by the CMake rules to produce versioned
shared objects, including a major-versioned SONAME.
New APIs:
---------
* `glslang::GetVersion()` returns a `Version` struct with the version
major, minor, patch and flavor.
Breaking API changes:
---------------------
* The public defines `GLSLANG_MINOR_VERSION` and `GLSLANG_PATCH_LEVEL`
have been entirely removed.
* `glslang/Public/ShaderLang.h` and `glslang/Include/revision.h` have
been deleted.
* Instead, `<build-dir>/include/glslang/build_info.h` is created in
the build directory, and `<build-dir>/include` is a CMake `PUBLIC`
(dependee-inherited) include directory for the glslang targets.
* `<build-dir>/include/glslang/build_info.h` contains the following
new #defines:
`GLSLANG_VERSION_MAJOR`, `GLSLANG_VERSION_MINOR`,
`GLSLANG_VERSION_PATCH`, `GLSLANG_VERSION_FLAVOR`,
`GLSLANG_VERSION_GREATER_THAN(major, minor, patch)`,
`GLSLANG_VERSION_GREATER_OR_EQUAL_TO(major, minor, patch)`,
`GLSLANG_VERSION_LESS_THAN(major, minor, patch)`,
`GLSLANG_VERSION_LESS_OR_EQUAL_TO(major, minor, patch)`
* The CMake install output directory contains a copy of
`build_info.h` at: `include/glslang/build_info.h`
* Python3 is now always required to build glslang (likely always
required for transitive dependency builds).
2020-06-17 10:17:19 +00:00
|
|
|
find_package(PythonInterp 3 REQUIRED)
|
|
|
|
|
|
|
|
# Root directory for build-time generated include files
|
|
|
|
set(GLSLANG_GENERATED_INCLUDEDIR "${CMAKE_BINARY_DIR}/include")
|
|
|
|
|
|
|
|
################################################################################
|
|
|
|
# Build version information generation
|
|
|
|
################################################################################
|
2020-07-10 13:39:39 +00:00
|
|
|
set(GLSLANG_CHANGES_FILE "${CMAKE_CURRENT_SOURCE_DIR}/CHANGES.md")
|
|
|
|
set(GLSLANG_BUILD_INFO_PY "${CMAKE_CURRENT_SOURCE_DIR}/build_info.py")
|
|
|
|
set(GLSLANG_BUILD_INFO_H_TMPL "${CMAKE_CURRENT_SOURCE_DIR}/build_info.h.tmpl")
|
Generate build information from CHANGES.md
This PR significantly reworks the way glslang is versioned.
Instead of committing changes to the `GLSLANG_MINOR_VERSION` define in
`glslang/Public/ShaderLang.h`, and using `make-revision` to generate
`GLSLANG_PATCH_LEVEL` in `glslang/Include/revision.h`, all version
information is now derived from the new `CHANGES.md` file.
`CHANGES.md` acts as the single source of truth for glslang version
information, along with a convenient place to put all release notes for
each notable change made.
`CHANGES.md` is parsed using the new `build_info.py` python script.
This script can read basic template files to produce new source files,
which it does to read the new `build_info.h.tmpl` to generate (at build
time) a glslang private header at
`<build-dir>/include/glslang/build_info.h`.
I've written generators for each of the CMake, Bazel, gn, and
`Android.mk` build scripts.
The new version code conforms to the Semantic Versioning 2.0 spec.
This new version is also used by the CMake rules to produce versioned
shared objects, including a major-versioned SONAME.
New APIs:
---------
* `glslang::GetVersion()` returns a `Version` struct with the version
major, minor, patch and flavor.
Breaking API changes:
---------------------
* The public defines `GLSLANG_MINOR_VERSION` and `GLSLANG_PATCH_LEVEL`
have been entirely removed.
* `glslang/Public/ShaderLang.h` and `glslang/Include/revision.h` have
been deleted.
* Instead, `<build-dir>/include/glslang/build_info.h` is created in
the build directory, and `<build-dir>/include` is a CMake `PUBLIC`
(dependee-inherited) include directory for the glslang targets.
* `<build-dir>/include/glslang/build_info.h` contains the following
new #defines:
`GLSLANG_VERSION_MAJOR`, `GLSLANG_VERSION_MINOR`,
`GLSLANG_VERSION_PATCH`, `GLSLANG_VERSION_FLAVOR`,
`GLSLANG_VERSION_GREATER_THAN(major, minor, patch)`,
`GLSLANG_VERSION_GREATER_OR_EQUAL_TO(major, minor, patch)`,
`GLSLANG_VERSION_LESS_THAN(major, minor, patch)`,
`GLSLANG_VERSION_LESS_OR_EQUAL_TO(major, minor, patch)`
* The CMake install output directory contains a copy of
`build_info.h` at: `include/glslang/build_info.h`
* Python3 is now always required to build glslang (likely always
required for transitive dependency builds).
2020-06-17 10:17:19 +00:00
|
|
|
set(GLSLANG_BUILD_INFO_H "${GLSLANG_GENERATED_INCLUDEDIR}/glslang/build_info.h")
|
|
|
|
|
|
|
|
# Command to build the build_info.h file
|
|
|
|
add_custom_command(
|
|
|
|
OUTPUT ${GLSLANG_BUILD_INFO_H}
|
|
|
|
COMMAND ${PYTHON_EXECUTABLE} "${GLSLANG_BUILD_INFO_PY}"
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}
|
|
|
|
"-i" ${GLSLANG_BUILD_INFO_H_TMPL}
|
|
|
|
"-o" ${GLSLANG_BUILD_INFO_H}
|
|
|
|
DEPENDS ${GLSLANG_BUILD_INFO_PY}
|
|
|
|
${GLSLANG_CHANGES_FILE}
|
|
|
|
${GLSLANG_BUILD_INFO_H_TMPL}
|
|
|
|
COMMENT "Generating ${GLSLANG_BUILD_INFO_H}")
|
|
|
|
|
|
|
|
# Target to build the build_info.h file
|
|
|
|
add_custom_target(glslang-build-info DEPENDS ${GLSLANG_BUILD_INFO_H})
|
|
|
|
|
|
|
|
# Populate the CMake GLSLANG_VERSION* variables with the build version
|
|
|
|
# information.
|
|
|
|
execute_process(
|
|
|
|
COMMAND ${PYTHON_EXECUTABLE} "${GLSLANG_BUILD_INFO_PY}"
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR} "<major>.<minor>.<patch><-flavor>;<major>;<minor>;<patch>;<flavor>"
|
|
|
|
OUTPUT_VARIABLE "GLSLANG_VERSIONS"
|
|
|
|
OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
|
|
list(GET "GLSLANG_VERSIONS" 0 "GLSLANG_VERSION")
|
|
|
|
list(GET "GLSLANG_VERSIONS" 1 "GLSLANG_VERSION_MAJOR")
|
|
|
|
list(GET "GLSLANG_VERSIONS" 2 "GLSLANG_VERSION_MINOR")
|
|
|
|
list(GET "GLSLANG_VERSIONS" 3 "GLSLANG_VERSION_PATCH")
|
|
|
|
list(GET "GLSLANG_VERSIONS" 4 "GLSLANG_VERSION_FLAVOR")
|
|
|
|
configure_file(${GLSLANG_CHANGES_FILE} "${CMAKE_CURRENT_BINARY_DIR}/CHANGES.md") # Required to re-run cmake on version change
|
|
|
|
|
|
|
|
# glslang_add_build_info_dependency() adds the glslang-build-info dependency and
|
|
|
|
# generated include directories to target.
|
|
|
|
function(glslang_add_build_info_dependency target)
|
|
|
|
target_include_directories(${target} PUBLIC $<BUILD_INTERFACE:${GLSLANG_GENERATED_INCLUDEDIR}>)
|
|
|
|
add_dependencies(${target} glslang-build-info)
|
|
|
|
endfunction()
|
2019-05-09 09:43:26 +00:00
|
|
|
|
2020-06-29 13:20:19 +00:00
|
|
|
# glslang_only_export_explicit_symbols() makes the symbol visibility hidden by
|
2020-07-31 06:09:17 +00:00
|
|
|
# default for <target> when building shared libraries, and sets the
|
|
|
|
# GLSLANG_IS_SHARED_LIBRARY define, and GLSLANG_EXPORTING to 1 when specifically
|
|
|
|
# building <target>.
|
2020-06-29 13:20:19 +00:00
|
|
|
function(glslang_only_export_explicit_symbols target)
|
|
|
|
if(BUILD_SHARED_LIBS)
|
2020-07-02 14:54:40 +00:00
|
|
|
target_compile_definitions(${target} PUBLIC "GLSLANG_IS_SHARED_LIBRARY=1")
|
2020-06-29 13:20:19 +00:00
|
|
|
if(WIN32)
|
|
|
|
target_compile_definitions(${target} PRIVATE "GLSLANG_EXPORTING=1")
|
2020-07-31 06:09:17 +00:00
|
|
|
else()
|
|
|
|
target_compile_options(${target} PRIVATE "-fvisibility=hidden")
|
2020-06-29 13:20:19 +00:00
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endfunction()
|
|
|
|
|
2020-07-07 12:24:04 +00:00
|
|
|
# glslang_pch() adds precompiled header rules to <target> for the pre-compiled
|
|
|
|
# header file <pch>. As target_precompile_headers() was added in CMake 3.16,
|
|
|
|
# this is a no-op if called on earlier versions of CMake.
|
|
|
|
if(NOT CMAKE_VERSION VERSION_LESS "3.16")
|
|
|
|
function(glslang_pch target pch)
|
|
|
|
target_precompile_headers(${target} PRIVATE ${pch})
|
|
|
|
endfunction()
|
|
|
|
else()
|
|
|
|
function(glslang_pch target pch)
|
|
|
|
endfunction()
|
2020-07-13 18:14:02 +00:00
|
|
|
message("Your CMake version is ${CMAKE_VERSION}. Update to at least 3.16 to enable precompiled headers to speed up incremental builds")
|
2020-07-07 12:24:04 +00:00
|
|
|
endif()
|
|
|
|
|
Generate build information from CHANGES.md
This PR significantly reworks the way glslang is versioned.
Instead of committing changes to the `GLSLANG_MINOR_VERSION` define in
`glslang/Public/ShaderLang.h`, and using `make-revision` to generate
`GLSLANG_PATCH_LEVEL` in `glslang/Include/revision.h`, all version
information is now derived from the new `CHANGES.md` file.
`CHANGES.md` acts as the single source of truth for glslang version
information, along with a convenient place to put all release notes for
each notable change made.
`CHANGES.md` is parsed using the new `build_info.py` python script.
This script can read basic template files to produce new source files,
which it does to read the new `build_info.h.tmpl` to generate (at build
time) a glslang private header at
`<build-dir>/include/glslang/build_info.h`.
I've written generators for each of the CMake, Bazel, gn, and
`Android.mk` build scripts.
The new version code conforms to the Semantic Versioning 2.0 spec.
This new version is also used by the CMake rules to produce versioned
shared objects, including a major-versioned SONAME.
New APIs:
---------
* `glslang::GetVersion()` returns a `Version` struct with the version
major, minor, patch and flavor.
Breaking API changes:
---------------------
* The public defines `GLSLANG_MINOR_VERSION` and `GLSLANG_PATCH_LEVEL`
have been entirely removed.
* `glslang/Public/ShaderLang.h` and `glslang/Include/revision.h` have
been deleted.
* Instead, `<build-dir>/include/glslang/build_info.h` is created in
the build directory, and `<build-dir>/include` is a CMake `PUBLIC`
(dependee-inherited) include directory for the glslang targets.
* `<build-dir>/include/glslang/build_info.h` contains the following
new #defines:
`GLSLANG_VERSION_MAJOR`, `GLSLANG_VERSION_MINOR`,
`GLSLANG_VERSION_PATCH`, `GLSLANG_VERSION_FLAVOR`,
`GLSLANG_VERSION_GREATER_THAN(major, minor, patch)`,
`GLSLANG_VERSION_GREATER_OR_EQUAL_TO(major, minor, patch)`,
`GLSLANG_VERSION_LESS_THAN(major, minor, patch)`,
`GLSLANG_VERSION_LESS_OR_EQUAL_TO(major, minor, patch)`
* The CMake install output directory contains a copy of
`build_info.h` at: `include/glslang/build_info.h`
* Python3 is now always required to build glslang (likely always
required for transitive dependency builds).
2020-06-17 10:17:19 +00:00
|
|
|
if(BUILD_EXTERNAL AND IS_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/External)
|
|
|
|
# We depend on these for later projects, so they should come first.
|
|
|
|
add_subdirectory(External)
|
|
|
|
endif()
|
|
|
|
|
2017-09-21 22:50:39 +00:00
|
|
|
if(NOT TARGET SPIRV-Tools-opt)
|
|
|
|
set(ENABLE_OPT OFF)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(ENABLE_OPT)
|
|
|
|
message(STATUS "optimizer enabled")
|
2018-03-29 17:49:14 +00:00
|
|
|
add_definitions(-DENABLE_OPT=1)
|
2018-04-06 01:52:38 +00:00
|
|
|
else()
|
|
|
|
if(ENABLE_HLSL)
|
|
|
|
message(STATUS "spirv-tools not linked - illegal SPIRV may be generated for HLSL")
|
|
|
|
endif()
|
2018-03-29 17:49:14 +00:00
|
|
|
add_definitions(-DENABLE_OPT=0)
|
2017-09-21 22:50:39 +00:00
|
|
|
endif()
|
|
|
|
|
2015-06-26 22:29:10 +00:00
|
|
|
add_subdirectory(glslang)
|
|
|
|
add_subdirectory(OGLCompilersDLL)
|
2016-12-20 00:56:00 +00:00
|
|
|
if(ENABLE_GLSLANG_BINARIES)
|
2017-04-29 08:57:36 +00:00
|
|
|
add_subdirectory(StandAlone)
|
2016-12-20 00:56:00 +00:00
|
|
|
endif()
|
2015-06-26 22:29:10 +00:00
|
|
|
add_subdirectory(SPIRV)
|
2017-01-09 22:10:14 +00:00
|
|
|
if(ENABLE_HLSL)
|
2017-01-09 01:20:25 +00:00
|
|
|
add_subdirectory(hlsl)
|
2017-01-11 21:50:16 +00:00
|
|
|
endif(ENABLE_HLSL)
|
2019-10-25 08:57:11 +00:00
|
|
|
if(ENABLE_CTEST)
|
|
|
|
add_subdirectory(gtests)
|
|
|
|
endif()
|
2019-10-15 19:21:21 +00:00
|
|
|
|
2020-05-21 11:33:17 +00:00
|
|
|
if(ENABLE_CTEST AND BUILD_TESTING)
|
2019-10-16 14:45:11 +00:00
|
|
|
# glslang-testsuite runs a bash script on Windows.
|
|
|
|
# Make sure to use '-o igncr' flag to ignore carriage returns (\r).
|
|
|
|
set(IGNORE_CR_FLAG "")
|
|
|
|
if(WIN32)
|
|
|
|
set(IGNORE_CR_FLAG -o igncr)
|
|
|
|
endif()
|
2019-10-15 19:21:21 +00:00
|
|
|
|
2019-10-16 14:45:11 +00:00
|
|
|
if (CMAKE_CONFIGURATION_TYPES)
|
2019-10-16 17:08:48 +00:00
|
|
|
set(RESULTS_PATH ${CMAKE_CURRENT_BINARY_DIR}/$<CONFIGURATION>/localResults)
|
|
|
|
set(VALIDATOR_PATH ${CMAKE_CURRENT_BINARY_DIR}/StandAlone/$<CONFIGURATION>/glslangValidator)
|
|
|
|
set(REMAP_PATH ${CMAKE_CURRENT_BINARY_DIR}/StandAlone/$<CONFIGURATION>/spirv-remap)
|
2019-10-16 14:45:11 +00:00
|
|
|
else(CMAKE_CONFIGURATION_TYPES)
|
2019-10-16 17:08:48 +00:00
|
|
|
set(RESULTS_PATH ${CMAKE_CURRENT_BINARY_DIR}/localResults)
|
|
|
|
set(VALIDATOR_PATH ${CMAKE_CURRENT_BINARY_DIR}/StandAlone/glslangValidator)
|
|
|
|
set(REMAP_PATH ${CMAKE_CURRENT_BINARY_DIR}/StandAlone/spirv-remap)
|
2019-10-16 14:45:11 +00:00
|
|
|
endif(CMAKE_CONFIGURATION_TYPES)
|
2019-10-16 17:08:48 +00:00
|
|
|
|
|
|
|
add_test(NAME glslang-testsuite
|
|
|
|
COMMAND bash ${IGNORE_CR_FLAG} runtests ${RESULTS_PATH} ${VALIDATOR_PATH} ${REMAP_PATH}
|
|
|
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/Test/)
|
2020-05-21 11:33:17 +00:00
|
|
|
endif()
|