-
Notifications
You must be signed in to change notification settings - Fork 809
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add new CMakeLists.txt to provide PhysXConfig.cmake #222
base: 4.1
Are you sure you want to change the base?
Changes from 13 commits
3e7b120
97be9e8
58b6760
4460472
3aaf16a
4100545
b9345f5
3fb447d
74e9ab2
d563176
7949240
7fb6320
82883b5
4c4a6ee
9789a7a
4bdc673
1db08c8
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
# Generated files (placed in source tree) | ||
PxConfig.h | ||
|
||
#GitHub C++ gitignore | ||
# Compiled Object files | ||
*.slo | ||
*.lo | ||
*.o | ||
*.obj | ||
# Precompiled Headers | ||
*.gch | ||
*.pch | ||
# Compiled Dynamic libraries | ||
*.so | ||
*.dylib | ||
*.dll | ||
# Fortran module files | ||
*.mod | ||
# Compiled Static libraries | ||
*.lai | ||
*.la | ||
*.a | ||
*.lib | ||
# Executables | ||
*.exe | ||
*.out | ||
*.app | ||
|
||
#EDITORS# | ||
*.swp | ||
*.swo | ||
*.orig | ||
*.*.orig | ||
Session.vim | ||
.eclimrc | ||
*.project | ||
*.cproject | ||
*.ycm_extra_conf.pyc | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,179 @@ | ||
## | ||
## 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. | ||
## * Neither the name of NVIDIA CORPORATION nor the names of its | ||
## 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 ``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 OWNER 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. | ||
## | ||
## Copyright (c) 2018-2019 NVIDIA Corporation. All rights reserved. | ||
## Copyright (c) 2019 Pablo Hernandez-Cerdan | ||
|
||
cmake_minimum_required(VERSION 3.13) | ||
# Change options for CMAKE_BUILD_TYPE and set default. | ||
# Same values than CMAKE_CONFIGURATION_TYPES | ||
# From https://gitlab.kitware.com/cmake/cmake/issues/19401 | ||
get_property(multiConfig GLOBAL PROPERTY GENERATOR_IS_MULTI_CONFIG) | ||
if(NOT multiConfig AND NOT DEFINED CMAKE_BUILD_TYPE) | ||
set(default_build_type "release") | ||
message(STATUS "Setting build type to '${default_build_type}' as none was specified.") | ||
set(CMAKE_BUILD_TYPE ${default_build_type} CACHE STRING "Choose the type of build.") | ||
set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS | ||
"release" "profile" "checked" "debug") | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'm not aware of what I would also add There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
I am not from NVidia, but from what I understand yes, libPhysXGpu (PhysXDevice in Windows...) are indeed close source and distributed by Nvidia in a binary form with each update of this repository. Only these GPU kernels are closed source, the rest is open source and is compiled when you build the project. Following up, these libraries are distributed for the 4 non-standard configurations of Nvidia: release, profile, checked, debug. Each one having their own compiler flags. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Your comment makes totally sense, thanks for the clarification. |
||
endif() | ||
|
||
file(READ "version.txt" PHYSX_VERSION) | ||
project(PhysX | ||
LANGUAGES C CXX | ||
VERSION ${PHYSX_VERSION}) | ||
message(STATUS "PhysX VERSION: ${PHYSX_VERSION}") | ||
cmake_policy(SET CMP0057 NEW) # Enable IN_LIST | ||
cmake_policy(SET CMP0077 NEW) # option() does nothing when variable is alredy set | ||
|
||
# PhysXSDK options: | ||
option(PX_BUILDSNIPPETS "Generate the snippets" OFF) | ||
option(PX_BUILDPUBLICSAMPLES "Generate the samples" OFF) | ||
option(PX_CMAKE_SUPPRESS_REGENERATION "Disable zero_check projects" OFF) | ||
# PhysX options: | ||
option(PX_SCALAR_MATH "Disable SIMD math" OFF) | ||
option(PX_GENERATE_STATIC_LIBRARIES "Generate static libraries" OFF) | ||
if(NOT DEFINED BUILD_SHARED_LIBS) | ||
if(PX_GENERATE_STATIC_LIBRARIES) | ||
set(BUILD_SHARED_LIBS OFF) | ||
else() | ||
set(BUILD_SHARED_LIBS ON) | ||
endif() | ||
else() | ||
if(BUILD_SHARED_LIBS EQUAL PX_GENERATE_STATIC_LIBRARIES) | ||
message(FATAL_ERROR "Contradictory options: BUILD_SHARED_LIBS and PX_GENERATE_STATIC_LIBRARIES have both the same value: ${BUILD_SHARED_LIBS}") | ||
endif() | ||
endif() | ||
Comment on lines
+69
to
+79
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. What about adding this variable in CACHE so that downstream users can easily switch them with There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Users can do that with the There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Ow that's right, I missed it! |
||
message(STATUS "BUILD_SHARED_LIBS: ${BUILD_SHARED_LIBS}") | ||
message(STATUS " PX_GENERATE_STATIC_LIBRARIES: ${PX_GENERATE_STATIC_LIBRARIES}") | ||
option(PX_EXPORT_LOWLEVEL_PDB "Export low level pdb's" OFF) | ||
option(PX_GENERATE_GPU_PROJECTS_ONLY "Generate GPU projects only. (Untested)" OFF) | ||
mark_as_advanced(PX_GENERATE_GPU_PROJECTS_ONLY) | ||
|
||
set(PUBLIC_RELEASE OFF) | ||
# Enable folder properties | ||
set_property(GLOBAL PROPERTY USE_FOLDERS ON) | ||
|
||
if(CMAKE_CONFIGURATION_TYPES) | ||
set(CMAKE_CONFIGURATION_TYPES debug checked profile release) | ||
set(CMAKE_CONFIGURATION_TYPES "${CMAKE_CONFIGURATION_TYPES}" CACHE STRING | ||
"Reset config to what we need" | ||
FORCE) | ||
|
||
set(CMAKE_SHARED_LINKER_FLAGS_CHECKED "") | ||
set(CMAKE_SHARED_LINKER_FLAGS_PROFILE "") | ||
|
||
endif() | ||
|
||
# Disable zero_check projects. The default for Switch and XboxOne is ON. | ||
if(PX_CMAKE_SUPPRESS_REGENERATION) | ||
set(CMAKE_SUPPRESS_REGENERATION TRUE) | ||
endif() | ||
|
||
### Set PHYSX_ROOT_DIR to PROJECT_SOURCE_DIR | ||
if(DEFINED PHYSX_ROOT_DIR) | ||
message(WARNING "PHYSX_ROOT_DIR is externally defined, but it will be overwritten in this CMakeLists. DEPRECATED") | ||
message("PHYSX_ROOT_DIR (externally set --not used--): ${PHYSX_ROOT_DIR}") | ||
message("PHYSX_ROOT_DIR (currently set): ${PROJECT_SOURCE_DIR}") | ||
endif() | ||
set(PHYSX_ROOT_DIR ${PROJECT_SOURCE_DIR}) | ||
|
||
### Set TARGET_BUILD_PLATFORM using CMAKE_SYSTEM_NAME | ||
# for compatibility with current CMake files, | ||
# for cross-complation, CMAKE_SYSTEM_NAME can be set when running cmake | ||
if(DEFINED TARGET_BUILD_PLATFORM) | ||
if(TARGET_BUILD_PLATFORM STREQUAL "switch" OR | ||
TARGET_BUILD_PLATFORM STREQUAL "playstation" OR | ||
TARGET_BUILD_PLATFORM STREQUAL "ios") | ||
message(FATAL_ERROR "switch, playstation and ios builds are not valid because have not been tested. Use official repository for these.") | ||
endif() | ||
message(INFO "TARGET_BUILD_PLATFORM (externally set --not used--): ${TARGET_BUILD_PLATFORM}") | ||
endif() | ||
|
||
set(TARGET_BUILD_PLATFORM "") | ||
if(CMAKE_SYSTEM_NAME STREQUAL "Windows") | ||
set(TARGET_BUILD_PLATFORM "windows") | ||
elseif(CMAKE_SYSTEM_NAME STREQUAL "Linux") | ||
set(TARGET_BUILD_PLATFORM "linux") | ||
elseif(CMAKE_SYSTEM_NAME STREQUAL "Darwin") | ||
set(TARGET_BUILD_PLATFORM "mac") | ||
elseif(CMAKE_SYSTEM_NAME STREQUAL "Android") | ||
set(TARGET_BUILD_PLATFORM "android") | ||
endif() | ||
|
||
### Set CMake folders | ||
set(CMAKEMODULES_PATH ${PROJECT_SOURCE_DIR}/../externals/cmakemodules/ | ||
CACHE INTERNAL "Path to CMakeModules") | ||
set(CMAKEMODULES_NAME "CMakeModules" CACHE INTERNAL "CMakeModules name") | ||
set(CMAKEMODULES_VERSION "1.27" CACHE INTERNAL "CMakeModules version from generation batch") | ||
# CMAKE_MODULE_PATH is empty by default | ||
list(APPEND CMAKE_MODULE_PATH ${CMAKEMODULES_PATH}) | ||
|
||
### Set platform specific files | ||
set(PROJECT_CMAKE_FILES_DIR source/compiler/cmake) | ||
set(PROJECT_CMAKE_FILES_ABSOLUTE_DIR ${PHYSX_ROOT_DIR}/${PROJECT_CMAKE_FILES_DIR}) | ||
# The following files define all the flags specific to platforms, compilers and build configurations. | ||
# The file is included in the source/ subdirectory | ||
set(PLATFORM_CMAKELISTS "${PHYSX_ROOT_DIR}/${PROJECT_CMAKE_FILES_DIR}/${TARGET_BUILD_PLATFORM}/CMakeLists.txt") | ||
|
||
set(CMAKE_POSITION_INDEPENDENT_CODE ON) | ||
|
||
# INSTALL PATHS | ||
# XXX(phcerdan) CMAKE_INSTALL_PREFIX by definition has to point to the root folder of the installation | ||
# but the upstream python configuration adds PhysX to the CMAKE_INSTALL_PREFIX, which is not standard, | ||
# and then hack it to install PxShared in parallel to PhysX. Solved here: | ||
set(PHYSX_INSTALL_PREFIX ${CMAKE_INSTALL_PREFIX}/PhysX CACHE INTERNAL "Install path to install PhysX") | ||
set(PXSHARED_PATH ${PROJECT_SOURCE_DIR}/../pxshared CACHE INTERNAL "Path to PxShared source") | ||
set(PXSHARED_INSTALL_PREFIX ${CMAKE_INSTALL_PREFIX}/PxShared CACHE INTERNAL "Path to install PxShared") | ||
|
||
# Set PX_ROOT_LIB_DIR (used in cmake files) | ||
string(TOLOWER ${CMAKE_C_COMPILER_ID} compiler_id) | ||
# No need to add TARGET_BUILD_PLATFORM and compiler_id in the folder structure | ||
# set(PX_ROOT_LIB_DIR "${PHYSX_INSTALL_PREFIX}/bin/${TARGET_BUILD_PLATFORM}\.${compiler_id}") | ||
set(PX_ROOT_LIB_DIR "${PHYSX_INSTALL_PREFIX}/bin") | ||
|
||
# We add CMakeLists.txt in the source folders, following standard CMake practices | ||
# Add PhysX SDK Source code to solution | ||
set(BUILD_SOURCE_FOLDER ${CMAKE_CURRENT_BINARY_DIR}/sdk_source_bin) | ||
add_subdirectory(source ${BUILD_SOURCE_FOLDER}) | ||
|
||
# TODO(phcerdan) Snippets and Samples are not integrated with the new CMake procedure | ||
# But check the project_using_physx for hints on how to integrate it. | ||
if(PX_BUILDSNIPPETS) | ||
# Add Snippets projects into the solution | ||
add_subdirectory(${PHYSX_ROOT_DIR}/snippets/compiler/cmake ${CMAKE_CURRENT_BINARY_DIR}/sdk_snippets_bin) | ||
|
||
message("Added Snippets") | ||
endif() | ||
|
||
if(PX_BUILDPUBLICSAMPLES) | ||
if(CMAKE_SYSTEM_NAME STREQUAL "Windows" OR | ||
CMAKE_SYSTEM_NAME STREQUAL "Linux") | ||
# Add samples projects into the solution | ||
add_subdirectory(${PHYSX_ROOT_DIR}/samples/compiler/cmake ${CMAKE_CURRENT_BINARY_DIR}/sdk_samples_bin) | ||
|
||
message("Added Samples") | ||
endif() | ||
endif() | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Took this for a spin on Windows VS2019 but ran into a few issues.
mkdir PhysX;
doesn't seem necessary../src/physx
instead of..src/
as that's where the CMakeLists.txt file is atOther than that, this worked wonders!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You cannot mix
add_subdirectory
andfind_package
like that.When you
add_subdirectory
, you are building PhysX, so no need to find anything, you already have the PhysX target in scope.Try to remove
find_package
.Thanks for pointing it out, there is a missing
cd PhysX
in the Readme.It should be:
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks, I'm quite new at CMake so this doesn't surprise me.
However, I did try that and found myself facing this message:
And wasn't able to figure out where
::PhysXCommon
comes from. Removing those namespaces, and just calling..Got me past those errors, but then onto a..
Given a mere..
Which leads me to believe the include directory isn't being included, and sure enough, looking at the generated Ninja build file, I can see that it's missing from the
main.cpp
file that triggers this error.Anything else I'm missing?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You have
PxPhysicsAPI.h
included in a header, have you tried linking publicly to PhysX?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I hadn't, but tried it just now. No change. :(
Anyway I can "force" it? I tried this...
..which brought new fire and fury.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I forgot, you have to link to specific targets you want:
Try:
Have a look at the sample project in this PR:
https://github.com/phcerdan/PhysX/blob/9789a7a8083d4a0a2e035adf53f8e7d0b14ad40b/project_using_physx/CMakeLists.txt
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks, but I tried that earlier (see above) and it gets me this error here:
It looks like those targets are only added with
find_package
? :SI've (temporarily) made my (minimal) project public here, if you would happen to be able to have a look:
This was a tricky one!