From: Sam Hocevar <sam@zoy.org>
To: Pete Wyckoff <pw@padd.com>
Cc: git@vger.kernel.org
Subject: Re: git-p4 workflow suggestions?
Date: Mon, 16 Mar 2009 19:01:09 +0100 [thread overview]
Message-ID: <20090316180108.GE27280@zoy.org> (raw)
In-Reply-To: <20090311125805.GA28155@padd.com>
On Wed, Mar 11, 2009, Pete Wyckoff wrote:
> sam@zoy.org wrote on Mon, 09 Mar 2009 15:21 +0100:
> > I have modified git and git-p4 to a point where they are usable in
> > my work environment. I am now faced with a new problem: Perforce's
> > composite workspaces. They allow you to "mount" parts of the repo onto
> > other directories, even nonempty ones.
> >
> > Take the following example repository, where a "framework" project
> > contains an example subdirectory with build files and other directories,
> > and a "project1" project contains subdirectories that are meant to
> > replace the ones in "example":
> >
> > //work/framework/example/src/
> > /include/
> > /Makefile
> > /...
> > //work/project1/src/
> > /include/
>
> In perforce terms, your "view mapping" looks like:
>
> //work/framework/example/src/... //client/src/...
> //work/project1/src/include/... //client/src/include/...
Yes, like this. More precisely:
//work/framework/example/... //client/...
//work/project1/src/... //client/src/...
//work/project1/include/... //client/include/...
> I'm not a pro with p4, but do deal with many-line mappings like
> this. Stock git-p4 handles these, except doesn't map correctly to
> the right-hand side. I haven't tried to see if it would correctly
> use the include files from project1 instead of framework in your
> example.
No luck here. If I clone //work with git-p4, I get two separate
/framework and /project1 directories, and the mapping is not done.
The "solution" I found so far was to clone //work and hack git-p4
so that it ignores //work/framework/example/src, and then symlink
//work/project1/src to //work/framework/example/src. This allows me to
pull changes with a single "git-p4 rebase" command. Unfortunately it
also requires me to clone a full, separate //work p4 workspace in order
to use "git-p4 submit" later, and that's more than 120 GiB wasted.
> If you can get git-p4 to figure out the mapping correctly, I don't
> expect any problems with respect to atomicity of commits. As far as
> perforce goes, a server seems to manage its entire p4 space as one
> big single project. Similarly with the git side of things---it's
> just a matter of getting this mapping correct.
>
> I too hacked the getClientSpec() part of git-p4 to put files into
> the correct directories in the git side. My changes are a bit
> messy, and may interfere with other usage models, hence not
> submitted. Maybe we should make an effort to get this right though.
> Do you have any changes to show how you are modifying things?
I'm curious to see your changes. I don't feel I completely understand
the p4 way to do things yet.
My changes are extremely messy but I will refactor them as time goes.
There is at least one other important thing my git-p4 does, which is not
storing the whole commit in memory. Combined with the patches I sent
last week to this list, it's the only way I can import the p4 repository
we have at work. (See http://zoy.org/~sam/git/clumsily-hacked-git-p4)
Feel free to contact me in private if you have questions or want
information that may not be mailing-list relevant. I'm all for cleaning
up things and getting a fully featured git-p4. I'm on that project for
at least three years, and there is absolutely no way my blood pressure
can stand that long with Perforce.
Cheers,
--
Sam.
next prev parent reply other threads:[~2009-03-16 18:03 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-03-09 14:21 git-p4 workflow suggestions? Sam Hocevar
2009-03-10 7:15 ` Christian Couder
2009-03-10 9:57 ` Sam Hocevar
2009-03-11 7:03 ` Christian Couder
2009-03-11 12:58 ` Pete Wyckoff
2009-03-16 18:01 ` Sam Hocevar [this message]
2009-03-17 15:18 ` Pete Wyckoff
2009-03-20 10:31 ` Sam Hocevar
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=20090316180108.GE27280@zoy.org \
--to=sam@zoy.org \
--cc=git@vger.kernel.org \
--cc=pw@padd.com \
/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;
as well as URLs for NNTP newsgroup(s).