Files
CMake/Tests/FindDoxygen/SimpleTest/CMakeLists.txt
Alex Turbov 59ffabfeec Improve Doxygen support
Except Graphviz's `dot` Doxygen may use few other utilities like
`mscgen` (Message Sequence Chart) and `dia` (Diagram Editor).

Now this module allows to manage Doxygen settings from `CMakeLists.txt`
and forget about `Doxyfile`s. Also it provides a helper function
to add a target to generate documentation: `doxygen_add_docs`.

Implement code review notes:

- Introduce `COMPONENTS` to find: `dot`, `mscgen` and `dia`;
- Deprecate variables `DOXYGEN_SKIP_DOT`, `DOXYGEN_EXECUTABLE`,
  `DOXYGEN_DOT_EXECUTABLE`, `DOXYGEN_DOT_FOUND` in favour of
  `doxygen_add_docs ` usage instead;
- Properly handle paths to found tools in Windows;
- Prevent adding a custom target if Doxygen was not really found;
- Introduce exported (executable) targets for found components.

Co-Author: Craig Scott <craig.scott@crascit.com>
2017-05-24 10:15:45 +07:00

60 lines
2.1 KiB
CMake

cmake_minimum_required(VERSION 3.8)
project(TestFindDoxygen VERSION 1.0 LANGUAGES NONE)
# Testing backward compatible signature
find_package(Doxygen REQUIRED)
if(TARGET Doxygen::doxygen)
# Check backward compatibility
if(NOT DOXYGEN_EXECUTABLE)
message(FATAL_ERROR "Backward compatibility broken: DOXYGEN_EXECUTABLE not set")
endif()
if(NOT DOXYGEN)
message(FATAL_ERROR "Backward compatibility broken: DOXYGEN not set")
endif()
# Check presence of expected generated files
foreach(file CMakeDoxyfile.in CMakeDoxygenDefaults.cmake)
if(NOT EXISTS "${PROJECT_BINARY_DIR}/${file}")
message(FATAL_ERROR "Missing generated file: ${file}")
endif()
endforeach()
else()
message(FATAL_ERROR "Import target Doxygen::doxygen not defined")
endif()
doxygen_add_docs(docsNoArgs)
if(NOT EXISTS "${PROJECT_BINARY_DIR}/Doxyfile.docsNoArgs")
message(FATAL_ERROR "Missing generated file: Doxyfile.docsNoArgs")
endif()
if(NOT TARGET docsNoArgs)
message(FATAL_ERROR "Target docsNoArgs not created")
endif()
configure_file(spaces_in_name.cpp.in "spaces in name.cpp" COPYONLY)
doxygen_add_docs(docsWithArgs
"${CMAKE_CURRENT_BINARY_DIR}/spaces in name.cpp"
main.cpp
)
if(NOT EXISTS "${PROJECT_BINARY_DIR}/Doxyfile.docsWithArgs")
message(FATAL_ERROR "Missing generated file: Doxyfile.docsWithArgs")
endif()
if(NOT TARGET docsWithArgs)
message(FATAL_ERROR "Target docsWithArgs not created")
endif()
# Note that CMake inserts at least one entry into SOURCES when a COMMAND or
# DEPENDS option is given to add_custom_target(), so rather than looking for an
# exact match, we only verify that the files we expect to be there are present
get_target_property(srcList docsWithArgs SOURCES)
set(expectedList
"${CMAKE_CURRENT_BINARY_DIR}/spaces in name.cpp"
"${CMAKE_CURRENT_SOURCE_DIR}/main.cpp"
)
foreach(f IN LISTS expectedList)
if(NOT f IN_LIST srcList)
message(FATAL_ERROR "SOURCES missing file: ${f}")
endif()
endforeach()
add_custom_target(allDocTargets)
add_dependencies(allDocTargets docsNoArgs docsWithArgs)