Skip to content

Latest commit

 

History

History
73 lines (54 loc) · 4.2 KB

README.md

File metadata and controls

73 lines (54 loc) · 4.2 KB

vcpkg

This repository is a fork of https://github.com/microsoft/vcpkg.

The default branch is "main" which is empty except for a github action that prebuilds various ports for the HPCC-Platform repository.

Active Branches

The following branches are active and correspond to the HPCC-Platform development branches:

Development Notes:

Building on Ubuntu

./bootstrap-vcpkg.sh
./vcpkg install --x-abi-tools-use-exact-versions --host-triplet=x64-linux-dynamic --triplet=x64-linux-dynamic

Two versions to consider

  1. The vcpkg build tool versions (cmake, ninja etc.): These are determined by the commit hash a branch is based on
  2. The default "baseline" for port versions: This is determined by the git hash found in the vcpkg-configuration.json

Creating a branch for new HPCC-Platform releases

To create a new branch for a new HPCC-Platform release, follow these steps:

Prerequisites:

  1. git clone this repository (e.g. git clone [email protected]:hpcc-systems/vcpkg.git)
  2. Add the official vcpkg repository as another remote called "microsoft" (e.g. git remote add microsoft [email protected]:microsoft/vcpkg.git)

In https://github.com/hpcc-systems/vcpkg:

  1. git fetch --all --tags to ensure you have all the latest changes
  2. Check https://github.com/microsoft/vcpkg/releases to locate the latest release (e.g. 2024.05.24)
  3. Checkout the latest HPCC-Platform release branch (e.g. hpcc-platform-9.6.x)
  4. Create a new branch for the new HPCC-Platform release (e.g. hpcc-platform-9.8.x)
  5. Update the vcpkg.json file to include the new HPCC-Platform release version (e.g. "version": "9.8.0")
  6. Commit the changes
  7. Rebase the branch on the latest version as identified in step 2 above ensuring you squash the rebased commits with a suitable comment (e.g. "chore: Squash commits for 9.8.0 gold release ")
  8. Update the baseline field in the vcpkg-configuration.json file to the commit hash from step 2 above
  9. In the HPCC-Platform repository, check the "vcpkg_overlays" folder for any new overlays that need to be added to the "overlays" folder in this repository. If found, copy them to the "overlays" folder in this repository
  10. Compare the contents of the "overlays" folder with the "vcpkg" folder. If any of the overlays match or are older than the vcpkg folder, delete them.
  11. Commit the changes with the --amend option to update the previous commit
  12. Push the new branch to https://github.com/hpcc-systems/vcpkg
  13. Checkout the "main" branch
  14. Update this README.md file to include a link to the new branch in the "Active Branches" section
  15. Update the .github/workflows/prebuild.yml file to include two new jobs corresponding to the new branch:
    • prebuild-docker-9-8
    • prebuild-gh_envs-9-8
  16. Commit the changes and issue a PR to the vcpkg repository

Note: Step 11 above will trigger several github actions to prebuild the new branch. Once the prebuilds are complete, the new branch can be used in the HPCC-Platform repository.

In https://github.com/hpcc-systems/HPCC-Platform:

  1. Create a new branch based on the "latest" candidate branch (e.g. master)
  2. Delete the contents of the "vcpkg_overlays" folder (as they have been relocated with step 8 above).
  3. Update the baseline field in the vcpkg-configuration.json file to match the commit hash from the vcpkg submodule
  4. Fetch the latest vcpkg submodule repository changes (e.g. cd vcpkg && git fetch --all)
  5. Checkout the new branch created in step 4 above (e.g. cd vcpkg && git checkout hpcc-platform-9.8.x)
  6. Commit the changes and issue a PR to the HPCC-Platform repository