Cmake中包含库和目录包含的共享对象

时间:2013-05-04 04:31:35

标签: c++ makefile cmake shared-objects mpic++

我是Cmake的新手,我正在尝试将其用作此approach的替代方法,但效果不佳。

我的结构很简单,我有:

App/src/
App/src/so1
App/src/so2
App/src/so3

在每个App/src/soN文件夹中,我有一个.cpp文件,该文件应编译成共享对象。 我知道我必须在上面列出的每个文件夹中添加一个CMakeLists.txt文件,但我真的迷失了图书馆链接和包含。

例如,假设App/src/so1下有以下文件:

App/src/so1/so1.hpp
App/src/so1/so1.cpp

共享对象so1.so需要-I /some/dir/include,还需要链接到-L /some/other/dir/lib -l otherdirlib。使用CMake进行此操作的适当指令是什么?

1 个答案:

答案 0 :(得分:2)

修改

使用文件和GLOB_RECURSE:

  

GLOB_RECURSE将生成类似于常规GLOB的列表,除外   它将遍历匹配目录的所有子目录   匹配文件。

我建议你重新安装你的文件:

app/
 |_ src/
 |_ include/
 |_ CMakeLists.txt
so1/
 |_ src/
 |_ include/
 |_ CMakeLists.txt
so2/
 |_ src/
 |_ include/
 |_ CMakeLists.txt
so3/
 |_ src/
 |_ include/
 |_ CMakeLists.txt
CMakeLists.txt

app文件夹中的CMakeLists.txt:

SET (APP_NAME app)

# Print variables to stdout
MESSAGE ( STATUS )
MESSAGE ( STATUS "Configuring ${APP_NAME}:" )
MESSAGE ( STATUS )

# Source code files
FILE (GLOB_RECURSE SOURCE_FILES src/*.cpp include/*.h include/*.inl)

# Compiler options
IF (CMAKE_COMPILER_IS_GNUCXX)
  ADD_DEFINITIONS (-ansi -Wall -Wextra -Werror -pthread)
ENDIF ()

# Build application
ADD_EXECUTABLE (${APP_NAME} ${SOURCE_FILES})

TARGET_LINK_LIBRARIES (${APP_NAME}
  ${SO1_LIB}
  ${SO2_LIB}
  ${SO3_LIB}
)

INSTALL (TARGETS ${APP_NAME} RUNTIME DESTINATION bin PERMISSIONS OWNER_READ OWNER_WRITE  OWNER_EXECUTE GROUP_READ GROUP_WRITE  GROUP_EXECUTE WORLD_READ WORLD_EXECUTE)

每个lib文件夹中的CMakeLists.txt都是这样的(相应地更改每个文件中的LIB_OUTPUT_NAME):

SET (LIB_OUTPUT_NAME so1)

# Print variables to stdout
MESSAGE ( STATUS )
MESSAGE ( STATUS "Configuring ${LIB_OUTPUT_NAME}:" )
MESSAGE ( STATUS )

# Source code, headers and test files
FILE (GLOB_RECURSE HEADER_FILES include/*.h include/*.inl)
FILE (GLOB_RECURSE SOURCE_FILES src/*.cpp include/*.h include/*.inl)
FILE (GLOB_RECURSE TEST_SRC_FILES tests/*.cpp tests/*.h tests/*.inl)

# Compiler options
IF (CMAKE_COMPILER_IS_GNUCXX)
  ADD_DEFINITIONS (-ansi -Wall -Wextra -Werror -pthread)
ENDIF ()

# Build library
ADD_LIBRARY (${LIB_OUTPUT_NAME} SHARED ${SOURCE_FILES})

然后在主CMakeLists.txt中:

CMAKE_MINIMUM_REQUIRED (VERSION 2.6)
PROJECT (App CXX)

# Set common variables
IF ("${CMAKE_BUILD_TYPE}" STREQUAL "Release")
  SET (BUILD_DIR build/release)
ELSE ()
  SET (BUILD_DIR build/debug)
ENDIF ()

# Print variables to stdout
MESSAGE ( STATUS )
MESSAGE ( STATUS "Building App:" )
MESSAGE ( STATUS "change a configuration variable with: cmake -D<Variable>=<Value>" )
MESSAGE ( STATUS "CMAKE_INSTALL_PREFIX = ${CMAKE_INSTALL_PREFIX}" )
MESSAGE ( STATUS "CMAKE_BUILD_TYPE = ${CMAKE_BUILD_TYPE}" )
MESSAGE ( STATUS "CMAKE_PREFIX_PATH = ${CMAKE_PREFIX_PATH}" )
MESSAGE ( STATUS )

# Remove build directory on clean target
SET_DIRECTORY_PROPERTIES (PROPERTIES ADDITIONAL_MAKE_CLEAN_FILES ${BUILD_DIR})

# Include directories
INCLUDE_DIRECTORIES (
  "app/include"
  "so1/include"
  "so2/include"
  "so3/include"
)

# Add common compiler flags
IF (CMAKE_COMPILER_IS_GNUCXX)
  SET(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CPP_FLAGS_RELEASE} -O2")
  SET(CMAKE_CXX_FLAGS_DEBUG  "${CMAKE_CXX_FLAGS_DEBUG} -O0 -g)
ENDIF ()

# Build all dynamic Libraries
ADD_SUBDIRECTORY (smartmatic ${BUILD_DIR}/so1)
SET (SO1_LIB ${CMAKE_CURRENT_SOURCE_DIR}/${BUILD_DIR}/so1/so1.so)

ADD_SUBDIRECTORY (saes-runtime ${BUILD_DIR}/so2)
SET (SO2_LIB ${CMAKE_CURRENT_SOURCE_DIR}/${BUILD_DIR}/so2/so2.so)

ADD_SUBDIRECTORY (saes-devices ${BUILD_DIR}/so3)
SET (SO3_LIB ${CMAKE_CURRENT_SOURCE_DIR}/${BUILD_DIR}/so3/so3.so)

# Add dynamic lib to app build for linking.
ADD_SUBDIRECTORY (so1 ${BUILD_DIR}/so1)
SET (SO1_LIB  ${CMAKE_CURRENT_SOURCE_DIR}/${BUILD_DIR}/so1/so1.so)

ADD_SUBDIRECTORY (so2 ${BUILD_DIR}/so2)
SET (SO2_LIB  ${CMAKE_CURRENT_SOURCE_DIR}/${BUILD_DIR}/so2/so2.so)

ADD_SUBDIRECTORY (so3 ${BUILD_DIR}/so3)
SET (SO3_LIB  ${CMAKE_CURRENT_SOURCE_DIR}/${BUILD_DIR}/so3/so3.so)

# Build Application
ADD_SUBDIRECTORY (app ${CMAKE_CURRENT_SOURCE_DIR}/${BUILD_DIR}/app)

更多信息:

http://www.cmake.org/cmake/help/cmake2.6docs.html