CMakeLists.txt 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475
  1. # this test creates a static library and an executable
  2. # the source to the library is then changed
  3. # and the build is done on the executable and if things
  4. # are working the executable should relink with the new
  5. # value. The subdir Project contains the CMakelists.txt
  6. # and source files for the test project.
  7. cmake_minimum_required (VERSION 2.6)
  8. project(BuildDepends)
  9. # This entire test takes place during the initial
  10. # configure step. It should not run again when the
  11. # project is built.
  12. set(CMAKE_SUPPRESS_REGENERATION 1)
  13. # Xcode needs some help with the fancy dependencies in this test.
  14. if(XCODE AND XCODE_VERSION VERSION_LESS 5)
  15. set(HELP_XCODE 1)
  16. endif()
  17. function(help_xcode_depends)
  18. if(HELP_XCODE)
  19. file(GLOB_RECURSE MACRO_OBJS
  20. ${BuildDepends_BINARY_DIR}/Project/zot_macro_*.o*
  21. )
  22. if(MACRO_OBJS)
  23. message("Helping Xcode by removing objects [${MACRO_OBJS}]")
  24. file(REMOVE ${MACRO_OBJS})
  25. endif()
  26. endif()
  27. endfunction()
  28. # The Intel compiler causes the MSVC linker to crash during
  29. # incremental linking, so avoid the /INCREMENTAL:YES flag.
  30. if(WIN32 AND "${CMAKE_CXX_COMPILER_ID}" MATCHES "Intel")
  31. set(_cmake_options "-DCMAKE_EXE_LINKER_FLAGS=")
  32. endif()
  33. if("${CMAKE_GENERATOR}" MATCHES "Make|Ninja")
  34. set(TEST_LINK_DEPENDS ${BuildDepends_BINARY_DIR}/Project/linkdep.txt)
  35. file(WRITE ${TEST_LINK_DEPENDS} "1")
  36. endif()
  37. list(APPEND _cmake_options "-DTEST_LINK_DEPENDS=${TEST_LINK_DEPENDS}")
  38. list(APPEND _cmake_options "-DCMAKE_FORCE_DEPFILES=1")
  39. if(NOT CMAKE_GENERATOR MATCHES "Visual Studio ([^9]|9[0-9])")
  40. set(TEST_MULTI3 1)
  41. list(APPEND _cmake_options "-DTEST_MULTI3=1")
  42. endif()
  43. file(MAKE_DIRECTORY ${BuildDepends_BINARY_DIR}/Project)
  44. message("Creating Project/foo.cxx")
  45. write_file(${BuildDepends_BINARY_DIR}/Project/foo.cxx
  46. "const char* foo() { return \"foo\";}" )
  47. file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot.hxx.in
  48. "static const char* zot = \"zot\";\n")
  49. file(WRITE ${BuildDepends_BINARY_DIR}/Project/dir/header.txt
  50. "#define HEADER_STRING \"ninja\"\n" )
  51. file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot_custom.hxx.in
  52. "static const char* zot_custom = \"zot_custom\";\n")
  53. file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot_macro_dir.hxx
  54. "static const char* zot_macro_dir = \"zot_macro_dir\";\n")
  55. file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot_macro_tgt.hxx
  56. "static const char* zot_macro_tgt = \"zot_macro_tgt\";\n")
  57. file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot_pch.hxx
  58. "#ifndef ZOT_PCH_HXX\n"
  59. "#define ZOT_PCH_HXX\n"
  60. "static const char* zot_pch = \"zot_pch\";\n"
  61. "#endif\n"
  62. )
  63. file(WRITE ${BuildDepends_BINARY_DIR}/Project/link_depends_no_shared_lib.h
  64. "#define link_depends_no_shared_lib_value 1\n")
  65. file(WRITE ${BuildDepends_BINARY_DIR}/Project/link_depends_no_shared_exe.h
  66. "#define link_depends_no_shared_exe_value 0\n")
  67. set(link_depends_no_shared_check_txt ${BuildDepends_BINARY_DIR}/Project/link_depends_no_shared_check.txt)
  68. file(WRITE ${BuildDepends_BINARY_DIR}/Project/object_depends.txt "0\n")
  69. set(object_depends_check_txt ${BuildDepends_BINARY_DIR}/Project/object_depends_check.txt)
  70. file(WRITE ${BuildDepends_BINARY_DIR}/Project/external.in "external original\n")
  71. file(WRITE ${BuildDepends_BINARY_DIR}/Project/multi1-in.txt "multi1-in original\n")
  72. file(WRITE ${BuildDepends_BINARY_DIR}/Project/multi2-stamp.txt "multi2-stamp original\n")
  73. file(WRITE ${BuildDepends_BINARY_DIR}/Project/multi3-stamp.txt "multi3-stamp original\n")
  74. help_xcode_depends()
  75. message("Building project first time")
  76. try_compile(RESULT
  77. ${BuildDepends_BINARY_DIR}/Project
  78. ${BuildDepends_SOURCE_DIR}/Project
  79. testRebuild
  80. CMAKE_FLAGS ${_cmake_options}
  81. OUTPUT_VARIABLE OUTPUT)
  82. if(HELP_XCODE)
  83. try_compile(RESULT
  84. ${BuildDepends_BINARY_DIR}/Project
  85. ${BuildDepends_SOURCE_DIR}/Project
  86. testRebuild
  87. OUTPUT_VARIABLE OUTPUT)
  88. try_compile(RESULT
  89. ${BuildDepends_BINARY_DIR}/Project
  90. ${BuildDepends_SOURCE_DIR}/Project
  91. testRebuild
  92. OUTPUT_VARIABLE OUTPUT)
  93. endif()
  94. message("Output from first build:\n${OUTPUT}")
  95. if(NOT RESULT)
  96. message(SEND_ERROR "Could not build test project (1)!")
  97. endif()
  98. # find and save the ninjadep executable
  99. set(ninjadep ${BuildDepends_BINARY_DIR}/Project/ninjadep${CMAKE_EXECUTABLE_SUFFIX})
  100. if(EXISTS
  101. "${BuildDepends_BINARY_DIR}/Project/Debug/ninjadep${CMAKE_EXECUTABLE_SUFFIX}" )
  102. message("found debug")
  103. set(ninjadep
  104. "${BuildDepends_BINARY_DIR}/Project/Debug/ninjadep${CMAKE_EXECUTABLE_SUFFIX}")
  105. endif()
  106. message("Running ${ninjadep} ")
  107. execute_process(COMMAND ${ninjadep} OUTPUT_VARIABLE out RESULT_VARIABLE runResult)
  108. string(REGEX REPLACE "[\r\n]" " " out "${out}")
  109. message("Run result: ${runResult} Output: \"${out}\"")
  110. if("${out}" STREQUAL "HEADER_STRING: ninja ")
  111. message("Worked!")
  112. else()
  113. message(SEND_ERROR "Project did not rebuild properly. Output[${out}]\n"
  114. " expected [HEADER_STRING: ninja]")
  115. endif()
  116. set(bar ${BuildDepends_BINARY_DIR}/Project/bar${CMAKE_EXECUTABLE_SUFFIX})
  117. if(EXISTS
  118. "${BuildDepends_BINARY_DIR}/Project/Debug/bar${CMAKE_EXECUTABLE_SUFFIX}" )
  119. message("found debug")
  120. set(bar
  121. "${BuildDepends_BINARY_DIR}/Project/Debug/bar${CMAKE_EXECUTABLE_SUFFIX}")
  122. endif()
  123. set(zot ${BuildDepends_BINARY_DIR}/Project/zot${CMAKE_EXECUTABLE_SUFFIX})
  124. if(EXISTS
  125. "${BuildDepends_BINARY_DIR}/Project/Debug/zot${CMAKE_EXECUTABLE_SUFFIX}" )
  126. message("found debug")
  127. set(zot
  128. "${BuildDepends_BINARY_DIR}/Project/Debug/zot${CMAKE_EXECUTABLE_SUFFIX}")
  129. endif()
  130. message("Running ${bar} ")
  131. execute_process(COMMAND ${bar} OUTPUT_VARIABLE out RESULT_VARIABLE runResult)
  132. string(REGEX REPLACE "[\r\n]" " " out "${out}")
  133. message("Run result: ${runResult} Output: \"${out}\"")
  134. if("${out}" STREQUAL "foo ")
  135. message("Worked!")
  136. else()
  137. message(SEND_ERROR "Project did not initially build properly: ${out}")
  138. endif()
  139. message("Running ${zot} ")
  140. execute_process(COMMAND ${zot} OUTPUT_VARIABLE out RESULT_VARIABLE runResult)
  141. string(REGEX REPLACE "[\r\n]" " " out "${out}")
  142. message("Run result: ${runResult} Output: \"${out}\"")
  143. set(VALUE_UNCHANGED "[zot] [zot_custom] [zot_macro_dir] [zot_macro_tgt] [zot_pch] ")
  144. if("${out}" STREQUAL "${VALUE_UNCHANGED}")
  145. message("Worked!")
  146. else()
  147. message(SEND_ERROR "Project did not initially build properly: ${out}")
  148. endif()
  149. if(EXISTS "${link_depends_no_shared_check_txt}")
  150. file(STRINGS "${link_depends_no_shared_check_txt}" link_depends_no_shared_check LIMIT_COUNT 1)
  151. if("${link_depends_no_shared_check}" STREQUAL "1")
  152. message(STATUS "link_depends_no_shared_exe is newer than link_depends_no_shared_lib as expected.")
  153. else()
  154. message(SEND_ERROR "Project did not initially build properly: "
  155. "link_depends_no_shared_exe is older than link_depends_no_shared_lib.")
  156. endif()
  157. else()
  158. message(SEND_ERROR "Project did not initially build properly: "
  159. "Targets link_depends_no_shared_lib and link_depends_no_shared_exe not both built.")
  160. endif()
  161. if(EXISTS ${BuildDepends_BINARY_DIR}/Project/external.out)
  162. file(STRINGS ${BuildDepends_BINARY_DIR}/Project/external.out external_out)
  163. if("${external_out}" STREQUAL "external original")
  164. message(STATUS "external.out contains '${external_out}'")
  165. else()
  166. message(SEND_ERROR "Project did not initially build properly: "
  167. "external.out contains '${external_out}'")
  168. endif()
  169. else()
  170. message(SEND_ERROR "Project did not initially build properly: "
  171. "external.out is missing")
  172. endif()
  173. if(EXISTS ${BuildDepends_BINARY_DIR}/Project/multi1-out2-copy.txt)
  174. file(STRINGS ${BuildDepends_BINARY_DIR}/Project/multi1-out2-copy.txt multi1_out)
  175. if("${multi1_out}" STREQUAL "multi1-in original")
  176. message(STATUS "multi1-out2-copy.txt contains '${multi1_out}'")
  177. else()
  178. message(SEND_ERROR "Project did not initially build properly: "
  179. "multi1-out2-copy.txt contains '${multi1_out}'")
  180. endif()
  181. else()
  182. message(SEND_ERROR "Project did not initially build properly: "
  183. "multi1-out2-copy.txt is missing")
  184. endif()
  185. if(EXISTS ${BuildDepends_BINARY_DIR}/Project/multi2-real.txt)
  186. if(${BuildDepends_BINARY_DIR}/Project/multi2-real.txt
  187. IS_NEWER_THAN ${BuildDepends_BINARY_DIR}/Project/multi2-stamp.txt)
  188. message(STATUS "multi2-real.txt is newer than multi2-stamp.txt")
  189. else()
  190. message(SEND_ERROR "Project did not initially build properly: "
  191. "multi2-real.txt is not newer than multi2-stamp.txt")
  192. endif()
  193. else()
  194. message(SEND_ERROR "Project did not initially build properly: "
  195. "multi2-real.txt is missing")
  196. endif()
  197. if(TEST_MULTI3)
  198. if(EXISTS ${BuildDepends_BINARY_DIR}/Project/multi3-real.txt)
  199. if(${BuildDepends_BINARY_DIR}/Project/multi3-real.txt
  200. IS_NEWER_THAN ${BuildDepends_BINARY_DIR}/Project/multi3-stamp.txt)
  201. message(STATUS "multi3-real.txt is newer than multi3-stamp.txt")
  202. else()
  203. message(SEND_ERROR "Project did not initially build properly: "
  204. "multi3-real.txt is not newer than multi3-stamp.txt")
  205. endif()
  206. else()
  207. message(SEND_ERROR "Project did not initially build properly: "
  208. "multi3-real.txt is missing")
  209. endif()
  210. endif()
  211. message("Waiting 3 seconds...")
  212. execute_process(COMMAND ${CMAKE_COMMAND} -E sleep 3)
  213. message("Modifying Project/foo.cxx")
  214. write_file(${BuildDepends_BINARY_DIR}/Project/foo.cxx
  215. "const char* foo() { return \"foo changed\";}" )
  216. file(WRITE "${BuildDepends_BINARY_DIR}/Project/dir/header.txt"
  217. "#define HEADER_STRING \"ninja changed\"\n" )
  218. file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot.hxx.in
  219. "static const char* zot = \"zot changed\";\n")
  220. file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot_custom.hxx.in
  221. "static const char* zot_custom = \"zot_custom changed\";\n")
  222. file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot_macro_dir.hxx
  223. "static const char* zot_macro_dir = \"zot_macro_dir changed\";\n")
  224. file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot_macro_tgt.hxx
  225. "static const char* zot_macro_tgt = \"zot_macro_tgt changed\";\n")
  226. file(WRITE ${BuildDepends_BINARY_DIR}/Project/zot_pch.hxx
  227. "#ifndef ZOT_PCH_HXX\n"
  228. "#define ZOT_PCH_HXX\n"
  229. "static const char* zot_pch = \"zot_pch changed\";\n"
  230. "#endif\n"
  231. )
  232. file(WRITE ${BuildDepends_BINARY_DIR}/Project/link_depends_no_shared_lib.h
  233. "#define link_depends_no_shared_lib_value 0\n")
  234. file(WRITE ${BuildDepends_BINARY_DIR}/Project/object_depends.txt "1\n")
  235. if(TEST_LINK_DEPENDS)
  236. file(WRITE ${TEST_LINK_DEPENDS} "2")
  237. endif()
  238. file(WRITE ${BuildDepends_BINARY_DIR}/Project/external.in "external changed\n")
  239. file(WRITE ${BuildDepends_BINARY_DIR}/Project/multi1-in.txt "multi1-in changed\n")
  240. file(WRITE ${BuildDepends_BINARY_DIR}/Project/multi2-stamp.txt "multi2-stamp changed\n")
  241. file(WRITE ${BuildDepends_BINARY_DIR}/Project/multi3-stamp.txt "multi3-stamp changed\n")
  242. help_xcode_depends()
  243. message("Building project second time")
  244. try_compile(RESULT
  245. ${BuildDepends_BINARY_DIR}/Project
  246. ${BuildDepends_SOURCE_DIR}/Project
  247. testRebuild
  248. CMAKE_FLAGS ${_cmake_options}
  249. OUTPUT_VARIABLE OUTPUT)
  250. # Xcode is in serious need of help here
  251. if(HELP_XCODE)
  252. try_compile(RESULT
  253. ${BuildDepends_BINARY_DIR}/Project
  254. ${BuildDepends_SOURCE_DIR}/Project
  255. testRebuild
  256. OUTPUT_VARIABLE OUTPUT)
  257. try_compile(RESULT
  258. ${BuildDepends_BINARY_DIR}/Project
  259. ${BuildDepends_SOURCE_DIR}/Project
  260. testRebuild
  261. OUTPUT_VARIABLE OUTPUT)
  262. endif()
  263. message("Output from second build:\n${OUTPUT}")
  264. if(NOT RESULT)
  265. message(SEND_ERROR "Could not build test project (2)!")
  266. endif()
  267. if(EXISTS
  268. "${BuildDepends_BINARY_DIR}/Project/Debug/bar${CMAKE_EXECUTABLE_SUFFIX}" )
  269. message("found debug")
  270. endif()
  271. if(EXISTS
  272. "${BuildDepends_BINARY_DIR}/Project/Debug/zot${CMAKE_EXECUTABLE_SUFFIX}" )
  273. message("found debug")
  274. endif()
  275. message("Running ${ninjadep} ")
  276. execute_process(COMMAND ${ninjadep} OUTPUT_VARIABLE out RESULT_VARIABLE runResult)
  277. string(REGEX REPLACE "[\r\n]" " " out "${out}")
  278. message("Run result: ${runResult} Output: \"${out}\"")
  279. if("${out}" STREQUAL "HEADER_STRING: ninja changed ")
  280. message("Worked!")
  281. else()
  282. message(SEND_ERROR "Project did not rebuild properly. Output[${out}]\n"
  283. " expected [HEADER_STRING: ninja changed]")
  284. endif()
  285. message("Running ${bar} ")
  286. execute_process(COMMAND ${bar} OUTPUT_VARIABLE out RESULT_VARIABLE runResult)
  287. string(REGEX REPLACE "[\r\n]" " " out "${out}")
  288. message("Run result: ${runResult} Output: \"${out}\"")
  289. if("${out}" STREQUAL "foo changed ")
  290. message("Worked!")
  291. else()
  292. message(SEND_ERROR "Project did not rebuild properly!")
  293. endif()
  294. message("Running ${zot} ")
  295. execute_process(COMMAND ${zot} OUTPUT_VARIABLE out RESULT_VARIABLE runResult)
  296. string(REGEX REPLACE "[\r\n]" " " out "${out}")
  297. message("Run result: ${runResult} Output: \"${out}\"")
  298. set(VALUE_CHANGED
  299. "[zot changed] [zot_custom changed] [zot_macro_dir changed] [zot_macro_tgt changed] [zot_pch changed] "
  300. )
  301. if("${out}" STREQUAL "${VALUE_CHANGED}")
  302. message("Worked!")
  303. else()
  304. message(SEND_ERROR "Project did not rebuild properly!")
  305. endif()
  306. if(TEST_LINK_DEPENDS)
  307. set(linkdep ${BuildDepends_BINARY_DIR}/Project/linkdep${CMAKE_EXECUTABLE_SUFFIX})
  308. if(${linkdep} IS_NEWER_THAN ${TEST_LINK_DEPENDS})
  309. message("LINK_DEPENDS worked")
  310. else()
  311. message(SEND_ERROR "LINK_DEPENDS failed. Executable
  312. ${linkdep}
  313. is not newer than dependency
  314. ${TEST_LINK_DEPENDS}
  315. ")
  316. endif()
  317. set(linkdep2 ${BuildDepends_BINARY_DIR}/Project/linkdep2${CMAKE_EXECUTABLE_SUFFIX})
  318. if(${linkdep2} IS_NEWER_THAN ${TEST_LINK_DEPENDS})
  319. message("INTERFACE_LINK_DEPENDS worked")
  320. else()
  321. message(SEND_ERROR "INTERFACE_LINK_DEPENDS failed. Executable
  322. ${linkdep2}
  323. is not newer than dependency
  324. ${TEST_LINK_DEPENDS}
  325. ")
  326. endif()
  327. set(linkdep3 ${BuildDepends_BINARY_DIR}/Project/linkdep3${CMAKE_EXECUTABLE_SUFFIX})
  328. if(${linkdep3} IS_NEWER_THAN ${TEST_LINK_DEPENDS})
  329. message("$<LINK_LANGUAGE> in LINK_DEPENDS worked")
  330. else()
  331. message(SEND_ERROR "$<LINK_LANGUAGE> in LINK_DEPENDS failed. Executable
  332. ${linkdep3}
  333. is not newer than dependency
  334. ${TEST_LINK_DEPENDS}
  335. ")
  336. endif()
  337. set(linkdep4 ${BuildDepends_BINARY_DIR}/Project/linkdep4${CMAKE_EXECUTABLE_SUFFIX})
  338. if(${linkdep4} IS_NEWER_THAN ${TEST_LINK_DEPENDS})
  339. message("$<LINK_LANGUAGE> in INTERFACE_LINK_DEPENDS worked")
  340. else()
  341. message(SEND_ERROR "$<LINK_LANGUAGE> in INTERFACE_LINK_DEPENDS failed. Executable
  342. ${linkdep4}
  343. is not newer than dependency
  344. ${TEST_LINK_DEPENDS}
  345. ")
  346. endif()
  347. endif()
  348. if(EXISTS "${link_depends_no_shared_check_txt}")
  349. file(STRINGS "${link_depends_no_shared_check_txt}" link_depends_no_shared_check LIMIT_COUNT 1)
  350. if("${link_depends_no_shared_check}" STREQUAL "0")
  351. message(STATUS "link_depends_no_shared_exe is older than link_depends_no_shared_lib as expected.")
  352. elseif(XCODE AND NOT XCODE_VERSION VERSION_LESS 5)
  353. message(STATUS "Known limitation: link_depends_no_shared_exe is newer than link_depends_no_shared_lib but we cannot stop Xcode ${XCODE_VERSION} from enforcing this dependency.")
  354. else()
  355. message(SEND_ERROR "Project did not rebuild properly: link_depends_no_shared_exe is newer than link_depends_no_shared_lib.")
  356. endif()
  357. else()
  358. message(SEND_ERROR "Project did not rebuild properly. "
  359. "Targets link_depends_no_shared_lib and link_depends_no_shared_exe not both built.")
  360. endif()
  361. if(EXISTS "${object_depends_check_txt}")
  362. file(STRINGS "${object_depends_check_txt}" object_depends_check LIMIT_COUNT 1)
  363. if("${object_depends_check}" STREQUAL "1")
  364. message(STATUS "object_depends exe is newer than object_depends.txt as expected.")
  365. elseif(CMAKE_GENERATOR MATCHES "Visual Studio|Xcode")
  366. message(STATUS "Known limitation: OBJECT_DEPENDS does not work on ${CMAKE_GENERATOR}")
  367. else()
  368. message(SEND_ERROR "Project did not rebuild properly: object_depends exe is not newer than object_depends.txt.")
  369. endif()
  370. else()
  371. message(SEND_ERROR "Project did not rebuild properly. "
  372. "object_depends exe and object_depends.txt are not both present.")
  373. endif()
  374. if(EXISTS ${BuildDepends_BINARY_DIR}/Project/external.out)
  375. file(STRINGS ${BuildDepends_BINARY_DIR}/Project/external.out external_out)
  376. if("${external_out}" STREQUAL "external changed")
  377. message(STATUS "external.out contains '${external_out}'")
  378. else()
  379. message(SEND_ERROR "Project did not rebuild properly: "
  380. "external.out contains '${external_out}'")
  381. endif()
  382. else()
  383. message(SEND_ERROR "Project did not rebuild properly: "
  384. "external.out is missing")
  385. endif()
  386. if(EXISTS ${BuildDepends_BINARY_DIR}/Project/multi1-out2-copy.txt)
  387. file(STRINGS ${BuildDepends_BINARY_DIR}/Project/multi1-out2-copy.txt multi1_out)
  388. if("${multi1_out}" STREQUAL "multi1-in changed")
  389. message(STATUS "multi1-out2-copy.txt contains '${multi1_out}'")
  390. else()
  391. message(SEND_ERROR "Project did not rebuild properly: "
  392. "multi1-out2-copy.txt contains '${multi1_out}'")
  393. endif()
  394. else()
  395. message(SEND_ERROR "Project did not rebuild properly: "
  396. "multi1-out2-copy.txt is missing")
  397. endif()
  398. if(EXISTS ${BuildDepends_BINARY_DIR}/Project/multi2-real.txt)
  399. if(${BuildDepends_BINARY_DIR}/Project/multi2-real.txt
  400. IS_NEWER_THAN ${BuildDepends_BINARY_DIR}/Project/multi2-stamp.txt)
  401. message(STATUS "multi2-real.txt is newer than multi2-stamp.txt")
  402. else()
  403. message(SEND_ERROR "Project did not rebuild properly: "
  404. "multi2-real.txt is not newer than multi2-stamp.txt")
  405. endif()
  406. else()
  407. message(SEND_ERROR "Project did not rebuild properly: "
  408. "multi2-real.txt is missing")
  409. endif()
  410. if(TEST_MULTI3)
  411. if(EXISTS ${BuildDepends_BINARY_DIR}/Project/multi3-real.txt)
  412. if(${BuildDepends_BINARY_DIR}/Project/multi3-real.txt
  413. IS_NEWER_THAN ${BuildDepends_BINARY_DIR}/Project/multi3-stamp.txt)
  414. message(STATUS "multi3-real.txt is newer than multi3-stamp.txt")
  415. else()
  416. message(SEND_ERROR "Project did not rebuild properly: "
  417. "multi3-real.txt is not newer than multi3-stamp.txt")
  418. endif()
  419. else()
  420. message(SEND_ERROR "Project did not rebuild properly: "
  421. "multi3-real.txt is missing")
  422. endif()
  423. endif()