目录
生成对象库OBJECT实例(wds/libwds/common/CMakeLists.txt)
生成库so(wds/libwds/CMakeLists.txt)
生成二进制可执行程序(wds/desktop_source/CMakeLists.txt)
cmake的所有语句都写在一个CMakeLists.txt的文件中,CMakeLists.txt文件确定后,直接使用cmake命令进行运行,但是这个命令要指向CMakeLists.txt所在的目录,cmake之后就会产生我们想要的makefile文件,然后再直接make就可以编译出我们需要的结果了。
更简单的解释就是cmake是为了生成makefile而存在,这样我们就不需要再去写makefile了,只需要写简单的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)
- # 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)
- # 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()