From: Gustavo Narea <gnarea@tech.2degreesnetwork.com>
To: "Ævar Arnfjörð Bjarmason" <avarab@gmail.com>
Cc: git@vger.kernel.org
Subject: Re: Multiple checkouts active for the same repository
Date: Fri, 24 Sep 2010 15:42:14 +0100 [thread overview]
Message-ID: <4C9CB8C6.1050101@tech.2degreesnetwork.com> (raw)
In-Reply-To: <AANLkTikvyM9wXrewRiG7OdBp5LMfnHSkA9dqZGT1Twpc@mail.gmail.com>
Hello,
On 24/09/10 14:07, Ævar Arnfjörð Bjarmason wrote:
> On Fri, Sep 24, 2010 at 09:29, Gustavo Narea
> <gnarea@tech.2degreesnetwork.com> wrote:
>
>> We're currently migrating from another DVCS.
>
> Which one?
Bazaar.
>> We are a team of Web developers and testers working on an application.
>> There are always a few development branches and a stable branch, and
>> testers need all the branches with the very latest code available at all
>> times.
>>
>> The way we handle it at the moment is very simple because the server
>> hosting the remote repository is the same that hosts the deployed
>> instances of each branch, so when we push to the remote repository, the
>> code for each site is automatically updated.
>>
>> We use the following structure:
>> /srv/repositories/project/branch1
>> /srv/repositories/project/branch2
>> /srv/repositories/project/branch3
>>
>> Is there any simple way to do this with Git? I can only think of two
>> options that involve hooks:
>>
>> * Have a hook that exports each branch to a directory like
>> /srv/repositories/project/branchN
>> * Have one Git repository per branch, so that each repository have a
>> different checkout active. Then the main remote repository will
>> have post-receive hooks that trigger a pull on each individual
>>
>> I'm not particularly happy with either way. Is there a better solution?
>
> If you really need this the best solution is to just `git clone` the
> project multiple times and check out each branch in its own dir. Then
> have some shellscript to update them all.
>
> But just using the Git workflow would be better.
OK, I'll do it that way.
>> Apart from the situation I describe in the initial email, there's
>> another limitation in the development environment: Our IDE, Eclipse +
>> Pydev, assumes each project (i.e., branch/checkout) to be on different
>> directories and each project should have different settings (e.g., paths
>> to dependencies, which could be different), but with GIt everything
>> would be a single project because it's all on the same path.
>
> Can't you just modify your build environment to check the output of
> `git symbolic-ref HEAD` or equivalent, instead of checking paths?
Yes, that's what I intend to do for the build system, but that wouldn't
solve the problem with the IDE:
Eclipse and PyDev (Python plugin) store their settings in the project
directory. For example, the one from PyDev contains the absolute paths
to all the dependencies, which makes features like auto-completion work;
I would have to mark these files are ignored because they change from
machine to machine, and sometimes from branch to branch.
So, no matter what the active branch is, I will always get the settings
for the first branch I configured. And if I change them, all the other
branches will be affected.
Any suggestions?
I tried playing with --git-dir and --work-tree, so that I could have the
repository in one place and the checkout for each branch on different
repositories, but it doesn't seem to be a good solution because we
cannot specify the branch in commands like git-status.
Thank you very much.
--
Gustavo Narea.
Software Developer.
2degrees, Ltd. <http://dev.2degreesnetwork.com/>.
next prev parent reply other threads:[~2010-09-24 14:42 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-09-24 9:29 Multiple checkouts active for the same repository Gustavo Narea
2010-09-24 11:55 ` Gustavo Narea
2010-09-24 13:07 ` Ævar Arnfjörð Bjarmason
2010-09-24 14:42 ` Gustavo Narea [this message]
2010-09-24 15:33 ` Julian Phillips
2010-09-24 16:32 ` Joshua Jensen
2010-09-27 10:33 ` Gustavo Narea
2010-09-27 11:53 ` Martin Pettersson
2010-09-24 15:57 ` Jakub Narebski
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=4C9CB8C6.1050101@tech.2degreesnetwork.com \
--to=gnarea@tech.2degreesnetwork.com \
--cc=avarab@gmail.com \
--cc=git@vger.kernel.org \
/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).