|
@@ -1,50 +1,63 @@
|
|
cmake_minimum_required(VERSION 2.8.11)
|
|
cmake_minimum_required(VERSION 2.8.11)
|
|
-# set(CMAKE_VERBOSE_MAKEFILE ON)
|
|
|
|
-
|
|
|
|
project(open62541 C)
|
|
project(open62541 C)
|
|
|
|
+# set(CMAKE_VERBOSE_MAKEFILE ON)
|
|
|
|
|
|
-FIND_PACKAGE(PythonInterp REQUIRED)
|
|
|
|
|
|
+######################
|
|
|
|
+# Check Dependencies #
|
|
|
|
+######################
|
|
|
|
|
|
-# Find Python-lxml
|
|
|
|
-execute_process ( COMMAND ${PYTHON_EXECUTABLE} -c "from distutils.sysconfig import get_python_lib; print(get_python_lib())" OUTPUT_VARIABLE PYTHON_SITE_PACKAGES OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
|
|
|
|
+# Find Python and Python-lxml
|
|
|
|
+find_package(PythonInterp REQUIRED)
|
|
|
|
+execute_process(COMMAND ${PYTHON_EXECUTABLE} -c "from distutils.sysconfig import get_python_lib; print(get_python_lib())"
|
|
|
|
+ OUTPUT_VARIABLE PYTHON_SITE_PACKAGES
|
|
|
|
+ OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
if(NOT EXISTS "${PYTHON_SITE_PACKAGES}/lxml")
|
|
if(NOT EXISTS "${PYTHON_SITE_PACKAGES}/lxml")
|
|
- execute_process ( COMMAND ${PYTHON_EXECUTABLE} -c "from distutils.sysconfig import get_python_lib; print(get_python_lib(True))" OUTPUT_VARIABLE PYTHON_SITE_PACKAGES OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
|
|
|
|
+ execute_process(COMMAND ${PYTHON_EXECUTABLE} -c "from distutils.sysconfig import get_python_lib; print(get_python_lib(True))"
|
|
|
|
+ OUTPUT_VARIABLE PYTHON_SITE_PACKAGES
|
|
|
|
+ OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
if(NOT EXISTS "${PYTHON_SITE_PACKAGES}/lxml")
|
|
if(NOT EXISTS "${PYTHON_SITE_PACKAGES}/lxml")
|
|
- message( FATAL_ERROR "Python-lxml is not installed.")
|
|
|
|
|
|
+ message(FATAL_ERROR "Python-lxml is not installed.")
|
|
endif()
|
|
endif()
|
|
endif()
|
|
endif()
|
|
|
|
|
|
|
|
+# Check for git
|
|
find_package(Git)
|
|
find_package(Git)
|
|
if(GIT_FOUND)
|
|
if(GIT_FOUND)
|
|
- execute_process(COMMAND ${GIT_EXECUTABLE} describe --abbrev=7 --dirty --always --tags RESULT_VARIABLE res_var OUTPUT_VARIABLE GIT_COM_ID )
|
|
|
|
- if( NOT ${res_var} EQUAL 0 )
|
|
|
|
- set( GIT_COMMIT_ID "unknown--git-commit-id-unknown")
|
|
|
|
- message( STATUS "Git failed (not a repo, or no tags). Build will not contain git revision info." )
|
|
|
|
|
|
+ execute_process(COMMAND ${GIT_EXECUTABLE} describe --abbrev=7 --dirty --always --tags
|
|
|
|
+ RESULT_VARIABLE res_var
|
|
|
|
+ OUTPUT_VARIABLE GIT_COM_ID )
|
|
|
|
+ if(NOT ${res_var} EQUAL 0)
|
|
|
|
+ set(GIT_COMMIT_ID "unknown--git-commit-id-unknown")
|
|
|
|
+ message(STATUS "Git failed (not a repo, or no tags). Build will not contain git revision info." )
|
|
else()
|
|
else()
|
|
- string( REPLACE "\n" "" GIT_COMMIT_ID ${GIT_COM_ID} )
|
|
|
|
|
|
+ string(REPLACE "\n" "" GIT_COMMIT_ID ${GIT_COM_ID} )
|
|
endif()
|
|
endif()
|
|
else()
|
|
else()
|
|
- set( GIT_COMMIT_ID "unknown--no-git-found")
|
|
|
|
- message( STATUS "Git not found. Build will not contain git revision info." )
|
|
|
|
|
|
+ set(GIT_COMMIT_ID "unknown--no-git-found")
|
|
|
|
+ message(STATUS "Git not found. Build will not contain git revision info." )
|
|
endif()
|
|
endif()
|
|
add_definitions("-DVERSION=${GIT_COMMIT_ID}")
|
|
add_definitions("-DVERSION=${GIT_COMMIT_ID}")
|
|
|
|
|
|
-MESSAGE (STATUS "Git version: " ${GIT_COMMIT_ID})
|
|
|
|
|
|
+message(STATUS "Git version: " ${GIT_COMMIT_ID})
|
|
|
|
|
|
set(CMAKE_MODULE_PATH "${PROJECT_SOURCE_DIR}/cmake")
|
|
set(CMAKE_MODULE_PATH "${PROJECT_SOURCE_DIR}/cmake")
|
|
|
|
|
|
|
|
+####################################
|
|
|
|
+# Build Type and Compiler Settings #
|
|
|
|
+####################################
|
|
|
|
+
|
|
# Set default build type.
|
|
# Set default build type.
|
|
if(NOT CMAKE_BUILD_TYPE)
|
|
if(NOT CMAKE_BUILD_TYPE)
|
|
- message(STATUS "CMAKE_BUILD_TYPE not given; setting to 'RelWithDebInfo'.")
|
|
|
|
- set(CMAKE_BUILD_TYPE "RelWithDebInfo" CACHE STRING "Choose the type of build." FORCE)
|
|
|
|
|
|
+ message(STATUS "CMAKE_BUILD_TYPE not given; setting to 'Debug'.")
|
|
|
|
+ set(CMAKE_BUILD_TYPE "Debug" CACHE STRING "Choose the type of build." FORCE)
|
|
endif()
|
|
endif()
|
|
|
|
|
|
# compiler flags
|
|
# compiler flags
|
|
if(CMAKE_COMPILER_IS_GNUCC OR "x${CMAKE_C_COMPILER_ID}" STREQUAL "xClang")
|
|
if(CMAKE_COMPILER_IS_GNUCC OR "x${CMAKE_C_COMPILER_ID}" STREQUAL "xClang")
|
|
add_definitions(-std=c99 -pipe -Wall -Wextra -Werror -Wformat -Wno-unused-parameter
|
|
add_definitions(-std=c99 -pipe -Wall -Wextra -Werror -Wformat -Wno-unused-parameter
|
|
- -Wno-unused-function -Wno-unused-label -Wpointer-arith -Wreturn-type -Wsign-compare -Wmultichar
|
|
|
|
- -Wcast-qual -Wmissing-prototypes -Wstrict-prototypes #-Wshadow #-Wconversion
|
|
|
|
- -Winit-self -Wuninitialized -Wformat-security -Wformat-nonliteral)
|
|
|
|
|
|
+ -Wno-unused-function -Wno-unused-label -Wpointer-arith -Wreturn-type -Wsign-compare -Wmultichar
|
|
|
|
+ -Wcast-qual -Wmissing-prototypes -Wstrict-prototypes #-Wshadow #-Wconversion
|
|
|
|
+ -Winit-self -Wuninitialized -Wformat-security -Wformat-nonliteral)
|
|
# 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)
|
|
@@ -76,7 +89,66 @@ elseif(MSVC)
|
|
set(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} /MTd")
|
|
set(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} /MTd")
|
|
endif()
|
|
endif()
|
|
|
|
|
|
-# build the main library
|
|
|
|
|
|
+############
|
|
|
|
+# Settings #
|
|
|
|
+############
|
|
|
|
+
|
|
|
|
+# Options
|
|
|
|
+set(UA_LOGLEVEL 300 CACHE STRING "Level at which logs shall be reported")
|
|
|
|
+option(UA_ENABLE_SUBSCRIPTIONS "Enable compilation of subscription and monitoring support." OFF)
|
|
|
|
+option(UA_ENABLE_METHODCALLS "Enable CallMethod/MethodCall service set" OFF)
|
|
|
|
+option(UA_ENABLE_MULTITHREADING "Enable multithreading" OFF)
|
|
|
|
+option(UA_ENABLE_NODEMANAGEMENT "Enable dynamic addition and removal of nodes" ON)
|
|
|
|
+option(UA_ENABLE_AMALGAMATION "Concatenate the library to a single file open62541.h/.c" OFF)
|
|
|
|
+option(UA_ENABLE_COVERAGE "Enable gcov coverage" OFF)
|
|
|
|
+if(UA_ENABLE_COVERAGE)
|
|
|
|
+ set(CMAKE_BUILD_TYPE DEBUG)
|
|
|
|
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fprofile-arcs -ftest-coverage")
|
|
|
|
+ set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -fprofile-arcs -ftest-coverage")
|
|
|
|
+ set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -fprofile-arcs -ftest-coverage")
|
|
|
|
+endif()
|
|
|
|
+
|
|
|
|
+# Advanced options
|
|
|
|
+option(UA_ENABLE_TYPENAMES "Add the type and member names to the UA_DataType structure" OFF)
|
|
|
|
+mark_as_advanced(UA_ENABLE_TYPENAMES)
|
|
|
|
+
|
|
|
|
+option(UA_ENABLE_GENERATE_NAMESPACE0 "Generate and load UA XML Namespace 0 definition" OFF)
|
|
|
|
+mark_as_advanced(UA_ENABLE_GENERATE_NAMESPACE0)
|
|
|
|
+
|
|
|
|
+option(UA_ENABLE_EMBEDDED_LIBC "Target has no libc, use internal definitions" OFF)
|
|
|
|
+mark_as_advanced(UA_ENABLE_EMBEDDED_LIBC)
|
|
|
|
+
|
|
|
|
+option(UA_ENABLE_EXTERNAL_NAMESPACES "Enable namespace handling by an external component (experimental)" OFF)
|
|
|
|
+mark_as_advanced(UA_ENABLE_EXTERNAL_NAMESPACES)
|
|
|
|
+
|
|
|
|
+option(UA_ENABLE_NONSTANDARD_STATELESS "Enable stateless extension" OFF)
|
|
|
|
+mark_as_advanced(UA_ENABLE_NONSTANDARD_STATELESS)
|
|
|
|
+
|
|
|
|
+option(UA_ENABLE_NONSTANDARD_UDP "Enable udp extension" OFF)
|
|
|
|
+mark_as_advanced(UA_ENABLE_NONSTANDARD_UDP)
|
|
|
|
+if(UA_ENABLE_NONSTANDARD_UDP)
|
|
|
|
+ set(UA_ENABLE_NONSTANDARD_STATELESS ON)
|
|
|
|
+endif()
|
|
|
|
+
|
|
|
|
+# Build Targets
|
|
|
|
+option(UA_BUILD_EXAMPLESERVER "Build the example server" OFF)
|
|
|
|
+option(UA_BUILD_EXAMPLECLIENT "Build a test client" OFF)
|
|
|
|
+option(UA_BUILD_UNIT_TESTS "Run unit tests after building" OFF)
|
|
|
|
+option(UA_BUILD_EXAMPLES "Build example servers and clients" OFF)
|
|
|
|
+option(UA_BUILD_DOCUMENTATION "Generate doxygen/sphinx documentation" OFF)
|
|
|
|
+
|
|
|
|
+# Advanced Build Targets
|
|
|
|
+option(UA_BUILD_SELFSIGNED_CERTIFICATE "Generate self-signed certificate" OFF)
|
|
|
|
+mark_as_advanced(UA_BUILD_SELFSIGNED_CERTIFICATE)
|
|
|
|
+
|
|
|
|
+#########################
|
|
|
|
+# Generate Main Library #
|
|
|
|
+#########################
|
|
|
|
+
|
|
|
|
+file(MAKE_DIRECTORY "${PROJECT_BINARY_DIR}/src_generated")
|
|
|
|
+include_directories(${PROJECT_BINARY_DIR}/src_generated) #needed to locate an include of examples/server_nodeset.c
|
|
|
|
+configure_file("include/ua_config.h.in" "${PROJECT_BINARY_DIR}/src_generated/ua_config.h")
|
|
|
|
+
|
|
set(exported_headers ${PROJECT_BINARY_DIR}/src_generated/ua_config.h
|
|
set(exported_headers ${PROJECT_BINARY_DIR}/src_generated/ua_config.h
|
|
${PROJECT_SOURCE_DIR}/include/ua_statuscodes.h
|
|
${PROJECT_SOURCE_DIR}/include/ua_statuscodes.h
|
|
${PROJECT_SOURCE_DIR}/include/ua_types.h
|
|
${PROJECT_SOURCE_DIR}/include/ua_types.h
|
|
@@ -133,76 +205,98 @@ set(lib_sources ${PROJECT_SOURCE_DIR}/src/ua_types.c
|
|
${PROJECT_SOURCE_DIR}/deps/pcg_basic.c)
|
|
${PROJECT_SOURCE_DIR}/deps/pcg_basic.c)
|
|
##TODO: make client stuff optional
|
|
##TODO: make client stuff optional
|
|
|
|
|
|
-## generate code from xml definitions
|
|
|
|
-file(MAKE_DIRECTORY "${PROJECT_BINARY_DIR}/src_generated")
|
|
|
|
|
|
+if(UA_ENABLE_METHODCALLS)
|
|
|
|
+ list(APPEND lib_sources ${PROJECT_SOURCE_DIR}/src/server/ua_services_call.c)
|
|
|
|
+endif()
|
|
|
|
|
|
-option(ENABLE_TYPEINTROSPECTION "Add the type and member names to the internal structures" OFF)
|
|
|
|
-mark_as_advanced(ENABLE_TYPEINTROSPECTION)
|
|
|
|
-if(ENABLE_TYPEINTROSPECTION)
|
|
|
|
- set(generate_typeintrospection "--typeintrospection")
|
|
|
|
|
|
+if(UA_ENABLE_EMBEDDED_LIBC)
|
|
|
|
+ list(APPEND lib_sources ${PROJECT_SOURCE_DIR}/deps/libc_string.c)
|
|
|
|
+endif()
|
|
|
|
+
|
|
|
|
+if(UA_ENABLE_MULTITHREADING)
|
|
|
|
+ find_package(Threads REQUIRED)
|
|
|
|
+ list(APPEND lib_sources ${PROJECT_SOURCE_DIR}/src/server/ua_nodestore_concurrent.c)
|
|
else()
|
|
else()
|
|
- set(generate_typeintrospection "")
|
|
|
|
|
|
+ list(APPEND lib_sources ${PROJECT_SOURCE_DIR}/src/server/ua_nodestore.c)
|
|
endif()
|
|
endif()
|
|
|
|
|
|
-option(UA_EMBEDDED_LIBC "Target has no libc, use internal definitions" OFF)
|
|
|
|
-if(UA_EMBEDDED_LIBC)
|
|
|
|
- list(APPEND lib_sources ${PROJECT_SOURCE_DIR}/deps/libc_string.c)
|
|
|
|
|
|
+set(generate_typeintrospection "")
|
|
|
|
+if(UA_ENABLE_TYPENAMES)
|
|
|
|
+ set(generate_typeintrospection "--typeintrospection")
|
|
endif()
|
|
endif()
|
|
|
|
|
|
-option(ENABLE_SUBSCRIPTIONS "Enable compilation of subscription and monitoring support." OFF)
|
|
|
|
-if(ENABLE_SUBSCRIPTIONS)
|
|
|
|
- set(ENABLE_SUBSCRIPTIONS ON) #to propagate it to the config file
|
|
|
|
|
|
+set(generate_subscriptiontypes "")
|
|
|
|
+if(UA_ENABLE_SUBSCRIPTIONS)
|
|
list(APPEND lib_sources ${PROJECT_SOURCE_DIR}/src/server/ua_services_subscription.c
|
|
list(APPEND lib_sources ${PROJECT_SOURCE_DIR}/src/server/ua_services_subscription.c
|
|
${PROJECT_SOURCE_DIR}/src/server/ua_subscription.c
|
|
${PROJECT_SOURCE_DIR}/src/server/ua_subscription.c
|
|
${PROJECT_SOURCE_DIR}/src/server/ua_subscription_manager.c
|
|
${PROJECT_SOURCE_DIR}/src/server/ua_subscription_manager.c
|
|
${PROJECT_SOURCE_DIR}/src/client/ua_client_highlevel_subscriptions.c)
|
|
${PROJECT_SOURCE_DIR}/src/client/ua_client_highlevel_subscriptions.c)
|
|
- ##append subscription headers at before ua_session.
|
|
|
|
|
|
+ #append subscription headers at before ua_session
|
|
list(FIND internal_headers "${PROJECT_SOURCE_DIR}/src/ua_session.h" UaSessionPos)
|
|
list(FIND internal_headers "${PROJECT_SOURCE_DIR}/src/ua_session.h" UaSessionPos)
|
|
list(INSERT internal_headers ${UaSessionPos} ${PROJECT_SOURCE_DIR}/src/server/ua_subscription.h
|
|
list(INSERT internal_headers ${UaSessionPos} ${PROJECT_SOURCE_DIR}/src/server/ua_subscription.h
|
|
${PROJECT_SOURCE_DIR}/src/server/ua_subscription_manager.h)
|
|
${PROJECT_SOURCE_DIR}/src/server/ua_subscription_manager.h)
|
|
|
|
+ set(generate_subscriptiontypes "--enable-subscription-types=1")
|
|
|
|
+endif()
|
|
|
|
|
|
- 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_encoding_binary.h
|
|
|
|
- PRE_BUILD
|
|
|
|
- COMMAND ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/tools/generate_datatypes.py --enable-subscription-types=1 ${generate_typeintrospection} --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
|
|
|
|
- ${CMAKE_CURRENT_SOURCE_DIR}/tools/schema/Opc.Ua.Types.bsd
|
|
|
|
- ${CMAKE_CURRENT_SOURCE_DIR}/tools/schema/NodeIds.csv)
|
|
|
|
-else()
|
|
|
|
|
|
+if(UA_ENABLE_GENERATE_NAMESPACE0)
|
|
|
|
+ set(GENERATE_NAMESPACE0_FILE "Opc.Ua.NodeSet2.xml" CACHE STRING "Namespace definition XML file")
|
|
|
|
+ set_property(CACHE GENERATE_NAMESPACE0_FILE PROPERTY STRINGS Opc.Ua.NodeSet2.xml Opc.Ua.NodeSet2.Minimal.xml)
|
|
|
|
+ list(APPEND internal_headers ${PROJECT_BINARY_DIR}/src_generated/ua_namespaceinit_generated.h)
|
|
|
|
+ list(APPEND lib_sources ${PROJECT_BINARY_DIR}/src_generated/ua_namespaceinit_generated.c)
|
|
|
|
+endif()
|
|
|
|
+
|
|
|
|
+#########################
|
|
|
|
+# Generate source files #
|
|
|
|
+#########################
|
|
|
|
+
|
|
|
|
+# standard data types
|
|
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
|
|
${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 ${generate_typeintrospection} --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
|
|
|
|
+ ${generate_subscriptiontypes}
|
|
|
|
+ ${generate_typeintrospection}
|
|
|
|
+ --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
|
|
${CMAKE_CURRENT_SOURCE_DIR}/tools/schema/Opc.Ua.Types.bsd
|
|
${CMAKE_CURRENT_SOURCE_DIR}/tools/schema/Opc.Ua.Types.bsd
|
|
${CMAKE_CURRENT_SOURCE_DIR}/tools/schema/NodeIds.csv)
|
|
${CMAKE_CURRENT_SOURCE_DIR}/tools/schema/NodeIds.csv)
|
|
-endif()
|
|
|
|
|
|
|
|
|
|
+# transport data types
|
|
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
|
|
${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 ${generate_typeintrospection} --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
|
|
|
|
+ ${generate_typeintrospection}
|
|
|
|
+ --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
|
|
${CMAKE_CURRENT_SOURCE_DIR}/tools/schema/Custom.Opc.Ua.Transport.bsd)
|
|
${CMAKE_CURRENT_SOURCE_DIR}/tools/schema/Custom.Opc.Ua.Transport.bsd)
|
|
|
|
|
|
|
|
+# nodeids
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/src_generated/ua_nodeids.h
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/src_generated/ua_nodeids.h
|
|
PRE_BUILD
|
|
PRE_BUILD
|
|
- COMMAND ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/tools/generate_nodeids.py ${PROJECT_SOURCE_DIR}/tools/schema/NodeIds.csv ${PROJECT_BINARY_DIR}/src_generated/ua_nodeids
|
|
|
|
|
|
+ COMMAND ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/tools/generate_nodeids.py
|
|
|
|
+ ${PROJECT_SOURCE_DIR}/tools/schema/NodeIds.csv
|
|
|
|
+ ${PROJECT_BINARY_DIR}/src_generated/ua_nodeids
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/tools/generate_nodeids.py
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/tools/generate_nodeids.py
|
|
${CMAKE_CURRENT_SOURCE_DIR}/tools/schema/NodeIds.csv)
|
|
${CMAKE_CURRENT_SOURCE_DIR}/tools/schema/NodeIds.csv)
|
|
|
|
|
|
-option(ENABLE_GENERATE_NAMESPACE0 "Generate and load UA XML Namespace 0 definition" OFF)
|
|
|
|
-if(ENABLE_GENERATE_NAMESPACE0)
|
|
|
|
-add_definitions(-DENABLE_GENERATE_NAMESPACE0)
|
|
|
|
-set(GENERATE_NAMESPACE0_FILE "Opc.Ua.NodeSet2.xml" CACHE STRING "Namespace definition XML file")
|
|
|
|
-set_property(CACHE GENERATE_NAMESPACE0_FILE PROPERTY STRINGS Opc.Ua.NodeSet2.xml Opc.Ua.NodeSet2.Minimal.xml)
|
|
|
|
|
|
+# generated namespace 0
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/src_generated/ua_namespaceinit_generated.c
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/src_generated/ua_namespaceinit_generated.c
|
|
${PROJECT_BINARY_DIR}/src_generated/ua_namespaceinit_generated.h
|
|
${PROJECT_BINARY_DIR}/src_generated/ua_namespaceinit_generated.h
|
|
PRE_BUILD
|
|
PRE_BUILD
|
|
- COMMAND ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/tools/pyUANamespace/generate_open62541CCode.py -i ${PROJECT_SOURCE_DIR}/tools/pyUANamespace/NodeID_AssumeExternal.txt -s description -b ${PROJECT_SOURCE_DIR}/tools/pyUANamespace/NodeID_Blacklist.txt ${PROJECT_SOURCE_DIR}/tools/schema/namespace0/${GENERATE_NAMESPACE0_FILE} ${PROJECT_BINARY_DIR}/src_generated/ua_namespaceinit_generated
|
|
|
|
|
|
+ COMMAND ${PYTHON_EXECUTABLE} ${PROJECT_SOURCE_DIR}/tools/pyUANamespace/generate_open62541CCode.py
|
|
|
|
+ -i ${PROJECT_SOURCE_DIR}/tools/pyUANamespace/NodeID_AssumeExternal.txt
|
|
|
|
+ -s description -b ${PROJECT_SOURCE_DIR}/tools/pyUANamespace/NodeID_Blacklist.txt
|
|
|
|
+ ${PROJECT_SOURCE_DIR}/tools/schema/namespace0/${GENERATE_NAMESPACE0_FILE}
|
|
|
|
+ ${PROJECT_BINARY_DIR}/src_generated/ua_namespaceinit_generated
|
|
DEPENDS ${PROJECT_SOURCE_DIR}/tools/schema/namespace0/${GENERATE_NAMESPACE0_FILE}
|
|
DEPENDS ${PROJECT_SOURCE_DIR}/tools/schema/namespace0/${GENERATE_NAMESPACE0_FILE}
|
|
${PROJECT_SOURCE_DIR}/tools/pyUANamespace/generate_open62541CCode.py
|
|
${PROJECT_SOURCE_DIR}/tools/pyUANamespace/generate_open62541CCode.py
|
|
${PROJECT_SOURCE_DIR}/tools/pyUANamespace/logger.py
|
|
${PROJECT_SOURCE_DIR}/tools/pyUANamespace/logger.py
|
|
@@ -212,81 +306,35 @@ add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/src_generated/ua_namespaceinit_g
|
|
${PROJECT_SOURCE_DIR}/tools/pyUANamespace/ua_namespace.py
|
|
${PROJECT_SOURCE_DIR}/tools/pyUANamespace/ua_namespace.py
|
|
${PROJECT_SOURCE_DIR}/tools/pyUANamespace/ua_node_types.py)
|
|
${PROJECT_SOURCE_DIR}/tools/pyUANamespace/ua_node_types.py)
|
|
|
|
|
|
-list(APPEND internal_headers ${PROJECT_BINARY_DIR}/src_generated/ua_namespaceinit_generated.h)
|
|
|
|
-list(APPEND lib_sources ${PROJECT_BINARY_DIR}/src_generated/ua_namespaceinit_generated.c)
|
|
|
|
-endif()
|
|
|
|
-
|
|
|
|
-## logging
|
|
|
|
-set(UA_LOGLEVEL 300 CACHE STRING "Level at which logs shall be reported")
|
|
|
|
-
|
|
|
|
-# Enable Methodcall service
|
|
|
|
-option(ENABLE_METHODCALLS "Enable CallMethod/MethodCall service set" OFF)
|
|
|
|
-if(ENABLE_METHODCALLS)
|
|
|
|
- set(ENABLE_METHODCALLS ON) #to propagate it to the config file
|
|
|
|
- list(APPEND lib_sources ${PROJECT_SOURCE_DIR}/src/server/ua_services_call.c)
|
|
|
|
-endif()
|
|
|
|
-
|
|
|
|
-## multithreading
|
|
|
|
-option(ENABLE_MULTITHREADING "Enable multithreading (experimental)" OFF)
|
|
|
|
-if(ENABLE_MULTITHREADING)
|
|
|
|
- set(UA_MULTITHREADING ON) #to propagate it to the config file
|
|
|
|
- find_package(Threads REQUIRED)
|
|
|
|
- list(APPEND lib_sources ${PROJECT_SOURCE_DIR}/src/server/ua_nodestore_concurrent.c)
|
|
|
|
-else()
|
|
|
|
- list(APPEND lib_sources ${PROJECT_SOURCE_DIR}/src/server/ua_nodestore.c)
|
|
|
|
-endif()
|
|
|
|
-
|
|
|
|
-option(ENABLE_EXTERNAL_NAMESPACES "Enable namespace handling by an external component (experimental)" OFF)
|
|
|
|
-if(ENABLE_EXTERNAL_NAMESPACES)
|
|
|
|
- add_definitions(-DUA_EXTERNAL_NAMESPACES)
|
|
|
|
-endif()
|
|
|
|
-
|
|
|
|
-## enable dynamic nodeset
|
|
|
|
-option(ENABLE_NODEMANAGEMENT "Enable dynamic addition and removal of nodes" ON)
|
|
|
|
-if(ENABLE_NODEMANAGEMENT)
|
|
|
|
- add_definitions(-DENABLE_NODEMANAGEMENT)
|
|
|
|
-endif()
|
|
|
|
-
|
|
|
|
-## set the precompiler flags
|
|
|
|
-configure_file("include/ua_config.h.in" "${PROJECT_BINARY_DIR}/src_generated/ua_config.h")
|
|
|
|
-
|
|
|
|
-## extensions
|
|
|
|
-option(EXTENSION_UDP "Enable udp extension" OFF)
|
|
|
|
-if(EXTENSION_UDP)
|
|
|
|
- add_definitions(-DEXTENSION_STATELESS)
|
|
|
|
- message(STATUS "Extensions: enabling udp")
|
|
|
|
- add_definitions(-DEXTENSION_UDP)
|
|
|
|
- add_executable(exampleServerUDP $<TARGET_OBJECTS:open62541-object> examples/networklayer_udp.c examples/server_udp.c)
|
|
|
|
- if(ENABLE_MULTITHREADING)
|
|
|
|
- target_link_libraries(exampleServerUDP urcu-cds urcu urcu-common)
|
|
|
|
- endif()
|
|
|
|
- if (NOT APPLE)
|
|
|
|
- target_link_libraries(exampleServerUDP rt)
|
|
|
|
- endif()
|
|
|
|
-endif()
|
|
|
|
-
|
|
|
|
-option(ENABLE_LEGACY "Enable LEGACY code" OFF)
|
|
|
|
-mark_as_advanced(ENABLE_LEGACY)
|
|
|
|
-
|
|
|
|
-option(EXTENSION_STATELESS "Enable stateless extension" OFF)
|
|
|
|
-if(EXTENSION_STATELESS)
|
|
|
|
- message(STATUS "Extensions: enabling stateless")
|
|
|
|
- add_definitions(-DEXTENSION_STATELESS)
|
|
|
|
-endif()
|
|
|
|
-
|
|
|
|
-option(ENABLE_AMALGAMATION "Concatenate the library to a single file open62541.h/.c" OFF)
|
|
|
|
|
|
+# single-file release
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/open62541.h
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/open62541.h
|
|
- PRE_BUILD
|
|
|
|
- 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})
|
|
|
|
|
|
+ PRE_BUILD
|
|
|
|
+ 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})
|
|
|
|
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/open62541.c
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/open62541.c
|
|
- PRE_BUILD
|
|
|
|
- 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}
|
|
|
|
- DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/tools/amalgamate.py ${internal_headers} ${PROJECT_SOURCE_DIR}/src/server/ua_nodestore_hash.inc ${lib_sources})
|
|
|
|
-
|
|
|
|
-if(ENABLE_AMALGAMATION)
|
|
|
|
|
|
+ PRE_BUILD
|
|
|
|
+ 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}
|
|
|
|
+ DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/tools/amalgamate.py
|
|
|
|
+ ${internal_headers}
|
|
|
|
+ ${PROJECT_SOURCE_DIR}/src/server/ua_nodestore_hash.inc
|
|
|
|
+ ${lib_sources})
|
|
|
|
+
|
|
|
|
+#################
|
|
|
|
+# Build Targets #
|
|
|
|
+#################
|
|
|
|
+
|
|
|
|
+# build shared library
|
|
|
|
+if(UA_ENABLE_AMALGAMATION)
|
|
add_custom_target(amalgamation ALL DEPENDS ${PROJECT_BINARY_DIR}/open62541.h ${PROJECT_BINARY_DIR}/open62541.c)
|
|
add_custom_target(amalgamation ALL DEPENDS ${PROJECT_BINARY_DIR}/open62541.h ${PROJECT_BINARY_DIR}/open62541.c)
|
|
add_library(open62541-object OBJECT ${PROJECT_BINARY_DIR}/open62541.c ${PROJECT_BINARY_DIR}/open62541.h)
|
|
add_library(open62541-object OBJECT ${PROJECT_BINARY_DIR}/open62541.c ${PROJECT_BINARY_DIR}/open62541.h)
|
|
include_directories(${PROJECT_BINARY_DIR})
|
|
include_directories(${PROJECT_BINARY_DIR})
|
|
@@ -297,40 +345,21 @@ else()
|
|
include_directories(${PROJECT_SOURCE_DIR}/deps)
|
|
include_directories(${PROJECT_SOURCE_DIR}/deps)
|
|
include_directories(${PROJECT_SOURCE_DIR}/src)
|
|
include_directories(${PROJECT_SOURCE_DIR}/src)
|
|
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>)
|
|
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)
|
|
target_compile_definitions(open62541-static PRIVATE -DUA_DYNAMIC_LINKING)
|
|
if(WIN32)
|
|
if(WIN32)
|
|
- # since networklayer_tcp is linked into the amalgate
|
|
|
|
- target_link_libraries(open62541 ws2_32)
|
|
|
|
- target_link_libraries(open62541-static ws2_32)
|
|
|
|
-endif()
|
|
|
|
-if(ENABLE_MULTITHREADING)
|
|
|
|
- target_link_libraries(open62541 urcu-cds urcu urcu-common pthread)
|
|
|
|
- target_link_libraries(open62541-static urcu-cds urcu urcu-common pthread)
|
|
|
|
-endif()
|
|
|
|
-
|
|
|
|
-# coverage
|
|
|
|
-option(ENABLE_COVERAGE "Enable gcov coverage" OFF)
|
|
|
|
-if(ENABLE_COVERAGE)
|
|
|
|
- message(STATUS "Enabling gcov support")
|
|
|
|
- set(CMAKE_BUILD_TYPE DEBUG)
|
|
|
|
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fprofile-arcs -ftest-coverage")
|
|
|
|
- set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -fprofile-arcs -ftest-coverage")
|
|
|
|
- set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -fprofile-arcs -ftest-coverage")
|
|
|
|
|
|
+ target_link_libraries(open62541 ws2_32)
|
|
|
|
+ target_link_libraries(open62541-static ws2_32)
|
|
endif()
|
|
endif()
|
|
|
|
|
|
-# build example server
|
|
|
|
-option(BUILD_EXAMPLESERVER "Build the example server" OFF)
|
|
|
|
-if(BUILD_EXAMPLESERVER)
|
|
|
|
|
|
+if(UA_BUILD_EXAMPLESERVER)
|
|
set(server_source $<TARGET_OBJECTS:open62541-object>)
|
|
set(server_source $<TARGET_OBJECTS:open62541-object>)
|
|
add_executable(server_static examples/server.c ${server_source})
|
|
add_executable(server_static examples/server.c ${server_source})
|
|
add_executable(server examples/server.c)
|
|
add_executable(server examples/server.c)
|
|
- if(ENABLE_AMALGAMATION)
|
|
|
|
|
|
+ if(UA_ENABLE_AMALGAMATION)
|
|
ADD_DEPENDENCIES(server amalgamation)
|
|
ADD_DEPENDENCIES(server amalgamation)
|
|
endif()
|
|
endif()
|
|
target_link_libraries(server open62541)
|
|
target_link_libraries(server open62541)
|
|
@@ -341,15 +370,23 @@ if(BUILD_EXAMPLESERVER)
|
|
target_link_libraries(server_static rt)
|
|
target_link_libraries(server_static rt)
|
|
target_link_libraries(server rt)
|
|
target_link_libraries(server rt)
|
|
endif()
|
|
endif()
|
|
- if(ENABLE_MULTITHREADING)
|
|
|
|
|
|
+ if(UA_ENABLE_MULTITHREADING)
|
|
target_link_libraries(server_static urcu-cds urcu urcu-common pthread)
|
|
target_link_libraries(server_static urcu-cds urcu urcu-common pthread)
|
|
target_link_libraries(server urcu-cds urcu urcu-common pthread)
|
|
target_link_libraries(server urcu-cds urcu urcu-common pthread)
|
|
endif()
|
|
endif()
|
|
|
|
+
|
|
|
|
+ if(UA_ENABLE_NONSTANDARD_UDP)
|
|
|
|
+ add_executable(exampleServerUDP $<TARGET_OBJECTS:open62541-object> examples/networklayer_udp.c examples/server_udp.c)
|
|
|
|
+ if(UA_ENABLE_MULTITHREADING)
|
|
|
|
+ target_link_libraries(exampleServerUDP urcu-cds urcu urcu-common)
|
|
|
|
+ endif()
|
|
|
|
+ if (NOT APPLE)
|
|
|
|
+ target_link_libraries(exampleServerUDP rt)
|
|
|
|
+ endif()
|
|
|
|
+ endif()
|
|
endif()
|
|
endif()
|
|
|
|
|
|
-## self-signed certificates
|
|
|
|
-option(GENERATE_SELFSIGNED "Generate self-signed certificates" OFF)
|
|
|
|
-if(GENERATE_SELFSIGNED)
|
|
|
|
|
|
+if(UA_BUILD_SELFSIGNED_CERTIFICATE)
|
|
message(STATUS "Enabling self-signed certificates")
|
|
message(STATUS "Enabling self-signed certificates")
|
|
find_package(OpenSSL REQUIRED)
|
|
find_package(OpenSSL REQUIRED)
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/server_cert.der
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/server_cert.der
|
|
@@ -360,14 +397,12 @@ if(GENERATE_SELFSIGNED)
|
|
add_custom_target(selfsigned ALL DEPENDS ${PROJECT_BINARY_DIR}/server_cert.der ${PROJECT_BINARY_DIR}/ca.crt)
|
|
add_custom_target(selfsigned ALL DEPENDS ${PROJECT_BINARY_DIR}/server_cert.der ${PROJECT_BINARY_DIR}/ca.crt)
|
|
endif()
|
|
endif()
|
|
|
|
|
|
-# build example client
|
|
|
|
-option(BUILD_EXAMPLECLIENT "Build a test client" OFF)
|
|
|
|
-if(BUILD_EXAMPLECLIENT)
|
|
|
|
|
|
+if(UA_BUILD_EXAMPLECLIENT)
|
|
add_definitions(-DBENCHMARK)
|
|
add_definitions(-DBENCHMARK)
|
|
set(client_source $<TARGET_OBJECTS:open62541-object>)
|
|
set(client_source $<TARGET_OBJECTS:open62541-object>)
|
|
add_executable(client_static examples/client.c ${client_source})
|
|
add_executable(client_static examples/client.c ${client_source})
|
|
add_executable(client examples/client.c)
|
|
add_executable(client examples/client.c)
|
|
- if(ENABLE_AMALGAMATION)
|
|
|
|
|
|
+ if(UA_ENABLE_AMALGAMATION)
|
|
ADD_DEPENDENCIES(client amalgamation)
|
|
ADD_DEPENDENCIES(client amalgamation)
|
|
endif()
|
|
endif()
|
|
target_link_libraries(client open62541)
|
|
target_link_libraries(client open62541)
|
|
@@ -378,32 +413,25 @@ if(BUILD_EXAMPLECLIENT)
|
|
target_link_libraries(client_static rt)
|
|
target_link_libraries(client_static rt)
|
|
target_link_libraries(client rt)
|
|
target_link_libraries(client rt)
|
|
endif()
|
|
endif()
|
|
- if(ENABLE_MULTITHREADING)
|
|
|
|
|
|
+ if(UA_ENABLE_MULTITHREADING)
|
|
target_link_libraries(client_static urcu-cds urcu urcu-common pthread)
|
|
target_link_libraries(client_static urcu-cds urcu urcu-common pthread)
|
|
target_link_libraries(client urcu-cds urcu urcu-common pthread)
|
|
target_link_libraries(client urcu-cds urcu urcu-common pthread)
|
|
endif()
|
|
endif()
|
|
if(EXTENSION_STATELESS AND NOT ENABLE_AMALGAMATION)
|
|
if(EXTENSION_STATELESS AND NOT ENABLE_AMALGAMATION)
|
|
add_executable(client_stateless examples/client_stateless.c ${client_source})
|
|
add_executable(client_stateless examples/client_stateless.c ${client_source})
|
|
- if(ENABLE_MULTITHREADING)
|
|
|
|
|
|
+ if(UA_ENABLE_MULTITHREADING)
|
|
target_link_libraries(client_stateless urcu-cds urcu urcu-common pthread)
|
|
target_link_libraries(client_stateless urcu-cds urcu urcu-common pthread)
|
|
endif()
|
|
endif()
|
|
endif()
|
|
endif()
|
|
- if(ENABLE_LEGACY AND NOT ENABLE_AMALGAMATION)
|
|
|
|
- add_executable(client_legacy ${PROJECT_SOURCE_DIR}/examples/client_legacy.c $<TARGET_OBJECTS:open62541-object>)
|
|
|
|
- target_link_libraries(client_legacy ${LIBS})
|
|
|
|
- endif()
|
|
|
|
endif()
|
|
endif()
|
|
|
|
|
|
-# build unit tests
|
|
|
|
-option(BUILD_UNIT_TESTS "Run unit tests after building" OFF)
|
|
|
|
-if(BUILD_UNIT_TESTS)
|
|
|
|
- add_definitions(-DBUILD_UNIT_TESTS)
|
|
|
|
|
|
+if(UA_BUILD_UNIT_TESTS)
|
|
|
|
+ add_definitions(-DUA_BUILD_UNIT_TESTS)
|
|
enable_testing()
|
|
enable_testing()
|
|
add_subdirectory(tests)
|
|
add_subdirectory(tests)
|
|
endif()
|
|
endif()
|
|
|
|
|
|
-option(BUILD_EXAMPLES "Build example servers and clients" OFF)
|
|
|
|
-if(BUILD_EXAMPLES)
|
|
|
|
|
|
+if(UA_BUILD_EXAMPLES)
|
|
#add_subdirectory(examples)
|
|
#add_subdirectory(examples)
|
|
#FIXME: we had problem with static linking for msvs, here a quick and dirty workaround
|
|
#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/3704374/linking-error-lnk2019-in-msvc-unresolved-symbols-with-imp-prefix-but-shoul
|
|
@@ -416,9 +444,9 @@ if(BUILD_EXAMPLES)
|
|
else()
|
|
else()
|
|
list(APPEND LIBS ws2_32)
|
|
list(APPEND LIBS ws2_32)
|
|
endif()
|
|
endif()
|
|
- if(ENABLE_MULTITHREADING)
|
|
|
|
|
|
+ if(UA_ENABLE_MULTITHREADING)
|
|
list(APPEND LIBS urcu-cds urcu urcu-common)
|
|
list(APPEND LIBS urcu-cds urcu urcu-common)
|
|
- endif(ENABLE_MULTITHREADING)
|
|
|
|
|
|
+ endif(UA_ENABLE_MULTITHREADING)
|
|
|
|
|
|
add_executable(server_variable ${PROJECT_SOURCE_DIR}/examples/server_variable.c $<TARGET_OBJECTS:open62541-object>)
|
|
add_executable(server_variable ${PROJECT_SOURCE_DIR}/examples/server_variable.c $<TARGET_OBJECTS:open62541-object>)
|
|
target_link_libraries(server_variable ${LIBS})
|
|
target_link_libraries(server_variable ${LIBS})
|
|
@@ -440,7 +468,11 @@ if(BUILD_EXAMPLES)
|
|
|
|
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/src_generated/nodeset.h ${PROJECT_BINARY_DIR}/src_generated/nodeset.c
|
|
add_custom_command(OUTPUT ${PROJECT_BINARY_DIR}/src_generated/nodeset.h ${PROJECT_BINARY_DIR}/src_generated/nodeset.c
|
|
PRE_BUILD
|
|
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
|
|
|
|
|
|
+ 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
|
|
DEPENDS ${PROJECT_SOURCE_DIR}/tools/pyUANamespace/generate_open62541CCode.py
|
|
${PROJECT_SOURCE_DIR}/tools/pyUANamespace/logger.py
|
|
${PROJECT_SOURCE_DIR}/tools/pyUANamespace/logger.py
|
|
${PROJECT_SOURCE_DIR}/tools/pyUANamespace/open62541_MacroHelper.py
|
|
${PROJECT_SOURCE_DIR}/tools/pyUANamespace/open62541_MacroHelper.py
|
|
@@ -451,35 +483,27 @@ if(BUILD_EXAMPLES)
|
|
${PROJECT_SOURCE_DIR}/tools/pyUANamespace/NodeID_Blacklist_FullNS0.txt
|
|
${PROJECT_SOURCE_DIR}/tools/pyUANamespace/NodeID_Blacklist_FullNS0.txt
|
|
${PROJECT_SOURCE_DIR}/examples/server_nodeset.xml)
|
|
${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>)
|
|
|
|
|
|
+ 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})
|
|
target_link_libraries(server_nodeset ${LIBS})
|
|
|
|
|
|
- if(ENABLE_METHODCALLS)
|
|
|
|
|
|
+ if(UA_ENABLE_METHODCALLS)
|
|
add_executable(server_method ${PROJECT_SOURCE_DIR}/examples/server_method.c $<TARGET_OBJECTS:open62541-object>)
|
|
add_executable(server_method ${PROJECT_SOURCE_DIR}/examples/server_method.c $<TARGET_OBJECTS:open62541-object>)
|
|
target_link_libraries(server_method ${LIBS})
|
|
target_link_libraries(server_method ${LIBS})
|
|
endif()
|
|
endif()
|
|
endif()
|
|
endif()
|
|
|
|
|
|
-# build documentation
|
|
|
|
-option(BUILD_DOCUMENTATION "Generate doxygen/sphinx documentation" OFF)
|
|
|
|
-if(BUILD_DOCUMENTATION)
|
|
|
|
- find_package(Doxygen REQUIRED)
|
|
|
|
|
|
+if(UA_BUILD_DOCUMENTATION)
|
|
find_package(Sphinx REQUIRED)
|
|
find_package(Sphinx REQUIRED)
|
|
- configure_file(${PROJECT_SOURCE_DIR}/doc/Doxyfile.in ${PROJECT_BINARY_DIR}/Doxyfile @ONLY)
|
|
|
|
configure_file(${PROJECT_SOURCE_DIR}/doc/conf.py ${PROJECT_BINARY_DIR}/conf.py @ONLY)
|
|
configure_file(${PROJECT_SOURCE_DIR}/doc/conf.py ${PROJECT_BINARY_DIR}/conf.py @ONLY)
|
|
- add_custom_target(doxygen
|
|
|
|
- ${DOXYGEN_EXECUTABLE} ${PROJECT_BINARY_DIR}/Doxyfile
|
|
|
|
- WORKING_DIRECTORY ${PROJECT_BINARY_DIR}
|
|
|
|
- COMMENT "Generating API documentation with Doxygen")
|
|
|
|
add_custom_target(latex ${SPHINX_EXECUTABLE}
|
|
add_custom_target(latex ${SPHINX_EXECUTABLE}
|
|
-b latex -c "${PROJECT_BINARY_DIR}"
|
|
-b latex -c "${PROJECT_BINARY_DIR}"
|
|
"${PROJECT_SOURCE_DIR}/doc" "${PROJECT_BINARY_DIR}/doc/sphinx"
|
|
"${PROJECT_SOURCE_DIR}/doc" "${PROJECT_BINARY_DIR}/doc/sphinx"
|
|
- DEPENDS doxygen
|
|
|
|
COMMENT "Building LaTeX sources for documentation with Sphinx")
|
|
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/"
|
|
COMMAND ${CMAKE_COMMAND} -E copy "${PROJECT_SOURCE_DIR}/doc/open62541_html.png" "${PROJECT_BINARY_DIR}/doc/sphinx/_static/"
|
|
- DEPENDS doxygen
|
|
|
|
COMMENT "Building HTML documentation with Sphinx")
|
|
COMMENT "Building HTML documentation with Sphinx")
|
|
endif()
|
|
endif()
|