Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/doc/doc/api/CMakeLists.txt @ 7334

Last change on this file since 7334 was 7334, checked in by rgrieder, 14 years ago

Fixed log file path for Doxygen.
You should now get doxy.log in the doc/api folder containing all warnings but without the rest of the output.

  • Property svn:eol-style set to native
File size: 3.2 KB
Line 
1# Add a "doc" target with CMake build system.
2# And configure doxy.config.in to doxy.config
3#
4# target "doc" allows building the documentation with doxygen/dot on WIN32 and Linux
5# Creates .chm windows help file if MS HTML help workshop
6# (available from http://msdn.microsoft.com/workshop/author/htmlhelp)
7# is installed with its DLLs in PATH.
8#
9#
10# Please note, that the tools, e.g.:
11# doxygen, dot, latex, dvips, makeindex, gswin32, etc.
12# must be in path.
13#
14# Note about Visual Studio Projects:
15# MSVS hast its own path environment which may differ from the shell.
16# See "Menu Tools/Options/Projects/VC++ Directories" in VS 7.1
17#
18# author Jan Woetzel 2004-2006
19# www.mip.informatik.uni-kiel.de/~jw
20# Adjustments for Orxonox by Reto Grieder
21
22FIND_PACKAGE(Doxygen QUIET)
23
24IF (DOXYGEN_FOUND)
25  # click+jump in Emacs and Visual Studio (for doxy.config) (jw)
26  IF(CMAKE_BUILD_TOOL MATCHES "msdev|devenv")
27    SET(DOXY_WARN_FORMAT "\"$file($line) : $text \"")
28  ELSE()
29    SET(DOXY_WARN_FORMAT "\"$file:$line: $text \"")
30  ENDIF()
31
32  SET(DOXY_INPUT_DIR  ${CMAKE_CURRENT_SOURCE_DIR})
33  SET(DOXY_OUTPUT_DIR ${CMAKE_CURRENT_BINARY_DIR})
34
35  # we need latex for doxygen because of the formulas
36  # Orxonox doesn't
37  #FIND_PACKAGE(LATEX)
38  #IF    (NOT LATEX_COMPILER)
39  #  MESSAGE(STATUS "latex command LATEX_COMPILER not found but usually required. You will probably get warnings and user inetraction on doxy run.")
40  #ENDIF (NOT LATEX_COMPILER)
41  #IF    (NOT MAKEINDEX_COMPILER)
42  #  MESSAGE(STATUS "makeindex command MAKEINDEX_COMPILER not found but usually required.")
43  #ENDIF (NOT MAKEINDEX_COMPILER)
44  #IF    (NOT DVIPS_CONVERTER)
45  #  MESSAGE(STATUS "dvips command DVIPS_CONVERTER not found but usually required.")
46  #ENDIF (NOT DVIPS_CONVERTER)
47
48  IF(EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/doxy.config.in)
49    # use (configured) doxy.config from (out of place) BUILD tree:
50    SET(DOXY_CONFIG ${CMAKE_CURRENT_BINARY_DIR}/doxy.config)
51    SET(DOXY_LOGFILE ${CMAKE_CURRENT_BINARY_DIR}/doxy.log)
52    CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/doxy.config.in ${CMAKE_CURRENT_BINARY_DIR}/doxy.config @ONLY)
53  ELSE()
54    MESSAGE(FATAL_ERROR "Warning: Could not find dox.config.in in the root directory.")
55  ENDIF()
56
57  ADD_CUSTOM_TARGET(doc ${DOXYGEN_EXECUTABLE} ${DOXY_CONFIG})
58
59  # create a windows help .chm file using hhc.exe
60  # HTMLHelp DLL must be in path!
61  # fallback: use hhw.exe interactively
62  IF(WIN32)
63    FIND_PACKAGE(HTMLHelp)
64    IF(HTML_HELP_COMPILER)
65      SET(TMP ${DOXY_OUTPUT_DIR}/html/index.hhp)
66      STRING(REGEX REPLACE "/" "\\\\" HHP_FILE ${TMP})
67      ADD_CUSTOM_TARGET(doc_chm ${HTML_HELP_COMPILER} ${HHP_FILE})
68      ADD_DEPENDENCIES(doc_chm doc)
69      # Adding a dependency somehow adds doc target as default build target
70      SET_TARGET_PROPERTIES(doc doc_chm PROPERTIES EXCLUDE_FROM_DEFAULT_BUILD TRUE)
71    ENDIF(HTML_HELP_COMPILER)
72  ENDIF (WIN32)
73
74
75  # Installation
76  INSTALL(
77    FILES ${DOXY_CONFIG} ${CMAKE_CURRENT_BINARY_DIR}/doxy.log
78    DESTINATION ${DOC_INSTALL_DIRECTORY}/api OPTIONAL
79  )
80  # Install command always needs the directory
81  IF(NOT EXISTS ${CMAKE_CURRENT_BINARY_DIR}/html)
82    FILE(MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/html)
83  ENDIF()
84  INSTALL(
85    DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/html
86    DESTINATION ${DOC_INSTALL_DIRECTORY}/api
87  )
88ENDIF(DOXYGEN_FOUND)
Note: See TracBrowser for help on using the repository browser.