IXWebSocket/docs/build.md
2022-08-02 13:28:59 -07:00

3.9 KiB

Build

CMake

CMakefiles for the library and the examples are available. This library has few dependencies, so it is possible to just add the source files into your project. Otherwise the usual way will suffice.

mkdir build # make a build dir so that you can build out of tree.
cd build
cmake -DUSE_TLS=1 ..
make -j
make install # will install to /usr/local on Unix, on macOS it is a good idea to sudo chown -R `whoami`:staff /usr/local

Headers and a static library will be installed to the target dir. There is a unittest which can be executed by typing make test.

Options for building:

  • -DBUILD_SHARED_LIBS=ON will build the unittest as a shared libary instead of a static library, which is the default
  • -DUSE_ZLIB=1 will enable zlib support, required for http client + server + websocket per message deflate extension
  • -DUSE_TLS=1 will enable TLS support
  • -DUSE_OPEN_SSL=1 will use openssl for the TLS support (default on Linux and Windows). When using a custom version of openssl (say a prebuilt version, odd runtime problems can happens, as in #319, and special cmake trickery will be required (see this comment)
  • -DUSE_MBED_TLS=1 will use mbedlts for the TLS support
  • -DUSE_WS=1 will build the ws interactive command line tool
  • -DUSE_TEST=1 will build the unittest

If you are on Windows, look at the appveyor file (not maintained much though) or rather the github actions which have instructions for building dependencies.

It is also possible to externally include the project, so that everything is fetched over the wire when you build like so:

    ExternalProject_Add(
        IXWebSocket
        GIT_REPOSITORY https://github.com/machinezone/IXWebSocket.git
        ...
    )

vcpkg

It is possible to get IXWebSocket through Microsoft vcpkg.

vcpkg install ixwebsocket

To use the installed package within a cmake project, use the following:

 set(CMAKE_TOOLCHAIN_FILE "$ENV{VCPKG_ROOT}/scripts/buildsystems/vcpkg.cmake" CACHE STRING "") # this is super important in order for cmake to include the vcpkg search/lib paths!

 # find library and its headers
 find_path(IXWEBSOCKET_INCLUDE_DIR ixwebsocket/IXWebSocket.h)
 find_library(IXWEBSOCKET_LIBRARY ixwebsocket)
 # include headers
 include_directories(${IXWEBSOCKET_INCLUDE_DIR})
 # ...
 target_link_libraries(${PROJECT_NAME} ... ${IXWEBSOCKET_LIBRARY}) # Cmake will automatically fail the generation if the lib was not found, i.e is set to NOTFOUND

Conan

Download

Conan is currently supported through a recipe in Conan Center (Bintray entry).

Package reference

  • Conan 1.21.0 and up: ixwebsocket/7.9.2
  • Earlier versions: ixwebsocket/7.9.2@_/_

Note that the version listed here might not be the latest one. See Bintray or the recipe itself for the latest version. If you're migrating from the previous, custom Bintray remote, note that the package reference has to be lower-case.

Docker

There is a Dockerfile for running the unittest on Linux, and to run the ws tool. It is also available on the docker registry.

docker run docker.pkg.github.com/machinezone/ixwebsocket/ws:latest --help

To use docker-compose you must make a docker container first.

$ make docker
...
$ docker compose up &
...
$ docker exec -it ixwebsocket_ws_1 bash
app@ca2340eb9106:~$ ws --help
ws is a websocket tool
...