cmake 如何定义一个变量,一个变量怎样才叫被定义
时间: 2023-07-13 09:06:29 浏览: 42
在 CMake 中定义一个变量可以使用 `set` 命令,例如:
```
set(MY_VARIABLE "Hello, World!")
```
上述命令会定义一个名为 `MY_VARIABLE` 的变量,其值为字符串 "Hello, World!"。
当一个变量被定义后,就可以在 CMake 脚本中使用该变量。例如:
```
message("My variable is: ${MY_VARIABLE}")
```
上述命令会输出 "My variable is: Hello, World!"。
在 CMake 中,一个变量被认为是被定义的,当且仅当该变量被设置了一个非空的值。例如:
```
set(MY_VARIABLE "")
```
上述命令定义了一个名为 `MY_VARIABLE` 的变量,但其值为空字符串,因此该变量仍然被认为是被定义的。如果将其设置为未定义的值,例如:
```
unset(MY_VARIABLE)
```
则该变量将被认为是未定义的。
相关问题
使用cmake写一个可以被其他cmake文件find_package的包
要编写一个可以被其他CMake文件find_package的包,需要执行以下步骤:
1. 创建一个包含代码的库或二进制文件,并将其安装到系统上。
2. 创建一个CMake配置文件,该文件定义了包的版本号、库/二进制文件路径等信息,并将其安装到系统上。
3. 创建一个CMake模块文件,该文件包含一个find_package函数,用于查找并加载CMake配置文件。
下面是更详细的步骤:
1. 创建库或二进制文件
在CMakeLists.txt中定义库或二进制文件,例如:
```
add_library(mylib SHARED mylib.cpp) # 创建一个共享库
install(TARGETS mylib LIBRARY DESTINATION lib) # 安装该库到系统上
```
2. 创建CMake配置文件
创建一个名为`mylib-config.cmake.in`的文件,该文件包含了包的版本号、库文件路径等信息。注意,该文件中需要使用`@VAR@`的形式来引用变量,CMake将在安装时将这些变量替换为实际值。例如:
```
@PACKAGE_INIT@
set(MYLIB_VERSION_MAJOR 1)
set(MYLIB_VERSION_MINOR 0)
set(MYLIB_VERSION_PATCH 0)
set(MYLIB_VERSION "${MYLIB_VERSION_MAJOR}.${MYLIB_VERSION_MINOR}.${MYLIB_VERSION_PATCH}")
set(MYLIB_INCLUDE_DIRS "${CMAKE_INSTALL_PREFIX}/include")
set(MYLIB_LIBRARIES "${CMAKE_INSTALL_PREFIX}/lib/libmylib.so")
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/mylib-config.cmake.in
${CMAKE_CURRENT_BINARY_DIR}/mylib-config.cmake @ONLY)
install(FILES ${CMAKE_CURRENT_BINARY_DIR}/mylib-config.cmake
DESTINATION lib/cmake/mylib)
```
该文件中使用了`@PACKAGE_INIT@`宏来加载CMake的基本配置信息。
3. 创建CMake模块文件
创建一个名为`FindMylib.cmake`的文件,该文件包含了一个find_package函数,用于查找并加载CMake配置文件。例如:
```
find_package(PkgConfig)
pkg_check_modules(PC_MYLIB QUIET mylib)
find_path(MYLIB_INCLUDE_DIR mylib.h
HINTS ${PC_MYLIB_INCLUDE_DIRS} ${CMAKE_INSTALL_PREFIX}/include)
find_library(MYLIB_LIBRARY NAMES mylib
HINTS ${PC_MYLIB_LIBDIR} ${CMAKE_INSTALL_PREFIX}/lib)
include(FindPackageHandleStandardArgs)
find_package_handle_standard_args(Mylib
REQUIRED_VARS MYLIB_INCLUDE_DIR MYLIB_LIBRARY
VERSION_VAR MYLIB_VERSION)
if(Mylib_FOUND)
set(MYLIB_LIBRARIES ${MYLIB_LIBRARY})
set(MYLIB_INCLUDE_DIRS ${MYLIB_INCLUDE_DIR})
endif()
mark_as_advanced(MYLIB_INCLUDE_DIR MYLIB_LIBRARY)
```
该文件中使用了`find_package_handle_standard_args`函数来检查包是否已找到,并将结果保存在`Mylib_FOUND`变量中。此外,还定义了`MYLIB_INCLUDE_DIRS`和`MYLIB_LIBRARIES`变量,用于在其他CMake文件中引用。
4. 安装包
在CMakeLists.txt中添加以下内容,用于安装CMake配置文件和模块文件:
```
install(FILES ${CMAKE_CURRENT_BINARY_DIR}/mylib-config.cmake
DESTINATION lib/cmake/mylib)
install(FILES FindMylib.cmake
DESTINATION lib/cmake/mylib)
```
5. 使用包
在其他CMake文件中,可以使用`find_package`函数来查找并加载该包,例如:
```
find_package(Mylib REQUIRED)
include_directories(${MYLIB_INCLUDE_DIRS})
target_link_libraries(myapp ${MYLIB_LIBRARIES})
```
注意,上述代码中的`Mylib`是指在FindMylib.cmake中定义的包名,而不是库/二进制文件的名称。
如何将宏变量通过cmake传入到源文件举个例子
可以通过使用CMake中的`add_compile_definitions`或`add_definitions`指令来定义宏变量并传递给源文件。例如,假设我们要定义一个名为`MY_DEFINITION`的宏变量并将其传递给`main.cpp`源文件,可以在CMakeLists.txt中添加以下代码:
```
cmake_minimum_required(VERSION 3.0)
project(MyProject)
# 定义宏变量
add_compile_definitions(MY_DEFINITION)
# 添加可执行文件并链接源文件
add_executable(MyExecutable main.cpp)
```
这样,在编译`MyExecutable`时,CMake会自动将`MY_DEFINITION`宏变量传递给`main.cpp`源文件。在`main.cpp`中,可以使用`#ifdef`或`#ifndef`宏指令来检查宏变量是否已定义。例如:
```
#include <iostream>
#ifdef MY_DEFINITION
#define MESSAGE "Hello World!"
#else
#define MESSAGE "Goodbye World!"
#endif
int main()
{
std::cout << MESSAGE << std::endl;
return 0;
}
```
如果`MY_DEFINITION`宏变量已定义,程序将输出`Hello World!`,否则将输出`Goodbye World!`。