The aim of this organization is to serve as a convenient collaboration place
for packaging third-party projects for build2
.
By hosting your packaging efforts under this organization (as opposed to, say, your personal workspace) you make it easier for others to join or, if you are no longer interested, to take over the package development/maintenance.
In addition to this organization we also have the
packaging@build2.org
mailing list and the
#build2
channel
on cpplang.slack.com
. To join, simply get
in touch using either medium.
This section describes how to package a third-party project for build2
while
the next section describes the ongoing versioning and release management once
this is done.
Note: this section is a work in progress. See also
build2
HOWTO for practical instructions and advice on how to achieve various things withbuild2
as well as projects that have already been packaged for examples (some of them containing theREADME-DEV
files with additional details on the packaging process).
If the third-party project is available from a git
repository, then the
recommended approach is to use the git
submodule mechanism to make the
third-party source code available inside the package repository, customarily
in a directory called upstream/
. We can then use symlinks to non-invasively
overlay the project's source code with buildfiles and, potentially, reorganize
its structure to better align with the supported source/output arrangements.
See Using Symlinks in build2 Projects
for details.
For more complex cases, when deciding on how to split the project into multiple packages (and what to call them) or which optional features to enable by default, it is recommended to use Debian and Fedora packages as a reference.
This section describes the recommended version and release management for an upstream package with the semantic version. The main challenge compared to developing our own project is that the version is controlled by upstream.
Note: The
bdep-release
command doesn't need the project to bebdep-init
'ed so we can use it for stubs (packages that do not contain source code and can only be obtained from the system).
Note: If we are dealing with a multi-package project (for example,
sqlite
, which consists of a library and an executable), then we assume they are all hosted in the same project repository and use$
in theirdepends
version constraints.
-
When packaging upstream for the first time, say version
A.B.C
, start with its snapshot versionA.B.C-a.0.z
.If instead packaging a stub for the first time, tag the first release:
$ bdep release --tag --show-push $ # review tag $ git push ...
-
When it's time to release, if the package has a final version, then there is nothing to do for the version and we can go directly to publishing.
If, however, the package has the snapshot version, then release its final version:
$ bdep release --no-open --show-push $ # review commit $ git push ...
To publish:
$ bdep publish
-
After final version
A.B.C
has been released, the package enters the "revision phase".During this phase we can change the "infrastructure" (
buildfiles
, etc) but should limit upstream source code changes only to bugfixes/warning squashing (preferably backported).In this phase every commit must be accompanies by the revision increment:
$ # make changes $ git add . $ bdep release --revision --show-push $ # review commit $ git push ... $ bdep publish
-
When a new upstream version is available, say
A.B.C
, and we are ready to upgrade, switch to its snapshot versionA.B.C-a.0.z
, similar to step 1:$ bdep release --open --no-commit --open-base A.B.C
Note that you should only push this change to
master
once you are certain upstream is good (i.e., you won't be able to go to a previous version of upstream once you've done this). So it may make sense to do this in a branch if external testing is required.