Fedora 23 Boost 1.59 Uplift
This change brings Boost 1.58.0 or later to Fedora 23. We generally aim to ship 1.59.0, as that seems likely to make it (hence the Change name), but 1.58.0 is out and available now.
- Name: Jon Wakely
- Email: jwakely redhat com
- Release notes owner:
- Targeted release: Fedora 23
- Last updated: 2015-06-07
- Tracker bug: BZ #1229030
- Side tag (f23-boost) created: http://fedorahosted.org/rel-eng/ticket/6197
The aim is to synchronize Fedora with the most recent Boost release. Because ABI stability is one of explicit Boost non-goals, this entails rebuilding of all dependent packages. This has also always entailed yours truly assisting maintainers of client packages in decoding cryptic boostese seen in output from g++. Such care is to be expected this time around as well.
Boost 1.59 does not have firm schedule yet. I do not think there is even a provisional schedule at this point. We may have to package Boost 1.58 instead.
Here is the Fedora 22 Change, should you need it.
Benefit to Fedora
Fedora will stay relevant, as far as Boost clients are concerned. It seems like Boost 1.59 will bring no new library. Boost 1.58 brought the Boost.Convert library.
Rebasing Boost has a fairly large impact on Fedora. For Fedora 20, the scope was: about 130 packages _must_ be rebuilt due to ABI breakage inherent in bumping Boost sonames. There were almost 250 client packages total. I expect these numbers to stay in the same ballpark for Fedora 23.
- Proposal owners:
- Build will be done with Boost.Build v2 (which is upstream-sanctioned way of building Boost)
- Request a "boost" build system tag (discussion): http://fedorahosted.org/rel-eng/ticket/6197 → f23-boost
- Build boost into that tag (take a look at the build #606493 for inspiration)
- Post a request for rebuilds to fedora-devel (XXX link to fedora-devel message here)
- Work on rebuilding dependent packages in the tag.
- When most is done, re-tag all the packages to rawhide
- Watch fedora-devel and assist in rebuilding broken Boost clients (by fixing the client, or Boost).
- Other developers: Those who depend on Boost DSO's will have to rebuild their packages. Feature owners will alleviate some of this work as indicated above, and will assist those whose packages fail to build in debugging them.
- Release engineering: Side tag creation.
- Policies and guidelines: Apart from scope, this is business as usual, so no policies, no guidelines.
- No impact on system upgrade.
- Some impact on other packages. Historically this hasn't been too big of a problem and could always be resolved before deadline.
How To Test
- No special hardware is needed.
- Integration testing simply consists of installing Boost packages (
yum install boost) on Fedora and checking that it does not break other packages (see below for a way to obtain a list of boost clients).
Expected to remain largely the same.
Packages that must be rebuilt:
$ repoquery -s --releasever=rawhide --whatrequires libboost\* --disablerepo=* --enablerepo=fedora | sort -u
$ repoquery --releasever=rawhide --archlist=src --whatrequires boost-devel --disablerepo='*' --enablerepo=fedora-source
- clean 1.59 (if everything works)
- patch 1.59 (the likely outcome)
- clean 1.58
- patch 1.58 (the likely fallback outcome)
- fedora 1.57 (the likely contingency plan)
- fedora 1.57 + patches (if new GCC rejects code in 1.57)
- remove Boost and its dependencies from Fedora
Boost's own test suite will likely catch many instances of what would otherwise bite us during rebuilds, so many of the wrinkles can be smoothed off-line.
- Contingency deadline: We will know within days after side-tag is created.
- Blocks release? Yes if there are client packages that are on installation media.
- http://www.boost.org/users/history/version_1_58_0.html (released the 17 April, 2015)
- http://www.boost.org/users/history/version_1_57_0.html (released the 3 November, 2014)
- http://www.boost.org/users/history/version_1_56_0.html (released the 7 August, 2014)
Boost has been upgraded to version XXX. Apart from a number of bugfixes, this brings XXX.