From 5b6896123b24cc18201ad45b82f608133b5dac40 Mon Sep 17 00:00:00 2001 From: Michael Hansen Date: Tue, 28 Jul 2015 20:41:28 -0700 Subject: [PATCH 1/4] Use CMake's FeatureSummary tool to provide more info about dependencies --- CMakeLists.txt | 163 +++++++++++++++--- Sources/Plasma/Apps/plClient/CMakeLists.txt | 7 + .../Plasma/NucleusLib/pnUUID/CMakeLists.txt | 5 + Sources/Tools/CMakeLists.txt | 35 +++- 4 files changed, 183 insertions(+), 27 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 242a83dd..3ded767f 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,6 +1,8 @@ project(Plasma) cmake_minimum_required(VERSION 2.8.11.2) +include(FeatureSummary) + if(POLICY CMP0054) cmake_policy(SET CMP0054 NEW) endif() @@ -41,25 +43,128 @@ set(CMAKE_MODULE_PATH "${CMAKE_SOURCE_DIR}/cmake") SET(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${Plasma_BINARY_DIR}/bin) # Find all 3rd-party libraries that are required -set(Python_ADDITIONAL_VERSIONS 2.7) find_package(OpenSSL REQUIRED) +set_package_properties(OpenSSL PROPERTIES + URL "https://www.openssl.org/" + DESCRIPTION "OpenSSL libraries for SSL/TLS" + TYPE REQUIRED +) + find_package(OpenAL REQUIRED) +set_package_properties(OpenAL PROPERTIES + URL "http://www.openal.org/" + DESCRIPTION "3D audio and EAX library" + TYPE REQUIRED +) + +set(Python_ADDITIONAL_VERSIONS 2.7) find_package(PythonLibs REQUIRED) +set_package_properties(PythonLibs PROPERTIES + URL "http://www.python.org" + DESCRIPTION "Python Scripting language C bindings" + TYPE REQUIRED +) + find_package(EXPAT REQUIRED) +set_package_properties(EXPAT PROPERTIES + URL "http://expat.sourceforge.net/" + DESCRIPTION "Expat XML Parser for C" + TYPE REQUIRED +) + find_package(ZLIB REQUIRED) +set_package_properties(ZLIB PROPERTIES + URL "http://www.zlib.net" + DESCRIPTION "Fast (de)compression library" + TYPE REQUIRED +) + find_package(JPEG REQUIRED) +set_package_properties(JPEG PROPERTIES + URL "http://libjpeg-turbo.virtualgl.org/" + DESCRIPTION "JPEG encoding and decoding library. libjpeg-turbo is recommended for better performance" + TYPE REQUIRED +) + find_package(PNG REQUIRED) -find_package(Ogg REQUIRED) #TODO: Not required if we aren't building the client -find_package(Vorbis REQUIRED) #TODO: Not required if we aren't building the client -find_package(Speex REQUIRED) #TODO: Not required if we aren't building the client +set_package_properties(PNG PROPERTIES + URL "http://www.libpng.org/pub/png/libpng.html" + DESCRIPTION "Efficient lossless image library" + TYPE REQUIRED +) + +#TODO: Not required if we aren't building the client +find_package(Ogg REQUIRED) +set_package_properties(Ogg PROPERTIES + URL "https://xiph.org/ogg/" + DESCRIPTION "Ogg multimedia container library for various audio and video codecs" + TYPE REQUIRED + PURPOSE "Required for audio support in the client" +) + +#TODO: Not required if we aren't building the client +find_package(Vorbis REQUIRED) +set_package_properties(Vorbis PROPERTIES + URL "https://xiph.org/vorbis/" + DESCRIPTION "Free and open audio codec for mid-to-high quality audio" + TYPE REQUIRED + PURPOSE "Required for audio support in the client" +) + +#TODO: Not required if we aren't building the client +find_package(Speex REQUIRED) +set_package_properties(Speex PROPERTIES + URL "http://www.speex.org/" + DESCRIPTION "Free and open audio codec specifically designed for speech" + TYPE REQUIRED + PURPOSE "Required for in-game voice chat in the client" +) + find_package(VPX) +set_package_properties(VPX PROPERTIES + URL "http://www.webmproject.org/" + DESCRIPTION "VP8 and VP9 video codec" + TYPE OPTIONAL + PURPOSE "Required for in-game video playback support" +) + find_package(Opus) +set_package_properties(Opus PROPERTIES + URL "https://www.opus-codec.org/" + DESCRIPTION "Versatile free and open audio codec" + TYPE OPTIONAL + PURPOSE "Required for in-game video playback support" +) + find_package(CURL REQUIRED) +set_package_properties(CURL PROPERTIES + URL "http://curl.haxx.se/libcurl/" + DESCRIPTION "Multi-protocol file transfer library" + TYPE REQUIRED +) + find_package(Freetype) +set_package_properties(Freetype PROPERTIES + URL "http://www.freetype.org/" + DESCRIPTION "Library for rendering fonts" + TYPE OPTIONAL + PURPOSE "Required in order to build the plFontConverter tool" +) if(WIN32) - find_package(PhysX REQUIRED) #TODO: Not required if we aren't building the client + #TODO: Not required if we aren't building the client + find_package(PhysX REQUIRED) + set_package_properties(PhysX PROPERTIES + URL "https://developer.nvidia.com/physx-sdk" + DESCRIPTION "Library for hardware-accelerated physics simulation for gaming" + TYPE REQUIRED + ) + find_package(DirectX REQUIRED) + set_package_properties(DirectX PROPERTIES + DESCRIPTION "Framework for hardware-accelerated 3D graphics on Microsoft platforms" + TYPE REQUIRED + ) endif(WIN32) if(VPX_FOUND AND Opus_FOUND) @@ -115,28 +220,44 @@ option(PLASMA_BUILD_RESOURCE_DAT "Do we want to build resource.dat?" ON) option(PLASMA_BUILD_LAUNCHER "Do we want to build plUruLauncher?" ON) option(PLASMA_BUILD_TOOLS "Do we want to build the Plasma tools?" ON) option(PLASMA_BUILD_TESTS "Do we want to build the unit tests?" OFF) -if(WIN32) - option(3dsm_BUILD_PLUGIN "Do we want to build the 3ds Max plugin?" OFF) -else() - set(3dsm_BUILD_PLUGIN OFF) -endif() if(PLASMA_BUILD_TOOLS) # Custom dummy target for compiling all tools add_custom_target(tools) endif() -if(3dsm_BUILD_PLUGIN) - find_package(MaxSDK REQUIRED) - add_definitions(-DBUILDING_MAXPLUGIN) -endif(3dsm_BUILD_PLUGIN) +if(WIN32) + find_package(MaxSDK) + set_package_properties(MaxSDK PROPERTIES + URL "http://www.autodesk.com/" + DESCRIPTION "SDK for integrating with the 3DS Max modelling software" + TYPE OPTIONAL + PURPOSE "Required for building the Plasma plugins for 3DS Max" + ) + + option(3dsm_BUILD_PLUGIN "Do we want to build the 3ds Max plugin?" OFF) + if (3dsm_BUILD_PLUGIN AND 3dsm_FOUND) + add_definitions(-DBUILDING_MAXPLUGIN) + endif() +else() + set(3dsm_BUILD_PLUGIN OFF) +endif() + +if(WIN32) + find_package(VLD) + set_package_properties(VLD PROPERTIES + URL "https://vld.codeplex.com/" + DESCRIPTION "Visual Leak Debugger for software compiled with Microsoft Visual C++" + TYPE OPTIONAL + PURPOSE "Useful for detecting memory leaks (MSVC only)" + ) -option(USE_VLD "Build and link with Visual Leak Detector (MSVC only)" OFF) -if(USE_VLD) - add_definitions(-DUSE_VLD) - find_package(VLD REQUIRED) - include_directories(${VLD_INCLUDE_DIR}) -endif(USE_VLD) + option(USE_VLD "Build and link with Visual Leak Detector" OFF) + if(USE_VLD AND VLD_FOUND) + add_definitions(-DUSE_VLD) + include_directories(${VLD_INCLUDE_DIR}) + endif(USE_VLD) +endif() include(TestBigEndian) test_big_endian(BIG_ENDIAN) @@ -162,3 +283,5 @@ if(PLASMA_BUILD_TESTS) add_custom_target(check COMMAND ${CMAKE_CTEST_COMMAND}) add_subdirectory(Sources/Tests EXCLUDE_FROM_ALL) endif(PLASMA_BUILD_TESTS) + +feature_summary(WHAT ALL FATAL_ON_MISSING_REQUIRED_PACKAGES) diff --git a/Sources/Plasma/Apps/plClient/CMakeLists.txt b/Sources/Plasma/Apps/plClient/CMakeLists.txt index bcead331..9c0f7e65 100644 --- a/Sources/Plasma/Apps/plClient/CMakeLists.txt +++ b/Sources/Plasma/Apps/plClient/CMakeLists.txt @@ -19,6 +19,13 @@ endif() # Test for Python Interpreter, which will be used for extra build scripts if available find_package(PythonInterp) +set_package_properties(PythonInterp PROPERTIES + URL "http://www.python.org" + DESCRIPTION "Python Scripting language interpreter" + TYPE OPTIONAL + PURPOSE "Used to (re-)build some client resource files" +) + if(PYTHONINTERP_FOUND) include(FindPythonModule) # Test for Python modules needed to build resource.dat diff --git a/Sources/Plasma/NucleusLib/pnUUID/CMakeLists.txt b/Sources/Plasma/NucleusLib/pnUUID/CMakeLists.txt index 0398aeb1..ca3e40f8 100644 --- a/Sources/Plasma/NucleusLib/pnUUID/CMakeLists.txt +++ b/Sources/Plasma/NucleusLib/pnUUID/CMakeLists.txt @@ -12,6 +12,11 @@ endif(WIN32) if(UNIX) if(NOT APPLE) find_package(Uuid REQUIRED) + set_package_properties(Uuid PROPERTIES + DESCRIPTION "UUID library for Linux (provided by util-linux)" + TYPE REQUIRED + ) + include_directories(${Uuid_INCLUDE_DIR}) endif() diff --git a/Sources/Tools/CMakeLists.txt b/Sources/Tools/CMakeLists.txt index ef7f2aa4..bd96ea77 100644 --- a/Sources/Tools/CMakeLists.txt +++ b/Sources/Tools/CMakeLists.txt @@ -1,9 +1,30 @@ -if(PLASMA_BUILD_TOOLS) - find_package(Qt5Core REQUIRED) - find_package(Qt5Widgets REQUIRED) +find_package(Qt5Core) +set_package_properties(Qt5Core PROPERTIES + URL "http://www.qt.io/" + DESCRIPTION "Cross-platform GUI framework for C++" + TYPE OPTIONAL + PURPOSE "Required for building GUI tools for Plasma" +) + +find_package(Qt5Widgets) +set_package_properties(Qt5Widgets PROPERTIES + URL "http://www.qt.io/" + DESCRIPTION "Cross-platform GUI framework for C++" + TYPE OPTIONAL + PURPOSE "Required for building GUI tools for Plasma" +) + +if(Qt5Core_FOUND AND Qt5Widgets_FOUND) + set(Qt5_LIBS_FOUND 1) +else() + set(Qt5_LIBS_FOUND 0) +endif() - add_subdirectory(plLocalizationEditor) - add_subdirectory(plResBrowser) +if(PLASMA_BUILD_TOOLS) + if(Qt5_LIBS_FOUND) + add_subdirectory(plLocalizationEditor) + add_subdirectory(plResBrowser) + endif() add_dependencies(tools plLocalizationEditor @@ -15,14 +36,14 @@ if(PLASMA_BUILD_TOOLS) add_dependencies(tools plShaderAssembler) endif() - if(FREETYPE_FOUND) + if(FREETYPE_FOUND AND Qt5_LIBS_FOUND) add_subdirectory(plFontConverter) add_dependencies(tools plFontConverter) endif() endif() # Max Stuff goes below here... -if(3dsm_BUILD_PLUGIN) +if(3dsm_FOUND AND 3dsm_BUILD_PLUGIN) add_subdirectory(MaxComponent) add_subdirectory(MaxConvert) add_subdirectory(MaxExport) From 5116fa9e2159ff7de529052978e6f2d05ee04400 Mon Sep 17 00:00:00 2001 From: Michael Hansen Date: Tue, 28 Jul 2015 20:52:32 -0700 Subject: [PATCH 2/4] Move tools subdirectory AFTER the flags it uses are defined --- CMakeLists.txt | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 3ded767f..b75102fa 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -221,11 +221,6 @@ option(PLASMA_BUILD_LAUNCHER "Do we want to build plUruLauncher?" ON) option(PLASMA_BUILD_TOOLS "Do we want to build the Plasma tools?" ON) option(PLASMA_BUILD_TESTS "Do we want to build the unit tests?" OFF) -if(PLASMA_BUILD_TOOLS) - # Custom dummy target for compiling all tools - add_custom_target(tools) -endif() - if(WIN32) find_package(MaxSDK) set_package_properties(MaxSDK PROPERTIES @@ -259,6 +254,11 @@ if(WIN32) endif(USE_VLD) endif() +if(PLASMA_BUILD_TOOLS) + # Custom dummy target for compiling all tools + add_custom_target(tools) +endif() + include(TestBigEndian) test_big_endian(BIG_ENDIAN) if(BIG_ENDIAN) From ab451790fd95f052f48c1bab6e15273911f62d02 Mon Sep 17 00:00:00 2001 From: Michael Hansen Date: Tue, 28 Jul 2015 21:01:56 -0700 Subject: [PATCH 3/4] Feature detection requires the package name to match what it searches for --- CMakeLists.txt | 4 ++-- cmake/{FindMaxSDK.cmake => Find3dsm.cmake} | 0 2 files changed, 2 insertions(+), 2 deletions(-) rename cmake/{FindMaxSDK.cmake => Find3dsm.cmake} (100%) diff --git a/CMakeLists.txt b/CMakeLists.txt index b75102fa..f12e174d 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -222,8 +222,8 @@ option(PLASMA_BUILD_TOOLS "Do we want to build the Plasma tools?" ON) option(PLASMA_BUILD_TESTS "Do we want to build the unit tests?" OFF) if(WIN32) - find_package(MaxSDK) - set_package_properties(MaxSDK PROPERTIES + find_package(3dsm) + set_package_properties(3dsm PROPERTIES URL "http://www.autodesk.com/" DESCRIPTION "SDK for integrating with the 3DS Max modelling software" TYPE OPTIONAL diff --git a/cmake/FindMaxSDK.cmake b/cmake/Find3dsm.cmake similarity index 100% rename from cmake/FindMaxSDK.cmake rename to cmake/Find3dsm.cmake From f06b8acbdc9e3b8d0cf5a71ce6acd098888f43f5 Mon Sep 17 00:00:00 2001 From: Michael Hansen Date: Wed, 29 Jul 2015 18:55:40 -0700 Subject: [PATCH 4/4] Fix cmake warnings --- CMakeLists.txt | 2 +- Sources/Tools/CMakeLists.txt | 10 +++++----- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index f12e174d..6e1fb14b 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -251,7 +251,7 @@ if(WIN32) if(USE_VLD AND VLD_FOUND) add_definitions(-DUSE_VLD) include_directories(${VLD_INCLUDE_DIR}) - endif(USE_VLD) + endif() endif() if(PLASMA_BUILD_TOOLS) diff --git a/Sources/Tools/CMakeLists.txt b/Sources/Tools/CMakeLists.txt index bd96ea77..c863d07a 100644 --- a/Sources/Tools/CMakeLists.txt +++ b/Sources/Tools/CMakeLists.txt @@ -24,12 +24,12 @@ if(PLASMA_BUILD_TOOLS) if(Qt5_LIBS_FOUND) add_subdirectory(plLocalizationEditor) add_subdirectory(plResBrowser) - endif() - add_dependencies(tools - plLocalizationEditor - plResBrowser - ) + add_dependencies(tools + plLocalizationEditor + plResBrowser + ) + endif() if(WIN32) add_subdirectory(plShaderAssembler)