CMakeLists.txt 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. find_package(Sphinx)
  2. find_package(LATEX)
  3. set(DOC_LATEX_DIR ${PROJECT_BINARY_DIR}/doc_latex)
  4. set(DOC_HTML_DIR ${PROJECT_BINARY_DIR}/doc)
  5. set(DOC_SRC_DIR ${PROJECT_BINARY_DIR}/doc_src)
  6. make_directory(${DOC_SRC_DIR})
  7. file(GLOB DOC_SRC "${PROJECT_SOURCE_DIR}/doc/*")
  8. list(REMOVE_ITEM DOC_SRC "${PROJECT_SOURCE_DIR}/doc/conf.py")
  9. file(COPY ${DOC_SRC} DESTINATION ${DOC_SRC_DIR})
  10. configure_file("${PROJECT_SOURCE_DIR}/doc/conf.py" "${DOC_SRC_DIR}/conf.py")
  11. function(generate_rst in out)
  12. add_custom_command(OUTPUT ${out} DEPENDS ${PROJECT_SOURCE_DIR}/tools/c2rst.py ${in}
  13. PRE_BUILD COMMAND ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/tools/c2rst.py ${in} ${out})
  14. endfunction()
  15. # Doc from headers
  16. generate_rst(${PROJECT_SOURCE_DIR}/include/open62541/types.h ${DOC_SRC_DIR}/types.rst)
  17. generate_rst(${PROJECT_SOURCE_DIR}/include/open62541/constants.h ${DOC_SRC_DIR}/constants.rst)
  18. generate_rst(${PROJECT_BINARY_DIR}/src_generated/open62541/statuscodes.h ${DOC_SRC_DIR}/statuscodes.rst)
  19. generate_rst(${PROJECT_BINARY_DIR}/src_generated/open62541/types_generated.h ${DOC_SRC_DIR}/types_generated.rst)
  20. generate_rst(${PROJECT_SOURCE_DIR}/include/open62541/server_config.h ${DOC_SRC_DIR}/server_config.rst)
  21. generate_rst(${PROJECT_SOURCE_DIR}/include/open62541/server.h ${DOC_SRC_DIR}/server.rst)
  22. generate_rst(${PROJECT_SOURCE_DIR}/include/open62541/client_config.h ${DOC_SRC_DIR}/client_config.rst)
  23. generate_rst(${PROJECT_SOURCE_DIR}/include/open62541/client_subscriptions.h ${DOC_SRC_DIR}/client_subscriptions.rst)
  24. generate_rst(${PROJECT_SOURCE_DIR}/include/open62541/client.h ${DOC_SRC_DIR}/client.rst)
  25. generate_rst(${PROJECT_SOURCE_DIR}/include/open62541/client_highlevel.h ${DOC_SRC_DIR}/client_highlevel.rst)
  26. generate_rst(${PROJECT_SOURCE_DIR}/include/open62541/plugin/log.h ${DOC_SRC_DIR}/plugin_log.rst)
  27. generate_rst(${PROJECT_SOURCE_DIR}/include/open62541/plugin/network.h ${DOC_SRC_DIR}/plugin_network.rst)
  28. generate_rst(${PROJECT_SOURCE_DIR}/include/open62541/plugin/accesscontrol.h ${DOC_SRC_DIR}/plugin_accesscontrol.rst)
  29. generate_rst(${PROJECT_SOURCE_DIR}/src/server/ua_services.h ${DOC_SRC_DIR}/services.rst)
  30. generate_rst(${PROJECT_SOURCE_DIR}/include/open62541/plugin/nodestore.h ${DOC_SRC_DIR}/nodestore.rst)
  31. generate_rst(${PROJECT_SOURCE_DIR}/include/open62541/plugin/pubsub.h ${DOC_SRC_DIR}/plugin_pubsub_connection.rst)
  32. generate_rst(${PROJECT_SOURCE_DIR}/include/open62541/server_pubsub.h ${DOC_SRC_DIR}/pubsub.rst)
  33. # Doc from tutorial code
  34. generate_rst(${PROJECT_SOURCE_DIR}/examples/tutorial_datatypes.c ${DOC_SRC_DIR}/tutorial_datatypes.rst)
  35. generate_rst(${PROJECT_SOURCE_DIR}/examples/tutorial_server_firststeps.c ${DOC_SRC_DIR}/tutorial_server_firststeps.rst)
  36. generate_rst(${PROJECT_SOURCE_DIR}/examples/tutorial_server_variable.c ${DOC_SRC_DIR}/tutorial_server_variable.rst)
  37. generate_rst(${PROJECT_SOURCE_DIR}/examples/tutorial_server_variabletype.c ${DOC_SRC_DIR}/tutorial_server_variabletype.rst)
  38. generate_rst(${PROJECT_SOURCE_DIR}/examples/tutorial_server_datasource.c ${DOC_SRC_DIR}/tutorial_server_datasource.rst)
  39. generate_rst(${PROJECT_SOURCE_DIR}/examples/tutorial_server_events.c ${DOC_SRC_DIR}/tutorial_server_events.rst)
  40. generate_rst(${PROJECT_SOURCE_DIR}/examples/tutorial_server_monitoreditems.c ${DOC_SRC_DIR}/tutorial_server_monitoreditems.rst)
  41. generate_rst(${PROJECT_SOURCE_DIR}/examples/tutorial_server_object.c ${DOC_SRC_DIR}/tutorial_server_object.rst)
  42. generate_rst(${PROJECT_SOURCE_DIR}/examples/tutorial_server_method.c ${DOC_SRC_DIR}/tutorial_server_method.rst)
  43. generate_rst(${PROJECT_SOURCE_DIR}/examples/tutorial_client_firststeps.c ${DOC_SRC_DIR}/tutorial_client_firststeps.rst)
  44. generate_rst(${PROJECT_SOURCE_DIR}/examples/pubsub/tutorial_pubsub_publish.c ${DOC_SRC_DIR}/tutorial_pubsub_publish.rst)
  45. add_custom_target(doc_latex ${SPHINX_EXECUTABLE}
  46. -b latex "${DOC_SRC_DIR}" "${DOC_LATEX_DIR}"
  47. DEPENDS ${DOC_SRC_DIR}/types.rst ${DOC_SRC_DIR}/constants.rst ${DOC_SRC_DIR}/types_generated.rst
  48. ${DOC_SRC_DIR}/statuscodes.rst
  49. ${DOC_SRC_DIR}/server.rst ${DOC_SRC_DIR}/server_config.rst
  50. ${DOC_SRC_DIR}/client.rst ${DOC_SRC_DIR}/client_subscriptions.rst
  51. ${DOC_SRC_DIR}/client_highlevel.rst ${DOC_SRC_DIR}/client_config.rst
  52. ${DOC_SRC_DIR}/plugin_log.rst ${DOC_SRC_DIR}/plugin_network.rst
  53. ${DOC_SRC_DIR}/services.rst ${DOC_SRC_DIR}/plugin_accesscontrol.rst
  54. ${DOC_SRC_DIR}/nodestore.rst
  55. ${DOC_SRC_DIR}/tutorials.rst
  56. ${DOC_SRC_DIR}/tutorial_datatypes.rst
  57. ${DOC_SRC_DIR}/tutorial_client_firststeps.rst
  58. ${DOC_SRC_DIR}/tutorial_server_firststeps.rst
  59. ${DOC_SRC_DIR}/tutorial_server_variable.rst
  60. ${DOC_SRC_DIR}/tutorial_server_variabletype.rst
  61. ${DOC_SRC_DIR}/tutorial_server_datasource.rst
  62. ${DOC_SRC_DIR}/tutorial_server_monitoreditems.rst
  63. ${DOC_SRC_DIR}/tutorial_server_object.rst
  64. ${DOC_SRC_DIR}/tutorial_server_method.rst
  65. ${DOC_SRC_DIR}/tutorial_pubsub_publish.rst
  66. ${DOC_SRC_DIR}/plugin_pubsub_connection.rst
  67. ${DOC_SRC_DIR}/pubsub.rst
  68. ${DOC_SRC_DIR}/tutorial_server_events.rst
  69. COMMENT "Building LaTeX sources for documentation with Sphinx")
  70. add_dependencies(doc_latex open62541)
  71. add_custom_target(doc_pdf ${PDFLATEX_COMPILER} -interaction=batchmode "open62541.tex"
  72. WORKING_DIRECTORY ${DOC_LATEX_DIR}
  73. # compile it twice so that the contents pages are correct
  74. COMMAND ${PDFLATEX_COMPILER} -interaction=batchmode "open62541.tex"
  75. DEPENDS ${PDFLATEX_COMPILER}
  76. COMMENT "Generating PDF documentation from LaTeX sources")
  77. add_dependencies(doc_pdf doc_latex)
  78. add_custom_target(doc ${SPHINX_EXECUTABLE}
  79. -b html "${DOC_SRC_DIR}" "${DOC_HTML_DIR}"
  80. DEPENDS ${DOC_SRC_DIR}/types.rst ${DOC_SRC_DIR}/constants.rst ${DOC_SRC_DIR}/types_generated.rst
  81. ${DOC_SRC_DIR}/statuscodes.rst
  82. ${DOC_SRC_DIR}/server.rst ${DOC_SRC_DIR}/server_config.rst
  83. ${DOC_SRC_DIR}/client.rst ${DOC_SRC_DIR}/client_subscriptions.rst
  84. ${DOC_SRC_DIR}/client_highlevel.rst ${DOC_SRC_DIR}/client_config.rst
  85. ${DOC_SRC_DIR}/plugin_log.rst ${DOC_SRC_DIR}/plugin_network.rst
  86. ${DOC_SRC_DIR}/services.rst ${DOC_SRC_DIR}/plugin_accesscontrol.rst
  87. ${DOC_SRC_DIR}/nodestore.rst
  88. ${DOC_SRC_DIR}/tutorials.rst
  89. ${DOC_SRC_DIR}/tutorial_datatypes.rst
  90. ${DOC_SRC_DIR}/tutorial_client_firststeps.rst
  91. ${DOC_SRC_DIR}/tutorial_server_firststeps.rst
  92. ${DOC_SRC_DIR}/tutorial_server_variable.rst
  93. ${DOC_SRC_DIR}/tutorial_server_variabletype.rst
  94. ${DOC_SRC_DIR}/tutorial_server_datasource.rst
  95. ${DOC_SRC_DIR}/tutorial_server_monitoreditems.rst
  96. ${DOC_SRC_DIR}/tutorial_server_object.rst
  97. ${DOC_SRC_DIR}/tutorial_server_method.rst
  98. ${DOC_SRC_DIR}/tutorial_pubsub_publish.rst
  99. ${DOC_SRC_DIR}/plugin_pubsub_connection.rst
  100. ${DOC_SRC_DIR}/pubsub.rst
  101. ${DOC_SRC_DIR}/tutorial_server_events.rst
  102. COMMENT "Building HTML documentation with Sphinx")
  103. add_dependencies(doc open62541)
  104. set_target_properties(doc doc_latex doc_pdf PROPERTIES EXCLUDE_FROM_DEFAULT_BUILD TRUE)
  105. set_target_properties(doc doc_latex doc_pdf PROPERTIES FOLDER "open62541/doc")