[Buildroot] [PATCH 09/16 v5] core/apply-patches: store full path of applied patches
Arnout Vandecappelle
arnout at mind.be
Sun Mar 20 16:28:54 UTC 2016
On 03/20/16 14:47, Thomas Petazzoni wrote:
> Hello,
>
> On Sat, 19 Mar 2016 23:37:46 +0100, Yann E. MORIN wrote:
>
>>>> * The package infra already knows which patches should be applied
>>>> (bundled patches, global patch dir, etc.), so it is technically able
>>>> to get the list of patches. Yes it's a bit annoying because the
>>>> logic to derive the list of patches is already inside the
>>>> apply-patches script. But maybe it's because too much smart stuff is
>>>> done in the apply-patch script without the package infrastructure
>>>> being aware.
>>
>> e-reading this, I don;t see a proposal in there. Did I miss something,
>> or did you forget to add something? ;-)
>
> Well, the proposal is to make the infrastructure aware of patches that
> are applied.
From a philosophical standpoint, I think this is indeed the best approach.
However, since even the simpler proposal below is already going to be very
complicated, and since this series already consists of 16 patches, I would
propose to leave that for later and accept Yann's approach for the time being.
It's not so horrible to be unacceptable IMHO, it's just not great.
Regards,
Arnout
>
>>>> * Alternatively, add an option to apply-patch.sh that will not apply
>>>> the patches, but show the list of patches that would be applied.
>>>> Like "apply-patch -l" for example. Then, when doing the legal-info,
>>>> you simply call "apply-patch -l" to retrieve the list of patches
>>>> that you need to copy.
>>
>> Well, it is in fact a bit more complex than just running apply-patches
>> to get the list of patches.
>>
>> First, some package do call apply-patches manually; there are 15 such
>> packages, some cal.ling apply-patches more than once (gcc, linux, linux
>> headers, uboot).
>>
>> Second, in that case, some patches are applied conditionally. We do not
>> want to duplicate that logic for legal-info.
>>
>> So, I stand that the best solution is my proposal, to store the list of
>> applied patches at the tiem they are applied, and use that later on for
>> the legal-info output.
>
> As suggested above, one way of doing this is to extend the
> infrastructure so that no package does a manual APPLY_PATCHES call. I
> haven't looked at the 15 different places where we call APPLY_PATCHES
> manually, so I have no idea what is the complexity of handling that at
> the infrastructure level, but it looks like some extension to the
> infrastructure would allow to radically simplify the logic to apply
> patches in U-Boot, Barebox, Linux, AT91Bootstrap, etc. Indeed, the only
> reason why they have special logic is because the infrastructure
> doesn't allow you passing a local directory in <pkg>_PATCH.
>
> Then, for packages like cvs, input-tools, mii-diag, netcat-openbsd,
> setserial, sysvinit and thttpd, the only reason why they call
> APPLY_PATCHES is to apply Debian patches, which are already part of the
> sources. So in fact, for those packages, your proposed logic would be
> somewhat incorrect, as it would store patches which are already in the
> source tarball.
>
> To me, your proposal of having apply-patches.sh fill in a file goes
> completely backward compared to what we've done with _EXTRA_DOWNLOADS.
> We've added _EXTRA_DOWNLOADS precisely to make sure that the
> infrastructure is aware of every file we download, instead of having
> random packages do their own downloading.
>
> Thomas
>
--
Arnout Vandecappelle arnout at mind be
Senior Embedded Software Architect +32-16-286500
Essensium/Mind http://www.mind.be
G.Geenslaan 9, 3001 Leuven, Belgium BE 872 984 063 RPR Leuven
LinkedIn profile: http://www.linkedin.com/in/arnoutvandecappelle
GPG fingerprint: 7493 020B C7E3 8618 8DEC 222C 82EB F404 F9AC 0DDF
More information about the buildroot
mailing list