ENH: add a test for external projects
This commit is contained in:
parent
32fe8caaef
commit
013b66d8fa
|
@ -598,6 +598,18 @@ IF(BUILD_TESTING)
|
||||||
"${CMake_BINARY_DIR}/Tests/SubDir/ShouldBeHere"
|
"${CMake_BINARY_DIR}/Tests/SubDir/ShouldBeHere"
|
||||||
"${CMake_BINARY_DIR}/Tests/SubDir/testfromsubdir.o"
|
"${CMake_BINARY_DIR}/Tests/SubDir/testfromsubdir.o"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
IF(${CMAKE_GENERATOR} MATCHES "Visual Studio")
|
||||||
|
ADD_TEST(VSExternalInclude ${CMAKE_CTEST_COMMAND}
|
||||||
|
--build-and-test
|
||||||
|
"${CMake_SOURCE_DIR}/Tests/VSExternalInclude"
|
||||||
|
"${CMake_BINARY_DIR}/Tests/VSExternalInclude"
|
||||||
|
--build-two-config
|
||||||
|
--build-generator ${CMAKE_GENERATOR}
|
||||||
|
--build-project VSExternalInclude
|
||||||
|
--build-makeprogram ${MAKEPROGRAM}
|
||||||
|
--test-command VSExternalInclude)
|
||||||
|
ENDIF(${CMAKE_GENERATOR} MATCHES "Visual Studio")
|
||||||
|
|
||||||
IF (APPLE)
|
IF (APPLE)
|
||||||
ADD_TEST(objc++ ${CMAKE_CTEST_COMMAND}
|
ADD_TEST(objc++ ${CMAKE_CTEST_COMMAND}
|
||||||
|
|
|
@ -0,0 +1,38 @@
|
||||||
|
PROJECT(VSExternalInclude)
|
||||||
|
|
||||||
|
IF(${CMAKE_GENERATOR} MATCHES "Visual Studio 6")
|
||||||
|
SET(PROJECT_EXT dps)
|
||||||
|
ELSE(${CMAKE_GENERATOR} MATCHES "Visual Studio 6")
|
||||||
|
SET(PROJECT_EXT vcproj)
|
||||||
|
ENDIF(${CMAKE_GENERATOR} MATCHES "Visual Studio 6")
|
||||||
|
|
||||||
|
|
||||||
|
# make sure directories exists
|
||||||
|
SET(LIB1_BINARY_DIR ${VSExternalInclude_BINARY_DIR}/Lib1)
|
||||||
|
MAKE_DIRECTORY("${LIB1_BINARY_DIR}")
|
||||||
|
|
||||||
|
SET(LIB2_BINARY_DIR ${VSExternalInclude_BINARY_DIR}/Lib2)
|
||||||
|
MAKE_DIRECTORY("${LIB2_BINARY_DIR}")
|
||||||
|
|
||||||
|
# generate lib1
|
||||||
|
EXEC_PROGRAM("${CMAKE_COMMAND}" "${LIB1_BINARY_DIR}" ARGS -G\"${CMAKE_GENERATOR}\"
|
||||||
|
\"${VSExternalInclude_SOURCE_DIR}/Lib1\" OUTPUT_VARIABLE OUT)
|
||||||
|
|
||||||
|
|
||||||
|
# generate lib2
|
||||||
|
EXEC_PROGRAM("${CMAKE_COMMAND}" "${LIB2_BINARY_DIR}" ARGS -G\"${CMAKE_GENERATOR}\"
|
||||||
|
\"${VSExternalInclude_SOURCE_DIR}/Lib2\" OUTPUT_VARIABLE OUT)
|
||||||
|
|
||||||
|
|
||||||
|
INCLUDE_EXTERNAL_MSPROJECT(lib1 ${VSExternalInclude_BINARY_DIR}/Lib1/LIB1.${PROJECT_EXT})
|
||||||
|
# lib2 depends on lib1
|
||||||
|
INCLUDE_EXTERNAL_MSPROJECT(lib2 ${VSExternalInclude_BINARY_DIR}/Lib2/LIB2.${PROJECT_EXT} lib1)
|
||||||
|
|
||||||
|
INCLUDE_DIRECTORIES(${VSExternalInclude_SOURCE_DIR}/Lib2 ${VSExternalInclude_SOURCE_DIR}/Lib1)
|
||||||
|
|
||||||
|
SET(SOURCES main.cpp)
|
||||||
|
|
||||||
|
ADD_EXECUTABLE(VSExternalInclude ${SOURCES})
|
||||||
|
|
||||||
|
# target depends on lib1
|
||||||
|
ADD_DEPENDENCIES(VSExternalInclude lib2)
|
|
@ -0,0 +1,5 @@
|
||||||
|
PROJECT(LIB1)
|
||||||
|
|
||||||
|
SET(SOURCES lib1.cpp)
|
||||||
|
|
||||||
|
ADD_LIBRARY(lib1 ${SOURCES})
|
|
@ -0,0 +1,7 @@
|
||||||
|
|
||||||
|
#include "lib1.h"
|
||||||
|
|
||||||
|
int add1(int num)
|
||||||
|
{
|
||||||
|
return num + 1;
|
||||||
|
}
|
|
@ -0,0 +1,8 @@
|
||||||
|
|
||||||
|
#ifndef LIB1_HPP
|
||||||
|
#define LIB1_HPP
|
||||||
|
|
||||||
|
int add1(int num);
|
||||||
|
|
||||||
|
|
||||||
|
#endif
|
|
@ -0,0 +1,7 @@
|
||||||
|
PROJECT(VSEXTERNAL_LIB2)
|
||||||
|
|
||||||
|
INCLUDE_DIRECTORIES(${VSEXTERNAL_LIB2_SOURCE_DIR}/../Lib1)
|
||||||
|
|
||||||
|
SET(SOURCES lib2.cpp)
|
||||||
|
|
||||||
|
ADD_LIBRARY(lib2 ${SOURCES})
|
|
@ -0,0 +1,9 @@
|
||||||
|
|
||||||
|
#include "lib2.h"
|
||||||
|
#include "lib1.h"
|
||||||
|
|
||||||
|
int add1_and_mult2(int num)
|
||||||
|
{
|
||||||
|
int tmp = add1(num);
|
||||||
|
return tmp * 2;
|
||||||
|
}
|
|
@ -0,0 +1,10 @@
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef LIB2_HPP
|
||||||
|
#define LIB2_HPP
|
||||||
|
|
||||||
|
#include "lib1.h"
|
||||||
|
|
||||||
|
int add1_and_mult2(int num);
|
||||||
|
|
||||||
|
#endif
|
|
@ -0,0 +1,9 @@
|
||||||
|
|
||||||
|
#include "lib2.h"
|
||||||
|
|
||||||
|
int main(int argc, char** argv)
|
||||||
|
{
|
||||||
|
int num = add1_and_mult2(4);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
Loading…
Reference in New Issue