目录
CMakeLists.txt用例详解(WDS中的用例)
CMakeLists.txt作用
生成对象库OBJECT实例(wds/libwds/common/CMakeLists.txt)
生成库so(wds/libwds/CMakeLists.txt)
生成二进制可执行程序(wds/desktop_source/CMakeLists.txt)
CMake相关参考
CMakeLists.txt用例详解(WDS中的用例)
CMakeLists.txt作用
cmake的所有语句都写在一个CMakeLists.txt的文件中,CMakeLists.txt文件确定后,直接使用cmake命令进行运行,但是这个命令要指向CMakeLists.txt所在的目录,cmake之后就会产生我们想要的makefile文件,然后再直接make就可以编译出我们需要的结果了。
更简单的解释就是cmake是为了生成makefile而存在,这样我们就不需要再去写makefile了,只需要写简单的CMakeLists.txt即可
生成对象库OBJECT实例(wds/libwds/common/CMakeLists.txt)
# c++编译器设置编译选项,例如-std=c++11选项,在编译c++代码时加上c++11支持选项
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11 -Wall -fvisibility=hidden -fPIC")
# c编译器设置编译选项
set(CMAKE_C_FLAGS "${CMAKE_CXX_FLAGS} -std=c99 -Wall")
# 将指定目录添加到编译器的头文件搜索路径之下,指定的目录被解释成当前源码路径的相对路径
# PROJECT_SOURCE_DIR为包含PROJECT()的最近一个CMakeLists.txt文件所在的文件夹
include_directories ("${PROJECT_SOURCE_DIR}" "${PROJECT_SOURCE_DIR}/libwds/rtsp/gen")
# add_library(<name> OBJECT [<source>...])
# 这种形式类型固定为OBJECT,以这种方式,只编译source列表的文件,但不将生成的目标文件打包或者链接为
# 库,而是在其他add_library()或者add_executable()生成目标的时候,可以使用形如
# $<TARGET_OBJECTS:name>的表达式将对象库作为源引入
# 见实例2引用
add_library(wdscommon OBJECT logging.cpp message_handler.cpp rtsp_input_handler.cpp video_format.cpp)
# 添加这条语句就是提醒编译器需要先生成wdscommon的依赖wdsrtsp,然后再去生成wdscommon
add_dependencies(wdscommon wdsrtsp)
生成库so(wds/libwds/CMakeLists.txt)
# c++编译器设置编译选项,例如-std=c++11选项,在编译c++代码时加上c++11支持选项
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11 -Wall -fvisibility=hidden")
# c编译器设置编译选项
set(CMAKE_C_FLAGS "${CMAKE_CXX_FLAGS} -std=c99 -Wall")
# 用来使用指定的源文件向工程中添加一个目标库(即生成库文件)
# STATIC为静态库.a, SHARED为动态库.so
# $<TARGET_OBJECTS:wdsrtsp>见实例1中add_library(<name> OBJECT [<source>...])用法
add_library(wds SHARED $<TARGET_OBJECTS:wdsrtsp>
$<TARGET_OBJECTS:wdscommon>
$<TARGET_OBJECTS:wdssink>
$<TARGET_OBJECTS:wdssource>)
# 按照规则,动态库是应该包含一个版本号的,
# VERSION指代动态库版本,SOVERSION指代API版本。
set_target_properties(wds PROPERTIES
VERSION ${WDS_VERSION_MAJOR}.${WDS_VERSION_MINOR}.${WDS_VERSION_PATCH}
SOVERSION ${WDS_VERSION_MAJOR})
# 参数中的TARGETS后面跟的就是我们通过ADD_EXECUTABLE 或者 ADD_LIBRARY 定义的目标文件,
# 可能是可执行二进制、动态库、静态库
# LIBRARY(动态库类型)为目标类型,ARCHIVE(静态库类型),RUNTIME(可执行二进制类型)
# DESTINATION 定义了安装的路径,后边一般跟着安装路径,绝对路径要以/开头,否则为相对路径
install(TARGETS wds LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR})
set(PUBLIC_HEADERS
public/connector_type.h
public/peer.h
public/video_format.h
public/sink.h
public/wds_export.h
public/audio_codec.h
public/media_manager.h
public/source.h
public/logging.h)
# 安装set指定PUBLIC_HEADERS文件到${CMAKE_INSTALL_FULL_INCLUDEDIR}/wds目录下
# CMAKE_INSTALL_FULL_INCLUDEDIR为编译输出include目录的绝对路径
install(FILES ${PUBLIC_HEADERS} DESTINATION ${CMAKE_INSTALL_FULL_INCLUDEDIR}/wds)
生成二进制可执行程序(wds/desktop_source/CMakeLists.txt)
# c++编译器设置编译选项,例如-std=c++11选项,在编译c++代码时加上c++11支持选项
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -pthread -std=c++11")
# 将指定目录添加到编译器的头文件搜索路径之下,指定的目录被解释成当前源码路径的相对路径
# PROJECT_SOURCE_DIR为包含PROJECT()的最近一个CMakeLists.txt文件所在的文件夹
include_directories ("${PROJECT_SOURCE_DIR}")
include_directories ("${PROJECT_SOURCE_DIR}/libwds/public")
include_directories ("${PROJECT_SOURCE_DIR}/libwds/parser")
include_directories ("${PROJECT_SOURCE_DIR}/p2p")
include_directories ("${PROJECT_SOURCE_DIR}/mirac_network")
# find_package用于查找包(通常是使用三方库),
# 并返回关于包的细节(使用包所依赖的头文件、库文件、编译选项、链接选项等).
# 如果某个依赖项既不提供查找模块,也不提供供应商打包的CMake文件,
# 依赖 pkg-config 程序,来找到系统上的包
find_package(PkgConfig REQUIRED)
# 当找到 pkg-config 时, CMake需要提供两个函数,来封装这个程序提供的功能
# pkg_check_modules,查找传递列表中的所有模块(库和/或程序)
# pkg_search_module 要在传递的列表中找到第一个工作模块 与 find_package 一样,这些函数接受
# REQUIRED 和 QUIET 参数
pkg_check_modules (GLIB2 REQUIRED glib-2.0)
include_directories(${GLIB2_INCLUDE_DIRS})
pkg_check_modules (GIO REQUIRED gio-2.0)
include_directories(${GIO_INCLUDE_DIRS})
pkg_check_modules (GST REQUIRED gstreamer-1.0)
include_directories(${GST_INCLUDE_DIRS})
# 使用指定的源文件来生成目标可执行文件
add_executable(desktop-source-test main.cpp source-app.cpp mirac_broker_source.cpp desktop_media_manager.cpp)
# 为desktop-source-test连接 库的头文件路径(被link库生成CMakeLists.txt中定义的头文件路径)
# 和对应定义的函数库路径
target_link_libraries (desktop-source-test mirac wds p2p ${GIO_LIBRARIES} ${GST_LIBRARIES})
# 安装可执行文件到指定生成目录
if (WDS_INSTALL_TESTS)
install(PROGRAMS desktop-source-test DESTINATION ${CMAKE_INSTALL_FULL_BINDIR})
endif()
CMake相关参考
Cmake 常用变量和常用环境变量
Cmake命令之cmake_minimum_required介绍
Cmake命令之set
Cmake命令之find_library
Cmake命令之find_package
Cmake命令之include_directories
Cmake命令之pkg_check_modules
Cmake命令之add_executable
Cmake命令之target_link_libraries
Cmake命令之add_subdirectory
Cmake命令之list
Cmake命令之project
Cmake命令之configure_file
Cmake命令之set_target_properties
Cmake命令之install
|