Hi Simon, On Sun, Jan 21, 2024 at 03:24:25PM +0000, Simon McVittie wrote: > > How annoying would it actually be to split this to a > > different source package? > > Really quite annoying. [...]
You gave more than sufficient reason. I won't argue. > If porters are interested in making bootstrap automatic despite cycles > like this one, I think a better route would be to be able to have > a list of suggested bootstrap steps and build-order considerations, > either centralized in some sort of cross infrastructure or distributed > among packages. I'd be fine with adding something like this to glib2.0, > for example, if it helped: > > Bootstrap-Before: dbus, gobject-introspection > Bootstrap-Build-Profiles: nogir, nocheck, noinsttest We effectively tried the approach of encoding bootstrap-info into individual packages with stage profiles and that was a bad idea. What stages are needed can (and does) change. For instance, we no longer need glibc's stage1 profile and go to stage2 directly. Hence, we try to more and more use profiles that change a particular aspect of a package in an obvious and isolated way and externally maintain how these are to be combined into a successful bootstrap. > Or, if we separated the nogir build profile that I'm proposing here into > two, something like this: > > nogir-changing-content > can change content: Y ("unreproducible"/"unsafe" profile) > can change package set: Y > nogir > can change content: N ("reproducible"/"safe" profile) > can change package set: Y > > would that allow automatic bootstrapping infrastructure to figure out > that it was both safe and desirable to build glib2.0 with nogir? I've considered this option for other profiles already and did not find it appealing. Often times, you are interested in enabling the profile without caring about whether it changes package contents, but such a split would require you to figure out which of the profiles you need (or simply both?). More and more I think that merely documenting which instances of these profiles are reproducible would be a better approach. I've had this float as a vague idea since a while: XS-Reproducible-Profiles: nogir It's a promise that a source package can issue about a subset of the profiles it supports. It bears some similarity to "Multi-Arch: foreign" in the sense that both are promises on how the interface behaves. In particular, such a declaration would be machine-checkable. We could simply run an autobuilder that verifies whether such declarations are practically correct (on amd64). Bootstrappers do not really need that separation into two different profile names that you propose. Having the information of which profiles are reproducible in which source packages (and which packages get disabled when enabling the profile), is what is needed. So this is what I prefer, but it still comes at a cost. We're up for changing lots of packages to declare these headers. And we're up for setting QA to verify these. I fear I cannot provide the capacity to do all of this and hence I have not pushed this forward. Manually ordering glib2.0 in the bootstrap tooling may be annoying, but that's about it. It still is way less work than any of the alternatives. > (I infer that there must be some sort of infrastructure that knows that > it's safe to build packages with "nocheck,noinsttest", otherwise glib2.0 > and dbus are already in a cyclic dependency for their test suites.) Not really. nocheck and noinsttest are issued by default and simply assumed to do the right thing in all cases. > [...] I'm sorry if that's > causing extra work for your use-case. Yes, that's causing extra work on my side, but that extra work is really low compared to the extra work on your side for the alternative. That makes the choice rather obvious to me. Also having this advance warning further lowers the cost on my side. You answered my question in way more detail than expected. Thank you. Helmut