12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 |
- find_package(Sphinx)
- find_package(LATEX)
- set(DOC_LATEX_DIR ${PROJECT_BINARY_DIR}/doc_latex)
- set(DOC_HTML_DIR ${PROJECT_BINARY_DIR}/doc)
- set(DOC_SRC_DIR ${PROJECT_BINARY_DIR}/doc_src)
- make_directory(${DOC_SRC_DIR})
- file(GLOB DOC_SRC "${PROJECT_SOURCE_DIR}/doc/*")
- list(REMOVE_ITEM DOC_SRC "${PROJECT_SOURCE_DIR}/doc/conf.py")
- file(COPY ${DOC_SRC} DESTINATION ${DOC_SRC_DIR})
- configure_file("${PROJECT_SOURCE_DIR}/doc/conf.py" "${DOC_SRC_DIR}/conf.py")
- function(generate_rst in out)
- add_custom_command(OUTPUT ${out} DEPENDS ${PROJECT_SOURCE_DIR}/tools/c2rst.py ${in}
- PRE_BUILD COMMAND ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/tools/c2rst.py ${in} ${out})
- endfunction()
- # Doc from headers
- generate_rst(${PROJECT_SOURCE_DIR}/include/ua_types.h ${DOC_SRC_DIR}/types.rst)
- generate_rst(${PROJECT_SOURCE_DIR}/include/ua_constants.h ${DOC_SRC_DIR}/constants.rst)
- generate_rst(${PROJECT_BINARY_DIR}/src_generated/ua_types_generated.h ${DOC_SRC_DIR}/types_generated.rst)
- generate_rst(${PROJECT_SOURCE_DIR}/include/ua_server.h ${DOC_SRC_DIR}/server.rst)
- generate_rst(${PROJECT_SOURCE_DIR}/include/ua_client.h ${DOC_SRC_DIR}/client.rst)
- generate_rst(${PROJECT_SOURCE_DIR}/include/ua_client_highlevel.h ${DOC_SRC_DIR}/client_highlevel.rst)
- generate_rst(${PROJECT_SOURCE_DIR}/include/ua_plugin_log.h ${DOC_SRC_DIR}/plugin_log.rst)
- generate_rst(${PROJECT_SOURCE_DIR}/include/ua_plugin_network.h ${DOC_SRC_DIR}/plugin_network.rst)
- generate_rst(${PROJECT_SOURCE_DIR}/include/ua_plugin_access_control.h ${DOC_SRC_DIR}/plugin_access_control.rst)
- generate_rst(${PROJECT_SOURCE_DIR}/src/server/ua_services.h ${DOC_SRC_DIR}/services.rst)
- generate_rst(${PROJECT_SOURCE_DIR}/include/ua_plugin_nodestore.h ${DOC_SRC_DIR}/nodestore.rst)
- # Doc from tutorial code
- generate_rst(${PROJECT_SOURCE_DIR}/examples/tutorial_datatypes.c ${DOC_SRC_DIR}/tutorial_datatypes.rst)
- generate_rst(${PROJECT_SOURCE_DIR}/examples/tutorial_server_firststeps.c ${DOC_SRC_DIR}/tutorial_server_firststeps.rst)
- generate_rst(${PROJECT_SOURCE_DIR}/examples/tutorial_server_variable.c ${DOC_SRC_DIR}/tutorial_server_variable.rst)
- generate_rst(${PROJECT_SOURCE_DIR}/examples/tutorial_server_variabletype.c ${DOC_SRC_DIR}/tutorial_server_variabletype.rst)
- generate_rst(${PROJECT_SOURCE_DIR}/examples/tutorial_server_datasource.c ${DOC_SRC_DIR}/tutorial_server_datasource.rst)
- generate_rst(${PROJECT_SOURCE_DIR}/examples/tutorial_server_object.c ${DOC_SRC_DIR}/tutorial_server_object.rst)
- generate_rst(${PROJECT_SOURCE_DIR}/examples/tutorial_server_method.c ${DOC_SRC_DIR}/tutorial_server_method.rst)
- generate_rst(${PROJECT_SOURCE_DIR}/examples/tutorial_client_firststeps.c ${DOC_SRC_DIR}/tutorial_client_firststeps.rst)
- add_custom_target(doc_latex ${SPHINX_EXECUTABLE}
- -b latex "${DOC_SRC_DIR}" "${DOC_LATEX_DIR}"
- DEPENDS ${DOC_SRC_DIR}/types.rst ${DOC_SRC_DIR}/constants.rst ${DOC_SRC_DIR}/types_generated.rst
- ${DOC_SRC_DIR}/server.rst ${DOC_SRC_DIR}/client.rst ${DOC_SRC_DIR}/client_highlevel.rst
- ${DOC_SRC_DIR}/plugin_log.rst ${DOC_SRC_DIR}/plugin_network.rst
- ${DOC_SRC_DIR}/services.rst ${DOC_SRC_DIR}/plugin_access_control.rst
- ${DOC_SRC_DIR}/nodestore.rst
- ${DOC_SRC_DIR}/tutorial_datatypes.rst
- ${DOC_SRC_DIR}/tutorial_client_firststeps.rst
- ${DOC_SRC_DIR}/tutorial_server_firststeps.rst
- ${DOC_SRC_DIR}/tutorial_server_variable.rst
- ${DOC_SRC_DIR}/tutorial_server_variabletype.rst
- ${DOC_SRC_DIR}/tutorial_server_datasource.rst
- ${DOC_SRC_DIR}/tutorial_server_object.rst
- ${DOC_SRC_DIR}/tutorial_server_method.rst
- COMMENT "Building LaTeX sources for documentation with Sphinx")
- add_dependencies(doc_latex open62541)
- add_custom_target(doc_pdf ${PDFLATEX_COMPILER} --quiet "open62541.tex"
- WORKING_DIRECTORY ${DOC_LATEX_DIR}
- # compile it twice so that the contents pages are correct
- COMMAND ${PDFLATEX_COMPILER} --quiet "open62541.tex"
- DEPENDS ${PDFLATEX_COMPILER}
- COMMENT "Generating PDF documentation from LaTeX sources")
- add_dependencies(doc_pdf doc_latex)
- add_custom_target(doc ${SPHINX_EXECUTABLE}
- -b html "${DOC_SRC_DIR}" "${DOC_HTML_DIR}"
- DEPENDS ${DOC_SRC_DIR}/types.rst ${DOC_SRC_DIR}/constants.rst ${DOC_SRC_DIR}/types_generated.rst
- ${DOC_SRC_DIR}/server.rst ${DOC_SRC_DIR}/client.rst ${DOC_SRC_DIR}/client_highlevel.rst
- ${DOC_SRC_DIR}/plugin_log.rst ${DOC_SRC_DIR}/plugin_network.rst
- ${DOC_SRC_DIR}/services.rst ${DOC_SRC_DIR}/plugin_access_control.rst
- ${DOC_SRC_DIR}/nodestore.rst
- ${DOC_SRC_DIR}/tutorial_datatypes.rst
- ${DOC_SRC_DIR}/tutorial_client_firststeps.rst
- ${DOC_SRC_DIR}/tutorial_server_firststeps.rst
- ${DOC_SRC_DIR}/tutorial_server_variable.rst
- ${DOC_SRC_DIR}/tutorial_server_variabletype.rst
- ${DOC_SRC_DIR}/tutorial_server_datasource.rst
- ${DOC_SRC_DIR}/tutorial_server_object.rst
- ${DOC_SRC_DIR}/tutorial_server_method.rst
- COMMENT "Building HTML documentation with Sphinx")
- add_dependencies(doc open62541)
- set_target_properties(doc doc_latex doc_pdf PROPERTIES EXCLUDE_FROM_DEFAULT_BUILD TRUE)
- set_target_properties(doc doc_latex doc_pdf PROPERTIES FOLDER "open62541/doc")
|