diff options
| author | Thomas Vanbesien <tvanbesi@proton.me> | 2026-02-17 02:27:51 +0100 |
|---|---|---|
| committer | Thomas Vanbesien <tvanbesi@proton.me> | 2026-02-17 02:27:51 +0100 |
| commit | c35eb35bb63a97b7c46e879819757a9cb48165b5 (patch) | |
| tree | abc7f07740fae388f4ff6776585b56f56ec558c9 /cmake/BuildDeps.cmake | |
| download | BobinkCOpcUa-c35eb35bb63a97b7c46e879819757a9cb48165b5.tar.gz BobinkCOpcUa-c35eb35bb63a97b7c46e879819757a9cb48165b5.zip | |
Initial commit: OPC UA discovery project
CMake-based C project using open62541 for OPC UA discovery.
Includes Local Discovery Server, register server, and find
servers client with OpenSSL encryption support.
Diffstat (limited to 'cmake/BuildDeps.cmake')
| -rw-r--r-- | cmake/BuildDeps.cmake | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/cmake/BuildDeps.cmake b/cmake/BuildDeps.cmake new file mode 100644 index 0000000..d535e0a --- /dev/null +++ b/cmake/BuildDeps.cmake @@ -0,0 +1,50 @@ +set(OPEN62541_SOURCE_DIR "${CMAKE_SOURCE_DIR}/deps/open62541") +set(OPEN62541_BUILD_DIR "${CMAKE_BINARY_DIR}/deps/open62541") +set(OPEN62541_INSTALL_DIR "${CMAKE_BINARY_DIR}/deps/open62541-install") + +# --- open62541 --- + +if(NOT EXISTS "${OPEN62541_SOURCE_DIR}/CMakeLists.txt") + message( + FATAL_ERROR + "open62541 submodule not initialized. Run: git submodule update --init --recursive" + ) +endif() + +if(NOT EXISTS "${OPEN62541_INSTALL_DIR}/lib/libopen62541.so") + + message(STATUS "Configuring open62541 in ${OPEN62541_BUILD_DIR}...") + set(_cmd + ${CMAKE_COMMAND} + -S + "${OPEN62541_SOURCE_DIR}" + -B + "${OPEN62541_BUILD_DIR}" + -G + Ninja + -DCMAKE_INSTALL_PREFIX=${OPEN62541_INSTALL_DIR} + -DUA_ENABLE_ENCRYPTION=OPENSSL + -DUA_ENABLE_DISCOVERY=ON) + execute_process(COMMAND ${_cmd} RESULT_VARIABLE _result) + if(_result) + message(FATAL_ERROR "${_cmd} failed: ${_result}") + endif() + + message(STATUS "Building open62541 in ${OPEN62541_BUILD_DIR}...") + set(_cmd ${CMAKE_COMMAND} --build "${OPEN62541_BUILD_DIR}" --parallel) + execute_process(COMMAND ${_cmd} RESULT_VARIABLE _result) + if(_result) + message(FATAL_ERROR "${_cmd} failed: ${_result}") + endif() + + message(STATUS "Installing open62541 to ${OPEN62541_INSTALL_DIR}...") + set(_cmd ${CMAKE_COMMAND} --install "${OPEN62541_BUILD_DIR}") + execute_process(COMMAND ${_cmd} RESULT_VARIABLE _result) + if(_result) + message(FATAL_ERROR "${_cmd} failed: ${_result}") + endif() +else() + message(STATUS "open62541 already built, skipping") +endif() + +find_package(open62541 REQUIRED PATHS "${OPEN62541_INSTALL_DIR}" NO_DEFAULT_PATH) |
