|
|
340e69 |
diff --git a/CMakeLists.txt b/CMakeLists.txt
|
|
|
340e69 |
index 7034bb6..27e90de 100644
|
|
|
340e69 |
--- a/CMakeLists.txt
|
|
|
340e69 |
+++ b/CMakeLists.txt
|
|
|
340e69 |
@@ -217,13 +217,16 @@ ADD_CUSTOM_TARGET(geotag-test COMMAND env EXIV2_BINDIR="${CMAKE_BINARY_DIR}"/bin
|
|
|
340e69 |
# effectively does a make doc on the root directory
|
|
|
340e69 |
# has to run 'make config' and './configure'
|
|
|
340e69 |
# and copy bin/taglist to <exiv2dir>/bin/taglist for use by 'make doc'
|
|
|
340e69 |
-IF( MINGW OR UNIX OR APPLE)
|
|
|
340e69 |
- ADD_CUSTOM_TARGET(doc
|
|
|
340e69 |
- WORKING_DIRECTORY "${CMAKE_SOURCE_DIR}/doc"
|
|
|
340e69 |
- COMMAND chmod +x ./cmake_doc.sh
|
|
|
340e69 |
- COMMAND ./cmake_doc.sh "${CMAKE_BINARY_DIR}"
|
|
|
340e69 |
- )
|
|
|
340e69 |
-ENDIF()
|
|
|
340e69 |
+# IF( MINGW OR UNIX OR APPLE)
|
|
|
340e69 |
+# ADD_CUSTOM_TARGET(doc
|
|
|
340e69 |
+# WORKING_DIRECTORY "${CMAKE_SOURCE_DIR}/doc"
|
|
|
340e69 |
+# COMMAND chmod +x ./cmake_doc.sh
|
|
|
340e69 |
+# COMMAND ./cmake_doc.sh "${CMAKE_BINARY_DIR}"
|
|
|
340e69 |
+# )
|
|
|
340e69 |
+# ENDIF()
|
|
|
340e69 |
+
|
|
|
340e69 |
+include(config/generateDoc.cmake REQUIRED)
|
|
|
340e69 |
+generate_documentation("${PROJECT_SOURCE_DIR}/config/Doxyfile")
|
|
|
340e69 |
|
|
|
340e69 |
# That's all Folks!
|
|
|
340e69 |
##
|
|
|
340e69 |
diff --git a/config/Doxyfile b/config/Doxyfile
|
|
|
340e69 |
index db62e1d..5d357a7 100644
|
|
|
340e69 |
--- a/config/Doxyfile
|
|
|
340e69 |
+++ b/config/Doxyfile
|
|
|
340e69 |
@@ -52,7 +52,7 @@ PROJECT_LOGO =
|
|
|
340e69 |
# If a relative path is entered, it will be relative to the location
|
|
|
340e69 |
# where doxygen was started. If left blank the current directory will be used.
|
|
|
340e69 |
|
|
|
340e69 |
-OUTPUT_DIRECTORY =
|
|
|
340e69 |
+OUTPUT_DIRECTORY = doc
|
|
|
340e69 |
|
|
|
340e69 |
# If the CREATE_SUBDIRS tag is set to YES, then doxygen will create
|
|
|
340e69 |
# 4096 sub-directories (in 2 levels) under the output directory of each output
|
|
|
340e69 |
@@ -1637,7 +1637,7 @@ TAGFILES =
|
|
|
340e69 |
# When a file name is specified after GENERATE_TAGFILE, doxygen will create
|
|
|
340e69 |
# a tag file that is based on the input files it reads.
|
|
|
340e69 |
|
|
|
340e69 |
-GENERATE_TAGFILE = html/exiv2.xml
|
|
|
340e69 |
+GENERATE_TAGFILE = doc/html/exiv2.xml
|
|
|
340e69 |
|
|
|
340e69 |
# If the ALLEXTERNALS tag is set to YES all external classes will be listed
|
|
|
340e69 |
# in the class index. If set to NO only the inherited external classes
|
|
|
340e69 |
diff --git a/config/generateDoc.cmake b/config/generateDoc.cmake
|
|
|
340e69 |
new file mode 100644
|
|
|
340e69 |
index 0000000..2b66078
|
|
|
340e69 |
--- /dev/null
|
|
|
340e69 |
+++ b/config/generateDoc.cmake
|
|
|
340e69 |
@@ -0,0 +1,28 @@
|
|
|
340e69 |
+# -helper macro to add a "doc" target with CMake build system.
|
|
|
340e69 |
+# and configure doxy.config.in to doxy.config
|
|
|
340e69 |
+#
|
|
|
340e69 |
+# target "doc" allows building the documentation with doxygen/dot on WIN32, Linux and Mac
|
|
|
340e69 |
+#
|
|
|
340e69 |
+
|
|
|
340e69 |
+find_package(Doxygen REQUIRED)
|
|
|
340e69 |
+
|
|
|
340e69 |
+macro(generate_documentation DOX_CONFIG_FILE)
|
|
|
340e69 |
+ if(NOT EXISTS "${DOX_CONFIG_FILE}")
|
|
|
340e69 |
+ message(FATAL_ERROR "Configuration file for doxygen not found")
|
|
|
340e69 |
+ endif()
|
|
|
340e69 |
+
|
|
|
340e69 |
+ #Define variables
|
|
|
340e69 |
+ set(INCDIR "${PROJECT_SOURCE_DIR}/include/exiv2")
|
|
|
340e69 |
+ set(SRCDIR "${PROJECT_SOURCE_DIR}/src")
|
|
|
340e69 |
+ set(ROOTDIR "${PROJECT_SOURCE_DIR}")
|
|
|
340e69 |
+ #set(TESTSDIR "${PROJECT_SOURCE_DIR}/tests")
|
|
|
340e69 |
+
|
|
|
340e69 |
+ configure_file(${DOX_CONFIG_FILE} ${CMAKE_CURRENT_BINARY_DIR}/doxy.config @ONLY) #OUT-OF-PLACE LOCATION
|
|
|
340e69 |
+ set(DOXY_CONFIG "${CMAKE_CURRENT_BINARY_DIR}/doxy.config")
|
|
|
340e69 |
+ add_custom_target(doc ${DOXYGEN_EXECUTABLE} ${DOXY_CONFIG})
|
|
|
340e69 |
+
|
|
|
340e69 |
+ install(DIRECTORY "${PROJECT_BINARY_DIR}/doc/html/" DESTINATION "share/doc/html/lib${PROJECT_NAME}")
|
|
|
340e69 |
+
|
|
|
340e69 |
+ set_property(DIRECTORY APPEND PROPERTY ADDITIONAL_MAKE_CLEAN_FILES doc)
|
|
|
340e69 |
+endmacro()
|
|
|
340e69 |
+
|