* git-svn adding too many blank lines during git-cherry-pick, and git-cherry getting confused
@ 2007-06-02 4:50 Robin H. Johnson
2007-06-05 10:24 ` Eric Wong
0 siblings, 1 reply; 2+ messages in thread
From: Robin H. Johnson @ 2007-06-02 4:50 UTC (permalink / raw)
To: Git Mailing List
[-- Attachment #1: Type: text/plain, Size: 1620 bytes --]
Hi,
Bit of weirdness I ran into.
I have a SVN tree, with a branch that gets some backported fixe (they
usually apply cleanly).
I commit the fix to the trunk + git-svn dcommit, and then switch to the
other branch, and git-cherry-pick the fix.
For git-svn commits, the log has:
On the trunk side, there is a two blank line before git-svn-id.
On the branch side, there are three blank lines before git-svn-id.
If I cherry-pick from that branch to a third branch, I get 4 blank
lines.
For regular SVN commits, the log has:
Only a single blank line before git-svn-id.
I think the source of the problem is that git-svn-id is being removed
when cherry-picking, but NOT the leading blank line.
This all leads to the hashes of the commits diverging badly, and then
git-cherry gets very confused when asked to compare the trunk vs. the
branches.
How do we solve it?
This is only on a conceptual level here, looking at the present state of
git-svn, I'm not sure how best to solve it.
git-svn fetch:
1. Get commit message from SVN.
2. Trim ALL trailing blank lines (and existing git-svn-id lines).
3. If the last line was header-style (Signed-off-by, CC, etc)
3.1. if it was, do not add a blank line.
3.2. If not, add a single blank line.
4. Insert git-svn-id header.
git-svn dcommit:
1. Get commit message (git cat-file commit ....)
2. Remove the git-svn-id line.
3. Remove all trailing blank lines.
4. Commit.
--
Robin Hugh Johnson
Gentoo Linux Developer & Council Member
E-Mail : robbat2@gentoo.org
GnuPG FP : 11AC BA4F 4778 E3F6 E4ED F38E B27B 944E 3488 4E85
[-- Attachment #2: Type: application/pgp-signature, Size: 321 bytes --]
^ permalink raw reply [flat|nested] 2+ messages in thread
* Re: git-svn adding too many blank lines during git-cherry-pick, and git-cherry getting confused
2007-06-02 4:50 git-svn adding too many blank lines during git-cherry-pick, and git-cherry getting confused Robin H. Johnson
@ 2007-06-05 10:24 ` Eric Wong
0 siblings, 0 replies; 2+ messages in thread
From: Eric Wong @ 2007-06-05 10:24 UTC (permalink / raw)
To: Robin H. Johnson; +Cc: Git Mailing List
"Robin H. Johnson" <robbat2@gentoo.org> wrote:
> Hi,
>
> Bit of weirdness I ran into.
>
> I have a SVN tree, with a branch that gets some backported fixe (they
> usually apply cleanly).
>
> I commit the fix to the trunk + git-svn dcommit, and then switch to the
> other branch, and git-cherry-pick the fix.
>
> For git-svn commits, the log has:
> On the trunk side, there is a two blank line before git-svn-id.
> On the branch side, there are three blank lines before git-svn-id.
> If I cherry-pick from that branch to a third branch, I get 4 blank
> lines.
>
> For regular SVN commits, the log has:
> Only a single blank line before git-svn-id.
>
> I think the source of the problem is that git-svn-id is being removed
> when cherry-picking, but NOT the leading blank line.
>
> This all leads to the hashes of the commits diverging badly, and then
> git-cherry gets very confused when asked to compare the trunk vs. the
> branches.
>
> How do we solve it?
> This is only on a conceptual level here, looking at the present state of
> git-svn, I'm not sure how best to solve it.
>
> git-svn fetch:
> 1. Get commit message from SVN.
> 2. Trim ALL trailing blank lines (and existing git-svn-id lines).
> 3. If the last line was header-style (Signed-off-by, CC, etc)
> 3.1. if it was, do not add a blank line.
> 3.2. If not, add a single blank line.
> 4. Insert git-svn-id header.
Too much magic. I don't think this is a good idea, at least
not by default.
> git-svn dcommit:
> 1. Get commit message (git cat-file commit ....)
> 2. Remove the git-svn-id line.
> 3. Remove all trailing blank lines.
> 4. Commit.
We already do step 3. The problem is that we fail to remove the newline
*before* the git-svn-id line. I'll make a mental note to fix this
sometime this week, I hope.
--
Eric Wong
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2007-06-05 10:24 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-06-02 4:50 git-svn adding too many blank lines during git-cherry-pick, and git-cherry getting confused Robin H. Johnson
2007-06-05 10:24 ` Eric Wong
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).