Bond is an open source, cross-platform framework for working with schematized data. It supports cross-language serialization/deserialization and powerful generic mechanisms for efficiently manipulating data. Bond is broadly used at Microsoft in high scale services.
IMPORTANT NOTE: The Bond Communications framework -- known as Bond Comm -- is deprecated. We recommend using Bond-over-gRPC for communication. The Bond Comm C# manual and the Bond Comm C++ manual are preserved for transition purposes.
Bond is published on GitHub at https://github.com/Microsoft/bond/.
For details, see the User's Manuals:
- C++
- C#
- Java
- Python
- Bond-over-gRPC
gbc, the Bond compiler/codegen tool- See also
the compiler library that
powers
gbc.
- See also
the compiler library that
powers
For a discussion how Bond compares to similar frameworks see Why Bond.
The Bond repository uses Git submodules and should be cloned with the
--recursive flag:
git clone --recursive https://github.com/Microsoft/bond.gitBond C++ library requires some C++11 features (currently limited to those supported bv Visual C++ 2013); a C++11 compiler is required. Additionally, to build Bond you will need CMake (3.1+), Haskell Stack (1.5.1+) and Boost (1.58+). (Note: Boost 1.59 may not work with Bond Comm due to some bugs in that version of the Boost ASIO library).
Following are specific instructions for building on various platforms.
Bond must be built with C++11 compiler. We test with Clang (3.8) and GNU C++ (5.4). We recommend Clang as it's faster with template-heavy code like Bond.
Run the following commands to install the minimal set of packages needed to build the core Bond library on Ubuntu 14.04:
sudo apt-get install \
clang \
cmake \
zlib1g-dev \
libboost-dev \
libboost-thread-devAdditionally, you need the Haskell Tool Stack. If your distro isn't shipping a new enough version of it, you may encounter some non-obvious build failures, so we recommend installing the latest Stack outside of package management:
curl -sSL https://get.haskellstack.org/ | shIn the root bond directory run:
mkdir build
cd build
cmake -DBOND_ENABLE_GRPC=FALSE ..
make
sudo make installThe build directory is just an example. Any directory can be used as the
build destination.
In order to build the Bond Python module, all the C++/Python tests and examples, and Bond-over-gRPC, a few more packages are needed.
sudo apt-get install \
autoconf \
build-essential \
golang \
libboost-date-time-dev \
libboost-python-dev \
libboost-test-dev \
libtool \
python2.7-devCMake needs to be re-run with different options. This can be done after building just the core libraries: the build tree will simply be updated with the new options.
cd build # or wherever you ran CMake before
cmake -DBOND_ENABLE_GRPC=TRUE -DgRPC_ZLIB_PROVIDER=package ..Running the following command in the build directory will build and execute all the tests and examples:
make --jobs 8 check
sudo make install # To install the other libraries just built(The unit tests are large so you may want to run 4-8 build jobs in parallel, assuming you have enough memory.)
Install Xcode and then run the following command to install the required packages using Homebrew (http://brew.sh/):
brew install \
cmake \
haskell-stack \
boost \
boost-python(boost-python is optional and only needed for Python support.)
Bond can be built on macOS using either standard *nix makefiles or Xcode. In
order to generate and build from makefiles, in the root bond directory run:
mkdir build
cd build
cmake -DBOND_ENABLE_GRPC=FALSE ..
make
sudo make installAlternatively, you can generate Xcode projects by passing the -G Xcode option
to cmake:
cmake -DBOND_ENABLE_GRPC=FALSE -G Xcode ..You can build and run unit tests by building the check target in Xcode or by
running make in the build directory:
make --jobs 8 checkNote that if you are using Homebrew's Python, you'll need to build boost-python from source:
brew install --build-from-source boost-pythonand tell cmake the location of Homebrew's libpython by setting the
PYTHON_LIBRARY variable, e.g.:
cmake .. \
-DPYTHON_LIBRARY=/usr/local/Cellar/python/2.7.9/Frameworks/Python.framework/Versions/2.7/lib/libpython2.7.dylibInstall the following tools:
- Visual Studio 2013 or 2015
- Visual Studio 2015 is required to build C# Bond from source
- CMake (http://www.cmake.org/download/)
- Haskell Stack (https://docs.haskellstack.org/en/stable/install_and_upgrade/#windows)
- .NET Core SDK (https://www.microsoft.com/net/core)
If you are building on a network behind a proxy, set the environment variable
HTTP_PROXY, e.g.:
set HTTP_PROXY=http://your-proxy-name:80Now you are ready to build the C# 4.0/4.5 version of Bond. Open the solution
file cs\cs.sln in Visual Studio and build as usual. The C# unit tests can
also be run from within the solution.
To build the .NET Core version of Bond, run the build script. The -Test
switch is used to run the unit tests as well.
.\cs\dnc\build -TestThe C++ and Python versions of Bond additionally require:
- Boost 1.58+ (http://www.boost.org/users/download/)
- Python 2.7 (https://www.python.org/downloads/)
You may need to set the environment variables BOOST_ROOT and BOOST_LIBRARYDIR
to specify where Boost and its pre-built libraries for your environment (MSVC 12 or MSVC 14) can be
found, e.g.:
set BOOST_ROOT=D:\boost_1_58_0
set BOOST_LIBRARYDIR=D:\boost_1_58_0\lib64-msvc-14.0The core Bond library and most examples only require Boost headers. The pre-built libraries are only needed for unit tests, Python, gRPC, and Comm support. If Boost or Python libraries are not found on the system, then some tests and examples will not be built.
In order to generate a solution to build the Bond Core C++ and Python with Visual
Studio 2015 run the following commands from the root bond directory:
mkdir build
cd build
set PreferredToolArchitecture=x64
cmake -DBOND_ENABLE_GRPC=FALSE -G "Visual Studio 14 2015 Win64" ..Setting PreferredToolArchitecture=x64 selects the 64-bit toolchain which
dramatically improves build speed. (The Bond unit tests are too big to build
with 32-bit tools.)
Instead of cmake you can also use cmake-gui and specify configuration
settings in the UI. This configuration step has to be performed only once. From
then on you can use the generated solution build\bond.sln from Visual Studio
or build from command line using cmake:
cmake --build . --target
cmake --build . --target INSTALLIn order to build and execute the unit tests and examples run:
cmake --build . --target check -- /maxcpucount:8To build Bond's gRPC++ integration from source, some of gRPC's prerequisites are also needed:
choco install activeperl golang ninja yasmYou will also need to enable gRPC in the cmake configuration step by running the following
in the build directory from above and then following the other cmake commands above:
cmake -DBOND_ENABLE_GRPC=TRUE -G "Visual Studio 14 2015 Win64" ..Interested in contributing to Bond? Take a look at our contribution guidelines to get started.
