This is a fork of open62541, https://github.com/open62541/open62541

Julius Pfrommer 1d0c0e9165 use cmake tests for unit tests il y a 10 ans
CMakeModules 61bf978379 check infrastructure il y a 10 ans
doc eca33ebd6d generate doxygen with cmake il y a 10 ans
examples cf423b3ed7 build on linux il y a 10 ans
schema e6ba7e219f Merge remote-tracking branch 'origin/master' into connection_secureChannel il y a 10 ans
src cf423b3ed7 build on linux il y a 10 ans
tests 1d0c0e9165 use cmake tests for unit tests il y a 10 ans
tools eca33ebd6d generate doxygen with cmake il y a 10 ans
wrappers a29e7aba18 add missing include to expat to python wrapper il y a 10 ans
.gitignore 596f70813a Merge of branch namespace_generation il y a 10 ans
.travis.yml 618909370d changed travis ci bot password il y a 10 ans
CMakeLists.txt 1d0c0e9165 use cmake tests for unit tests il y a 10 ans
LICENSE 9310d323c9 changed .gitignore again il y a 10 ans
README.md 9c58f4d79b add liburcu-dev (for multithreading) to the dependencies il y a 10 ans

README.md

open62541

An open-source communication stack implementation of OPC UA (OPC Unified Architecture) licensed under LGPL + static linking exception.

Ohloh Project Status Build Status Coverage Status Coverity Scan Build Status

Documentation

Documentation is generated from Doxygen annotations in the source code. The current version can be accessed at http://open62541.org/doxygen/.

Getting dependencies

Ubuntu

Getting gcc toolchain:
sudo apt-get install build-essential subversion git autoconf libtool pkg-config texinfo
Getting python toolchain for the 62541 structures code generator:
sudo apt-get install python python-lxml 
Getting additional libraries:
sudo apt-get install expat libexpat1-dev liburcu-dev
Getting and installing check as unit test framework (http://check.sourceforge.net/):
$ svn checkout https://svn.code.sf.net/p/check/code/trunk check-code
$ cd check-code
$ autoreconf --install
$ ./configure
$ make
$ sudo make install
$ sudo ldconfig
Getting and using Doxygen
  • install the needed packages bash sudo apt-get install graphviz doxygen
  • configure autotools, clean and build: bash $ ./configure --enable-doxygen $ make clean $ make all
  • the output is generated in doc/html/index.htm
  • configure the output of Doxygen with doc/Doxygen.in file

Windows

Getting MinGW and MSYS:
Get Gtk+ bundle (just for m4 marcros and pkg-config):
Get expat
  • start MinGW Installation Manager
  • choose all Packages, mark mingw32-expat and install
  • Open MinGW\msys\1.0\msys.bat bash $ mingw-get install libexpat
Get Python and lxml:
  • download Python (Windows x86 MSI Installer) at https://python.org/downloads (necessary version: 2.7.x)
  • install the executable
  • add the install directory (e. g. "c:\python27") to your windows path variable [Selectable in the setup-options]
  • restart mingw console
  • install lxml by either downloading and installing http://www.lfd.uci.edu/~gohlke/pythonlibs/#lxml (choose the version which fits to your python installation (x86 version)) or by following the instructions given here: http://lxml.de/installation.html
  • add ("C:\Python27\Tools\Scripts") to your windows path variable
Get git (IMPORTANT: get 1.8.4, since 1.8.5.2 has a bug):
SVN:
Getting and installing check as unit testing framework (http://check.sourceforge.net/):
  • Open MinGW\msys\1.0\msys.bat
$ svn checkout svn://svn.code.sf.net/p/check/code/trunk check-code
$ cd check-code
$ autoreconf --install
$ ./configure
$ make
$ make install
Adjusting MinGW
  • open the file c:\MinGW\include\io.h and replace every off64_t with _off64_t (4x should off64_t appear)
  • open the file c:\MinGW\include\unistd.h and replace every off_t with _off_t (2x should off_t appear)
  • download the queue.h header @ http://cvsweb.netbsd.org/bsdweb.cgi/src/sys/sys/queue.h and copy it to c:\MinGW\include\sys

Building

  • use autogen.sh only first time and whenever aclocal.m4 or configure.ac were modified bash $ cd open62541 $ ./autogen.sh $ ./configure --enable-debug=yes $ make $ make check

Configure Options

  • --enable-debug=(yes|no|verbose) - omit/include debug code
  • --enable-multithreading - enable pthreads (for examples/src/opcuaServerMT)
  • --enable-doxygen - make documentation as well
  • --enable-coverage - profiling with gcov,lcov, make check will generate reports in tests/coverage