* Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c
[not found] ` <AANLkTimRKCYYQmgwY0DHu5+e-ggT8grJbdjWFvUqTzH=@mail.gmail.com>
@ 2010-09-03 18:23 ` Uwe Kleine-König
2010-09-03 18:43 ` [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c) Jonathan Nieder
0 siblings, 1 reply; 16+ messages in thread
From: Uwe Kleine-König @ 2010-09-03 18:23 UTC (permalink / raw)
To: Magnus Damm
Cc: Jean-Christophe PLAGNIOL-VILLARD, linux-arm-kernel, linux-sh, git
Hello,
[added git ML to Cc:]
On Fri, Sep 03, 2010 at 07:18:43PM +0900, Magnus Damm wrote:
> On Thu, Sep 2, 2010 at 10:39 PM, Jean-Christophe PLAGNIOL-VILLARD
> <plagnioj@jcrosoft.com> wrote:
> > factorise some generic infrastructure to assist looking up struct clks
> > for the ARM & SH architecture.
> >
> > as the code is identical at 99%
> >
> > put the arch specific code for allocation as example in asm/clkdev.h
> >
> > Signed-off-by: Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>
> > ---
> > v3:
> > wrong comment removed
> > headers fixed
>
> [snip]
>
> I can't apply this patch using GNU patch. I've tested 2.5.9 and 2.6.1
> from Gentoo.
>
> Using --dry-run is fine, but omitting dry-run gives me:
>
> ...
> patching file arch/arm/common/clkdev.c
> patching file arch/sh/include/asm/clkdev.h
> Hunk #1 FAILED at 1.
> Hunk #2 FAILED at 11.
> 2 out of 2 hunks FAILED -- saving rejects to file
> arch/sh/include/asm/clkdev.h.rej
>
> I guess this is caused by the last "renaming" hunk, see below.
>
> I thought these things were supposed to work out of the box...
Yes, they work out of the box, but only for people using git :-)
Maybe git-apply can be used instead of patch?
Best regards
Uwe
--
Pengutronix e.K. | Uwe Kleine-König |
Industrial Linux Solutions | http://www.pengutronix.de/ |
^ permalink raw reply [flat|nested] 16+ messages in thread
* [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c)
2010-09-03 18:23 ` [PATCH V3] arm & sh: factorised duplicated clkdev.c Uwe Kleine-König
@ 2010-09-03 18:43 ` Jonathan Nieder
2010-09-03 19:29 ` Russell King - ARM Linux
2010-09-03 22:58 ` [bug-patch] " Andreas Gruenbacher
0 siblings, 2 replies; 16+ messages in thread
From: Jonathan Nieder @ 2010-09-03 18:43 UTC (permalink / raw)
To: Uwe Kleine-König
Cc: Magnus Damm, Jean-Christophe PLAGNIOL-VILLARD, linux-arm-kernel,
linux-sh, git, bug-patch
(+cc: bug-patch)
Hi,
Uwe Kleine-König wrote:
> On Fri, Sep 03, 2010 at 07:18:43PM +0900, Magnus Damm wrote:
>> Using --dry-run is fine, but omitting dry-run gives me:
>>
>> ...
>> patching file arch/arm/common/clkdev.c
>> patching file arch/sh/include/asm/clkdev.h
>> Hunk #1 FAILED at 1.
>> Hunk #2 FAILED at 11.
>> 2 out of 2 hunks FAILED -- saving rejects to file
>> arch/sh/include/asm/clkdev.h.rej
>>
>> I guess this is caused by the last "renaming" hunk, see below.
Yep, I can reproduce this. Patch applies with "git apply",
"patch --dry-run -p1" accepts it, "patch -p1" fails.
$ patch --version | head -1
GNU patch 2.6.1.85-423d
$ cd ~/src/linux-2.6
$ git checkout 2bfc96a12
$ git clean -fd
$ wget http://download.gmane.org/gmane.linux.ports.sh.devel/8747/8748
$ patch -p1 --quiet --dry-run <8748
$ echo $?
0
$ patch -p1 --quiet <8748
2 out of 2 hunks FAILED -- saving rejects to file include/linux/clkdev.h.rej
$ echo $?
1
Andreas: ideas?
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c)
2010-09-03 18:43 ` [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c) Jonathan Nieder
@ 2010-09-03 19:29 ` Russell King - ARM Linux
2010-09-03 19:33 ` Uwe Kleine-König
2010-09-03 19:34 ` Matthieu Moy
2010-09-03 22:58 ` [bug-patch] " Andreas Gruenbacher
1 sibling, 2 replies; 16+ messages in thread
From: Russell King - ARM Linux @ 2010-09-03 19:29 UTC (permalink / raw)
To: Jonathan Nieder
Cc: Uwe Kleine-König, linux-sh, bug-patch, Magnus Damm,
linux-arm-kernel, Jean-Christophe PLAGNIOL-VILLARD, git
On Fri, Sep 03, 2010 at 01:43:51PM -0500, Jonathan Nieder wrote:
> (+cc: bug-patch)
>
> Hi,
>
> Uwe Kleine-König wrote:
> > On Fri, Sep 03, 2010 at 07:18:43PM +0900, Magnus Damm wrote:
>
> >> Using --dry-run is fine, but omitting dry-run gives me:
> >>
> >> ...
> >> patching file arch/arm/common/clkdev.c
> >> patching file arch/sh/include/asm/clkdev.h
> >> Hunk #1 FAILED at 1.
> >> Hunk #2 FAILED at 11.
> >> 2 out of 2 hunks FAILED -- saving rejects to file
> >> arch/sh/include/asm/clkdev.h.rej
> >>
> >> I guess this is caused by the last "renaming" hunk, see below.
>
> Yep, I can reproduce this. Patch applies with "git apply",
> "patch --dry-run -p1" accepts it, "patch -p1" fails.
git patches include additional metadata for renaming files, which gnu patch
will not understand.
If you want GNU patch compatible diffs, don't use -C or -M when generating
patches out of git.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c)
2010-09-03 19:29 ` Russell King - ARM Linux
@ 2010-09-03 19:33 ` Uwe Kleine-König
2010-09-03 19:45 ` Andreas Schwab
2010-09-04 0:03 ` Russell King - ARM Linux
2010-09-03 19:34 ` Matthieu Moy
1 sibling, 2 replies; 16+ messages in thread
From: Uwe Kleine-König @ 2010-09-03 19:33 UTC (permalink / raw)
To: Russell King - ARM Linux
Cc: Jonathan Nieder, linux-sh, bug-patch, Magnus Damm,
linux-arm-kernel, Jean-Christophe PLAGNIOL-VILLARD, git
Hey Russell,
On Fri, Sep 03, 2010 at 08:29:07PM +0100, Russell King - ARM Linux wrote:
> On Fri, Sep 03, 2010 at 01:43:51PM -0500, Jonathan Nieder wrote:
> > Uwe Kleine-König wrote:
> > > On Fri, Sep 03, 2010 at 07:18:43PM +0900, Magnus Damm wrote:
> >
> > >> Using --dry-run is fine, but omitting dry-run gives me:
> > >>
> > >> ...
> > >> patching file arch/arm/common/clkdev.c
> > >> patching file arch/sh/include/asm/clkdev.h
> > >> Hunk #1 FAILED at 1.
> > >> Hunk #2 FAILED at 11.
> > >> 2 out of 2 hunks FAILED -- saving rejects to file
> > >> arch/sh/include/asm/clkdev.h.rej
> > >>
> > >> I guess this is caused by the last "renaming" hunk, see below.
> >
> > Yep, I can reproduce this. Patch applies with "git apply",
> > "patch --dry-run -p1" accepts it, "patch -p1" fails.
>
> git patches include additional metadata for renaming files, which gnu patch
> will not understand.
>
> If you want GNU patch compatible diffs, don't use -C or -M when generating
> patches out of git.
Still GNU patch should then already fail in --dry-run mode.
Best regards
Uwe
--
Pengutronix e.K. | Uwe Kleine-König |
Industrial Linux Solutions | http://www.pengutronix.de/ |
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c)
2010-09-03 19:29 ` Russell King - ARM Linux
2010-09-03 19:33 ` Uwe Kleine-König
@ 2010-09-03 19:34 ` Matthieu Moy
1 sibling, 0 replies; 16+ messages in thread
From: Matthieu Moy @ 2010-09-03 19:34 UTC (permalink / raw)
To: Russell King - ARM Linux
Cc: Jonathan Nieder, Uwe Kleine-König, linux-sh, bug-patch,
Magnus Damm, linux-arm-kernel, Jean-Christophe PLAGNIOL-VILLARD,
git
Russell King - ARM Linux <linux@arm.linux.org.uk> writes:
> git patches include additional metadata for renaming files, which gnu patch
> will not understand.
>
> If you want GNU patch compatible diffs, don't use -C or -M when generating
> patches out of git.
Fyi: actually, GNU patch will support git-style patches in the next
version according to
http://savannah.gnu.org/forum/forum.php?forum_id=6320
--
Matthieu Moy
http://www-verimag.imag.fr/~moy/
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c)
2010-09-03 19:33 ` Uwe Kleine-König
@ 2010-09-03 19:45 ` Andreas Schwab
2010-09-04 0:03 ` Russell King - ARM Linux
1 sibling, 0 replies; 16+ messages in thread
From: Andreas Schwab @ 2010-09-03 19:45 UTC (permalink / raw)
To: Uwe Kleine-König
Cc: Russell King - ARM Linux, Jonathan Nieder, linux-sh, bug-patch,
Magnus Damm, linux-arm-kernel, Jean-Christophe PLAGNIOL-VILLARD,
git
Uwe Kleine-König <u.kleine-koenig@pengutronix.de> writes:
> Still GNU patch should then already fail in --dry-run mode.
Since --dry-run doesn't actually perform any changes it can easily be
fooled when a file is patched twice.
Andreas.
--
Andreas Schwab, schwab@linux-m68k.org
GPG Key fingerprint = 58CA 54C7 6D53 942B 1756 01D3 44D5 214B 8276 4ED5
"And now for something completely different."
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [bug-patch] [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c)
2010-09-03 18:43 ` [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c) Jonathan Nieder
2010-09-03 19:29 ` Russell King - ARM Linux
@ 2010-09-03 22:58 ` Andreas Gruenbacher
2010-09-03 23:32 ` Jonathan Nieder
2010-09-04 3:21 ` Jean-Christophe PLAGNIOL-VILLARD
1 sibling, 2 replies; 16+ messages in thread
From: Andreas Gruenbacher @ 2010-09-03 22:58 UTC (permalink / raw)
To: Jonathan Nieder
Cc: bug-patch, Uwe Kleine-König, linux-sh, Magnus Damm,
linux-arm-kernel, Jean-Christophe PLAGNIOL-VILLARD, git
Hi,
On Friday 03 September 2010 20:43:51 Jonathan Nieder wrote:
> Uwe Kleine-König wrote:
> > On Fri, Sep 03, 2010 at 07:18:43PM +0900, Magnus Damm wrote:
>
> >> Using --dry-run is fine, but omitting dry-run gives me:
> >>
> >> ...
> >> patching file arch/arm/common/clkdev.c
> >> patching file arch/sh/include/asm/clkdev.h
> >> Hunk #1 FAILED at 1.
> >> Hunk #2 FAILED at 11.
> >> 2 out of 2 hunks FAILED -- saving rejects to file
> >> arch/sh/include/asm/clkdev.h.rej
> >>
> >> I guess this is caused by the last "renaming" hunk, see below.
>
> Yep, I can reproduce this. Patch applies with "git apply",
> "patch --dry-run -p1" accepts it, "patch -p1" fails.
>
> $ patch --version | head -1
> GNU patch 2.6.1.85-423d
> $ cd ~/src/linux-2.6
> $ git checkout 2bfc96a12
> $ git clean -fd
> $ wget http://download.gmane.org/gmane.linux.ports.sh.devel/8747/8748
> [...]
something pretty bizarre is going on here. The wget output modifies the same
file twice, but both patches to this file have the same source sha1 (5645f35):
> diff --git a/arch/sh/include/asm/clkdev.h b/arch/sh/include/asm/clkdev.h
> dissimilarity index 69%
> index 5645f35..6ba9186 100644
> --- a/arch/sh/include/asm/clkdev.h
> +++ b/arch/sh/include/asm/clkdev.h
> diff --git a/arch/sh/include/asm/clkdev.h b/include/linux/clkdev.h
> similarity index 85%
> rename from arch/sh/include/asm/clkdev.h
> rename to include/linux/clkdev.h
> index 5645f35..457bcb0 100644
So "git apply" and "patch --dry-run" seem to work only by accident.
How was this patch generated: with git itself?
The fact that "patch --dry-run" may not work for patches that modify the same
file twice is a known defect. I don't know how to solve this in a reasonably
elegant way. Luckily the problem only triggers when people are doing
something "strange" such as concatenating patches.
Andreas
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [bug-patch] [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c)
2010-09-03 22:58 ` [bug-patch] " Andreas Gruenbacher
@ 2010-09-03 23:32 ` Jonathan Nieder
2010-09-04 21:57 ` Andreas Gruenbacher
2010-09-04 3:21 ` Jean-Christophe PLAGNIOL-VILLARD
1 sibling, 1 reply; 16+ messages in thread
From: Jonathan Nieder @ 2010-09-03 23:32 UTC (permalink / raw)
To: Andreas Gruenbacher
Cc: bug-patch, Uwe Kleine-König, linux-sh, Magnus Damm,
linux-arm-kernel, Jean-Christophe PLAGNIOL-VILLARD, git
Andreas Gruenbacher wrote:
> something pretty bizarre is going on here. The wget output modifies the same
> file twice, but both patches to this file have the same source sha1 (5645f35):
>From the git v1.6.0-rc0~92 changelog entry:
apply: fix copy/rename breakage
7ebd52a (Merge branch 'dz/apply-again', 2008-07-01) taught "git-apply" to
grok a (non-git) patch that is a concatenation of separate patches that
touch the same file number of times, by recording the postimage of patch
application of previous round and using it as the preimage for later
rounds.
This "incremental" mode of patch application fundamentally contradicts
with the way git rename/copy patches are designed. When a git patch talks
about a file A getting modified, and a new file B created out of A, like
this:
diff --git a/A b/A
--- a/A
+++ b/A
... change text here ...
diff --git a/A b/B
copy from A
copy to B
--- a/A
+++ b/B
... change text here ...
the second change to produce B does not depend on what is done to A with
the first change in any way. This is explicitly done so for reviewability
of individual patches.
With this commit, we do not look at 'fn_table' that records the postimage
of previous round when applying a patch to produce a new file out of an
existing file.
> How was this patch generated: with git itself?
Yes, the patch basically agrees with what I get by applying it and running
git format-patch -M -B HEAD^..HEAD
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c)
2010-09-03 19:33 ` Uwe Kleine-König
2010-09-03 19:45 ` Andreas Schwab
@ 2010-09-04 0:03 ` Russell King - ARM Linux
2010-09-04 21:33 ` [bug-patch] " Andreas Gruenbacher
1 sibling, 1 reply; 16+ messages in thread
From: Russell King - ARM Linux @ 2010-09-04 0:03 UTC (permalink / raw)
To: Uwe Kleine-König
Cc: Jonathan Nieder, linux-sh, bug-patch, Magnus Damm,
linux-arm-kernel, Jean-Christophe PLAGNIOL-VILLARD, git
On Fri, Sep 03, 2010 at 09:33:09PM +0200, Uwe Kleine-König wrote:
> > git patches include additional metadata for renaming files, which gnu patch
> > will not understand.
> >
> > If you want GNU patch compatible diffs, don't use -C or -M when generating
> > patches out of git.
> Still GNU patch should then already fail in --dry-run mode.
And now look at the patch - it touches arch/sh/include/asm/clkdev.h twice.
Once to remove it and once as a rename.
GNU patch not in --dry-run mode will first remove arch/sh/include/asm/clkdev.h,
and then not have a file to deal with when it tries to patch the rename
part. Whereas with --dry-run, the file stays around.
As I say, it's because GNU patch doesn't (currently) understand GIT
patches. I wouldn't call that a bug in GNU patch.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [bug-patch] [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c)
2010-09-03 22:58 ` [bug-patch] " Andreas Gruenbacher
2010-09-03 23:32 ` Jonathan Nieder
@ 2010-09-04 3:21 ` Jean-Christophe PLAGNIOL-VILLARD
1 sibling, 0 replies; 16+ messages in thread
From: Jean-Christophe PLAGNIOL-VILLARD @ 2010-09-04 3:21 UTC (permalink / raw)
To: Andreas Gruenbacher
Cc: Jonathan Nieder, bug-patch, Uwe Kleine-König, linux-sh,
Magnus Damm, linux-arm-kernel, git
>
> So "git apply" and "patch --dry-run" seem to work only by accident.
>
> How was this patch generated: with git itself?
I did as usual
git format-patch -M -B -C HEAD~
>
> The fact that "patch --dry-run" may not work for patches that modify the same
> file twice is a known defect. I don't know how to solve this in a reasonably
> elegant way. Luckily the problem only triggers when people are doing
> something "strange" such as concatenating patches.
Best Regards,
J.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [bug-patch] Re: [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c)
2010-09-04 0:03 ` Russell King - ARM Linux
@ 2010-09-04 21:33 ` Andreas Gruenbacher
2010-09-04 21:45 ` Russell King - ARM Linux
0 siblings, 1 reply; 16+ messages in thread
From: Andreas Gruenbacher @ 2010-09-04 21:33 UTC (permalink / raw)
To: bug-patch
Cc: Russell King - ARM Linux, Uwe Kleine-König, linux-sh,
Magnus Damm, Jonathan Nieder, git,
Jean-Christophe PLAGNIOL-VILLARD, linux-arm-kernel
On Saturday 04 September 2010 02:03:48 Russell King - ARM Linux wrote:
> As I say, it's because GNU patch doesn't (currently) understand GIT
> patches. I wouldn't call that a bug in GNU patch.
GNU patch in the version used does understand GIT patch headers and does
support things like renames.
The --dry-run option often will not work when the same file is modified more
than once in the same patch, though. This is because GNU patch doesn't
remember the intermediary states of files.
In this case, the patch itself is broken.
Andreas
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [bug-patch] Re: [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c)
2010-09-04 21:33 ` [bug-patch] " Andreas Gruenbacher
@ 2010-09-04 21:45 ` Russell King - ARM Linux
2010-09-04 21:46 ` Andreas Gruenbacher
0 siblings, 1 reply; 16+ messages in thread
From: Russell King - ARM Linux @ 2010-09-04 21:45 UTC (permalink / raw)
To: Andreas Gruenbacher
Cc: bug-patch, Uwe Kleine-König, linux-sh, Magnus Damm,
Jonathan Nieder, git, Jean-Christophe PLAGNIOL-VILLARD,
linux-arm-kernel
On Sat, Sep 04, 2010 at 11:33:51PM +0200, Andreas Gruenbacher wrote:
> On Saturday 04 September 2010 02:03:48 Russell King - ARM Linux wrote:
> > As I say, it's because GNU patch doesn't (currently) understand GIT
> > patches. I wouldn't call that a bug in GNU patch.
>
> GNU patch in the version used does understand GIT patch headers and does
> support things like renames.
>
> The --dry-run option often will not work when the same file is modified more
> than once in the same patch, though. This is because GNU patch doesn't
> remember the intermediary states of files.
>
> In this case, the patch itself is broken.
GIT has many options to control how it produces patches, and -C or -M
allow it to reduce the size of patches making them more reviewable. It
also makes them incompatible with GNU patch, whether or not GNU patch
understands the GIT headers.
As I've already said - if you want GNU compatible patches, don't generate
GIT patches using -C or -M.
Simples.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [bug-patch] Re: [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c)
2010-09-04 21:45 ` Russell King - ARM Linux
@ 2010-09-04 21:46 ` Andreas Gruenbacher
2010-09-04 22:01 ` Russell King - ARM Linux
0 siblings, 1 reply; 16+ messages in thread
From: Andreas Gruenbacher @ 2010-09-04 21:46 UTC (permalink / raw)
To: Russell King - ARM Linux
Cc: bug-patch, Uwe Kleine-König, linux-sh, Magnus Damm,
Jonathan Nieder, git, Jean-Christophe PLAGNIOL-VILLARD,
linux-arm-kernel
On Saturday 04 September 2010 23:45:27 Russell King - ARM Linux wrote:
> It also makes them incompatible with GNU patch, whether or not GNU patch
> understands the GIT headers.
Aha? Then why do you think GNU patch tries to understand the GIt patch
headers? So that it can be incompatible with GIT?
Andreas
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [bug-patch] [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c)
2010-09-03 23:32 ` Jonathan Nieder
@ 2010-09-04 21:57 ` Andreas Gruenbacher
0 siblings, 0 replies; 16+ messages in thread
From: Andreas Gruenbacher @ 2010-09-04 21:57 UTC (permalink / raw)
To: Jonathan Nieder
Cc: bug-patch, Uwe Kleine-König, linux-sh, Magnus Damm,
linux-arm-kernel, Jean-Christophe PLAGNIOL-VILLARD, git
On Saturday 04 September 2010 01:32:52 Jonathan Nieder wrote:
> Andreas Gruenbacher wrote:
>
> > something pretty bizarre is going on here. The wget output modifies the same
> > file twice, but both patches to this file have the same source sha1 (5645f35):
>
> From the git v1.6.0-rc0~92 changelog entry:
>
> apply: fix copy/rename breakage
>
> 7ebd52a (Merge branch 'dz/apply-again', 2008-07-01) taught "git-apply" to
> grok a (non-git) patch that is a concatenation of separate patches that
> touch the same file number of times, by recording the postimage of patch
> application of previous round and using it as the preimage for later
> rounds.
>
> This "incremental" mode of patch application fundamentally contradicts
> with the way git rename/copy patches are designed. When a git patch talks
> about a file A getting modified, and a new file B created out of A, like
> this:
>
> diff --git a/A b/A
> --- a/A
> +++ b/A
> ... change text here ...
> diff --git a/A b/B
> copy from A
> copy to B
> --- a/A
> +++ b/B
> ... change text here ...
>
> the second change to produce B does not depend on what is done to A with
> the first change in any way. This is explicitly done so for reviewability
> of individual patches.
>
> With this commit, we do not look at 'fn_table' that records the postimage
> of previous round when applying a patch to produce a new file out of an
> existing file.
Ouch ... this gets really messy when a user concatenates git style patches
and they are not applied to exactly the same source tree.
Thanks for digging out this commit message!
Andreas
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [bug-patch] Re: [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c)
2010-09-04 21:46 ` Andreas Gruenbacher
@ 2010-09-04 22:01 ` Russell King - ARM Linux
2010-09-04 22:26 ` Andreas Gruenbacher
0 siblings, 1 reply; 16+ messages in thread
From: Russell King - ARM Linux @ 2010-09-04 22:01 UTC (permalink / raw)
To: Andreas Gruenbacher
Cc: bug-patch, Uwe Kleine-König, linux-sh, Magnus Damm,
Jonathan Nieder, git, Jean-Christophe PLAGNIOL-VILLARD,
linux-arm-kernel
On Sat, Sep 04, 2010 at 11:46:11PM +0200, Andreas Gruenbacher wrote:
> On Saturday 04 September 2010 23:45:27 Russell King - ARM Linux wrote:
> > It also makes them incompatible with GNU patch, whether or not GNU patch
> > understands the GIT headers.
>
> Aha? Then why do you think GNU patch tries to understand the GIt patch
> headers? So that it can be incompatible with GIT?
Read what you said last time around. "In this case, the patch itself is
broken."
So, because GNU patch doesn't understand the patch file, the patch file
must be broken? No, the patch file is fine with GIT which can apply it
correctly, but incompatible with GNU patch because of the way GNU patch
works (as you yourself said, GNU patch doesn't keep the intermediate
states.)
I repeat - if you want maximum compatibility, want GNU patch to be able
to apply the patch with or without --dry-run, then don't use -C or -M
when generating patches with git.
Simples.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [bug-patch] Re: [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c)
2010-09-04 22:01 ` Russell King - ARM Linux
@ 2010-09-04 22:26 ` Andreas Gruenbacher
0 siblings, 0 replies; 16+ messages in thread
From: Andreas Gruenbacher @ 2010-09-04 22:26 UTC (permalink / raw)
To: Russell King - ARM Linux
Cc: bug-patch, Uwe Kleine-König, linux-sh, Magnus Damm,
Jonathan Nieder, git, Jean-Christophe PLAGNIOL-VILLARD,
linux-arm-kernel
On Sunday 05 September 2010 00:01:52 Russell King - ARM Linux wrote:
> On Sat, Sep 04, 2010 at 11:46:11PM +0200, Andreas Gruenbacher wrote:
> > On Saturday 04 September 2010 23:45:27 Russell King - ARM Linux wrote:
> > > It also makes them incompatible with GNU patch, whether or not GNU patch
> > > understands the GIT headers.
> >
> > Aha? Then why do you think GNU patch tries to understand the GIt patch
> > headers? So that it can be incompatible with GIT?
>
> Read what you said last time around. "In this case, the patch itself is
> broken."
I was corrected on that by Jonathan Nieder's mail which describes a detail of
the GIT patch format that I didn't know about. So it's a bug in the way GNU
patch handles the git patch format and not an error in the patch. Not nice
and probably not easy to fix, but not fundamentally unfixable.
Andreas
^ permalink raw reply [flat|nested] 16+ messages in thread
end of thread, other threads:[~2010-09-04 22:32 UTC | newest]
Thread overview: 16+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <1283431716-21540-1-git-send-email-plagnioj@jcrosoft.com>
[not found] ` <1283434786-26479-1-git-send-email-plagnioj@jcrosoft.com>
[not found] ` <AANLkTimRKCYYQmgwY0DHu5+e-ggT8grJbdjWFvUqTzH=@mail.gmail.com>
2010-09-03 18:23 ` [PATCH V3] arm & sh: factorised duplicated clkdev.c Uwe Kleine-König
2010-09-03 18:43 ` [BUG?] rename patch accepted with --dry-run, rejected without (Re: [PATCH V3] arm & sh: factorised duplicated clkdev.c) Jonathan Nieder
2010-09-03 19:29 ` Russell King - ARM Linux
2010-09-03 19:33 ` Uwe Kleine-König
2010-09-03 19:45 ` Andreas Schwab
2010-09-04 0:03 ` Russell King - ARM Linux
2010-09-04 21:33 ` [bug-patch] " Andreas Gruenbacher
2010-09-04 21:45 ` Russell King - ARM Linux
2010-09-04 21:46 ` Andreas Gruenbacher
2010-09-04 22:01 ` Russell King - ARM Linux
2010-09-04 22:26 ` Andreas Gruenbacher
2010-09-03 19:34 ` Matthieu Moy
2010-09-03 22:58 ` [bug-patch] " Andreas Gruenbacher
2010-09-03 23:32 ` Jonathan Nieder
2010-09-04 21:57 ` Andreas Gruenbacher
2010-09-04 3:21 ` Jean-Christophe PLAGNIOL-VILLARD
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).