Buildroot Archive on lore.kernel.org
 help / color / mirror / Atom feed
From: Baruch Siach <baruch@tkos.co.il>
To: buildroot@busybox.net
Subject: [Buildroot] [PATCH] support/scripts/apply-patches: use "git apply" as a fallback when applying patches
Date: Fri, 11 Jan 2019 05:35:13 +0200	[thread overview]
Message-ID: <87wonbhnny.fsf@tarshish> (raw)
In-Reply-To: <20190110203004.9812-1-thomas.petazzoni@bootlin.com>

Hi Thomas,

On Thu, Jan 10 2019, Thomas Petazzoni wrote:

> We currently use plain old "patch" to apply patches. While this works
> fine in most situations, it doesn't work well for patches generated
> with git format-patch that:
>
>  - Contain changes to binary files
>
>  - Or contain changes to files in directories that were symlinks to
>    other directories, with the symlink being removed as part of the
>    same patch.
>
> We encountered such issues with a large stack of patches to be applied
> on top of arm-trusted-firmware. Such patches apply perfectly fine with
> "git apply".
>
> Switching everybody to unconditionally use "git apply" seems a bit
> risky, so instead we take a different route: if applying the patch
> with "patch" fails, then we try with "git apply".

This makes git a host dependency. Should we add host-git, or list git
with host requirements?

baruch

> A few implementation notes:
>
>  - The script has "set -e" so for the "patch --dry-run" command, we
>    have to take special precautions to not bail out of the script on
>    error.
>
>  - Also due to "set -e", the check on the return value of "patch" is
>    no longer needed, and we also don't need to check the return value
>    of "git apply".
>
>  - We need to pass "--git-dir=/dev/null", otherwise "git apply"
>    travels up the directory hierarchy until it finds a .git folder. If
>    it finds one, but the files being patched are not under version
>    control, it skips patching those files. Obviously, the files in
>    output/build/foo/ are not under version control, so this behavior
>    is not desirable. Simply making "git apply" believe it is not
>    running from inside a Git repository disables this check.
>
> Cc: Kostya Porotchkin <kostap@marvell.com>
> Signed-off-by: Thomas Petazzoni <thomas.petazzoni@bootlin.com>
> ---
>  support/scripts/apply-patches.sh | 15 +++++++++++----
>  1 file changed, 11 insertions(+), 4 deletions(-)
>
> diff --git a/support/scripts/apply-patches.sh b/support/scripts/apply-patches.sh
> index 66fef262ee..0fd336968e 100755
> --- a/support/scripts/apply-patches.sh
> +++ b/support/scripts/apply-patches.sh
> @@ -119,11 +119,18 @@ function apply_patch {
>          exit 1
>      fi
>      echo "${path}/${patch}" >> ${builddir}/.applied_patches_list
> -    ${uncomp} "${path}/$patch" | patch -g0 -p1 -E -d "${builddir}" -t -N $silent
> -    if [ $? != 0 ] ; then
> -        echo "Patch failed!  Please fix ${patch}!"
> -        exit 1
> +
> +    # We don't want this to abort the script on failure (script is run
> +    # with set -e)
> +    ${uncomp} "${path}/$patch" | patch -g0 -p1 -E -d "${builddir}" --dry-run -t -N -s && retval=0 || retval=$?
> +    if [ $retval -eq 0 ] ; then
> +	    ${uncomp} "${path}/$patch" | patch -g0 -p1 -E -d "${builddir}" -t -N $silent
> +	    # Due to set -e, if we reach here, applying the patch was successful
> +	    return
>      fi
> +
> +    [ -z "${silent}" ] && gitopts=-v
> +    (cd ${builddir}; ${uncomp} "${path}/$patch" | git --git-dir=/dev/null apply -p1 ${gitopts})
>  }
>
>  function scan_patchdir {


--
     http://baruch.siach.name/blog/                  ~. .~   Tk Open Systems
=}------------------------------------------------ooO--U--Ooo------------{=
   - baruch at tkos.co.il - tel: +972.52.368.4656, http://www.tkos.co.il -

  reply	other threads:[~2019-01-11  3:35 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2019-01-10 20:30 [Buildroot] [PATCH] support/scripts/apply-patches: use "git apply" as a fallback when applying patches Thomas Petazzoni
2019-01-11  3:35 ` Baruch Siach [this message]
2019-01-11  8:15   ` Thomas Petazzoni
2019-01-13  8:00     ` Baruch Siach
2019-01-23 14:17       ` Arnout Vandecappelle
2019-01-23 20:34         ` Peter Korsgaard

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=87wonbhnny.fsf@tarshish \
    --to=baruch@tkos.co.il \
    --cc=buildroot@busybox.net \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox