git.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* git PATH reordering
@ 2006-11-06 13:33 Janos Farkas
  2006-11-06 13:58 ` Andy Whitcroft
  0 siblings, 1 reply; 2+ messages in thread
From: Janos Farkas @ 2006-11-06 13:33 UTC (permalink / raw)
  To: git

Hi!

I'm facing an issue which seems to originate about a year ago, so I'm a
bit late :)

Apparently, most git commands seem to tweak their PATH to make sure the
corresponding version of a subcommand gets ran in the case there are
multiple ones in there.

The thing is, since this "ensuring" is done by prepend_to_path(), which
can then change all exec() afterwards.   Usually, that's not a problem,
but that made git run an unexpectedly different ssh command for remote
access.  When I discovered what the problem is, I easily fixed it by
setting GIT_SSH to the explicit path, and I can live with that, but it's
a bit confusing.

I don't want to start a neverending thread, so if my bikeshed doesn't
interest you, I'll give up :)  But the way it's done now seems to be for
the case which should be very rare.

As I see, all this PATH manipulation logic was meant to solve the case
when the desired "git" version is not in the path or some mismatching
components of it is.  Including the case when you want to point some
higher level tool to one specific version of "git" to be used,
irrespective of PATH.  Is this the right way to do it?  Is it
really required at all?

Apart from getting rid of this (possibly useful?) munging, I could see
about two ways to change the behavior to less surprising:

- Don't make PATH munging if "our" path is in the PATH already.
- Save the PATH before munging, and restore before any non-git command
  is run.  This is a bit complex, as multiple languages are used,
  including sh..

Both could make sense, but I don't think either is the correct way.

What bit me, if someone cares about the details, is that on my system,
everything is in the correct path, even git*.  There is however a private
~/bin at the front of the PATH containing some preferred/fixed versions
of some system tools.  When git (living as a normal citizen in /usr/bin)
does its PATH munging, it puts /usr/bin in the front of the path,
skipping this well built house of cards.  As I said, I can live with
that, since only ssh is one that I can designate as "important", and
that one can be set separately with GIT_SSH, but still..


^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2006-11-06 13:59 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2006-11-06 13:33 git PATH reordering Janos Farkas
2006-11-06 13:58 ` Andy Whitcroft

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).