1
0

sdlmanpages.cmake 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  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" "" ${ARGN})
  5. if(NOT ARG_NAME)
  6. set(ARG_NAME "${PROJECT_NAME}")
  7. endif()
  8. if(NOT ARG_SOURCE_DIR)
  9. set(ARG_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}")
  10. endif()
  11. if(NOT ARG_OPTION_FILE)
  12. set(ARG_OPTION_FILE "${PROJECT_SOURCE_DIR}/.wikiheaders-options")
  13. endif()
  14. if(NOT ARG_HEADERS_DIR)
  15. set(ARG_HEADERS_DIR "${PROJECT_SOURCE_DIR}/include/SDL3")
  16. endif()
  17. # FIXME: get rid of SYMBOL and let the perl script figure out the dependencies
  18. if(NOT ARG_SYMBOL)
  19. message(FATAL_ERROR "Missing required SYMBOL argument")
  20. endif()
  21. if(NOT ARG_BUILD_DOCDIR)
  22. set(ARG_BUILD_DOCDIR "${CMAKE_CURRENT_BINARY_DIR}/docs")
  23. endif()
  24. set(BUILD_WIKIDIR "${ARG_BUILD_DOCDIR}/wiki")
  25. set(BUILD_MANDIR "${ARG_BUILD_DOCDIR}/man")
  26. find_package(Perl)
  27. file(GLOB HEADER_FILES "${ARG_HEADERS_DIR}/*.h")
  28. set(result FALSE)
  29. if(PERL_FOUND AND EXISTS "${ARG_WIKIHEADERS_PL_PATH}")
  30. add_custom_command(
  31. OUTPUT "${BUILD_WIKIDIR}/${ARG_SYMBOL}.md"
  32. COMMAND "${CMAKE_COMMAND}" -E make_directory "${BUILD_WIKIDIR}"
  33. COMMAND "${PERL_EXECUTABLE}" "${ARG_WIKIHEADERS_PL_PATH}" "${ARG_SOURCE_DIR}" "${BUILD_WIKIDIR}" "--options=${ARG_OPTION_FILE}" --copy-to-wiki
  34. DEPENDS ${HEADER_FILES} "${ARG_WIKIHEADERS_PL_PATH}" "${ARG_OPTION_FILE}"
  35. COMMENT "Generating ${ARG_NAME} wiki markdown files"
  36. )
  37. add_custom_command(
  38. OUTPUT "${BUILD_MANDIR}/man3/${ARG_SYMBOL}.3"
  39. COMMAND "${PERL_EXECUTABLE}" "${ARG_WIKIHEADERS_PL_PATH}" "${ARG_SOURCE_DIR}" "${BUILD_WIKIDIR}" "--options=${ARG_OPTION_FILE}" "--manpath=${BUILD_MANDIR}" --copy-to-manpages
  40. DEPENDS "${BUILD_WIKIDIR}/${ARG_SYMBOL}.md" "${ARG_WIKIHEADERS_PL_PATH}" "${ARG_OPTION_FILE}"
  41. COMMENT "Generating ${ARG_NAME} man pages"
  42. )
  43. add_custom_target(${ARG_NAME}-docs ALL DEPENDS "${BUILD_MANDIR}/man3/${ARG_SYMBOL}.3")
  44. install(DIRECTORY "${BUILD_MANDIR}/" DESTINATION "${CMAKE_INSTALL_MANDIR}")
  45. set(result TRUE)
  46. endif()
  47. if(ARG_RESULT_VARIABLE)
  48. set(${ARG_RESULT_VARIABLE} ${result} PARENT_SCOPE)
  49. endif()
  50. endfunction()