CMakeLists.txt 3.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. find_package(Sphinx REQUIRED)
  2. find_package(LATEX)
  3. set(DOC_LATEX_DIR ${PROJECT_BINARY_DIR}/doc_latex)
  4. make_directory(${PROJECT_BINARY_DIR}/doc_src)
  5. file(GLOB DOC_SRC "${PROJECT_SOURCE_DIR}/doc/*")
  6. file(COPY ${DOC_SRC} DESTINATION ${PROJECT_BINARY_DIR}/doc_src)
  7. function(generate_rst in out)
  8. add_custom_command(OUTPUT ${out}
  9. DEPENDS ${PROJECT_SOURCE_DIR}/tools/c2rst.py ${in}
  10. PRE_BUILD
  11. COMMAND ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/tools/c2rst.py ${in} ${out})
  12. endfunction()
  13. generate_rst(${PROJECT_SOURCE_DIR}/include/ua_types.h ${PROJECT_BINARY_DIR}/doc_src/types.rst)
  14. generate_rst(${PROJECT_SOURCE_DIR}/include/ua_constants.h ${PROJECT_BINARY_DIR}/doc_src/constants.rst)
  15. generate_rst(${PROJECT_BINARY_DIR}/src_generated/ua_types_generated.h ${PROJECT_BINARY_DIR}/doc_src/types_generated.rst)
  16. generate_rst(${PROJECT_SOURCE_DIR}/include/ua_server.h ${PROJECT_BINARY_DIR}/doc_src/server.rst)
  17. generate_rst(${PROJECT_SOURCE_DIR}/include/ua_client.h ${PROJECT_BINARY_DIR}/doc_src/client.rst)
  18. generate_rst(${PROJECT_SOURCE_DIR}/include/ua_client_highlevel.h ${PROJECT_BINARY_DIR}/doc_src/client_highlevel.rst)
  19. generate_rst(${PROJECT_SOURCE_DIR}/include/ua_log.h ${PROJECT_BINARY_DIR}/doc_src/log.rst)
  20. generate_rst(${PROJECT_SOURCE_DIR}/include/ua_connection.h ${PROJECT_BINARY_DIR}/doc_src/connection.rst)
  21. generate_rst(${PROJECT_SOURCE_DIR}/src/server/ua_services.h ${PROJECT_BINARY_DIR}/doc_src/services.rst)
  22. generate_rst(${PROJECT_SOURCE_DIR}/src/server/ua_nodestore.h ${PROJECT_BINARY_DIR}/doc_src/nodestore.rst)
  23. add_custom_target(doc_latex ${SPHINX_EXECUTABLE}
  24. -b latex -c "${PROJECT_BINARY_DIR}/doc_src" "${PROJECT_BINARY_DIR}/doc_src" "${PROJECT_BINARY_DIR}/doc_latex"
  25. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/types.rst
  26. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/constants.rst
  27. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/types_generated.rst
  28. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/server.rst
  29. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/client.rst
  30. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/client_highlevel.rst
  31. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/log.rst
  32. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/connection.rst
  33. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/services.rst
  34. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/nodestore.rst
  35. COMMENT "Building LaTeX sources for documentation with Sphinx")
  36. add_dependencies(doc_latex open62541)
  37. add_custom_target(doc_pdf ${PDFLATEX_COMPILER} -q "open62541.tex"
  38. WORKING_DIRECTORY ${DOC_LATEX_DIR}
  39. # compile it twice so that the contents pages are correct
  40. COMMAND ${PDFLATEX_COMPILER} -q "open62541.tex"
  41. DEPENDS ${PDFLATEX_COMPILER}
  42. COMMENT "Generating PDF documentation from LaTeX sources")
  43. add_dependencies(doc_pdf doc_latex)
  44. add_custom_target(doc ${SPHINX_EXECUTABLE}
  45. -b html -c "${PROJECT_BINARY_DIR}/doc_src" "${PROJECT_BINARY_DIR}/doc_src" "${PROJECT_BINARY_DIR}/doc"
  46. COMMAND ${CMAKE_COMMAND} -E copy "${PROJECT_BINARY_DIR}/doc_src/open62541_html.png" "${PROJECT_BINARY_DIR}/doc/_static/"
  47. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/types.rst
  48. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/constants.rst
  49. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/types_generated.rst
  50. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/server.rst
  51. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/client.rst
  52. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/client_highlevel.rst
  53. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/log.rst
  54. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/connection.rst
  55. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/services.rst
  56. DEPENDS ${PROJECT_BINARY_DIR}/doc_src/nodestore.rst
  57. COMMENT "Building HTML documentation with Sphinx")
  58. add_dependencies(doc open62541)