This document describes how to set up your workstation to build the Google Cloud C++ client libraries using CMake. The intended audience is developers of the client libraries that want to verify their changes will work with CMake and/or prefer to use CMake for whatever reason.
- Packaging maintainers or developers who prefer to install the library in a
fixed directory (such as
/usr/local
or/opt
) should consult the packaging guide. - Developers who prefer using a package manager such as vcpkg, or Conda, should follow the instructions for their package manager.
- Developers wanting to use the libraries as part of a larger CMake or Bazel project should consult the quickstart guides for the library or libraries they want to use.
- Developers wanting to compile the library just to run some examples or tests should read the build and install section from the top-level README.
- Contributors and developers to
google-cloud-cpp
wanting to work with CMake should read the current document.
The document assumes you are using a Linux workstation running Ubuntu, changing the instructions for other distributions or operating systems is left as an exercise to the reader. PRs to improve this document are most welcome!
Unless explicitly stated, this document assumes you running these commands at the top-level directory of the project, as in:
cd $HOME
git clone git@github:<github-username>/google-cloud-cpp.git
cd google-cloud-cpp
vcpkg is a package manager for C++ that builds
from source and installs any binary artifacts in $HOME
. We recommend
using vcpkg
for local development. In these instructions, we will
install vcpkg
descriptions in $HOME/vcpkg
, you can change the
vcpkg
location, just remember to adapt these instructions as you go
along. Download the vcpkg
package descriptions using git
:
git -C $HOME clone https://github.com/microsoft/vcpkg
Then bootstrap the vcpkg
tool:
env VCPKG_ROOT="${vcpkg_dir}" $HOME/vcpkg/bootstrap-vcpkg.sh
Now you can use vcpkg
to compile google-cloud-cpp
. Just add one option
to the cmake
configure step:
cd $HOME/google-cloud-cpp
cmake -G Ninja -S . -B build-out/home \
-DCMAKE_TOOLCHAIN_FILE=$HOME/vcpkg/scripts/buildsystems/vcpkg.cmake
cmake --build build-out/home
The first time you run this command it can take a significant time to download
and compile all the dependencies (Abseil, gRPC, Protobuf, etc). Note that vcpkg
caches binary artifacts (in $HOME/.cache/vcpkg
) so a second build would be
much faster:
cd $HOME/another-google-cloud-cpp-clone
cmake -G Ninja -S . -B build-out/home \
-DCMAKE_TOOLCHAIN_FILE=$HOME/vcpkg/scripts/buildsystems/vcpkg.cmake
cmake --build build-out/home
Once you have built google-cloud-cpp
you can run the unit tests using:
env -C build-out/home ctest --output-on-failure -LE integration-test
If you also want to run the integration tests you need to setup multiple environment variables, and then run:
To set up the environment variables, run the script using:
source ci/etc/integration-tests-config.sh
env -C build-out/home ctest --output-on-failure
You can configure and build with different compilers, build options, etc. all sharing the same pre-built dependencies.
If your workstation has multiple compilers (or multiple versions of a compiler) installed, you can change the compiler using:
CXX=clang++ CC=clang \
cmake -G Ninja -S . -B build-out/clang \
-DCMAKE_TOOLCHAIN_FILE=$HOME/vcpkg/scripts/buildsystems/vcpkg.cmake
# Then compile and test normally:
cmake --build build-out/clang
(cd build-out/clang && ctest --output-on-failure -LE integration-test)
vcpkg
uses the compiler as part of its binary cache inputs, that is, changing
the compiler will require rebuilding the dependencies from source. The good
news is that vcpkg
can hold multiple versions of a binary artifact in its
cache.
By default, the system is compiled with optimizations on; if you want to compile a debug version, use:
cmake -G Ninja -S . -B build-out/manual -DCMAKE_BUILD_TYPE=Debug
# Then compile and test normally:
cmake --build build-out/manual
(cd build-out/manual && ctest --output-on-failure -LE integration-test)
google-cloud-cpp
supports the standard CMake
build types.