Blame SOURCES/exiv2-fix-documentation-build.patch

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
+