Re: Embedded Linux development with GIT

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,

On Thu, 5 Jul 2007, Johannes Sixt wrote:

> Sean Kelley wrote:
> > 
> > I have a situation where we have a local GIT repository that is based
> > on v2.6.17.  We initially added the source tarball to an empty
> > repository and then started applying changes to it.  Looking back,
> > that might not have been the best idea 400 commits later.
> 
> That is possible using a graft:
> 
>   $ echo "$x $(git rev-parse v2.6.17^0)" >> .git/info/grafts
> 
> where $x is the SHA1 of the first commit you made on top of the imported
> tarball.

Yes, this is also how I would do it.

> This way you have spliced your history with Linus's history. (This is a 
> strictly _local_ matter! Every clone of your history must repeat the 
> game!)

Now, here I disagree slightly.  If you merge just once, subsequent merges 
will be possible even without that graft.

So if you merge with some newer Linux version, all your cloners get the 
benefit.

> Now, Linus will not be able to pull from your faked history because he
> doesn't know about the graft.

Except if you merge with a more recent version of Linux.

However, I doubt that such a distant (in terms of time!) merge would 
appeal to Linus.  I guess you have to rebase on top of Linus' version 
_anyway_.

> In order to fix that, you can run git-filter-branch from current git's 
> master branch to rewrite your history:
> 
>   $ git filter-branch new-master v2.6.17..master
> 
> Read the man page of git-filter-branch, and understand the implications
> before you publish the result.

This is a way to fix your history, yes.  Note that filter-branch is not 
yet in an official release of Git, and so you either have to wait for 
1.5.3, or you get filter-branch from git.git's "next" branch (just picking 
this one script should work fine, if you have at least 1.5.1 installed).

Note that this rewrites the history, so all the disadvantages of 
rebasing with pulling apply here, too.

But as stated above, I think you have to rebase eventually anyway, if you 
go for inclusion in Linus' tree.  In that case, the filter-branch is 
unnecessary.

Ciao,
Dscho

-
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux