git.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* 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).