Logo

dev-resources.site

for different kinds of informations.

vcpkg - how to modify dependencies

Published at
9/27/2024
Categories
vcpkg
cpp
cmake
dependency
Author
stickyfingies
Categories
4 categories in total
vcpkg
open
cpp
open
cmake
open
dependency
open
Author
13 person written this
stickyfingies
open
vcpkg - how to modify dependencies

Purpose

This tutorial is made for existing projects that use vcpkg to manage their C++ dependencies.

Sometimes, it becomes necessary to modify some elements of a C++ library that your project depends on. Modifications can include:

  • Changing compilation flags
  • Changing installation strategies
  • Changing source code
  • Changing static data

This tutorial demonstrates how to apply these changes to a dependency installed with vcpkg in a way that's cheap, shareable, and permanent.

The full process can be completed in 15 minutes.

Project Structure

We'll use a mock project structure, like so:

project/
 |-- include/
 |-- src/
 |-- vcpkg/
 |-- CMakeLists.txt
 |-- README.md
Enter fullscreen mode Exit fullscreen mode

In this example, we'd likely set up the vcpkg CLI utility, like so:

# pwd: at project root
chmod +x ./vcpkg/bootstrap-vcpkg.sh
./vcpkg/bootstrap-vcpkg.sh
Enter fullscreen mode Exit fullscreen mode

Step (1 of 4): Create a Local Registry

The first change we'll make to the project structure is making a directory to hold our vcpkg portfiles.

A Port is a small, cheap collection of metadata files which instruct vcpkg on how to download, configure, build, and install your dependencies.

To customize our dependency, we're going to copy its portfiles and place them in our own custom registry.

First, let's create a directory to hold our vcpkg portfiles:

# pwd: at project root
mkdir registry
Enter fullscreen mode Exit fullscreen mode

Call it whatever you'd like. This tutorial refers to it as a local registry.

Step (2 of 4): Copy the Port Files

This tutorial will use the fake "foobaz" package as an example.

# pwd: at project root
./vcpkg/vcpkg install foobaz
Enter fullscreen mode Exit fullscreen mode

We're going to copy the foobaz portfiles into our local registry in order to apply our modifications in the future.

# pwd: at project root
cp -r ./vcpkg/ports/foobaz ./registry/foobaz
Enter fullscreen mode Exit fullscreen mode

Take a look inside ./registry/foobaz and you'll probably see three files:

project/
 |-- registry/
 |    |-- foobaz/
 |    |    |-- build_fixes.patch
 |    |    |-- portfile.cmake
 |    |    |-- vcpkg.json
Enter fullscreen mode Exit fullscreen mode

Let's examine each of them.

  • build_fixes.patch is a git diff that vcpkg applies to your dependency's source tree before compiling and installing it.
  • portfile.cmake is a cmake script that tells vcpkg where to find your dependency's source tree, plus some other stuff.
  • vcpkg.json is a metadata file that's conceptually similar to a package.json file from the Node.js universe.

It's recommended to keep vcpkg.json the same.

This tutorial is going to demonstrate how to generate a new build_fixes.patch file, and it will contain the modifications you want to apply to the source code, build configuration, etc.

Please note that portfile.cmake is run in CMake's script mode, so we cannot use this to change build parameters for our dependency. Those must be modified from within the build_fixes.patch instead.

Step (3 of 4): Generating a Patch File

Awesome, it's time to make some changes!

First, clone the dependency's source tree, so we can make our changes. This is a temporary folder that won't be checked into your git project. I'm cloning inside of registry/foobaz for convenience, but you may put it anywhere you'd like.

# pwd: at project/registry/foobaz
git clone https://github.com/username/foobaz.git source
Enter fullscreen mode Exit fullscreen mode

Next, we're going to apply the existing build_fixes.patch file on top of the source tree. This puts our dependency's source into the state that vcpkg uses by default when you install it.

# pwd: at project/registry/foobaz/source
git apply ../build_fixes.patch
Enter fullscreen mode Exit fullscreen mode

Now, it's time to make your changes! You can modify the CMakeLists.txt to adjust build configuration, comment out source files, introduce new code, whatever the hell you want.

Dancing Cat GIF

After applying your modifications, create a new git diff file. This overwrites the existing build_fixes.patch with the changes you've just made (plus whatever was already there).

# pwd: at project/registry/foobaz/source
git diff > ../build_fixes.patch
Enter fullscreen mode Exit fullscreen mode

Remove the source tree when you're done.

# pwd: at project/registry/foobaz
rm -rf source
Enter fullscreen mode Exit fullscreen mode

Finale (4 of 4): Use your Modified Dependency

It is necessary to remove foobaz from vcpkg so that we can re-install our modified version.

# pwd: at project/
./vcpkg/vcpkg remove foobaz
Enter fullscreen mode Exit fullscreen mode

From now on, to make vcpkg download your modified dependency, the CLI tool must be invoked like so:

# pwd: at project/
./vcpkg/vcpkg install foobaz --overlay-ports=registry/foobaz
Enter fullscreen mode Exit fullscreen mode

Check it out! You're done! 🎈

Find me on github

cmake Article's
30 articles in total
Favicon
Fixing libdc1394.so.22: cannot open shared object file (ㅠ﹏ㅠ)
Favicon
Automate Versioning with Git and CMake
Favicon
vcpkg - how to modify dependencies
Favicon
Getting started with GoogleTest and CMake
Favicon
Building a Desktop C++ Barcode Scanner with Slimmed-Down OpenCV and Webcam
Favicon
Use cosmocc to cross‐compile a CMake project
Favicon
Improve Productivity with CMake and Compiler Cache Integration
Favicon
Conan: Your Embedded Cross-Compilation Champion
Favicon
Streamlining STM32 Projects: VS Code, CMake and clangd
Favicon
Easily add packages to CMake with CPM
Favicon
Jolt Physics raylib: trying 3D C++ Game Physics Engine
Favicon
Using raylib with Dear ImGui: Game Dev Debugging UI
Favicon
Using Jolt with flecs & Dear ImGui: Game Physics Introspection
Favicon
codemapper: join dev team of this sources analysis tool (C++/Qt5)
Favicon
CMake on SMT32 | Episode 8: build with Docker
Favicon
CMake on SMT32 | Episode 7: unit tests
Favicon
[04/52] MOAR CMAKEZ!
Favicon
How to use Flatbuffers in a C++ project with Conan?
Favicon
[03/52] - CMake and Git Submodules: More Advanced Cases
Favicon
get_cmake_version raise SKBuildError(msg) from err
Favicon
Basic C++ Unit Testing with GTest, CMake, and Submodules
Favicon
Felt Cute, Might git rm --rf
Favicon
Install CMake on Windows
Favicon
Maximizing Automation and Scripting in CMake for Efficient Software Development
Favicon
Include custom CMake modules
Favicon
Build a project on Windows 11 using MinGW
Favicon
Cleanup my dependency management with vcpkg
Favicon
CMake cheat sheet!
Favicon
CPM.cmake to make CMake's FetchContent easier
Favicon
The SYSTEM property from CMake 3.25

Featured ones: