YCM-MODULES(7) | YCM | YCM-MODULES(7) |
ycm-modules - YCM Modules Reference
Extracts version numbers from a version string:
extract_version (<name> [REVERSE_NAME])
Tries to extract the following variables (the second version is used if REVERSE_NAME is set as argument):
<name>_MAJOR_VERSION or <name>_VERSION_MAJOR - <name> major version <name>_MINOR_VERSION or <name>_VERSION_MINOR - <name> minor version <name>_PATCH_VERSION or <name>_VERSION_PATCH - <name> patch version <name>_TWEAK_VERSION or <name>_VERSION_TWEAK - <name> tweak version <name>_VERSION_COUNT - number of version components, 0 to 4
Return a list containing the names of all known CMake Properties.
Only properties returned by cmake --help-property-list are returned, custom properties will not be on the returned list.
Properties containing <CONFIG> or <LANG> are expanded to the correct property name.
Extract information from a git repository.
git_commit_info([SOURCE DIR <dir>]
[PREFIX <prefix>]
[REVISION <rev>]
[FATAL])
If SOURCE_DIR is a git repository, it checks the given REVISION and sets the following variables:
If SOURCE_DIR is not set, then the PROJECT_SOURCE_DIR cmake variable is used.
If PREFIX is not set, then the PROJECT_NAME cmake variable is used.
REVISION can be a commit hash, a tag, a branch, or anything that git can parse as a revision. If REVISION` is not set, then ``HEAD is used.
If FATAL is set, a fatal error is emitted when the source dir is not a git repository, or when git was not found. This is disabled by default to allow downloads from non-git sources (archives, wrappers, etc.), but can be enabled if required.
git_wt_info([SOURCE DIR <dir>]
[PREFIX <prefix>]
[FATAL])
If SOURCE_DIR is a git repository, it checks current revision and sets the following variables:
If SOURCE_DIR is not set, then the PROJECT_SOURCE_DIR cmake variable is used.
If PREFIX is not set, then the PROJECT_NAME cmake variable is used.
If FATAL is set, a fatal error is emitted when the source dir is not a git repository, or when git was not found. This is disabled by default to allow downloads from non-git sources (archives, wrappers, etc.), but can be enabled if required.
Adds the include_url() command that useful to download and include other CMake modules from a given url.
Downloads a file from given url and includes it:
include_url(<url> # Url to be downloaded
[DESTINATION <destination>] # Where the file will be saved
[EXPECTED_HASH <ALGO=value>] # Verify downloaded file's hash
[EXPECTED_MD5 <sum>] # Short-hand for "EXPECTED_HASH MD5=sum"
[DOWNLOAD_ONCE] # Download the file only once
[DOWNLOAD_ALWAYS] # Download the file every time
[OPTIONAL] # Do not fail file cannot be included
[RESULT_VARIABLE <variable>] # The local path for the file included
[RETRIES <retries>] # Try download <retries> times (default 3)
[QUIET] # Don't print anything
#--Download arguments-----------
[INACTIVITY_TIMEOUT <timeout>] # Timeout after <timeout> seconds of inactivity
[TIMEOUT <timeout>] # Timeout after <timeout> seconds
[STATUS <status>] # Download status variable
[LOG <log>] # Download log variable
[SHOW_PROGRESS] # Show download progress
[TLS_VERIFY <on|off>] # Check certificates
[TLS_CAINFO <file>] # Custom Certificate Authority file
#--Include arguments------------
[NO_POLICY_SCOPE] # Do not manage a new policy entry
)
The include_url macro downloads a file from given url and includes it. It works both in -P script mode and when configuring a CMakeLists.txt file.
If DESTINATION is specified, the file is saved at the given location with the original file name, if <destination> is a directory, or with the given file name, if <destination> is a file name.
The arguments EXPECTED_HASH, EXPECTED_MD5 are used to ensure that the file included is the one expected. If the <url> is a local file (i.e. starts with file://) the hash check is performed also on the file converted to the non-native end-of-line style. See the documentation of the file() command for further information about these arguments.
If the DOWNLOAD_ONCE option is specified, the file is not downloaded if the file already exists and the hash is correct. If the DOWNLOAD_ALWAYS option is specified, the file is downloaded at every CMake execution, and an error is raised on failure. If none of these two option is specifies, the default behaviour is to try to download the file at every CMake execution, but no error is raised if the download fails if a version of the file already exists. This is useful when CMake should try to update the file to the latest version, before including it.
If the OPTIONAL option is specified, no error will be caused if for any reason the file cannot be downloaded or included. If RESULT_VARIABLE is given, the variable will be set to the full filename which has been downloaded and included or NOTFOUND if it failed. See the documentation of the file() command for further information about these arguments.
If the RETRIES option is specified, the download will be tried If the QUIET option is specified, the command will emit no output.
The arguments INACTIVITY_TIMEOUT, TIMEOUT, STATUS, LOG, SHOW_PROGRESS, TLS_VERIFY, and TLS_CAINFO are passed to the file(DOWNLOAD) command. See the documentation of the file() command for a detailed description of these arguments.
The arguments NO_POLICY_SCOPE is passed to the include() command. See the documentation of the include() and cmake_policy() commands for a detailed description of this argument.
Adds the replace_imported_targets() command that useful to replace paths with imported targets in link variables (like <FOO>_LIBRARIES) and targets.
Replace imported targets in a list of and targets and paths:
replace_imported_targets(<var> [target [target [...]]])
Each path in var corrisponding to one of the targets will be replaced with the corrisponding target, taking care to remove the relative optimized and debug keywords.
For each existing target in var, the following properties will be searched for imported locations of targets, and, if set, will be replaced in the same way:
IMPORTED_LINK_DEPENDENT_LIBRARIES IMPORTED_LINK_DEPENDENT_LIBRARIES_<CONFIG> IMPORTED_LINK_INTERFACE_LIBRARIES IMPORTED_LINK_INTERFACE_LIBRARIES_<CONFIG> INTERFACE_LINK_LIBRARIES LINK_INTERFACE_LIBRARIES LINK_INTERFACE_LIBRARIES_<CONFIG> LINK_LIBRARIES
Try to find a package using a cmake config file, or pkgconfig:
standard_find_module(<name>
<pkgconfig name>
[NOT_REQUIRED]
[QUIET]
[SKIP_CMAKE_CONFIG]
[SKIP_PKG_CONFIG]
[TARGET <target>]
[REPLACE_TARGETS <target> [...]] )
If the package is found, the following variables (where possible) are created:
<name>_FOUND - System has <name> <name>_INCLUDE_DIRS - <name> include directory <name>_LIBRARIES - <name> libraries <name>_DEFINITIONS - Additional compiler flags for <name> <name>_VERSION - <name> version <name>_MAJOR_VERSION - <name> major version <name>_MINOR_VERSION - <name> minor version <name>_PATCH_VERSION - <name> patch version <name>_TWEAK_VERSION - <name> tweak version <name>_VERSION_COUNT - Number of version components, 0 to 4
For each library that requires to be linked (i.e. -llib) it creates:
<name>_<LIB>_LIBRARY_RELEASE (cached, advanced) <name>_<LIB>_LIBRARY_DEBUG (cached, advanced, and empty by default) <name>_<LIB>_LIBRARY <name>_<LIB>_LIBRARY_FOUND
In a FindXXX.cmake module, this macro can be used at the beginning. The NOT_REQUIRED can be added to avoid failing if the package was not found, but pkg-config is installed. The QUIET argument can be used to hide the output from find_package_handle_standard_args. If <name>_FOUND is FALSE at the end, more “custom” searches can be used (for windows, etc.)
If SKIP_CMAKE_CONFIG or SKIP_PKG_CONFIG are set, the relative step is skipped
If TARGET is specified, in pkg-config mode, an imported target will be created using the first library returned by pkg-config as imported location.
The REPLACE_TARGETS can be used to pass a list of imported targets that will be detected in variables and target properties, and replaced with the corresponding target.
If one of the STANDARD_FIND_MODULE_USE_IMPORTED_TARGET or STANDARD_FIND_MODULE_USE_IMPORTED_TARGET_<name> are enabled, and a TARGET is specified, the <name>_LIBRARIES variable content is replaced with the imported target.
If one of the variables STANDARD_FIND_MODULE_DEBUG or STANDARD_FIND_MODULE_DEBUG_<name> is enabled, prints more useful debug output
A helper module to make your package easier to be found by other projects.
Create and install a basic version of cmake config files for your project:
install_basic_package_files(<Name>
COMPATIBILITY <compatibility>
[VERSION <version>]
[ARCH_INDEPENDENT]
[NO_EXPORT | EXPORT <export>] # (default = "EXPORT <Name>")
[NO_SET_AND_CHECK_MACRO]
[NO_CHECK_REQUIRED_COMPONENTS_MACRO]
[VARS_PREFIX <prefix>] # (default = "<Name>")
[EXPORT_DESTINATION <destination>]
[INSTALL_DESTINATION <destination>]
[NAMESPACE <namespace>] # (default = "<Name>::")
[EXTRA_PATH_VARS_SUFFIX path1 [path2 ...]]
[CONFIG_TEMPLATE <file>]
[UPPERCASE_FILENAMES | LOWERCASE_FILENAMES]
[DEPENDENCIES <dependency1> "<dependency2> [...]" ...]
[PRIVATE_DEPENDENCIES <dependency1> "<dependency2> [...]" ...]
[INCLUDE_FILE <file> | INCLUDE_CONTENT <content>]
[COMPONENT <component>] # (default = "<Name>")
)
Depending on UPPERCASE_FILENAMES and LOWERCASE_FILENAMES, this function generates 3 files:
If neither UPPERCASE_FILENAMES nor LOWERCASE_FILENAMES is set, a file <Name>Config.cmake.in or <name>-config.cmake.in is searched, and the convention is chosed according to the file found. If no file was found, the uppercase convention is used.
The DEPENDENCIES argument can be used to set a list of dependencies that will be searched using the find_dependency() command from the CMakeFindDependencyMacro module. Dependencies can be followed by any of the possible find_dependency() argument. In this case, all the arguments must be specified within double quotes (e.g. "<dependency> 1.0.0 EXACT", or "<dependency> CONFIG"). The PRIVATE_DEPENDENCIES argument is similar to DEPENDENCIES, but these dependencies are included only when BUILD_SHARED_LIBS is OFF. If a libraries is declared STATIC, OBJECT or INTERFACE, and they link to some dependency, these should be added using the DEPENDENCIES argument, since the PRIVATE_DEPENDENCIES argument would work only when BUILD_SHARED_LIBS is disabled.
When using a custom template file, the @PACKAGE_DEPENDENCIES@ string is replaced with the code checking for the dependencies specified by these two argument.
If the ARCH_INDEPENDENT option is enabled, the installed package version will be considered compatible even if it was built for a different architecture than the requested architecture.
Each file is generated twice, one for the build directory and one for the installation directory. The INSTALL_DESTINATION argument can be passed to install the files in a location different from the default one (${CMAKE_INSTALL_DATADIR}/cmake/${Name} if the ARCH_INDEPENDENT option is enabled, ${CMAKE_INSTALL_LIBDIR}/cmake/${Name} otherwise). The EXPORT_DESTINATION argument can be passed to generate the files in the build tree in a location different from the default one (CMAKE_BINARY_DIR). If this is a relative path, it is considered relative to the CMAKE_CURRENT_BINARY_DIR directory.
The build directory is exported to the CMake user package registry if the build option CMAKE_EXPORT_PACKAGE_REGISTRY is set.
The <Name>ConfigVersion.cmake file is generated using write_basic_package_version_file(). The VERSION, COMPATIBILITY, and
``ARCH_INDEPENDENT``arguments are passed to this function.
VERSION shall be in the form <major>[.<minor>[.<patch>[.<tweak>]]]]. If no VERSION is given, the PROJECT_VERSION variable is used. If this hasn’t been set, it errors out. The VERSION argument is also used to replace the @PACKAGE_VERSION@ string in the configuration file.
COMPATIBILITY shall be any of the options accepted by the write_basic_package_version_file() command (AnyNewerVersion, SameMajorVersion, SameMinorVersion [CMake 3.11], or ExactVersion). These options are explained in write_basic_package_version_file() command documentation. If your project has more elaborate version matching rules, you will need to write your own custom ConfigVersion.cmake file instead of using this macro.
The <Name>Config.cmake file is generated using configure_package_config_file(). The NO_SET_AND_CHECK_MACRO, NO_CHECK_REQUIRED_COMPONENTS_MACRO, and arguments are passed to this function.
By default install_basic_package_files() also generates the two helper macros set_and_check() and check_required_components() into the <Name>Config.cmake file. set_and_check() should be used instead of the normal set() command for setting directories and file locations. Additionally to setting the variable it also checks that the referenced file or directory actually exists and fails with a FATAL_ERROR otherwise. This makes sure that the created <Name>Config.cmake file does not contain wrong references. When using the NO_SET_AND_CHECK_MACRO, this macro is not generated into the ``<Name>Config.cmake file.
By default, install_basic_package_files() append a call to check_required_components(<Name>) in <Name>Config.cmake file if the package supports components. This macro checks whether all requested, non-optional components have been found, and if this is not the case, sets the <Name>_FOUND variable to FALSE, so that the package is considered to be not found. It does that by testing the <Name>_<Component>_FOUND variables for all requested required components. When using the NO_CHECK_REQUIRED_COMPONENTS_MACRO option, this macro is not generated into the <Name>Config.cmake file.
Finally, the files in the build and install directory are exactly the same.
See the documentation of CMakePackageConfigHelpers module for further information and references therein.
If the CONFIG_TEMPLATE argument is passed, the specified file is used as template for generating the configuration file, otherwise this module expects to find a <Name>Config.cmake.in or <name>-config.cmake.in file either in current source directory. If the file does not exist, a very basic file is created.
A set of variables are checked and passed to configure_package_config_file() as PATH_VARS. For each of the SUFFIX considered, if one of the variables:
<VARS_PREFIX>_(BUILD|INSTALL)_<SUFFIX> (BUILD|INSTALL)_<VARS_PREFIX>_<SUFFIX>
is defined, the <VARS_PREFIX>_<SUFFIX> variable will be defined before configuring the package. In order to use that variable in the config file, you have to add a line:
set_and_check(<VARS_PREFIX>_<SUFFIX> \"@PACKAGE_<VARS_PREFIX>_<SUFFIX>@\")
if the path must exist or just:
set(<VARS_PREFIX>_<SUFFIX> \"@PACKAGE_<VARS_PREFIX>_<SUFFIX>@\")
if the path could be missing.
These variable will have different values whether you are using the package from the build tree or from the install directory. Also these files will contain only relative paths, meaning that you can move the whole installation and the CMake files will still work.
Default PATH_VARS suffixes are:
BINDIR BIN_DIR SBINDIR SBIN_DIR LIBEXECDIR LIBEXEC_DIR SYSCONFDIR SYSCONF_DIR SHAREDSTATEDIR SHAREDSTATE_DIR LOCALSTATEDIR LOCALSTATE_DIR LIBDIR LIB_DIR INCLUDEDIR INCLUDE_DIR OLDINCLUDEDIR OLDINCLUDE_DIR DATAROOTDIR DATAROOT_DIR DATADIR DATA_DIR INFODIR INFO_DIR LOCALEDIR LOCALE_DIR MANDIR MAN_DIR DOCDIR DOC_DIR
more suffixes can be added using the EXTRA_PATH_VARS_SUFFIX argument.
The <Name>Targets.cmake is generated using export(EXPORT) in the build tree and install(EXPORT) in the installation directory. The targets are exported using the value for the NAMESPACE argument as namespace. The export can be passed using the EXPORT argument. If no export is used (e.g. for a CMake script library), pass NO_EXPORT.
If the INCLUDE_FILE argument is passed, the content of the specified file (which might contain @variables@) is appended to the generated <Name>Config.cmake file. If the INCLUDE_CONTENT argument is passed, the specified content (which might contain @variables@) is appended to the generated <Name>Config.cmake file. When a CONFIG_TEMPLATE is passed, or a <Name>ConfigVersion.cmake.in or a <name>-config-version.cmake.in file is available, these 2 arguments are used to replace the ``@INCLUDED_CONTENT@ string in this file. This allows one to inject custom code to this file, useful e.g. to set additional variables which are loaded by downstream projects.
Note that content specified with INCLUDE_FILE or INCLUDE_CONTENT cannot reference any of the PATH_VARS because this content is not expanded by configure_package_config_file().
If the COMPONENT argument is passed, it is forwarded to the install() commands, otherwise <Name> is used.
Add the “uninstall” target for your project:
include(AddUninstallTarget)
will create a file cmake_uninstall.cmake in the build directory and add a custom target uninstall (or UNINSTALL on Visual Studio and Xcode) that will remove the files installed by your package (using install_manifest.txt). See also https://gitlab.kitware.com/cmake/community/wikis/FAQ#can-i-do-make-uninstall-with-cmake
The AddUninstallTarget module must be included in your main CMakeLists.txt. If included in a subdirectory it does nothing. This allows you to use it safely in your main CMakeLists.txt and include your project using add_subdirectory (for example when using it with FetchContent).
If the uninstall target already exists, the module does nothing.
Add support to RPATH during installation to the project and the targets
.. code-block:: cmake
Normally (depending on the platform) when you install a shared library you can either specify its absolute path as the install name, or leave just the library name itself. In the former case the library will be correctly linked during run time by all executables and other shared libraries, but it must not change its install location. This is often the case for libraries installed in the system default library directory (e.g. /usr/lib). In the latter case, instead, the library can be moved anywhere in the file system but at run time the dynamic linker must be able to find it. This is often accomplished by setting environmental variables (i.e. LD_LIBRARY_PATH on Linux). This procedure is usually not desirable for two main reasons:
RPATH aims in solving the issues introduced by the second installation method. Using run-path dependent libraries you can create a directory structure containing executables and dependent libraries that users can relocate without breaking it. A run-path dependent library is a dependent library whose complete install name is not known when the library is created. Instead, the library specifies that the dynamic loader must resolve the library’s install name when it loads the executable that depends on the library. The executable or the other shared library will hardcode in the binary itself the additional search directories to be passed to the dynamic linker. This works great in conjunction with relative paths. This command will enable support to RPATH to your project. It will enable the following things:
The command has the following parameters:
Note: see https://gitlab.kitware.com/cmake/cmake/issues/16589 for further details.
.. code-block:: cmake
Searches for a package and builds it if it cannot be found.
Searches for a package and builds it if it cannot be found:
find_or_build_package(<PackageName> <find_package_args>)
This module tries to locate a package using find_package(). If the package cannot be found it tries to build it, by including Build<package>. This file should contain the instructions to download and build the package (for example using ExternalProject)
The arguments passed to the function, are passed to the find_package() command.
FIXME Figure out how to handle the REQUIRED and QUIET arguments
If the package was found, the USE_SYSTEM_<PackageName> cached variable can be disabled in order to force CMake to build the package instead of using the one found on the system. To automatically force CMake to build all the packages that are also found on the system, the YCM_DISABLE_SYSTEM_PACKAGES cache variable can be enabled.
This function sets these variables:
HAVE_SYSTEM_<PackageName> # The package was found on the system HAVE_<PackageName> # The package is available
The user should use the latest, to check if a package is available, instead of checking using <PackageName>_FOUND. For example
FIXME Check uppercase (${_PKG}) and lowercase (${_pkg}) variables
find_or_build_package(Foo) if(HAVE_Foo)
... endif()
Using this variable, building a package is explicitly forbidden. therefore if the package cannot be found on the system, the HAVE_<PackageName> will be set to false.
A helper for ExternalProject:
ycm_ep_helper(<name>
[DOCS]
[TYPE <type>]
[STYLE <style>]
[COMPONENT <component>] (default = "external")
[FOLDER <folder> (default = "<component>")
[REPOSITORY <repo>]
[EXCLUDE_FROM_ALL <0|1>]
#--Git and Hg only arguments-----------
[TAG <tag>]
#--Svn only arguments-----------
[REVISION <revision>]
[USERNAME <username>]
[PASSWORD <password>]
[TRUST_CERT <0|1>]
#--CMake arguments---------
[CMAKE_ARGS]
[CMAKE_CACHE_ARGS]
[CMAKE_CACHE_DEFAULT_ARGS]
[DEPENDS]
[DOWNLOAD_COMMAND]
[UPDATE_COMMAND]
[PATCH_COMMAND]
[CONFIGURE_COMMAND]
[BUILD_COMMAND]
[INSTALL_COMMAND]
[TEST_COMMAND]
[CLEAN_COMMAND] (not in ExternalProject)
[TEST_AFTER_INSTALL]
[TEST_BEFORE_INSTALL]
[TEST_EXCLUDE_FROM_MAIN]
) YCM_BOOTSTRAP()
Find the Open Asset Importer Library (assimp)
The following variables may be set to influence this module’s behavior:
This module defines the IMPORTED target assimp::assimp for the library assimp.
This module defines the following variables:
Try to find the ACE library
Targets set:
ACE::ACE (links the ACE library) ACE::ACE_INLINE (INTERFACE library for ACE inlines only)
Variables set:
ACE_FOUND - System has ACE library ACE_LIBRARIES - ACE link libraries ACE_INCLUDE_DIRS - ACE library include directories ACE_DEFINITIONS - Additional compiler flags for ACE library ACE_VERSION - ACE library version ACE_MAJOR_VERSION - ACE major version ACE_MINOR_VERSION - ACE minor version ACE_BETA_VERSION - ACE beta version
Options variables:
ACE_INLINE (default ON)
The ACE::ACE target passes __ACE_INLINE__ by default, this can be
changed by setting ACE_INLINE = OFF.
The ACE_DEFINITIONS variable is also influenced by the same option.
Find the Atlas (and Lapack) libraries
Created:
CFW2CANAPI_INC_DIRS - Directories to include to use esdcan api CFW2CANAPI_LIB - Default library to link against to use the esdcan API CFF2CANAPI_FOUND - If false, don't try to use esdcan API
Created:
DRAGONFLYAPI_INC_DIRS - Directories to include to use dragonfly API DRAGONFLYAPI_LIB - Default library to link against to use the dragonfly API DRAGONFLYAPI_FOUND - If false, don't try to use dragonfly API
Created:
ESDCANAPI_INC_DIRS - Directories to include to use esdcan api ESDCANAPI_LIB - Default library to link against to use the esdcan API ESDCANAPI_FOUND - If false, don't try to use esdcan API
Try to find the Freenect library. Once done this will define the following variables:
Freenect_FOUND - System has Freenect Freenect_INCLUDE_DIRS - Freenect include directory Freenect_LIBRARIES - Freenect libraries Freenect_DEFINITIONS - Additional compiler flags for Freenect Freenect_VERSION - Freenect version Freenect_MAJOR_VERSION - Freenect major version Freenect_MINOR_VERSION - Freenect minor version Freenect_PATCH_VERSION - Freenect patch version
Try to find ftdi. Once done this will define:
FTDI_FOUND - system has ftdi FTDI_INCLUDE_DIR - ~ the ftdi include directory FTDI_LIBRARY - Link these to use ftdi
Try to find the Fuse library. Once done this will define the following variables:
Fuse_FOUND - System has Fuse Fuse_INCLUDE_DIRS - Fuse include directory Fuse_LIBRARIES - Fuse libraries Fuse_DEFINITIONS - Additional compiler flags for Fuse Fuse_VERSION - Fuse version Fuse_MAJOR_VERSION - Fuse major version Fuse_MINOR_VERSION - Fuse minor version Fuse_PATCH_VERSION - Fuse patch version Fuse_TWEAK_VERSION - Fuse tweak version
Find the GLFW3 framework.
This module defines the IMPORTED target GLFW3::GLFW3, if GLFW3 has been found.
This module defines the following variables:
GLFW3_INCLUDE_DIRS - include directories for GLFW3 GLFW3_LIBRARIES - libraries to link against GLFW3 GLFW3_FOUND - true if GLFW3 has been found and can be used
If the library is not found on system paths, the GLFW3_ROOT environment variable can be used to locate the lbrary.
Find the OpenGL Mathematics (glm)
The following variables may be set to influence this module’s behavior:
This module defines the IMPORTED target glm for the library glm.
This module defines the following variables:
Wrap kitware’s original FindGLUT script to work on windows with binary distribution. Standardize variables.
In windows require you set GLUT_DIR
Set:
GLUT_FOUND GLUT_LIBRARIES GLUT_INCLUDE_DIRS
Check if this module is still needed with recent CMake releases.
Try to find the GooCanvas library. Once done this will define the following variables:
GooCanvas_FOUND - System has GooCanvas GooCanvas_INCLUDE_DIRS - GooCanvas include directory GooCanvas_LIBRARIES - GooCanvas libraries GooCanvas_DEFINITIONS - Additional compiler flags for GooCanvas GooCanvas_VERSION - GooCanvas version GooCanvas_MAJOR_VERSION - GooCanvas major version GooCanvas_MINOR_VERSION - GooCanvas minor version GooCanvas_PATCH_VERSION - GooCanvas patch version GooCanvas_TWEAK_VERSION - GooCanvas tweak version
If the library is found, the imported target GooCanvas::goocanvas is created.
Try to find the GooCanvasMM library. Once done this will define the following variables:
GooCanvasMM_FOUND - System has GooCanvasMM GooCanvasMM_INCLUDE_DIRS - GooCanvasMM include directory GooCanvasMM_LIBRARIES - GooCanvasMM libraries GooCanvasMM_DEFINITIONS - Additional compiler flags for GooCanvasMM GooCanvasMM_VERSION - GooCanvasMM version GooCanvasMM_MAJOR_VERSION - GooCanvasMM major version GooCanvasMM_MINOR_VERSION - GooCanvasMM minor version GooCanvasMM_PATCH_VERSION - GooCanvasMM patch version GooCanvasMM_TWEAK_VERSION - GooCanvasMM tweak version
If the library is found, the imported target GooCanvasMM::goocanvasmm is created.
Try to find GSL library Once run this will define:
GSL_FOUND GSL_INCLUDE_DIR GSL_INCLUDE_DIRS GSL_LIBRARIES GSL_LINK_DIRECTORIES GSLCBLAS_LIBRARY GSL_LIBRARY
Try to find the GtkDatabox library. Once done this will define the following variables:
GtkDatabox_FOUND - System has GtkDatabox GtkDatabox_INCLUDE_DIRS - GtkDatabox include directory GtkDatabox_LIBRARIES - GtkDatabox libraries GtkDatabox_DEFINITIONS - Additional compiler flags for GtkDatabox GtkDatabox_VERSION - GtkDatabox version GtkDatabox_MAJOR_VERSION - GtkDatabox major version GtkDatabox_MINOR_VERSION - GtkDatabox minor version GtkDatabox_PATCH_VERSION - GtkDatabox patch version GtkDatabox_TWEAK_VERSION - GtkDatabox tweak version
If the library is found, the imported target GtkDatabox::gtkdatabox is created.
Try to find the GtkDataboxMM library. Once done this will define the following variables:
GtkDataboxMM_FOUND - System has GtkDataboxMM GtkDataboxMM_INCLUDE_DIRS - GtkDataboxMM include directory GtkDataboxMM_LIBRARIES - GtkDataboxMM libraries GtkDataboxMM_DEFINITIONS - Additional compiler flags for GtkDataboxMM GtkDataboxMM_VERSION - GtkDataboxMM version GtkDataboxMM_MAJOR_VERSION - GtkDataboxMM major version GtkDataboxMM_MINOR_VERSION - GtkDataboxMM minor version GtkDataboxMM_PATCH_VERSION - GtkDataboxMM patch version GtkDataboxMM_TWEAK_VERSION - GtkDataboxMM tweak version
If the library is found, the imported target GtkDataboxMM::gtkdataboxmm is created.
Find the I2C device library.
Once done this will define the following variables:
I2C_INCLUDE_DIRS - I2C include directory I2C_LIBRARIES - I2C libraries I2C_FOUND - if false, you cannot build anything that requires I2C
Try to locate the IPOPT library
On non Windows systems, use pkg-config to try to locate the library, if this fails then try to locate the library in the directory pointed by the IPOPT_DIR environment variable.
On Windows systems, just try to find the library using the IPOPT_DIR environment variable.
Create the following variables:
IPOPT_INCLUDE_DIRS - Directories to include to use IPOPT IPOPT_LIBRARIES - Default library to link against to use IPOPT IPOPT_DEFINITIONS - Flags to be added to linker's options IPOPT_LINK_FLAGS - Flags to be added to linker's options IPOPT_FOUND - If false, don't try to use IPOPT
Try to find the IPP library.
Try to find the libdc1394 library. Once done this will define the following variables:
Libdc1394_FOUND - System has libdc1394 Libdc1394_INCLUDE_DIRS - libdc1394 include directory Libdc1394_LIBRARIES - libdc1394 libraries Libdc1394_DEFINITIONS - Additional compiler flags for libdc1394 Libdc1394_VERSION - libdc1394 version Libdc1394_MAJOR_VERSION - libdc1394 major version Libdc1394_MINOR_VERSION - libdc1394 minor version Libdc1394_PATCH_VERSION - libdc1394 patch version
Try to find NetBSD Editline library (libedit), a Berkeley-style licensed command line editor library provides generic line editing, history, and tokenization functions, similar to those found in GNU Readline. Once done this will define the following variables:
Libedit_FOUND - System has Editline library Libedit_INCLUDE_DIRS - Editline library include directory Libedit_LIBRARIES - Editline library libraries Libedit_DEFINITIONS - Additional compiler flags for Editline library Libedit_VERSION - Editline library version Libedit_MAJOR_VERSION - Editline library major version Libedit_MINOR_VERSION - Editline library minor version
Environment variables used to locate the Editline library:
READLINE_DIR - Libedit root directory
Cached variables used to locate the NetBSD Editline library:
Libedit_INCLUDE_DIR - the Libedit include directory Libedit_LIBRARY_RELEASE - NetBSD Editline library (release) Libedit_LIBRARY_DEBUG - NetBSD Editline library (debug)
Find the LibOVR library in Oculus Rift SDK.
This module defines the following IMPORTED targets if LibOVR has been found:
LibOVR::OVRKernel LibOVR::OVR
This module defines the following variables:
LibOVR_FOUND - System has LibOVR LibOVR_VERSION - LibOVR version LibOVR_VERSION_PRODUCT - LibOVR product version LibOVR_VERSION_MAJOR - LibOVR major version LibOVR_VERSION_MINOR - LibOVR minor version LibOVR_VERSION_PATCH - LibOVR patch version LibOVR_VERSION_BUILD - LibOVR build number LibOVR_VERSION_STRING - LibOVR version LibOVR_VERSION_DETAILED_STRING - LibOVR version (including build number) LibOVR_INCLUDE_DIRS - Include directories for LibOVR LibOVR_LIBRARIES - libraries to link against LibOVR
Try to find the libusb-1 library. Once done this will define the following variables:
Libusb1_FOUND - System has libusb-1 Libusb1_INCLUDE_DIRS - libusb-1 include directory Libusb1_LIBRARIES - libusb-1 libraries Libusb1_DEFINITIONS - Additional compiler flags for libusb-1 Libusb1_VERSION - libusb-1 version Libusb1_MAJOR_VERSION - libusb-1 major version Libusb1_MINOR_VERSION - libusb-1 minor version Libusb1_PATCH_VERSION - libusb-1 patch version
Try to find the libv4l2 library. Once done this will define the following variables:
Libv4l2_FOUND - System has libv4l2 Libv4l2_INCLUDE_DIRS - libv4l2 include directory Libv4l2_LIBRARIES - libv4l2 libraries Libv4l2_DEFINITIONS - Additional compiler flags for libv4l2 Libv4l2_VERSION - libv4l2 version Libv4l2_MAJOR_VERSION - libv4l2 major version Libv4l2_MINOR_VERSION - libv4l2 minor version Libv4l2_PATCH_VERSION - libv4l2 patch version Libv4l2_TWEAK_VERSION - libv4l2 tweak version
Try to find the libv4lconvert library. Once done this will define the following variables:
Libv4lconvert_FOUND - System has libv4lconvert Libv4lconvert_INCLUDE_DIRS - libv4lconvert include directory Libv4lconvert_LIBRARIES - libv4lconvert libraries Libv4lconvert_DEFINITIONS - Additional compiler flags for libv4lconvert Libv4lconvert_VERSION - libv4lconvert version Libv4lconvert_MAJOR_VERSION - libv4lconvert major version Libv4lconvert_MINOR_VERSION - libv4lconvert minor version Libv4lconvert_PATCH_VERSION - libv4lconvert patch version Libv4lconvert_TWEAK_VERSION - libv4lconvert tweak version
Try to find NVIDIACg libraries
Options:
ODE_DOUBLE_PRECISION -use double precision ode libraries ODE_STATIC -link against static libraries
On exit create the following variables:
ODE_INCLUDE_DIRS - Directories to include to use ODE ODE_LIBRARIES - Default library to link against to use ODE ODE_FOUND - If false, library not found
Find OpenCV - variables set:
OpenCV_FOUND OpenCV_LIBRARIES OpenCV_INCLUDE_DIRS
This script is a combination from multiple sources that use different variable names; the names are reconciled at the end of the script.
Check if this module is still needed with recent CMake releases.
Check if the license is correct
Wrap kitware’s original FindOpenGL. Standardize variables.
In windows require you set OpenGL_DIR
Set:
OpenGL_FOUND OpenGL_LIBRARIES OpenGL_INCLUDE_DIRS
Check if this module is still needed with recent CMake releases.
Try to find the OpenNI library. Once done this will define the following variables:
OpenNI_FOUND - System has OpenNI OpenNI_INCLUDE_DIRS - OpenNI include directory OpenNI_LIBRARIES - OpenNI libraries OpenNI_DEFINITIONS - Additional compiler flags for OpenNI OpenNI_VERSION - OpenNI version OpenNI_MAJOR_VERSION - OpenNI major version OpenNI_MINOR_VERSION - OpenNI minor version OpenNI_PATCH_VERSION - OpenNI patch version
Created:
PLXCANAPI_INC_DIRS - Directories to include to use esdcan api PLXCANAPI_LIB - Default library to link against to use the esdcan API PLXCANAPI_FOUND - If false, don't try to use esdcan API
Try to find the PortAudio library.
Try to find the qpOASES library. Once done this will define the following variables:
qpOASES_FOUND - System has qpOASES qpOASES_INCLUDE_DIRS - qpOASES include directory qpOASES_LIBRARIES - qpOASES libraries
qpOASES does not have an “install” step, and the includes are in the source tree, while the libraries are in the build tree. Therefore the environment and cmake variables qpOASES_SOURCE_DIR and qpOASES_BINARY_DIR will be used to locate the includes and libraries.
Try to find GNU Readline, a library for easy editing of command lines. Once done this will define the following variables:
Readline_FOUND - System has GNU Readline Readline_INCLUDE_DIRS - GNU Readline include directory Readline_LIBRARIES - GNU Readline libraries Readline_DEFINITIONS - Additional compiler flags for GNU Readline Readline_VERSION - GNU Readline version Readline_MAJOR_VERSION - GNU Readline major version Readline_MINOR_VERSION - GNU Readline minor version
Environment variables used to locate the GNU Readline library:
READLINE_DIR - Readline root directory
Cached variables used to locate the GNU Readline library:
Readline_INCLUDE_DIR - the Readline include directory Readline_LIBRARY_RELEASE - GNU Readline library (release) Readline_LIBRARY_DEBUG - GNU Readline library (debug)
Try to find the SQLite library. Once done this will define the following variables:
SQLite_FOUND - System has SQLite SQLite_INCLUDE_DIRS - SQLite include directory SQLite_LIBRARIES - SQLite libraries SQLite_DEFINITIONS - Additional compiler flags for SQLite SQLite_VERSION - SQLite version SQLite_MAJOR_VERSION - SQLite major version SQLite_MINOR_VERSION - SQLite minor version SQLite_PATCH_VERSION - SQLite patch version SQLite_TWEAK_VERSION - SQLite tweak version
Try to find Stage, a library for easy editing of command lines. Once done this will define the following variables:
Stage_FOUND - System has Stage Stage_INCLUDE_DIRS - Stage include directory Stage_LIBRARIES - Stage libraries Stage_DEFINITIONS - Additional compiler flags for Stage Stage_VERSION - Stage version Stage_MAJOR_VERSION - Stage major version Stage_MINOR_VERSION - Stage minor version
Environment variables used to locate the Stage library: Stage_DIR - Stage root directory
Cached variables used to locate the Stage library: Stage_INCLUDE_DIR - the Stage include directory Stage_LIBRARY_RELEASE - Stage library (release) Stage_LIBRARY_DEBUG - Stage library (debug)
Try to find the TinyXML library. Once done this will define the following variables:
TinyXML_FOUND - System has TinyXML TinyXML_INCLUDE_DIRS - TinyXML include directory TinyXML_LIBRARIES - TinyXML libraries TinyXML_DEFINITIONS - Additional compiler flags for TinyXML TinyXML_VERSION - TinyXML version TinyXML_MAJOR_VERSION - TinyXML major version TinyXML_MINOR_VERSION - TinyXML minor version TinyXML_PATCH_VERSION - TinyXML patch version
Try to find the YamlCpp library. Once done this will define the following variables:
YamlCpp_FOUND - System has YamlCpp YamlCpp_INCLUDE_DIRS - YamlCpp include directory YamlCpp_LIBRARIES - YamlCpp libraries YamlCpp_DEFINITIONS - Additional compiler flags for YamlCpp YamlCpp_VERSION - YamlCpp version YamlCpp_MAJOR_VERSION - YamlCpp major version YamlCpp_MINOR_VERSION - YamlCpp minor version YamlCpp_PATCH_VERSION - YamlCpp patch version YamlCpp_TWEAK_VERSION - YamlCpp tweak version
ECM - extra-cmake-modules (from KDE project)
Eigen3
GazeboYARPPlugins
GooCanvas
GooCanvasMM
GtkDatabox
GtkDataboxMM
ICUB
qpOASES
TinyXML
YARP
These modules are patched versions of the ones included in CMake.
ExternalProject_Add(<name> [<option>...])
The individual steps within the process can be driven independently if required (e.g. for CDash submission) and extra custom steps can be defined, along with the ability to control the step dependencies. The directory structure used for the management of the external project can also be customized. The function supports a large number of options which can be used to tailor the external project behavior.
NOTE:
If any of the above ..._DIR options are not specified, their defaults are computed as follows. If the PREFIX option is given or the EP_PREFIX directory property is set, then an external project is built and installed under the specified prefix:
TMP_DIR = <prefix>/tmp STAMP_DIR = <prefix>/src/<name>-stamp DOWNLOAD_DIR = <prefix>/src SOURCE_DIR = <prefix>/src/<name> BINARY_DIR = <prefix>/src/<name>-build INSTALL_DIR = <prefix> LOG_DIR = <STAMP_DIR>
Otherwise, if the EP_BASE directory property is set then components of an external project are stored under the specified base:
TMP_DIR = <base>/tmp/<name> STAMP_DIR = <base>/Stamp/<name> DOWNLOAD_DIR = <base>/Download/<name> SOURCE_DIR = <base>/Source/<name> BINARY_DIR = <base>/Build/<name> INSTALL_DIR = <base>/Install/<name> LOG_DIR = <STAMP_DIR>
If no PREFIX, EP_PREFIX, or EP_BASE is specified, then the default is to set PREFIX to <name>-prefix. Relative paths are interpreted with respect to CMAKE_CURRENT_BINARY_DIR at the point where ExternalProject_Add() is called.
If GIT_SHALLOW is enabled then GIT_TAG works only with branch names and tags. A commit hash is not allowed.
When this option is present, it is generally advisable to make the value a cache variable under the developer’s control rather than hard-coding it. If this option is not present, the default value is taken from the EP_UPDATE_DISCONNECTED directory property. If that is also not defined, updates are performed as normal. The EP_UPDATE_DISCONNECTED directory property is intended as a convenience for controlling the UPDATE_DISCONNECTED behavior for an entire section of a project’s directory hierarchy and may be a more convenient method of giving developers control over whether or not to perform updates (assuming the project also provides a cache variable or some other convenient method for setting the directory property).
ExternalProject_Add(example
... # Download options, etc.
BUILD_COMMAND ${CMAKE_COMMAND} -E echo "Starting $<CONFIG> build"
COMMAND ${CMAKE_COMMAND} --build <BINARY_DIR> --config $<CONFIG>
COMMAND ${CMAKE_COMMAND} -E echo "$<CONFIG> build complete" )
It should also be noted that each build step is created via a call to ExternalProject_Add_Step(). See that command’s documentation for the automatic substitutions that are supported for some options.
ExternalProject_Get_Property(<name> <prop1> [<prop2>...])
The function stores property values in variables of the same name. Property names correspond to the keyword argument names of ExternalProject_Add(). For example, the source directory might be retrieved like so:
ExternalProject_Get_property(myExtProj SOURCE_DIR) message("Source dir of myExtProj = ${SOURCE_DIR}")
The ExternalProject_Add() function on its own is often sufficient for incorporating an external project into the main build. Certain scenarios require additional work to implement desired behavior, such as adding in a custom step or making steps available as manually triggerable targets. The ExternalProject_Add_Step(), ExternalProject_Add_StepTargets() and ExternalProject_Add_StepDependencies functions provide the lower level control needed to implement such step-level capabilities.
ExternalProject_Add_Step(<name> <step> [<option>...])
<name> is the same as the name passed to the original call to ExternalProject_Add(). The specified <step> must not be one of the pre-defined steps (mkdir, download, update, skip-update, patch, configure, build, install or test). The supported options are:
The command line, comment, working directory and byproducts of every standard and custom step are processed to replace the tokens <SOURCE_DIR>, <SOURCE_SUBDIR>, <BINARY_DIR>, <INSTALL_DIR> <TMP_DIR>, <DOWNLOAD_DIR> and <DOWNLOADED_FILE> with their corresponding property values defined in the original call to ExternalProject_Add().
ExternalProject_Add_StepTargets(<name> [NO_DEPENDS] <step1> [<step2>...])
Creating a target for a step allows it to be used as a dependency of another target or to be triggered manually. Having targets for specific steps also allows them to be driven independently of each other by specifying targets on build command lines. For example, you may be submitting to a sub-project based dashboard where you want to drive the configure portion of the build, then submit to the dashboard, followed by the build portion, followed by tests. If you invoke a custom target that depends on a step halfway through the step dependency chain, then all the previous steps will also run to ensure everything is up to date.
If the NO_DEPENDS option is specified, the step target will not depend on the dependencies of the external project (i.e. on any dependencies of the <name> custom target created by ExternalProject_Add()). This is usually safe for the download, update and patch steps, since they do not typically require that the dependencies are updated and built. Using NO_DEPENDS for any of the other pre-defined steps, however, may break parallel builds. Only use NO_DEPENDS where it is certain that the named steps genuinely do not have dependencies. For custom steps, consider whether or not the custom commands require the dependencies to be configured, built and installed.
Internally, ExternalProject_Add() calls ExternalProject_Add_Step() to create each step. If any STEP_TARGETS or INDEPENDENT_STEP_TARGETS were specified, then ExternalProject_Add_StepTargets() will also be called after ExternalProject_Add_Step(). INDEPENDENT_STEP_TARGETS have the NO_DEPENDS option set, whereas STEP_TARGETS do not. Other than that, the two options result in ExternalProject_Add_StepTargets() being called in the same way. Even if a step is not mentioned in either of those two options, ExternalProject_Add_StepTargets() can still be called later to manually define a target for the step.
The STEP_TARGETS and INDEPENDENT_STEP_TARGETS options for ExternalProject_Add() are generally the easiest way to ensure targets are created for specific steps of interest. For custom steps, ExternalProject_Add_StepTargets() must be called explicitly if a target should also be created for that custom step. An alternative to these two options is to populate the EP_STEP_TARGETS and EP_INDEPENDENT_STEP_TARGETS directory properties. These act as defaults for the step target options and can save having to repeatedly specify the same set of step targets when multiple external projects are being defined.
ExternalProject_Add_StepDependencies(<name> <step> <target1> [<target2>...])
This function takes care to set both target and file level dependencies and will ensure that parallel builds will not break. It should be used instead of add_dependencies() whenever adding a dependency for some of the step targets generated by the ExternalProject module.
The following example shows how to download and build a hypothetical project called FooBar from github:
include(ExternalProject) ExternalProject_Add(foobar
GIT_REPOSITORY git@github.com:FooCo/FooBar.git
GIT_TAG origin/release/1.2.3 )
For the sake of the example, also define a second hypothetical external project called SecretSauce, which is downloaded from a web server. Two URLs are given to take advantage of a faster internal network if available, with a fallback to a slower external server. The project is a typical Makefile project with no configure step, so some of the default commands are overridden. The build is only required to build the sauce target:
find_program(MAKE_EXE NAMES gmake nmake make) ExternalProject_Add(secretsauce
URL http://intranet.somecompany.com/artifacts/sauce-2.7.tgz
https://www.somecompany.com/downloads/sauce-2.7.zip
URL_HASH MD5=d41d8cd98f00b204e9800998ecf8427e
CONFIGURE_COMMAND ""
BUILD_COMMAND ${MAKE_EXE} sauce )
Suppose the build step of secretsauce requires that foobar must already be built. This could be enforced like so:
ExternalProject_Add_StepDependencies(secretsauce build foobar)
Another alternative would be to create a custom target for foobar’s build step and make secretsauce depend on that rather than the whole foobar project. This would mean foobar only needs to be built, it doesn’t need to run its install or test steps before secretsauce can be built. The dependency can also be defined along with the secretsauce project:
ExternalProject_Add_StepTargets(foobar build) ExternalProject_Add(secretsauce
URL http://intranet.somecompany.com/artifacts/sauce-2.7.tgz
https://www.somecompany.com/downloads/sauce-2.7.zip
URL_HASH MD5=d41d8cd98f00b204e9800998ecf8427e
CONFIGURE_COMMAND ""
BUILD_COMMAND ${MAKE_EXE} sauce
DEPENDS foobar-build )
Instead of calling ExternalProject_Add_StepTargets(), the target could be defined along with the foobar project itself:
ExternalProject_Add(foobar
GIT_REPOSITORY git@github.com:FooCo/FooBar.git
GIT_TAG origin/release/1.2.3
STEP_TARGETS build )
If many external projects should have the same set of step targets, setting a directory property may be more convenient. The build step target could be created automatically by setting the EP_STEP_TARGETS directory property before creating the external projects with ExternalProject_Add():
set_property(DIRECTORY PROPERTY EP_STEP_TARGETS build)
Lastly, suppose that secretsauce provides a script called makedoc which can be used to generate its own documentation. Further suppose that the script expects the output directory to be provided as the only parameter and that it should be run from the secretsauce source directory. A custom step and a custom target to trigger the script can be defined like so:
ExternalProject_Add_Step(secretsauce docs
COMMAND <SOURCE_DIR>/makedoc <BINARY_DIR>
WORKING_DIRECTORY <SOURCE_DIR>
COMMENT "Building secretsauce docs"
ALWAYS TRUE
EXCLUDE_FROM_MAIN TRUE ) ExternalProject_Add_StepTargets(secretsauce docs)
The custom step could then be triggered from the main build like so:
cmake --build . --target secretsauce-docs
Parse arguments given to a macro or a function.
cmake_parse_arguments() is intended to be used in macros or functions for parsing the arguments given to that macro or function. It processes the arguments and defines a set of variables which hold the values of the respective options.
cmake_parse_arguments(<prefix>
<options>
<one_value_keywords>
<multi_value_keywords>
[CMAKE_PARSE_ARGUMENTS_SKIP_EMPTY|CMAKE_PARSE_ARGUMENTS_KEEP_EMPTY]
args...
)
The <options> argument contains all options for the respective macro, i.e. keywords which can be used when calling the macro without any value following, like e.g. the OPTIONAL keyword of the install() command.
The <one_value_keywords> argument contains all keywords for this macro which are followed by one value, like e.g. DESTINATION keyword of the install() command.
The <multi_value_keywords> argument contains all keywords for this macro which can be followed by more than one value, like e.g. the TARGETS or FILES keywords of the install() command.
When done, cmake_parse_arguments() will have defined for each of the keywords listed in <options>, <one_value_keywords> and <multi_value_keywords> a variable composed of the given <prefix> followed by “_” and the name of the respective keyword. These variables will then hold the respective value from the argument list. For the <options> keywords this will be TRUE or FALSE.
All remaining arguments are collected in a variable <prefix>_UNPARSED_ARGUMENTS, this can be checked afterwards to see whether your macro was called with unrecognized parameters.
The cmake CMAKE_PARSE_ARGUMENTS_SKIP_EMPTY (old behaviour) and CMAKE_PARSE_ARGUMENTS_KEEP_EMPTY options decide how empty arguments should be handled. If none of these options is set, for backwards compatibility, if CMAKE_MINIMUM_REQUIRED_VERSION < 3.0.0, the default behaviour is to skip empty arguments, otherwise the default behaviour is to keep them. Using the CMAKE_PARSE_ARGUMENTS_DEFAULT_SKIP_EMPTY variable the user can explicitly set the default behaviour in current scope.
As an example here a my_install() macro, which takes similar arguments as the real install() command:
function(MY_INSTALL)
set(options OPTIONAL FAST)
set(oneValueArgs DESTINATION RENAME)
set(multiValueArgs TARGETS CONFIGURATIONS)
cmake_parse_arguments(MY_INSTALL "${options}" "${oneValueArgs}" "${multiValueArgs}" "${ARGN}" )
...
Assume my_install() has been called like this:
my_install(TARGETS foo bar DESTINATION bin OPTIONAL blub)
After the cmake_parse_arguments() call the macro will have set the following variables:
MY_INSTALL_OPTIONAL = TRUE MY_INSTALL_FAST = FALSE (this option was not used when calling my_install() MY_INSTALL_DESTINATION = "bin" MY_INSTALL_RENAME = "" (was not used) MY_INSTALL_TARGETS = "foo;bar" MY_INSTALL_CONFIGURATIONS = "" (was not used) MY_INSTALL_UNPARSED_ARGUMENTS = "blub" (no value expected after "OPTIONAL"
You can then continue and process these variables.
Keywords terminate lists of values, e.g. if directly after a one_value_keyword another recognized keyword follows, this is interpreted as the beginning of the new option. E.g. my_install(TARGETS foo DESTINATION OPTIONAL) would result in MY_INSTALL_DESTINATION set to “OPTIONAL”, but MY_INSTALL_DESTINATION would be empty and MY_INSTALL_OPTIONAL would be set to TRUE therefore.
If the “CMAKE_PARSE_ARGUMENTS_SKIP_EMPTY” option is set, cmake_parse_argumentswill not consider empty arguments. Therefore
my_install(DESTINATION "" TARGETS foo "" bar)
Will set
MY_INSTALL_DESTINATION = (unset) MY_INSTALL_MULTI = "foo;bar"
Using the “CMAKE_PARSE_ARGUMENTS_SKIP_EMPTY” option instead, will set
MY_INSTALL_SINGLE = "" MY_INSTALL_MULTI = "foo;;bar"
It is also important to note that:
cmake_parse_arguments(MY_INSTALL "${options}" "${oneValueArgs}" "${multiValueArgs}" "${ARGN}" ) cmake_parse_arguments(MY_INSTALL "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN} )
Will behave differently, because in the latter case empty arguments are not passed to cmake_parse_arguments.
WARNING:
Copyright 2013-2019 Istituto Italiano di Tecnologia (IIT)
January 15, 2021 | 0.12. |