$ git clone https://github.com/paullouisageneau/libdatachannel.git
$ cd libdatachannel
$ git submodule update --init --recursive
The CMake library targets libdatachannel
and libdatachannel-static
respectively correspond to the shared and static libraries. The default target will build tests and examples.
The option USE_GNUTLS
allows to switch between OpenSSL (default) and GnuTLS, and the option USE_NICE
allows to switch between libjuice as submodule (default) and libnice. The options USE_SYSTEM_SRTP
and USE_SYSTEM_JUICE
allow to link against the system library rather than building the submodule, for libsrtp and libjuice respectively.
If you only need Data Channels, the option NO_MEDIA
allows to make the library lighter by removing media support. Similarly, NO_WEBSOCKET
removes WebSocket support.
$ cmake -B build -DUSE_GNUTLS=1 -DUSE_NICE=0
$ cd build
$ make -j2
To generate an Xcode project in the build
directory:
$ cmake -B build -DUSE_GNUTLS=0 -DUSE_NICE=0 -G Xcode
You need to add OpenSSL root directory if the build fails with the following message:
Could NOT find OpenSSL, try to set the path to OpenSSL root folder in the system variable OPENSSL_ROOT_DIR (missing: OPENSSL_CRYPTO_LIBRARY OPENSSL_INCLUDE_DIR)
For example:
$ cmake -B build -DUSE_GNUTLS=0 -DUSE_NICE=0 -G Xcode -DOPENSSL_ROOT_DIR=/usr/local/Cellar/openssl\@1.1/1.1.1h/
$ cmake -B build -DCMAKE_TOOLCHAIN_FILE=/usr/share/mingw/toolchain-x86_64-w64-mingw32.cmake # replace with your toolchain file
$ cd build
$ make -j2
$ cmake -B build -G "NMake Makefiles"
$ cd build
$ nmake
The option USE_GNUTLS
allows to switch between OpenSSL (default) and GnuTLS, and the option USE_NICE
allows to switch between libjuice as submodule (default) and libnice.
If you only need Data Channels, the option NO_MEDIA
removes media support. Similarly, NO_WEBSOCKET
removes WebSocket support.
$ make USE_GNUTLS=1 USE_NICE=0