sdlmanpages.cmake 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. include(CMakeParseArguments)
  2. include(GNUInstallDirs)
  3. function(SDL_generate_manpages)
  4. cmake_parse_arguments(ARG "" "RESULT_VARIABLE;NAME;BUILD_DOCDIR;HEADERS_DIR;SOURCE_DIR;SYMBOL;OPTION_FILE;WIKIHEADERS_PL_PATH;REVISION" "" ${ARGN})
  5. set(wikiheaders_extra_args)
  6. if(NOT ARG_NAME)
  7. set(ARG_NAME "${PROJECT_NAME}")
  8. endif()
  9. if(NOT ARG_SOURCE_DIR)
  10. set(ARG_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}")
  11. endif()
  12. if(NOT ARG_OPTION_FILE)
  13. set(ARG_OPTION_FILE "${PROJECT_SOURCE_DIR}/.wikiheaders-options")
  14. endif()
  15. if(NOT ARG_HEADERS_DIR)
  16. message(FATAL_ERROR "Missing required HEADERS_DIR argument")
  17. endif()
  18. # FIXME: get rid of SYMBOL and let the perl script figure out the dependencies
  19. if(NOT ARG_SYMBOL)
  20. message(FATAL_ERROR "Missing required SYMBOL argument")
  21. endif()
  22. if(ARG_REVISION)
  23. list(APPEND wikiheaders_extra_args "--rev=${ARG_REVISION}")
  24. endif()
  25. if(NOT ARG_BUILD_DOCDIR)
  26. set(ARG_BUILD_DOCDIR "${CMAKE_CURRENT_BINARY_DIR}/docs")
  27. endif()
  28. set(BUILD_WIKIDIR "${ARG_BUILD_DOCDIR}/wiki")
  29. set(BUILD_MANDIR "${ARG_BUILD_DOCDIR}/man")
  30. find_package(Perl)
  31. file(GLOB HEADER_FILES "${ARG_HEADERS_DIR}/*.h")
  32. set(result FALSE)
  33. if(PERL_FOUND AND EXISTS "${ARG_WIKIHEADERS_PL_PATH}")
  34. add_custom_command(
  35. OUTPUT "${BUILD_WIKIDIR}/${ARG_SYMBOL}.md"
  36. COMMAND "${CMAKE_COMMAND}" -E make_directory "${BUILD_WIKIDIR}"
  37. COMMAND "${PERL_EXECUTABLE}" "${ARG_WIKIHEADERS_PL_PATH}" "${ARG_SOURCE_DIR}" "${BUILD_WIKIDIR}" "--options=${ARG_OPTION_FILE}" --copy-to-wiki ${wikiheaders_extra_args}
  38. DEPENDS ${HEADER_FILES} "${ARG_WIKIHEADERS_PL_PATH}" "${ARG_OPTION_FILE}"
  39. COMMENT "Generating ${ARG_NAME} wiki markdown files"
  40. )
  41. add_custom_command(
  42. OUTPUT "${BUILD_MANDIR}/man3/${ARG_SYMBOL}.3"
  43. COMMAND "${PERL_EXECUTABLE}" "${ARG_WIKIHEADERS_PL_PATH}" "${ARG_SOURCE_DIR}" "${BUILD_WIKIDIR}" "--options=${ARG_OPTION_FILE}" "--manpath=${BUILD_MANDIR}" --copy-to-manpages ${wikiheaders_extra_args}
  44. DEPENDS "${BUILD_WIKIDIR}/${ARG_SYMBOL}.md" "${ARG_WIKIHEADERS_PL_PATH}" "${ARG_OPTION_FILE}"
  45. COMMENT "Generating ${ARG_NAME} man pages"
  46. )
  47. add_custom_target(${ARG_NAME}-docs ALL DEPENDS "${BUILD_MANDIR}/man3/${ARG_SYMBOL}.3")
  48. install(DIRECTORY "${BUILD_MANDIR}/" DESTINATION "${CMAKE_INSTALL_MANDIR}")
  49. set(result TRUE)
  50. endif()
  51. if(ARG_RESULT_VARIABLE)
  52. set(${ARG_RESULT_VARIABLE} ${result} PARENT_SCOPE)
  53. endif()
  54. endfunction()