|
@@ -48,7 +48,7 @@ if(CMAKE_COMPILER_IS_GNUCC OR "x${CMAKE_C_COMPILER_ID}" STREQUAL "xClang")
|
|
# binary size reduction settings
|
|
# binary size reduction settings
|
|
add_definitions(-ffunction-sections -fdata-sections -fno-stack-protector -fno-unwind-tables
|
|
add_definitions(-ffunction-sections -fdata-sections -fno-stack-protector -fno-unwind-tables
|
|
-fno-asynchronous-unwind-tables -fno-math-errno -fmerge-all-constants -fno-ident)
|
|
-fno-asynchronous-unwind-tables -fno-math-errno -fmerge-all-constants -fno-ident)
|
|
- if (APPLE)
|
|
|
|
|
|
+ if(APPLE)
|
|
set(CMAKE_C_LINK_FLAGS "${CMAKE_C_LINK_FLAGS} -Wl,-dead_strip")
|
|
set(CMAKE_C_LINK_FLAGS "${CMAKE_C_LINK_FLAGS} -Wl,-dead_strip")
|
|
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,-dead_strip")
|
|
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,-dead_strip")
|
|
else()
|
|
else()
|
|
@@ -56,19 +56,18 @@ if(CMAKE_COMPILER_IS_GNUCC OR "x${CMAKE_C_COMPILER_ID}" STREQUAL "xClang")
|
|
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,--gc-sections")
|
|
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,--gc-sections")
|
|
endif()
|
|
endif()
|
|
set(CMAKE_SHARED_LIBRARY_LINK_C_FLAGS "") # cmake sets -rdynamic by default
|
|
set(CMAKE_SHARED_LIBRARY_LINK_C_FLAGS "") # cmake sets -rdynamic by default
|
|
- if(NOT WIN32)
|
|
|
|
- if(NOT CYGWIN)
|
|
|
|
|
|
+ if(NOT WIN32 AND NOT CYGWIN)
|
|
add_definitions(-fvisibility=hidden -fPIC)
|
|
add_definitions(-fvisibility=hidden -fPIC)
|
|
- if (NOT APPLE)
|
|
|
|
- set(CMAKE_C_LINK_FLAGS "${CMAKE_C_LINK_FLAGS} -Wl,-z,norelro -Wl,--hash-style=gnu -Wl,--build-id=none")
|
|
|
|
- endif()
|
|
|
|
|
|
+ if(NOT APPLE)
|
|
|
|
+ # these settings reduce the binary size by ~2kb
|
|
|
|
+ set(CMAKE_C_LINK_FLAGS "${CMAKE_C_LINK_FLAGS} -Wl,-z,norelro -Wl,--hash-style=gnu -Wl,--build-id=none")
|
|
endif()
|
|
endif()
|
|
endif()
|
|
endif()
|
|
if(CMAKE_BUILD_TYPE STREQUAL "MinSizeRel" OR CMAKE_BUILD_TYPE STREQUAL "Release")
|
|
if(CMAKE_BUILD_TYPE STREQUAL "MinSizeRel" OR CMAKE_BUILD_TYPE STREQUAL "Release")
|
|
set(CMAKE_C_LINK_FLAGS "${CMAKE_C_LINK_FLAGS} -s")
|
|
set(CMAKE_C_LINK_FLAGS "${CMAKE_C_LINK_FLAGS} -s")
|
|
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -s")
|
|
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -s")
|
|
endif()
|
|
endif()
|
|
- if (APPLE)
|
|
|
|
|
|
+ if(APPLE)
|
|
set(CMAKE_MACOSX_RPATH 1)
|
|
set(CMAKE_MACOSX_RPATH 1)
|
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -D_DARWIN_C_SOURCE=1")
|
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -D_DARWIN_C_SOURCE=1")
|
|
endif()
|
|
endif()
|
|
@@ -91,8 +90,10 @@ set(exported_headers ${PROJECT_BINARY_DIR}/src_generated/ua_config.h
|
|
${PROJECT_SOURCE_DIR}/examples/logger_stdout.h)
|
|
${PROJECT_SOURCE_DIR}/examples/logger_stdout.h)
|
|
set(internal_headers ${PROJECT_SOURCE_DIR}/src/ua_util.h
|
|
set(internal_headers ${PROJECT_SOURCE_DIR}/src/ua_util.h
|
|
${PROJECT_SOURCE_DIR}/deps/queue.h
|
|
${PROJECT_SOURCE_DIR}/deps/queue.h
|
|
- ${PROJECT_BINARY_DIR}/src_generated/ua_transport_generated.h
|
|
|
|
${PROJECT_SOURCE_DIR}/src/ua_types_encoding_binary.h
|
|
${PROJECT_SOURCE_DIR}/src/ua_types_encoding_binary.h
|
|
|
|
+ ${PROJECT_BINARY_DIR}/src_generated/ua_types_generated_encoding_binary.h
|
|
|
|
+ ${PROJECT_BINARY_DIR}/src_generated/ua_transport_generated.h
|
|
|
|
+ ${PROJECT_BINARY_DIR}/src_generated/ua_transport_generated_encoding_binary.h
|
|
${PROJECT_SOURCE_DIR}/src/ua_securechannel.h
|
|
${PROJECT_SOURCE_DIR}/src/ua_securechannel.h
|
|
${PROJECT_SOURCE_DIR}/src/server/ua_nodes.h
|
|
${PROJECT_SOURCE_DIR}/src/server/ua_nodes.h
|
|
${PROJECT_SOURCE_DIR}/src/ua_session.h
|
|
${PROJECT_SOURCE_DIR}/src/ua_session.h
|
|
@@ -143,6 +144,7 @@ if(ENABLE_SUBSCRIPTIONS)
|
|
|
|
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/src_generated/ua_types_generated.c
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/src_generated/ua_types_generated.c
|
|
${PROJECT_BINARY_DIR}/src_generated/ua_types_generated.h
|
|
${PROJECT_BINARY_DIR}/src_generated/ua_types_generated.h
|
|
|
|
+ ${PROJECT_BINARY_DIR}/src_generated/ua_types_generated_encoding_binary.h
|
|
PRE_BUILD
|
|
PRE_BUILD
|
|
COMMAND ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/tools/generate_datatypes.py --enable-subscription-types=1 --typedescriptions ${PROJECT_SOURCE_DIR}/tools/schema/NodeIds.csv 0 ${PROJECT_SOURCE_DIR}/tools/schema/Opc.Ua.Types.bsd ${PROJECT_BINARY_DIR}/src_generated/ua_types
|
|
COMMAND ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/tools/generate_datatypes.py --enable-subscription-types=1 --typedescriptions ${PROJECT_SOURCE_DIR}/tools/schema/NodeIds.csv 0 ${PROJECT_SOURCE_DIR}/tools/schema/Opc.Ua.Types.bsd ${PROJECT_BINARY_DIR}/src_generated/ua_types
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/tools/generate_datatypes.py
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/tools/generate_datatypes.py
|
|
@@ -151,6 +153,7 @@ if(ENABLE_SUBSCRIPTIONS)
|
|
else()
|
|
else()
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/src_generated/ua_types_generated.c
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/src_generated/ua_types_generated.c
|
|
${PROJECT_BINARY_DIR}/src_generated/ua_types_generated.h
|
|
${PROJECT_BINARY_DIR}/src_generated/ua_types_generated.h
|
|
|
|
+ ${PROJECT_BINARY_DIR}/src_generated/ua_types_generated_encoding_binary.h
|
|
PRE_BUILD
|
|
PRE_BUILD
|
|
COMMAND ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/tools/generate_datatypes.py --typedescriptions ${PROJECT_SOURCE_DIR}/tools/schema/NodeIds.csv 0 ${PROJECT_SOURCE_DIR}/tools/schema/Opc.Ua.Types.bsd ${PROJECT_BINARY_DIR}/src_generated/ua_types
|
|
COMMAND ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/tools/generate_datatypes.py --typedescriptions ${PROJECT_SOURCE_DIR}/tools/schema/NodeIds.csv 0 ${PROJECT_SOURCE_DIR}/tools/schema/Opc.Ua.Types.bsd ${PROJECT_BINARY_DIR}/src_generated/ua_types
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/tools/generate_datatypes.py
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/tools/generate_datatypes.py
|
|
@@ -160,6 +163,7 @@ endif()
|
|
|
|
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/src_generated/ua_transport_generated.c
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/src_generated/ua_transport_generated.c
|
|
${PROJECT_BINARY_DIR}/src_generated/ua_transport_generated.h
|
|
${PROJECT_BINARY_DIR}/src_generated/ua_transport_generated.h
|
|
|
|
+ ${PROJECT_BINARY_DIR}/src_generated/ua_transport_generated_encoding_binary.h
|
|
PRE_BUILD
|
|
PRE_BUILD
|
|
COMMAND ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/tools/generate_datatypes.py --ns0-types-xml ${PROJECT_SOURCE_DIR}/tools/schema/Opc.Ua.Types.bsd 1 ${PROJECT_SOURCE_DIR}/tools/schema/Custom.Opc.Ua.Transport.bsd ${PROJECT_BINARY_DIR}/src_generated/ua_transport
|
|
COMMAND ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/tools/generate_datatypes.py --ns0-types-xml ${PROJECT_SOURCE_DIR}/tools/schema/Opc.Ua.Types.bsd 1 ${PROJECT_SOURCE_DIR}/tools/schema/Custom.Opc.Ua.Transport.bsd ${PROJECT_BINARY_DIR}/src_generated/ua_transport
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/tools/generate_datatypes.py
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/tools/generate_datatypes.py
|
|
@@ -250,16 +254,12 @@ option(ENABLE_AMALGAMATION "Concatenate the library to a single file open62541.h
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/open62541.h
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/open62541.h
|
|
PRE_BUILD
|
|
PRE_BUILD
|
|
COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/tools/amalgamate.py ${GIT_COMMIT_ID} ${CMAKE_CURRENT_BINARY_DIR}/open62541.h ${exported_headers}
|
|
COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/tools/amalgamate.py ${GIT_COMMIT_ID} ${CMAKE_CURRENT_BINARY_DIR}/open62541.h ${exported_headers}
|
|
-
|
|
|
|
-
|
|
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/tools/amalgamate.py ${exported_headers} ${internal_headers})
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/tools/amalgamate.py ${exported_headers} ${internal_headers})
|
|
|
|
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/open62541.c
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/open62541.c
|
|
PRE_BUILD
|
|
PRE_BUILD
|
|
-
|
|
|
|
COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/tools/amalgamate.py ${GIT_COMMIT_ID} ${CMAKE_CURRENT_BINARY_DIR}/open62541.c
|
|
COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/tools/amalgamate.py ${GIT_COMMIT_ID} ${CMAKE_CURRENT_BINARY_DIR}/open62541.c
|
|
${internal_headers} ${PROJECT_SOURCE_DIR}/src/server/ua_nodestore_hash.inc ${lib_sources}
|
|
${internal_headers} ${PROJECT_SOURCE_DIR}/src/server/ua_nodestore_hash.inc ${lib_sources}
|
|
-
|
|
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/tools/amalgamate.py ${internal_headers} ${PROJECT_SOURCE_DIR}/src/server/ua_nodestore_hash.inc ${lib_sources})
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/tools/amalgamate.py ${internal_headers} ${PROJECT_SOURCE_DIR}/src/server/ua_nodestore_hash.inc ${lib_sources})
|
|
|
|
|
|
if(ENABLE_AMALGAMATION)
|
|
if(ENABLE_AMALGAMATION)
|
|
@@ -272,16 +272,22 @@ else()
|
|
include_directories(${PROJECT_SOURCE_DIR}/include)
|
|
include_directories(${PROJECT_SOURCE_DIR}/include)
|
|
include_directories(${PROJECT_SOURCE_DIR}/deps)
|
|
include_directories(${PROJECT_SOURCE_DIR}/deps)
|
|
include_directories(${PROJECT_SOURCE_DIR}/src)
|
|
include_directories(${PROJECT_SOURCE_DIR}/src)
|
|
- include_directories(${PROJECT_BINARY_DIR}/src_generated)
|
|
|
|
endif()
|
|
endif()
|
|
|
|
+include_directories(${PROJECT_BINARY_DIR}/src_generated) #needed to locate an include of examples/server_nodeset.c
|
|
target_compile_definitions(open62541-object PRIVATE -DUA_DYNAMIC_LINKING)
|
|
target_compile_definitions(open62541-object PRIVATE -DUA_DYNAMIC_LINKING)
|
|
|
|
+
|
|
add_library(open62541 SHARED $<TARGET_OBJECTS:open62541-object>)
|
|
add_library(open62541 SHARED $<TARGET_OBJECTS:open62541-object>)
|
|
|
|
+add_library(open62541-static STATIC $<TARGET_OBJECTS:open62541-object>)
|
|
target_compile_definitions(open62541 PRIVATE -DUA_DYNAMIC_LINKING)
|
|
target_compile_definitions(open62541 PRIVATE -DUA_DYNAMIC_LINKING)
|
|
|
|
+target_compile_definitions(open62541-static PRIVATE -DUA_DYNAMIC_LINKING)
|
|
if(WIN32)
|
|
if(WIN32)
|
|
- target_link_libraries(open62541 ws2_32) #since networklayer_tcp is linked into the amalgate
|
|
|
|
|
|
+ # since networklayer_tcp is linked into the amalgate
|
|
|
|
+ target_link_libraries(open62541 ws2_32)
|
|
|
|
+ target_link_libraries(open62541-static ws2_32)
|
|
endif()
|
|
endif()
|
|
if(ENABLE_MULTITHREADING)
|
|
if(ENABLE_MULTITHREADING)
|
|
target_link_libraries(open62541 urcu-cds urcu urcu-common pthread)
|
|
target_link_libraries(open62541 urcu-cds urcu urcu-common pthread)
|
|
|
|
+ target_link_libraries(open62541-static urcu-cds urcu urcu-common pthread)
|
|
endif()
|
|
endif()
|
|
|
|
|
|
# build language bindings for the library
|
|
# build language bindings for the library
|
|
@@ -377,7 +383,57 @@ endif()
|
|
|
|
|
|
option(BUILD_EXAMPLES "Build example servers and clients" OFF)
|
|
option(BUILD_EXAMPLES "Build example servers and clients" OFF)
|
|
if(BUILD_EXAMPLES)
|
|
if(BUILD_EXAMPLES)
|
|
- add_subdirectory(examples)
|
|
|
|
|
|
+ #add_subdirectory(examples)
|
|
|
|
+ #FIXME: we had problem with static linking for msvs, here a quick and dirty workaround
|
|
|
|
+ #http://stackoverflow.com/questions/3704374/linking-error-lnk2019-in-msvc-unresolved-symbols-with-imp-prefix-but-shoul
|
|
|
|
+ #http://stackoverflow.com/questions/1089828/same-header-file-for-both-dll-and-static-library
|
|
|
|
+ if(NOT WIN32)
|
|
|
|
+ list(APPEND LIBS pthread)
|
|
|
|
+ if (NOT APPLE)
|
|
|
|
+ list(APPEND LIBS rt)
|
|
|
|
+ endif()
|
|
|
|
+ else()
|
|
|
|
+ list(APPEND LIBS ws2_32)
|
|
|
|
+ endif()
|
|
|
|
+ if(ENABLE_MULTITHREADING)
|
|
|
|
+ list(APPEND LIBS urcu-cds urcu urcu-common)
|
|
|
|
+ endif(ENABLE_MULTITHREADING)
|
|
|
|
+
|
|
|
|
+ add_executable(server_variable ${PROJECT_SOURCE_DIR}/examples/server_variable.c $<TARGET_OBJECTS:open62541-object>)
|
|
|
|
+ target_link_libraries(server_variable ${LIBS})
|
|
|
|
+
|
|
|
|
+ add_executable(server_datasource ${PROJECT_SOURCE_DIR}/examples/server_datasource.c $<TARGET_OBJECTS:open62541-object>)
|
|
|
|
+ target_link_libraries(server_datasource ${LIBS})
|
|
|
|
+
|
|
|
|
+ add_executable(server_firstSteps ${PROJECT_SOURCE_DIR}/examples/server_firstSteps.c $<TARGET_OBJECTS:open62541-object>)
|
|
|
|
+ target_link_libraries(server_firstSteps ${LIBS})
|
|
|
|
+
|
|
|
|
+ add_executable(client_firstSteps ${PROJECT_SOURCE_DIR}/examples/client_firstSteps.c $<TARGET_OBJECTS:open62541-object>)
|
|
|
|
+ target_link_libraries(client_firstSteps ${LIBS})
|
|
|
|
+
|
|
|
|
+ add_executable(server_repeated_job ${PROJECT_SOURCE_DIR}/examples/server_repeated_job.c $<TARGET_OBJECTS:open62541-object>)
|
|
|
|
+ target_link_libraries(server_repeated_job ${LIBS})
|
|
|
|
+
|
|
|
|
+ add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/src_generated/nodeset.h ${PROJECT_BINARY_DIR}/src_generated/nodeset.c
|
|
|
|
+ PRE_BUILD
|
|
|
|
+ COMMAND ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/tools/pyUANamespace/generate_open62541CCode.py -i ${PROJECT_SOURCE_DIR}/tools/pyUANamespace/NodeID_Blacklist_FullNS0.txt ${PROJECT_SOURCE_DIR}/tools/schema/namespace0/Opc.Ua.NodeSet2.xml ${PROJECT_SOURCE_DIR}/examples/server_nodeset.xml ${PROJECT_BINARY_DIR}/src_generated/nodeset
|
|
|
|
+ DEPENDS ${PROJECT_SOURCE_DIR}/tools/pyUANamespace/generate_open62541CCode.py
|
|
|
|
+ ${PROJECT_SOURCE_DIR}/tools/pyUANamespace/logger.py
|
|
|
|
+ ${PROJECT_SOURCE_DIR}/tools/pyUANamespace/open62541_MacroHelper.py
|
|
|
|
+ ${PROJECT_SOURCE_DIR}/tools/pyUANamespace/ua_builtin_types.py
|
|
|
|
+ ${PROJECT_SOURCE_DIR}/tools/pyUANamespace/ua_constants.py
|
|
|
|
+ ${PROJECT_SOURCE_DIR}/tools/pyUANamespace/ua_namespace.py
|
|
|
|
+ ${PROJECT_SOURCE_DIR}/tools/pyUANamespace/ua_node_types.py
|
|
|
|
+ ${PROJECT_SOURCE_DIR}/tools/pyUANamespace/NodeID_Blacklist_FullNS0.txt
|
|
|
|
+ ${PROJECT_SOURCE_DIR}/examples/server_nodeset.xml)
|
|
|
|
+
|
|
|
|
+ add_executable(server_nodeset ${PROJECT_SOURCE_DIR}/examples/server_nodeset.c ${PROJECT_BINARY_DIR}/src_generated/nodeset.c $<TARGET_OBJECTS:open62541-object>)
|
|
|
|
+ target_link_libraries(server_nodeset ${LIBS})
|
|
|
|
+
|
|
|
|
+ if(ENABLE_METHODCALLS)
|
|
|
|
+ add_executable(server_method ${PROJECT_SOURCE_DIR}/examples/server_method.c $<TARGET_OBJECTS:open62541-object>)
|
|
|
|
+ target_link_libraries(server_method ${LIBS})
|
|
|
|
+ endif()
|
|
endif()
|
|
endif()
|
|
|
|
|
|
# build documentation
|
|
# build documentation
|
|
@@ -391,9 +447,15 @@ if(BUILD_DOCUMENTATION)
|
|
${DOXYGEN_EXECUTABLE} ${PROJECT_BINARY_DIR}/Doxyfile
|
|
${DOXYGEN_EXECUTABLE} ${PROJECT_BINARY_DIR}/Doxyfile
|
|
WORKING_DIRECTORY ${PROJECT_BINARY_DIR}
|
|
WORKING_DIRECTORY ${PROJECT_BINARY_DIR}
|
|
COMMENT "Generating API documentation with Doxygen")
|
|
COMMENT "Generating API documentation with Doxygen")
|
|
|
|
+ add_custom_target(latex ${SPHINX_EXECUTABLE}
|
|
|
|
+ -b latex -c "${PROJECT_BINARY_DIR}"
|
|
|
|
+ "${PROJECT_SOURCE_DIR}/doc" "${PROJECT_BINARY_DIR}/doc/sphinx"
|
|
|
|
+ DEPENDS doxygen
|
|
|
|
+ COMMENT "Building LaTeX sources for documentation with Sphinx")
|
|
add_custom_target(doc ${SPHINX_EXECUTABLE}
|
|
add_custom_target(doc ${SPHINX_EXECUTABLE}
|
|
-b html -c "${PROJECT_BINARY_DIR}"
|
|
-b html -c "${PROJECT_BINARY_DIR}"
|
|
"${PROJECT_SOURCE_DIR}/doc" "${PROJECT_BINARY_DIR}/doc/sphinx"
|
|
"${PROJECT_SOURCE_DIR}/doc" "${PROJECT_BINARY_DIR}/doc/sphinx"
|
|
|
|
+ COMMAND ${CMAKE_COMMAND} -E copy "${PROJECT_SOURCE_DIR}/doc/open62541_html.png" "${PROJECT_BINARY_DIR}/doc/sphinx/_static/"
|
|
DEPENDS doxygen
|
|
DEPENDS doxygen
|
|
COMMENT "Building HTML documentation with Sphinx")
|
|
COMMENT "Building HTML documentation with Sphinx")
|
|
endif()
|
|
endif()
|