Skip to content

Latest commit

 

History

History
75 lines (53 loc) · 2.46 KB

INSTALL.md

File metadata and controls

75 lines (53 loc) · 2.46 KB

How to build

Bear should be quite portable on UNIX operating systems. It has been tested on FreeBSD, GNU/Linux and OS X.

Build dependencies

  1. C++ compiler, to compile the sources. (Shall support C++17 dialect.)
  2. CMake, to configure the build. (Minimum version is 3.2) And a build tool supported by CMake.
  3. pkg-config to look up for dependencies' compiler flags.
  4. protoc and grpc_cpp_plugin commands. (See gRPC dependencies.)

Dependencies

The dependencies can come from OS packages or the build will fetch the sources and build locally.

Developer dependencies:

Install dependencies from packages on Fedora 32

dnf install python cmake pkg-config
dnf install json-devel spdlog-devel fmt-devel grpc-devel grpc-plugins
dnf install gtest-devel gmock-devel # optional for running the tests

Install dependencies from packages on Arch

pacman -S python cmake pkg-config
pacman -S grpc spdlog fmt nlohmann-json
pacman -S gtest gmock # optional for running the tests

Install dependencies from packages on Ubuntu 20.04

apt-get install python cmake pkg-config
apt-get install libfmt-dev libspdlog-dev nlohmann-json3-dev
apt-get install libgrpc++-dev protobuf-compiler-grpc

Install dependencies from packages from Brew

brew install fmt spdlog nlohmann-json grpc pkg-config

Build commands

Ideally, you should build Bear in a separate build directory.

cmake -DENABLE_UNIT_TESTS=OFF -DENABLE_FUNC_TESTS=OFF $BEAR_SOURCE_DIR
make all
make install

You can configure the build process with passing arguments to cmake.

To run test during the build process, you will need to install the test frameworks and re-configure the build. For unit testing Bear uses googletest, which will be built from source if you not install it before.

# install `lit` the functional test framework into a python virtualenv
mkvirtualenv bear
pip install lit
# it's important to re-run the configure step again
cmake $BEAR_SOURCE_DIR
cmake --build $build_dir --parallel 4
make check