* [PATCH RFC] Move all dashed form git commands to libexecdir @ 2007-11-27 15:02 Nguyễn Thái Ngọc Duy 2007-11-27 15:12 ` Johannes Schindelin ` (2 more replies) 0 siblings, 3 replies; 92+ messages in thread From: Nguyễn Thái Ngọc Duy @ 2007-11-27 15:02 UTC (permalink / raw) To: git Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com> --- We have talked about it for quite some time now. How about making it happen? I won't miss dashed form commands much :) A compromised approach could be keeping porcelain commands in bindir, only plumbings are moved to libexecdir. That would be less shock than this. config.mak.in | 2 +- 1 files changed, 1 insertions(+), 1 deletions(-) diff --git a/config.mak.in b/config.mak.in index 11d256e..1db0338 100644 --- a/config.mak.in +++ b/config.mak.in @@ -11,7 +11,7 @@ TCLTK_PATH = @TCLTK_PATH@ prefix = @prefix@ exec_prefix = @exec_prefix@ bindir = @bindir@ -#gitexecdir = @libexecdir@/git-core/ +gitexecdir = @libexecdir@/git-core/ datarootdir = @datarootdir@ template_dir = @datadir@/git-core/templates/ -- 1.5.3.GIT ^ permalink raw reply related [flat|nested] 92+ messages in thread
* Re: [PATCH RFC] Move all dashed form git commands to libexecdir 2007-11-27 15:02 [PATCH RFC] Move all dashed form git commands to libexecdir Nguyễn Thái Ngọc Duy @ 2007-11-27 15:12 ` Johannes Schindelin 2007-11-27 15:25 ` Nicolas Pitre 2007-11-27 16:04 ` [PATCH] " Nguyễn Thái Ngoc Duy 2 siblings, 0 replies; 92+ messages in thread From: Johannes Schindelin @ 2007-11-27 15:12 UTC (permalink / raw) To: Nguyễn Thái Ngọc Duy; +Cc: git [-- Attachment #1: Type: TEXT/PLAIN, Size: 450 bytes --] Hi, On Tue, 27 Nov 2007, Nguyễn Thái Ngọc Duy wrote: > diff --git a/config.mak.in b/config.mak.in I don't use configure, and don't expect distros to use it either. Maybe you want to change Makefile first, so that the hard-core "next" followers test it first? Then, when everything is worked out and deemed to be stable, Junio can merge it to "master", and we can adjust the rpm spec and bug packagers to change their setup? Ciao, Dscho ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH RFC] Move all dashed form git commands to libexecdir 2007-11-27 15:02 [PATCH RFC] Move all dashed form git commands to libexecdir Nguyễn Thái Ngọc Duy 2007-11-27 15:12 ` Johannes Schindelin @ 2007-11-27 15:25 ` Nicolas Pitre 2007-11-27 16:04 ` [PATCH] " Nguyễn Thái Ngoc Duy 2 siblings, 0 replies; 92+ messages in thread From: Nicolas Pitre @ 2007-11-27 15:25 UTC (permalink / raw) To: Nguyễn Thái Ngọc Duy; +Cc: git [-- Attachment #1: Type: TEXT/PLAIN, Size: 390 bytes --] On Tue, 27 Nov 2007, Nguyễn Thái Ngọc Duy wrote: > We have talked about it for quite some time now. How about > making it happen? I won't miss dashed form commands much :) > > A compromised approach could be keeping porcelain commands > in bindir, only plumbings are moved to libexecdir. That would > be less shock than this. I think that would be an excellent idea. Nicolas ^ permalink raw reply [flat|nested] 92+ messages in thread
* [PATCH] Move all dashed form git commands to libexecdir 2007-11-27 15:02 [PATCH RFC] Move all dashed form git commands to libexecdir Nguyễn Thái Ngọc Duy 2007-11-27 15:12 ` Johannes Schindelin 2007-11-27 15:25 ` Nicolas Pitre @ 2007-11-27 16:04 ` Nguyễn Thái Ngoc Duy 2007-11-27 16:18 ` Johannes Schindelin 2 siblings, 1 reply; 92+ messages in thread From: Nguyễn Thái Ngoc Duy @ 2007-11-27 16:04 UTC (permalink / raw) To: git Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com> --- Both configure and make-only ways should work now Makefile | 2 +- config.mak.in | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/Makefile b/Makefile index 313f9a2..377d7be 100644 --- a/Makefile +++ b/Makefile @@ -154,7 +154,7 @@ STRIP ?= strip prefix = $(HOME) bindir = $(prefix)/bin -gitexecdir = $(bindir) +gitexecdir = $(prefix)/libexec/git-core sharedir = $(prefix)/share template_dir = $(sharedir)/git-core/templates ifeq ($(prefix),/usr) diff --git a/config.mak.in b/config.mak.in index 11d256e..1db0338 100644 --- a/config.mak.in +++ b/config.mak.in @@ -11,7 +11,7 @@ TCLTK_PATH = @TCLTK_PATH@ prefix = @prefix@ exec_prefix = @exec_prefix@ bindir = @bindir@ -#gitexecdir = @libexecdir@/git-core/ +gitexecdir = @libexecdir@/git-core/ datarootdir = @datarootdir@ template_dir = @datadir@/git-core/templates/ -- 1.5.3.GIT ^ permalink raw reply related [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-27 16:04 ` [PATCH] " Nguyễn Thái Ngoc Duy @ 2007-11-27 16:18 ` Johannes Schindelin 2007-11-28 0:07 ` Jan Hudec 0 siblings, 1 reply; 92+ messages in thread From: Johannes Schindelin @ 2007-11-27 16:18 UTC (permalink / raw) To: Nguyễn Thái Ngoc Duy; +Cc: git [-- Attachment #1: Type: TEXT/PLAIN, Size: 199 bytes --] Hi, On Tue, 27 Nov 2007, Nguyễn Thái Ngoc Duy wrote: > Both configure and make-only ways should work now I thought your plan was to put the non-porcelain into the libexecdir only? Ciao, Dscho ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-27 16:18 ` Johannes Schindelin @ 2007-11-28 0:07 ` Jan Hudec 2007-11-28 1:13 ` Junio C Hamano 0 siblings, 1 reply; 92+ messages in thread From: Jan Hudec @ 2007-11-28 0:07 UTC (permalink / raw) To: Johannes Schindelin; +Cc: Nguyễn Thái Ngoc Duy, git [-- Attachment #1: Type: text/plain, Size: 517 bytes --] On Tue, Nov 27, 2007 at 16:18:01 +0000, Johannes Schindelin wrote: > Hi, > > On Tue, 27 Nov 2007, Nguyễn Thái Ngoc Duy wrote: > > > Both configure and make-only ways should work now > > I thought your plan was to put the non-porcelain into the libexecdir only? I had the impression that deprecating the dash notation for /all/ use was approved some time ago. Though I don't want to search through the list archives this late in the night to check it. -- Jan 'Bulb' Hudec <bulb@ucw.cz> [-- Attachment #2: Digital signature --] [-- Type: application/pgp-signature, Size: 189 bytes --] ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-28 0:07 ` Jan Hudec @ 2007-11-28 1:13 ` Junio C Hamano 2007-11-28 8:18 ` Jan Hudec 2007-11-28 8:36 ` Nguyen Thai Ngoc Duy 0 siblings, 2 replies; 92+ messages in thread From: Junio C Hamano @ 2007-11-28 1:13 UTC (permalink / raw) To: Jan Hudec; +Cc: Johannes Schindelin, Nguyễn Thái Ngoc Duy, git Jan Hudec <bulb@ucw.cz> writes: > On Tue, Nov 27, 2007 at 16:18:01 +0000, Johannes Schindelin wrote: >> Hi, >> >> On Tue, 27 Nov 2007, Nguyễn Thái Ngoc Duy wrote: >> >> > Both configure and make-only ways should work now >> >> I thought your plan was to put the non-porcelain into the libexecdir only? > > I had the impression that deprecating the dash notation for /all/ use was > approved some time ago. Though I don't want to search through the list > archives this late in the night to check it. Yes. Moving the dash-form commands out of end user's PATH was something distros and users have been allowed to do since forever, and strictly speaking, using dash form from the command line was already deprecated at that point. If your script runs git-foo without first asking "git --exec-path" and prepending it to the path, your script would not find git-foo if the installation uses gitexecdir that is not on the usual $PATH, either. I essentially just said that your patch is unnecessary, but at the same time, your patch does not go far enough. As Nico earlier pointed out, we ship a sample rpm spec, which would also need to be updated. We do not ship a sample debian/rules anymore, thank $DEITY ;-) Also, because we do not remove existing files from the installation target directory when we do "make install", the commit log message should carry a big fat warning that says "remove old installation of git from your $(bindir) when you try this," for people who build from the source, and we need to repeat the deprecation notice in bold red letters in the Release Notes for perhaps git 1.6.0. In case somebody is thinking about 36e5e70e0f40 (Start deprecating "git-command" in favor of "git command"), that is a somewhat different issue. What Linus suggested is not installing git-foo link for built-in commands _anywhere_ on the filesystem. Not just "out of user's PATH". That is not deprecating dash form but removing the support for it. We need to give ample time for users to adjust to such a change. ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-28 1:13 ` Junio C Hamano @ 2007-11-28 8:18 ` Jan Hudec 2007-11-28 8:36 ` Nguyen Thai Ngoc Duy 1 sibling, 0 replies; 92+ messages in thread From: Jan Hudec @ 2007-11-28 8:18 UTC (permalink / raw) To: Junio C Hamano; +Cc: Johannes Schindelin, Nguyễn Thái Ngoc Duy, git On Tue, Nov 27, 2007 at 17:13:58 -0800, Junio C Hamano wrote: > Jan Hudec <bulb@ucw.cz> writes: > > On Tue, Nov 27, 2007 at 16:18:01 +0000, Johannes Schindelin wrote: > >> On Tue, 27 Nov 2007, Nguyễn Thái Ngoc Duy wrote: > >> > >> > Both configure and make-only ways should work now > >> > >> I thought your plan was to put the non-porcelain into the libexecdir only? > > > > I had the impression that deprecating the dash notation for /all/ use was > > approved some time ago. Though I don't want to search through the list > > archives this late in the night to check it. > > [...] > > In case somebody is thinking about 36e5e70e0f40 (Start deprecating > "git-command" in favor of "git command"), that is a somewhat different > issue. What Linus suggested is not installing git-foo link for built-in > commands _anywhere_ on the filesystem. Not just "out of user's PATH". > That is not deprecating dash form but removing the support for it. We > need to give ample time for users to adjust to such a change. Yes, that is what I said I recall seeing. Installing out of user's PATH is a step towards not installing at all and the change suggests it has been already accepted as a general direction for future. Or not? -- Jan 'Bulb' Hudec <bulb@ucw.cz> ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-28 1:13 ` Junio C Hamano 2007-11-28 8:18 ` Jan Hudec @ 2007-11-28 8:36 ` Nguyen Thai Ngoc Duy 2007-11-28 23:14 ` Junio C Hamano 2007-11-29 0:14 ` Jakub Narebski 1 sibling, 2 replies; 92+ messages in thread From: Nguyen Thai Ngoc Duy @ 2007-11-28 8:36 UTC (permalink / raw) To: Junio C Hamano; +Cc: Jan Hudec, Johannes Schindelin, git On Nov 28, 2007 8:13 AM, Junio C Hamano <gitster@pobox.com> wrote: > In case somebody is thinking about 36e5e70e0f40 (Start deprecating > "git-command" in favor of "git command"), that is a somewhat different > issue. What Linus suggested is not installing git-foo link for built-in > commands _anywhere_ on the filesystem. Not just "out of user's PATH". > That is not deprecating dash form but removing the support for it. We > need to give ample time for users to adjust to such a change. A little note on this one. I've been using git without builtin links for a while with my git-box port. There are still some builtin fixups needed. And because execv_git_cmd() always uses dash form, so it's impossible to use vanilla git without builtin links. -- Duy ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-28 8:36 ` Nguyen Thai Ngoc Duy @ 2007-11-28 23:14 ` Junio C Hamano 2007-11-28 23:40 ` Johannes Schindelin ` (3 more replies) 2007-11-29 0:14 ` Jakub Narebski 1 sibling, 4 replies; 92+ messages in thread From: Junio C Hamano @ 2007-11-28 23:14 UTC (permalink / raw) To: Nguyen Thai Ngoc Duy; +Cc: Jan Hudec, Johannes Schindelin, git "Nguyen Thai Ngoc Duy" <pclouds@gmail.com> writes: > On Nov 28, 2007 8:13 AM, Junio C Hamano <gitster@pobox.com> wrote: >> In case somebody is thinking about 36e5e70e0f40 (Start deprecating >> "git-command" in favor of "git command"), that is a somewhat different >> issue. What Linus suggested is not installing git-foo link for built-in >> commands _anywhere_ on the filesystem. Not just "out of user's PATH". >> That is not deprecating dash form but removing the support for it. We >> need to give ample time for users to adjust to such a change. > > A little note on this one. I've been using git without builtin links > for a while with my git-box port. There are still some builtin fixups > needed. And because execv_git_cmd() always uses dash form, so it's > impossible to use vanilla git without builtin links. Thanks for a heads up. Would people agree with a rough roadmap like this? - v1.5.4 will ship with gitexecdir=$(bindir) in Makefile. But the release notes for the version will warn users that: (1) using git-foo from the command line, and (2) using git-foo from your scripts without first prepending the return value of "git --exec-path" to the PATH is now officially deprecated (it has been deprecated for a long time since January 2006, v1.2.0~149) and upcoming v1.5.5 will ship with the default configuration that does not install git-foo form in user's PATH. - Post v1.5.4, start cooking gitexecdir=$(libexecdir)/git-core, aiming for inclusion in v1.5.5, perhaps in Mar-Feb 2008 timeframe. - The release notes for v1.5.5 will warn users that git-foo will be removed in v1.6.0 for many commands and it will be merely an accident if some of them still work. - Post v1.5.5, start cooking the change that does not install hardlinks for built-in commands, aiming for inclusion in v1.6.0, by the end of 2008. ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-28 23:14 ` Junio C Hamano @ 2007-11-28 23:40 ` Johannes Schindelin 2007-11-28 23:48 ` Junio C Hamano 2007-11-29 0:59 ` A Large Angry SCM ` (2 subsequent siblings) 3 siblings, 1 reply; 92+ messages in thread From: Johannes Schindelin @ 2007-11-28 23:40 UTC (permalink / raw) To: Junio C Hamano; +Cc: Nguyen Thai Ngoc Duy, Jan Hudec, git Hi, On Wed, 28 Nov 2007, Junio C Hamano wrote: > "Nguyen Thai Ngoc Duy" <pclouds@gmail.com> writes: > > > On Nov 28, 2007 8:13 AM, Junio C Hamano <gitster@pobox.com> wrote: > >> In case somebody is thinking about 36e5e70e0f40 (Start deprecating > >> "git-command" in favor of "git command"), that is a somewhat different > >> issue. What Linus suggested is not installing git-foo link for built-in > >> commands _anywhere_ on the filesystem. Not just "out of user's PATH". > >> That is not deprecating dash form but removing the support for it. We > >> need to give ample time for users to adjust to such a change. > > > > A little note on this one. I've been using git without builtin links > > for a while with my git-box port. There are still some builtin fixups > > needed. And because execv_git_cmd() always uses dash form, so it's > > impossible to use vanilla git without builtin links. > > Thanks for a heads up. > > Would people agree with a rough roadmap like this? > > - v1.5.4 will ship with gitexecdir=$(bindir) in Makefile. But the > release notes for the version will warn users that: > > (1) using git-foo from the command line, and > > (2) using git-foo from your scripts without first prepending the > return value of "git --exec-path" to the PATH > > is now officially deprecated (it has been deprecated for a long time > since January 2006, v1.2.0~149) and upcoming v1.5.5 will ship with > the default configuration that does not install git-foo form in > user's PATH. Maybe we can squeeze a step in here where only porcelains are installed in the bindir? FWIW I think that we should fix the problem with the builtins being called via their hard links. But how? As of now, libgit.a has no idea what the builtins are; this information is buried in git.c. The fundamental problem is that we cannot move handle_internal_command() into libgit.a, because it has pointers to all builtin cmd_*() functions. So maybe the best solution would be to try "git <command>" first, and then "git-<command>"? But this means another exec() call :-( Ciao, Dscho ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-28 23:40 ` Johannes Schindelin @ 2007-11-28 23:48 ` Junio C Hamano 2007-11-29 0:01 ` Johannes Schindelin 0 siblings, 1 reply; 92+ messages in thread From: Junio C Hamano @ 2007-11-28 23:48 UTC (permalink / raw) To: Johannes Schindelin; +Cc: Nguyen Thai Ngoc Duy, Jan Hudec, git Johannes Schindelin <Johannes.Schindelin@gmx.de> writes: > The fundamental problem is that we cannot move handle_internal_command() > into libgit.a, because it has pointers to all builtin cmd_*() functions. What's wrong with having cmd_* functions in the library to begin with? ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-28 23:48 ` Junio C Hamano @ 2007-11-29 0:01 ` Johannes Schindelin 0 siblings, 0 replies; 92+ messages in thread From: Johannes Schindelin @ 2007-11-29 0:01 UTC (permalink / raw) To: Junio C Hamano; +Cc: Nguyen Thai Ngoc Duy, Jan Hudec, git Hi, On Wed, 28 Nov 2007, Junio C Hamano wrote: > Johannes Schindelin <Johannes.Schindelin@gmx.de> writes: > > > The fundamental problem is that we cannot move > > handle_internal_command() into libgit.a, because it has pointers to > > all builtin cmd_*() functions. > > What's wrong with having cmd_* functions in the library to begin with? I was considering it not desirable (after all, the library is meant to have common functions in it), but you're right... Ciao, Dscho ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-28 23:14 ` Junio C Hamano 2007-11-28 23:40 ` Johannes Schindelin @ 2007-11-29 0:59 ` A Large Angry SCM 2007-11-29 1:02 ` Junio C Hamano 2007-11-29 3:17 ` Nguyen Thai Ngoc Duy 2007-11-29 15:08 ` Jeff King 3 siblings, 1 reply; 92+ messages in thread From: A Large Angry SCM @ 2007-11-29 0:59 UTC (permalink / raw) To: Junio C Hamano; +Cc: git Junio C Hamano wrote: [...] > Would people agree with a rough roadmap like this? > > - v1.5.4 will ship with gitexecdir=$(bindir) in Makefile. But the > release notes for the version will warn users that: > > (1) using git-foo from the command line, and > > (2) using git-foo from your scripts without first prepending the > return value of "git --exec-path" to the PATH > > is now officially deprecated (it has been deprecated for a long time > since January 2006, v1.2.0~149) and upcoming v1.5.5 will ship with > the default configuration that does not install git-foo form in > user's PATH. > > - Post v1.5.4, start cooking gitexecdir=$(libexecdir)/git-core, aiming > for inclusion in v1.5.5, perhaps in Mar-Feb 2008 timeframe. > > - The release notes for v1.5.5 will warn users that git-foo will be > removed in v1.6.0 for many commands and it will be merely an accident > if some of them still work. > > - Post v1.5.5, start cooking the change that does not install hardlinks > for built-in commands, aiming for inclusion in v1.6.0, by the end of > 2008. So long as there remains the option in the Makefile to install the "dashed" commands in $(bindir) for those of us that wish it. ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-29 0:59 ` A Large Angry SCM @ 2007-11-29 1:02 ` Junio C Hamano 0 siblings, 0 replies; 92+ messages in thread From: Junio C Hamano @ 2007-11-29 1:02 UTC (permalink / raw) To: gitzilla; +Cc: git A Large Angry SCM <gitzilla@gmail.com> writes: > Junio C Hamano wrote: > [...] >> Would people agree with a rough roadmap like this? >> >> - v1.5.4 will ship with gitexecdir=$(bindir) in Makefile. But the >> release notes for the version will warn users that: >> >> (1) using git-foo from the command line, and >> >> (2) using git-foo from your scripts without first prepending the >> return value of "git --exec-path" to the PATH >> >> is now officially deprecated (it has been deprecated for a long time >> since January 2006, v1.2.0~149) and upcoming v1.5.5 will ship with >> the default configuration that does not install git-foo form in >> user's PATH. >> >> - Post v1.5.4, start cooking gitexecdir=$(libexecdir)/git-core, aiming >> for inclusion in v1.5.5, perhaps in Mar-Feb 2008 timeframe. >> >> - The release notes for v1.5.5 will warn users that git-foo will be >> removed in v1.6.0 for many commands and it will be merely an accident >> if some of them still work. >> >> - Post v1.5.5, start cooking the change that does not install hardlinks >> for built-in commands, aiming for inclusion in v1.6.0, by the end of >> 2008. > > So long as there remains the option in the Makefile to install the > "dashed" commands in $(bindir) for those of us that wish it. Surely. Actually they already have that option of going dashless themselves, so in a sense it is not strictly necessary to make a big deal out of this. ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-28 23:14 ` Junio C Hamano 2007-11-28 23:40 ` Johannes Schindelin 2007-11-29 0:59 ` A Large Angry SCM @ 2007-11-29 3:17 ` Nguyen Thai Ngoc Duy 2007-11-29 14:09 ` Nicolas Pitre 2007-11-29 15:08 ` Jeff King 3 siblings, 1 reply; 92+ messages in thread From: Nguyen Thai Ngoc Duy @ 2007-11-29 3:17 UTC (permalink / raw) To: Junio C Hamano; +Cc: Jan Hudec, Johannes Schindelin, git On Nov 29, 2007 6:14 AM, Junio C Hamano <gitster@pobox.com> wrote: > > "Nguyen Thai Ngoc Duy" <pclouds@gmail.com> writes: > > > On Nov 28, 2007 8:13 AM, Junio C Hamano <gitster@pobox.com> wrote: > >> In case somebody is thinking about 36e5e70e0f40 (Start deprecating > >> "git-command" in favor of "git command"), that is a somewhat different > >> issue. What Linus suggested is not installing git-foo link for built-in > >> commands _anywhere_ on the filesystem. Not just "out of user's PATH". > >> That is not deprecating dash form but removing the support for it. We > >> need to give ample time for users to adjust to such a change. > > > > A little note on this one. I've been using git without builtin links > > for a while with my git-box port. There are still some builtin fixups > > needed. And because execv_git_cmd() always uses dash form, so it's > > impossible to use vanilla git without builtin links. > > Thanks for a heads up. > > Would people agree with a rough roadmap like this? > > - v1.5.4 will ship with gitexecdir=$(bindir) in Makefile. But the > release notes for the version will warn users that: > > (1) using git-foo from the command line, and > > (2) using git-foo from your scripts without first prepending the > return value of "git --exec-path" to the PATH > > is now officially deprecated (it has been deprecated for a long time > since January 2006, v1.2.0~149) and upcoming v1.5.5 will ship with > the default configuration that does not install git-foo form in > user's PATH. > > - Post v1.5.4, start cooking gitexecdir=$(libexecdir)/git-core, aiming > for inclusion in v1.5.5, perhaps in Mar-Feb 2008 timeframe. > > - The release notes for v1.5.5 will warn users that git-foo will be > removed in v1.6.0 for many commands and it will be merely an accident > if some of them still work. > > - Post v1.5.5, start cooking the change that does not install hardlinks > for built-in commands, aiming for inclusion in v1.6.0, by the end of > 2008. There won't be a stage when only porcelain git-foos are in $(bindir)? I could stop working on the relevant patch then. -- Duy ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-29 3:17 ` Nguyen Thai Ngoc Duy @ 2007-11-29 14:09 ` Nicolas Pitre 2007-11-29 22:36 ` Junio C Hamano 0 siblings, 1 reply; 92+ messages in thread From: Nicolas Pitre @ 2007-11-29 14:09 UTC (permalink / raw) To: Nguyen Thai Ngoc Duy; +Cc: Junio C Hamano, Jan Hudec, Johannes Schindelin, git On Thu, 29 Nov 2007, Nguyen Thai Ngoc Duy wrote: > On Nov 29, 2007 6:14 AM, Junio C Hamano <gitster@pobox.com> wrote: > > > > "Nguyen Thai Ngoc Duy" <pclouds@gmail.com> writes: > > > > > On Nov 28, 2007 8:13 AM, Junio C Hamano <gitster@pobox.com> wrote: > > >> In case somebody is thinking about 36e5e70e0f40 (Start deprecating > > >> "git-command" in favor of "git command"), that is a somewhat different > > >> issue. What Linus suggested is not installing git-foo link for built-in > > >> commands _anywhere_ on the filesystem. Not just "out of user's PATH". > > >> That is not deprecating dash form but removing the support for it. We > > >> need to give ample time for users to adjust to such a change. > > > > > > A little note on this one. I've been using git without builtin links > > > for a while with my git-box port. There are still some builtin fixups > > > needed. And because execv_git_cmd() always uses dash form, so it's > > > impossible to use vanilla git without builtin links. > > > > Thanks for a heads up. > > > > Would people agree with a rough roadmap like this? > > > > - v1.5.4 will ship with gitexecdir=$(bindir) in Makefile. But the > > release notes for the version will warn users that: > > > > (1) using git-foo from the command line, and > > > > (2) using git-foo from your scripts without first prepending the > > return value of "git --exec-path" to the PATH > > > > is now officially deprecated (it has been deprecated for a long time > > since January 2006, v1.2.0~149) and upcoming v1.5.5 will ship with > > the default configuration that does not install git-foo form in > > user's PATH. > > > > - Post v1.5.4, start cooking gitexecdir=$(libexecdir)/git-core, aiming > > for inclusion in v1.5.5, perhaps in Mar-Feb 2008 timeframe. > > > > - The release notes for v1.5.5 will warn users that git-foo will be > > removed in v1.6.0 for many commands and it will be merely an accident > > if some of them still work. > > > > - Post v1.5.5, start cooking the change that does not install hardlinks > > for built-in commands, aiming for inclusion in v1.6.0, by the end of > > 2008. > > There won't be a stage when only porcelain git-foos are in $(bindir)? > I could stop working on the relevant patch then. Well, I personally found your effort really nice. I think Junio is overly cautious in this case, and I would prefer to see the number of git commands in the default path drop rather sooner than later. Nicolas ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-29 14:09 ` Nicolas Pitre @ 2007-11-29 22:36 ` Junio C Hamano 2007-11-30 7:32 ` Wincent Colaiuta 2007-11-30 11:28 ` Eyvind Bernhardsen 0 siblings, 2 replies; 92+ messages in thread From: Junio C Hamano @ 2007-11-29 22:36 UTC (permalink / raw) To: Nicolas Pitre; +Cc: Nguyen Thai Ngoc Duy, Jan Hudec, Johannes Schindelin, git Nicolas Pitre <nico@cam.org> writes: > On Thu, 29 Nov 2007, Nguyen Thai Ngoc Duy wrote: > >> There won't be a stage when only porcelain git-foos are in $(bindir)? >> I could stop working on the relevant patch then. > > Well, I personally found your effort really nice. I think Junio is > overly cautious in this case, and I would prefer to see the number of > git commands in the default path drop rather sooner than later. I agree with the first sentence. And yes I am playing it safe, and at the same time I do not think the "default" really matters as much as people think. If people are really serious about reducing the number of commands in the path, I would expect fixes and bugreports saying "I am setting gitexecdir different from bindir in _my_ installation when I build git, and here are the things that does not work if I do so". Within the span of more than 20 months (77cb17e9 introduced gitexecdir in Jan 2006), I do not think there was a single such report or patch, other than the message from Nguyen that started this thread. Which means one of two things (1) we got everything right and there is nothing to fix, other than changing the default like Nguyen's patch does, or (2) nobody is interested in moving git-foo out of their PATH for _his_ own use, but pushing changes that would affect _other_ people without testing. I am of course hoping that (1) is the case. And it could be that in open-source settings often the silent majority is content with what's already there, and that many people who are indeed interested in moving git-foo out of their PATH are doing so happily without telling the others of their success. But it still worries me. And people's scripts, especially old/unmaintained ones that google still knows about, are worrysome too. Didn't we just see a message that says "git-update-cache in a script I picked up from google does not work" on the list? ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-29 22:36 ` Junio C Hamano @ 2007-11-30 7:32 ` Wincent Colaiuta 2007-11-30 11:28 ` Eyvind Bernhardsen 1 sibling, 0 replies; 92+ messages in thread From: Wincent Colaiuta @ 2007-11-30 7:32 UTC (permalink / raw) To: Junio C Hamano Cc: Nicolas Pitre, Nguyen Thai Ngoc Duy, Jan Hudec, Johannes Schindelin, git El 29/11/2007, a las 23:36, Junio C Hamano escribió: > If people are really serious about reducing the number of commands in > the path, I would expect fixes and bugreports saying "I am setting > gitexecdir different from bindir in _my_ installation when I build > git, > and here are the things that does not work if I do so". Within the > span > of more than 20 months (77cb17e9 introduced gitexecdir in Jan 2006), I > do not think there was a single such report or patch, other than the > message from Nguyen that started this thread. One reason why there have been no reports is probably because 99% of people have never heard of gitexecdir nor know what it does. $ git grep gitexecdir | awk -F : '{print $1}' | uniq Makefile config.mak.in git-gui/Makefile git-gui/macosx/AppMain.tcl git.c Try googling for "site:git.or.cz gitexecdir" Basically, seems the only way you could know about it is if you've heard it mentioned on this mailing list and decided to study the Makefile. Cheers, Wincent ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-29 22:36 ` Junio C Hamano 2007-11-30 7:32 ` Wincent Colaiuta @ 2007-11-30 11:28 ` Eyvind Bernhardsen 2007-11-30 12:08 ` [PATCH] transport.c: call dash-less form of receive-pack and upload-pack on remote Johannes Schindelin 2007-11-30 12:19 ` [PATCH] Move all dashed form git commands to libexecdir Nguyen Thai Ngoc Duy 1 sibling, 2 replies; 92+ messages in thread From: Eyvind Bernhardsen @ 2007-11-30 11:28 UTC (permalink / raw) To: Junio C Hamano Cc: Nicolas Pitre, Nguyen Thai Ngoc Duy, Jan Hudec, Johannes Schindelin, git On 29. nov. 2007, at 23.36, Junio C Hamano wrote: [...] > If people are really serious about reducing the number of commands in > the path, I would expect fixes and bugreports saying "I am setting > gitexecdir different from bindir in _my_ installation when I build > git, > and here are the things that does not work if I do so". Within the > span > of more than 20 months (77cb17e9 introduced gitexecdir in Jan 2006), I > do not think there was a single such report or patch, other than the > message from Nguyen that started this thread. I'm setting gitexecdir different from bindir in my installation, and here are the things that don't work: - When pushing to my system over ssh, git-receive-pack and git-upload- pack are expected to be in $PATH. I resolved the problem by putting symlinks in /usr/local/bin. I haven't seen any other problems, but then again, I only use git plumbing commands and my own scripts. Eyvind ^ permalink raw reply [flat|nested] 92+ messages in thread
* [PATCH] transport.c: call dash-less form of receive-pack and upload-pack on remote 2007-11-30 11:28 ` Eyvind Bernhardsen @ 2007-11-30 12:08 ` Johannes Schindelin 2007-12-01 2:36 ` Junio C Hamano 2007-11-30 12:19 ` [PATCH] Move all dashed form git commands to libexecdir Nguyen Thai Ngoc Duy 1 sibling, 1 reply; 92+ messages in thread From: Johannes Schindelin @ 2007-11-30 12:08 UTC (permalink / raw) To: Eyvind Bernhardsen Cc: Junio C Hamano, Nicolas Pitre, Nguyen Thai Ngoc Duy, Jan Hudec, git Since we plan to move the dash-form (git-<whatever>) into an execdir, it make sense to prepare our git protocol users for it. Noticed by Eyvind Bernhardsen. Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de> --- On Fri, 30 Nov 2007, Eyvind Bernhardsen wrote: > - When pushing to my system over ssh, git-receive-pack and > git-upload-pack are expected to be in $PATH. I resolved the > problem by putting symlinks in /usr/local/bin. How about this? (I only compile-tested it...) transport.c | 4 ++-- 1 files changed, 2 insertions(+), 2 deletions(-) diff --git a/transport.c b/transport.c index 50db980..7bd0846 100644 --- a/transport.c +++ b/transport.c @@ -736,10 +736,10 @@ struct transport *transport_get(struct remote *remote, const char *url) ret->disconnect = disconnect_git; data->thin = 1; - data->uploadpack = "git-upload-pack"; + data->uploadpack = "git upload-pack"; if (remote && remote->uploadpack) data->uploadpack = remote->uploadpack; - data->receivepack = "git-receive-pack"; + data->receivepack = "git receive-pack"; if (remote && remote->receivepack) data->receivepack = remote->receivepack; } -- 1.5.3.6.2088.g8c260 ^ permalink raw reply related [flat|nested] 92+ messages in thread
* Re: [PATCH] transport.c: call dash-less form of receive-pack and upload-pack on remote 2007-11-30 12:08 ` [PATCH] transport.c: call dash-less form of receive-pack and upload-pack on remote Johannes Schindelin @ 2007-12-01 2:36 ` Junio C Hamano 2007-12-01 10:17 ` Johannes Schindelin 0 siblings, 1 reply; 92+ messages in thread From: Junio C Hamano @ 2007-12-01 2:36 UTC (permalink / raw) To: Johannes Schindelin Cc: Eyvind Bernhardsen, Nicolas Pitre, Nguyen Thai Ngoc Duy, Jan Hudec, git Johannes Schindelin <Johannes.Schindelin@gmx.de> writes: > Since we plan to move the dash-form (git-<whatever>) into an execdir, it > make sense to prepare our git protocol users for it. > > Noticed by Eyvind Bernhardsen. > > Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de> > --- > > On Fri, 30 Nov 2007, Eyvind Bernhardsen wrote: > > > - When pushing to my system over ssh, git-receive-pack and > > git-upload-pack are expected to be in $PATH. I resolved the > > problem by putting symlinks in /usr/local/bin. > > How about this? (I only compile-tested it...) I only eyeball-tested it and looks Okay, but that does not assure us much ;-). Is this change easy to test using local transport? ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] transport.c: call dash-less form of receive-pack and upload-pack on remote 2007-12-01 2:36 ` Junio C Hamano @ 2007-12-01 10:17 ` Johannes Schindelin 2007-12-01 19:30 ` Junio C Hamano 0 siblings, 1 reply; 92+ messages in thread From: Johannes Schindelin @ 2007-12-01 10:17 UTC (permalink / raw) To: Junio C Hamano Cc: Eyvind Bernhardsen, Nicolas Pitre, Nguyen Thai Ngoc Duy, Jan Hudec, git Hi, On Fri, 30 Nov 2007, Junio C Hamano wrote: > Johannes Schindelin <Johannes.Schindelin@gmx.de> writes: > > > Since we plan to move the dash-form (git-<whatever>) into an execdir, it > > make sense to prepare our git protocol users for it. > > > > Noticed by Eyvind Bernhardsen. > > > > Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de> > > --- > > > > On Fri, 30 Nov 2007, Eyvind Bernhardsen wrote: > > > > > - When pushing to my system over ssh, git-receive-pack and > > > git-upload-pack are expected to be in $PATH. I resolved the > > > problem by putting symlinks in /usr/local/bin. > > > > How about this? (I only compile-tested it...) > > I only eyeball-tested it and looks Okay, but that does not assure us > much ;-). Is this change easy to test using local transport? Seems like it breaks down with git-shell. But then, I think that we just have to fix execv_git_cmd() to call builtins via "git" instead. Ciao, Dscho ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] transport.c: call dash-less form of receive-pack and upload-pack on remote 2007-12-01 10:17 ` Johannes Schindelin @ 2007-12-01 19:30 ` Junio C Hamano 2007-12-01 23:03 ` Johannes Schindelin 0 siblings, 1 reply; 92+ messages in thread From: Junio C Hamano @ 2007-12-01 19:30 UTC (permalink / raw) To: Johannes Schindelin Cc: Eyvind Bernhardsen, Nicolas Pitre, Nguyen Thai Ngoc Duy, Jan Hudec, git Johannes Schindelin <Johannes.Schindelin@gmx.de> writes: >> I only eyeball-tested it and looks Okay, but that does not assure us >> much ;-). Is this change easy to test using local transport? > > Seems like it breaks down with git-shell. But then, I think that we just > have to fix execv_git_cmd() to call builtins via "git" instead. So in execv_git_cmd(), instead of doing the strbuf_addf(), we do something like this (and drop your patch)? --- exec_cmd.c | 34 +++++++++++++--------------------- 1 files changed, 13 insertions(+), 21 deletions(-) diff --git a/exec_cmd.c b/exec_cmd.c index 2d0a758..2920335 100644 --- a/exec_cmd.c +++ b/exec_cmd.c @@ -65,32 +65,24 @@ void setup_path(const char *cmd_path) int execv_git_cmd(const char **argv) { - struct strbuf cmd; - const char *tmp; - - strbuf_init(&cmd, 0); - strbuf_addf(&cmd, "git-%s", argv[0]); - - /* - * argv[0] must be the git command, but the argv array - * belongs to the caller, and may be reused in - * subsequent loop iterations. Save argv[0] and - * restore it on error. - */ - tmp = argv[0]; - argv[0] = cmd.buf; - - trace_argv_printf(argv, -1, "trace: exec:"); + int i; + const char **args; + + for (i = 0; argv[i]; i++) + ; + args = xcalloc(i + 1, sizeof(*args)); + for (i = 0; argv[i]; i++) + args[i+1] = argv[i]; + args[0] = "git"; + args[i+1] = NULL; + trace_argv_printf(args, -1, "trace: exec:"); /* execvp() can only ever return if it fails */ - execvp(cmd.buf, (char **)argv); + execvp(args[0], (char **)args); trace_printf("trace: exec failed: %s\n", strerror(errno)); - argv[0] = tmp; - - strbuf_release(&cmd); - + free(args); return -1; } ^ permalink raw reply related [flat|nested] 92+ messages in thread
* Re: [PATCH] transport.c: call dash-less form of receive-pack and upload-pack on remote 2007-12-01 19:30 ` Junio C Hamano @ 2007-12-01 23:03 ` Johannes Schindelin 2007-12-01 23:15 ` Johannes Schindelin 0 siblings, 1 reply; 92+ messages in thread From: Johannes Schindelin @ 2007-12-01 23:03 UTC (permalink / raw) To: Junio C Hamano Cc: Eyvind Bernhardsen, Nicolas Pitre, Nguyen Thai Ngoc Duy, Jan Hudec, git Hi, On Sat, 1 Dec 2007, Junio C Hamano wrote: > Johannes Schindelin <Johannes.Schindelin@gmx.de> writes: > > >> I only eyeball-tested it and looks Okay, but that does not assure us > >> much ;-). Is this change easy to test using local transport? > > > > Seems like it breaks down with git-shell. But then, I think that we just > > have to fix execv_git_cmd() to call builtins via "git" instead. > > So in execv_git_cmd(), instead of doing the strbuf_addf(), we do > something like this (and drop your patch)? You know what is really funny? I have this in my stash: -- snip -- exec_cmd.c | 30 ++++++++++++------------------ t/t0020-crlf.sh | 2 +- 2 files changed, 13 insertions(+), 19 deletions(-) diff --git a/exec_cmd.c b/exec_cmd.c index 2d0a758..7d022a2 100644 --- a/exec_cmd.c +++ b/exec_cmd.c @@ -65,31 +65,25 @@ void setup_path(const char *cmd_path) int execv_git_cmd(const char **argv) { - struct strbuf cmd; - const char *tmp; + int i; + char **new_argv; - strbuf_init(&cmd, 0); - strbuf_addf(&cmd, "git-%s", argv[0]); + for (i = 0; argv[i]; i++) + ; /* do nothing */ + new_argv = xmalloc((i + 2) * sizeof(*new_argv)); + new_argv[0] = "git"; + for (i = 0; argv[i]; i++) + new_argv[i + 1] = (char *)argv[i]; + new_argv[i] = NULL; - /* - * argv[0] must be the git command, but the argv array - * belongs to the caller, and may be reused in - * subsequent loop iterations. Save argv[0] and - * restore it on error. - */ - tmp = argv[0]; - argv[0] = cmd.buf; - - trace_argv_printf(argv, -1, "trace: exec:"); + trace_argv_printf((const char **)new_argv, -1, "trace: exec:"); /* execvp() can only ever return if it fails */ - execvp(cmd.buf, (char **)argv); + execvp(new_argv[0], new_argv); trace_printf("trace: exec failed: %s\n", strerror(errno)); - argv[0] = tmp; - - strbuf_release(&cmd); + free(new_argv); return -1; } diff --git a/t/t0020-crlf.sh b/t/t0020-crlf.sh index 62bc4bb..275379d 100755 --- a/t/t0020-crlf.sh +++ b/t/t0020-crlf.sh @@ -36,7 +36,7 @@ test_expect_success setup ' for w in Some extra lines here; do echo $w; done >>one && git diff >patch.file && - patched=`git hash-object --stdin <one` && + patched=`GIT_TRACE=2 git hash-object --stdin <one` && git read-tree --reset -u HEAD && echo happy. -- snap -- Which looks awfully like your patch (except that I called it new_argv, I think). Now you might ask why there is such a funny patch to t0020? Well, the patch does not work as-is. Will investigate right now, Dscho ^ permalink raw reply related [flat|nested] 92+ messages in thread
* Re: [PATCH] transport.c: call dash-less form of receive-pack and upload-pack on remote 2007-12-01 23:03 ` Johannes Schindelin @ 2007-12-01 23:15 ` Johannes Schindelin 2007-12-02 1:57 ` Junio C Hamano 2007-12-02 2:52 ` [PATCH 0/3] Call builtin functions directly, was " Johannes Schindelin 0 siblings, 2 replies; 92+ messages in thread From: Johannes Schindelin @ 2007-12-01 23:15 UTC (permalink / raw) To: Junio C Hamano Cc: Eyvind Bernhardsen, Nicolas Pitre, Nguyen Thai Ngoc Duy, Jan Hudec, git Hi, On Sat, 1 Dec 2007, Johannes Schindelin wrote: > Will investigate right now, The problem is that "git <command>" will call execv_git_cmd() for non-builtins, which in turn will execute "git <command>", ... ad infinitum. Ciao, Dscho ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] transport.c: call dash-less form of receive-pack and upload-pack on remote 2007-12-01 23:15 ` Johannes Schindelin @ 2007-12-02 1:57 ` Junio C Hamano 2007-12-02 2:52 ` [PATCH 0/3] Call builtin functions directly, was " Johannes Schindelin 1 sibling, 0 replies; 92+ messages in thread From: Junio C Hamano @ 2007-12-02 1:57 UTC (permalink / raw) To: Johannes Schindelin Cc: Eyvind Bernhardsen, Nicolas Pitre, Nguyen Thai Ngoc Duy, Jan Hudec, git Johannes Schindelin <Johannes.Schindelin@gmx.de> writes: > On Sat, 1 Dec 2007, Johannes Schindelin wrote: > >> Will investigate right now, > > The problem is that "git <command>" will call execv_git_cmd() for > non-builtins, which in turn will execute "git <command>", ... ad > infinitum. Ok, then the ".. then try the external ones" in git.c needs to do the execvp itself, which should not be a big deal. Very funny ;-). ^ permalink raw reply [flat|nested] 92+ messages in thread
* [PATCH 0/3] Call builtin functions directly, was Re: [PATCH] transport.c: call dash-less form of receive-pack and upload-pack on remote 2007-12-01 23:15 ` Johannes Schindelin 2007-12-02 1:57 ` Junio C Hamano @ 2007-12-02 2:52 ` Johannes Schindelin 2007-12-02 2:54 ` [PATCH 1/3] Introduce release_all_objects() Johannes Schindelin ` (3 more replies) 1 sibling, 4 replies; 92+ messages in thread From: Johannes Schindelin @ 2007-12-02 2:52 UTC (permalink / raw) To: Junio C Hamano Cc: Eyvind Bernhardsen, Nicolas Pitre, Nguyen Thai Ngoc Duy, Jan Hudec, git Hi, On Sat, 1 Dec 2007, Johannes Schindelin wrote: > On Sat, 1 Dec 2007, Johannes Schindelin wrote: > > > Will investigate right now, > > The problem is that "git <command>" will call execv_git_cmd() for > non-builtins, which in turn will execute "git <command>", ... ad > infinitum. Okay, I bit the apple and tried to move the builtins into the library, and rename handle_internal_command into execv_git_builtin(), moving it into exec-cmd.c. Big mistake. Why? Because there is at least one caller, git-bundle, which relies on execv_git_cmd() _not_ reusing all those "nice" one-shot static variables, like for example the object hashmap and the objects themselves. Now, it seems that we can get away for the moment with just introducing an object release mechanism and calling that in execv_git_builtin() before calling a builtin function, because the existing callers do not rely on more than a cleanup of the objects. But it is hairy, since it is such an essential part of git. And since I was utterly tired while preparing this patch series. So I suggest maybe putting this into pu, but no further for the moment. I will use the patched git in the next days, though, to catch breakages (hopefully). Ciao, Dscho ^ permalink raw reply [flat|nested] 92+ messages in thread
* [PATCH 1/3] Introduce release_all_objects() 2007-12-02 2:52 ` [PATCH 0/3] Call builtin functions directly, was " Johannes Schindelin @ 2007-12-02 2:54 ` Johannes Schindelin 2007-12-02 2:54 ` [PATCH 2/3] Include the objects needed for the builtin functions into libgit.a Johannes Schindelin ` (2 subsequent siblings) 3 siblings, 0 replies; 92+ messages in thread From: Johannes Schindelin @ 2007-12-02 2:54 UTC (permalink / raw) To: Junio C Hamano Cc: Eyvind Bernhardsen, Nicolas Pitre, Nguyen Thai Ngoc Duy, Jan Hudec, git The new function release_all_objects() can be used to flush the object cache. This will be needed for the upcoming change in execv_git_cmd(), which should call the builtin functions directly instead of calling execvp(). Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de> --- Guess how surprised I was when "free(commit);" would work the first time, but not the second... ATM I use an ugly way to cope with the static "nr" variables in alloc.c: I just do not free() the last block. It might be a better idea to refactor the (quite ugly) code in alloc.c to have global structures a la #define BLOCKING 1024 struct object_block { size_t struct_size; int nr; /* first (uint32_t *) is pointer to previous block */ void *block; }; static void *alloc_node(struct object_block *block) { if (!block || block->nr >= BLOCKING) { void *next = xmalloc(sizeof(void *) + BLOCKING * block->struct_size); *(void **)next = block->block; block->block = next; block->nr = 0; } return block->block + sizeof(void *) + block->struct_size * block->nr++; } static void release_nodes(struct object_block *block) { while (block->block) { void *previous = *(void **)block->block; free(block->block); block->block = previous; } block->nr = 0; /* not strictly necessary */ } #define DEFINE_ALLOCATOR(type) \ static object_block type##s = { sizeof(struct type) }; \ struct type *alloc_##type##_node(void) \ { \ return alloc_node(&type##s); \ } DEFINE_ALLOCATOR(object) DEFINE_ALLOCATOR(blob) DEFINE_ALLOCATOR(tree) DEFINE_ALLOCATOR(commit) DEFINE_ALLOCATOR(tag) but I am waaay too tired to brush this up, test it and submit it (hint, hint). alloc.c | 31 ++++++++++++++++++++++++++++++- blob.c | 3 +++ blob.h | 1 + cache.h | 6 ++++++ commit.c | 8 ++++++++ commit.h | 2 ++ object.c | 24 ++++++++++++++++++++++++ object.h | 2 ++ tag.c | 8 ++++++++ tag.h | 2 ++ tree.c | 6 ++++++ tree.h | 1 + 12 files changed, 93 insertions(+), 1 deletions(-) diff --git a/alloc.c b/alloc.c index 216c23a..8c5e5e0 100644 --- a/alloc.c +++ b/alloc.c @@ -20,6 +20,7 @@ #define DEFINE_ALLOCATOR(name, type) \ static unsigned int name##_allocs; \ +static void *last_alloced_##name; \ void *alloc_##name##_node(void) \ { \ static int nr; \ @@ -28,13 +29,32 @@ void *alloc_##name##_node(void) \ \ if (!nr) { \ nr = BLOCKING; \ - block = xmalloc(BLOCKING * sizeof(type)); \ + struct { \ + void *previous; \ + type block[BLOCKING]; \ + } *buf = xmalloc(sizeof(*buf)); \ + buf->previous = last_alloced_##name; \ + last_alloced_##name = buf; \ + block = buf->block; \ } \ nr--; \ name##_allocs++; \ ret = block++; \ memset(ret, 0, sizeof(type)); \ return ret; \ +} \ + \ +void release_all_##name##_nodes(void) \ +{ \ + void *buf = last_alloced_##name; \ + if (!buf) \ + return; \ + buf = *(void **)buf; \ + while (buf) { \ + void *next = *(void **)buf; \ + free(buf); \ + buf = next; \ + } \ } union any_object { @@ -74,3 +94,12 @@ void alloc_report(void) REPORT(commit); REPORT(tag); } + +void release_all_nodes(void) +{ + release_all_blob_nodes(); + release_all_tree_nodes(); + release_all_commit_nodes(); + release_all_tag_nodes(); + release_all_object_nodes(); +} diff --git a/blob.c b/blob.c index bd7d078..63756e6 100644 --- a/blob.c +++ b/blob.c @@ -18,6 +18,9 @@ struct blob *lookup_blob(const unsigned char *sha1) return (struct blob *) obj; } +void release_blob(struct blob *blob) { +} + int parse_blob_buffer(struct blob *item, void *buffer, unsigned long size) { item->object.parsed = 1; diff --git a/blob.h b/blob.h index ea5d9e9..7560671 100644 --- a/blob.h +++ b/blob.h @@ -10,6 +10,7 @@ struct blob { }; struct blob *lookup_blob(const unsigned char *sha1); +void release_blob(struct blob *blob); int parse_blob_buffer(struct blob *item, void *buffer, unsigned long size); diff --git a/cache.h b/cache.h index 4e59646..cc50f1c 100644 --- a/cache.h +++ b/cache.h @@ -613,6 +613,12 @@ extern void *alloc_tree_node(void); extern void *alloc_commit_node(void); extern void *alloc_tag_node(void); extern void *alloc_object_node(void); +extern void release_all_blob_nodes(void); +extern void release_all_tree_nodes(void); +extern void release_all_commit_nodes(void); +extern void release_all_tag_nodes(void); +extern void release_all_object_nodes(void); +extern void release_all_nodes(void); extern void alloc_report(void); /* trace.c */ diff --git a/commit.c b/commit.c index f074811..59c2236 100644 --- a/commit.c +++ b/commit.c @@ -48,6 +48,14 @@ struct commit *lookup_commit(const unsigned char *sha1) return check_commit(obj, sha1, 0); } +void release_commit(struct commit *commit) +{ + if (commit->parents) + free_commit_list(commit->parents); + if (commit->buffer) + free(commit->buffer); +} + static unsigned long parse_commit_date(const char *buf) { unsigned long date; diff --git a/commit.h b/commit.h index 10e2b5d..363b9fb 100644 --- a/commit.h +++ b/commit.h @@ -21,6 +21,7 @@ struct commit { char *buffer; }; + extern int save_commit_buffer; extern const char *commit_type; @@ -35,6 +36,7 @@ struct commit *lookup_commit(const unsigned char *sha1); struct commit *lookup_commit_reference(const unsigned char *sha1); struct commit *lookup_commit_reference_gently(const unsigned char *sha1, int quiet); +void release_commit(struct commit *commit); int parse_commit_buffer(struct commit *item, void *buffer, unsigned long size); diff --git a/object.c b/object.c index 16793d9..f217122 100644 --- a/object.c +++ b/object.c @@ -192,6 +192,30 @@ struct object *parse_object(const unsigned char *sha1) return NULL; } +void release_all_objects(void) +{ + int i; + for (i = 0; i < obj_hash_size; i++) + if (obj_hash[i]) { + switch (obj_hash[i]->type) { + case OBJ_BLOB: + release_blob((struct blob *)obj_hash[i]); + break; + case OBJ_COMMIT: + release_commit((struct commit *)obj_hash[i]); + break; + /*case OBJ_TREE: + release_tree((struct tree *)obj_hash[i]); + break; + case OBJ_TAG: + release_tag((struct tag *)obj_hash[i]); + break;*/ + } + obj_hash[i] = NULL; + } + release_all_nodes(); +} + struct object_list *object_list_insert(struct object *item, struct object_list **list_p) { diff --git a/object.h b/object.h index 397bbfa..ad6184c 100644 --- a/object.h +++ b/object.h @@ -44,6 +44,8 @@ extern unsigned int get_max_object_index(void); extern struct object *get_indexed_object(unsigned int); extern struct object_refs *lookup_object_refs(struct object *); +extern void release_all_objects(void); + /** Internal only **/ struct object *lookup_object(const unsigned char *sha1); diff --git a/tag.c b/tag.c index f62bcdd..8bc6840 100644 --- a/tag.c +++ b/tag.c @@ -33,6 +33,14 @@ struct tag *lookup_tag(const unsigned char *sha1) return (struct tag *) obj; } +void release_tag(struct tag *tag) +{ + if (tag->tag) + free(tag->tag); + if (tag->signature) + free(tag->signature); +} + int parse_tag_buffer(struct tag *item, void *data, unsigned long size) { int typelen, taglen; diff --git a/tag.h b/tag.h index 7a0cb00..fbc6048 100644 --- a/tag.h +++ b/tag.h @@ -12,6 +12,8 @@ struct tag { char *signature; /* not actually implemented */ }; +void release_tag(struct tag *tag); + extern struct tag *lookup_tag(const unsigned char *sha1); extern int parse_tag_buffer(struct tag *item, void *data, unsigned long size); extern int parse_tag(struct tag *item); diff --git a/tree.c b/tree.c index 8c0819f..ee99bc6 100644 --- a/tree.c +++ b/tree.c @@ -202,6 +202,12 @@ struct tree *lookup_tree(const unsigned char *sha1) return (struct tree *) obj; } +void release_tree(struct tree *tree) +{ + if (tree->buffer) + free(tree->buffer); +} + /* * NOTE! Tree refs to external git repositories * (ie gitlinks) do not count as real references. diff --git a/tree.h b/tree.h index dd25c53..f8372a2 100644 --- a/tree.h +++ b/tree.h @@ -12,6 +12,7 @@ struct tree { }; struct tree *lookup_tree(const unsigned char *sha1); +void release_tree(struct tree *tree); int parse_tree_buffer(struct tree *item, void *buffer, unsigned long size); -- 1.5.3.6.2112.ge2263 ^ permalink raw reply related [flat|nested] 92+ messages in thread
* [PATCH 2/3] Include the objects needed for the builtin functions into libgit.a 2007-12-02 2:52 ` [PATCH 0/3] Call builtin functions directly, was " Johannes Schindelin 2007-12-02 2:54 ` [PATCH 1/3] Introduce release_all_objects() Johannes Schindelin @ 2007-12-02 2:54 ` Johannes Schindelin 2007-12-02 2:55 ` [PATCH 3/3] Introduce execv_git_builtin() and use it Johannes Schindelin 2007-12-02 5:19 ` [PATCH 0/3] Call builtin functions directly, was Re: [PATCH] transport.c: call dash-less form of receive-pack and upload-pack on remote Junio C Hamano 3 siblings, 0 replies; 92+ messages in thread From: Johannes Schindelin @ 2007-12-02 2:54 UTC (permalink / raw) To: Junio C Hamano Cc: Eyvind Bernhardsen, Nicolas Pitre, Nguyen Thai Ngoc Duy, Jan Hudec, git For the upcoming change in execv_git_cmd() to call builtin functions directly, it is necessary to be able to access the builtins, so move the corresponding objects into libgit.a. Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de> --- Makefile | 14 +++++++++----- 1 files changed, 9 insertions(+), 5 deletions(-) diff --git a/Makefile b/Makefile index f000a5e..f9a62eb 100644 --- a/Makefile +++ b/Makefile @@ -314,7 +314,8 @@ LIB_OBJS = \ alloc.o merge-file.o path-list.o help.o unpack-trees.o $(DIFF_OBJS) \ color.o wt-status.o archive-zip.o archive-tar.o shallow.o utf8.o \ convert.o attr.o decorate.o progress.o mailmap.o symlinks.o remote.o \ - transport.o bundle.o walker.o parse-options.o + transport.o bundle.o walker.o parse-options.o \ + $(BUILTIN_OBJS) BUILTIN_OBJS = \ builtin-add.o \ @@ -785,12 +786,12 @@ strip: $(PROGRAMS) git$X $(STRIP) $(STRIP_OPTS) $(PROGRAMS) git$X git.o: git.c common-cmds.h GIT-CFLAGS - $(QUIET_CC)$(CC) -DGIT_VERSION='"$(GIT_VERSION)"' \ + $(QUIET_CC)$(CC) \ $(ALL_CFLAGS) -c $(filter %.c,$^) git$X: git.o $(BUILTIN_OBJS) $(GITLIBS) $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ git.o \ - $(BUILTIN_OBJS) $(ALL_LDFLAGS) $(LIBS) + $(ALL_LDFLAGS) $(LIBS) help.o: common-cmds.h @@ -894,7 +895,10 @@ git.o git.spec \ $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) $< exec_cmd.o: exec_cmd.c GIT-CFLAGS - $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) '-DGIT_EXEC_PATH="$(gitexecdir_SQ)"' $< + $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) \ + -DGIT_EXEC_PATH='"$(gitexecdir_SQ)"' \ + -DGIT_VERSION='"$(GIT_VERSION)"' \ + $< builtin-init-db.o: builtin-init-db.c GIT-CFLAGS $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) -DDEFAULT_GIT_TEMPLATE_DIR='"$(template_dir_SQ)"' $< @@ -920,7 +924,7 @@ git-http-push$X: revision.o http.o http-push.o $(GITLIBS) $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \ $(LIBS) $(CURL_LIBCURL) $(EXPAT_LIBEXPAT) -$(LIB_OBJS) $(BUILTIN_OBJS): $(LIB_H) +$(LIB_OBJS): $(LIB_H) $(patsubst git-%$X,%.o,$(PROGRAMS)): $(LIB_H) $(wildcard */*.h) builtin-revert.o builtin-runstatus.o wt-status.o: wt-status.h -- 1.5.3.6.2112.ge2263 ^ permalink raw reply related [flat|nested] 92+ messages in thread
* [PATCH 3/3] Introduce execv_git_builtin() and use it 2007-12-02 2:52 ` [PATCH 0/3] Call builtin functions directly, was " Johannes Schindelin 2007-12-02 2:54 ` [PATCH 1/3] Introduce release_all_objects() Johannes Schindelin 2007-12-02 2:54 ` [PATCH 2/3] Include the objects needed for the builtin functions into libgit.a Johannes Schindelin @ 2007-12-02 2:55 ` Johannes Schindelin 2007-12-02 3:04 ` Johannes Schindelin 2007-12-02 5:19 ` [PATCH 0/3] Call builtin functions directly, was Re: [PATCH] transport.c: call dash-less form of receive-pack and upload-pack on remote Junio C Hamano 3 siblings, 1 reply; 92+ messages in thread From: Johannes Schindelin @ 2007-12-02 2:55 UTC (permalink / raw) To: Junio C Hamano Cc: Eyvind Bernhardsen, Nicolas Pitre, Nguyen Thai Ngoc Duy, Jan Hudec, git You can call execv_git_builtin() to execute a builtin command. This function is a reborn handle_internal_command() from git.c, and has the semantics of execv_git_cmd(), i.e. it exits with the exit code of the builtin if there is a matching builtin, but it avoids the real execvp() call. This function calls release_all_objects() and discard_cache() to start from a clean slate (this, along with the calculation of argc, is the only difference from a straight code move). The test suite passes, which at least does not contradict the hypothesis that this is good enough. However, it might be necessary to de-initialize more global variables. The function execv_git_cmd() and git.c's main() function were changed to take advantage of execv_git_builtin(). Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de> --- exec_cmd.c | 178 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ exec_cmd.h | 1 + git.c | 172 +--------------------------------------------------------- 3 files changed, 180 insertions(+), 171 deletions(-) diff --git a/exec_cmd.c b/exec_cmd.c index 2d0a758..ac21181 100644 --- a/exec_cmd.c +++ b/exec_cmd.c @@ -1,6 +1,8 @@ #include "cache.h" #include "exec_cmd.h" #include "quote.h" +#include "builtin.h" +#include "object.h" #define MAX_ARGS 32 extern char **environ; @@ -63,11 +65,187 @@ void setup_path(const char *cmd_path) strbuf_release(&new_path); } +const char git_usage_string[] = + "git [--version] [--exec-path[=GIT_EXEC_PATH]] [-p|--paginate|--no-pager] [--bare] [--git-dir=GIT_DIR] [--work-tree=GIT_WORK_TREE] [--help] COMMAND [ARGS]"; + +const char git_version_string[] = GIT_VERSION; + +#define RUN_SETUP (1<<0) +#define USE_PAGER (1<<1) +/* + * require working tree to be present -- anything uses this needs + * RUN_SETUP for reading from the configuration file. + */ +#define NEED_WORK_TREE (1<<2) + +struct cmd_struct { + const char *cmd; + int (*fn)(int, const char **, const char *); + int option; +}; + +static int run_command(struct cmd_struct *p, int argc, const char **argv) +{ + int status; + struct stat st; + const char *prefix; + + prefix = NULL; + if (p->option & RUN_SETUP) + prefix = setup_git_directory(); + if (p->option & USE_PAGER) + setup_pager(); + if (p->option & NEED_WORK_TREE) + setup_work_tree(); + + trace_argv_printf(argv, argc, "trace: built-in: git"); + + status = p->fn(argc, argv, prefix); + if (status) + return status & 0xff; + + /* Somebody closed stdout? */ + if (fstat(fileno(stdout), &st)) + return 0; + /* Ignore write errors for pipes and sockets.. */ + if (S_ISFIFO(st.st_mode) || S_ISSOCK(st.st_mode)) + return 0; + + /* Check for ENOSPC and EIO errors.. */ + if (fflush(stdout)) + die("write failure on standard output: %s", strerror(errno)); + if (ferror(stdout)) + die("unknown write failure on standard output"); + if (fclose(stdout)) + die("close failed on standard output: %s", strerror(errno)); + return 0; +} + +int execv_git_builtin(const char **argv) +{ + const char *cmd = argv[0]; + static struct cmd_struct commands[] = { + { "add", cmd_add, RUN_SETUP | NEED_WORK_TREE }, + { "annotate", cmd_annotate, RUN_SETUP }, + { "apply", cmd_apply }, + { "archive", cmd_archive }, + { "blame", cmd_blame, RUN_SETUP }, + { "branch", cmd_branch, RUN_SETUP }, + { "bundle", cmd_bundle }, + { "cat-file", cmd_cat_file, RUN_SETUP }, + { "checkout-index", cmd_checkout_index, + RUN_SETUP | NEED_WORK_TREE}, + { "check-ref-format", cmd_check_ref_format }, + { "check-attr", cmd_check_attr, RUN_SETUP | NEED_WORK_TREE }, + { "cherry", cmd_cherry, RUN_SETUP }, + { "cherry-pick", cmd_cherry_pick, RUN_SETUP | NEED_WORK_TREE }, + { "clean", cmd_clean, RUN_SETUP | NEED_WORK_TREE }, + { "commit", cmd_commit, RUN_SETUP | NEED_WORK_TREE }, + { "commit-tree", cmd_commit_tree, RUN_SETUP }, + { "config", cmd_config }, + { "count-objects", cmd_count_objects, RUN_SETUP }, + { "describe", cmd_describe, RUN_SETUP }, + { "diff", cmd_diff }, + { "diff-files", cmd_diff_files }, + { "diff-index", cmd_diff_index, RUN_SETUP }, + { "diff-tree", cmd_diff_tree, RUN_SETUP }, + { "fast-export", cmd_fast_export, RUN_SETUP }, + { "fetch", cmd_fetch, RUN_SETUP }, + { "fetch-pack", cmd_fetch_pack, RUN_SETUP }, + { "fetch--tool", cmd_fetch__tool, RUN_SETUP }, + { "fmt", cmd_fmt }, + { "fmt-merge-msg", cmd_fmt_merge_msg, RUN_SETUP }, + { "for-each-ref", cmd_for_each_ref, RUN_SETUP }, + { "format-patch", cmd_format_patch, RUN_SETUP }, + { "fsck", cmd_fsck, RUN_SETUP }, + { "fsck-objects", cmd_fsck, RUN_SETUP }, + { "gc", cmd_gc, RUN_SETUP }, + { "get-tar-commit-id", cmd_get_tar_commit_id }, + { "grep", cmd_grep, RUN_SETUP | USE_PAGER }, + { "help", cmd_help }, +#ifndef NO_CURL + { "http-fetch", cmd_http_fetch, RUN_SETUP }, +#endif + { "init", cmd_init_db }, + { "init-db", cmd_init_db }, + { "log", cmd_log, RUN_SETUP | USE_PAGER }, + { "ls-files", cmd_ls_files, RUN_SETUP }, + { "ls-tree", cmd_ls_tree, RUN_SETUP }, + { "ls-remote", cmd_ls_remote }, + { "mailinfo", cmd_mailinfo }, + { "mailsplit", cmd_mailsplit }, + { "merge-base", cmd_merge_base, RUN_SETUP }, + { "merge-file", cmd_merge_file }, + { "merge-ours", cmd_merge_ours, RUN_SETUP }, + { "mv", cmd_mv, RUN_SETUP | NEED_WORK_TREE }, + { "name-rev", cmd_name_rev, RUN_SETUP }, + { "pack-objects", cmd_pack_objects, RUN_SETUP }, + { "peek-remote", cmd_ls_remote }, + { "pickaxe", cmd_blame, RUN_SETUP }, + { "prune", cmd_prune, RUN_SETUP }, + { "prune-packed", cmd_prune_packed, RUN_SETUP }, + { "push", cmd_push, RUN_SETUP }, + { "read-tree", cmd_read_tree, RUN_SETUP }, + { "reflog", cmd_reflog, RUN_SETUP }, + { "repo-config", cmd_config }, + { "rerere", cmd_rerere, RUN_SETUP }, + { "reset", cmd_reset, RUN_SETUP }, + { "rev-list", cmd_rev_list, RUN_SETUP }, + { "rev-parse", cmd_rev_parse }, + { "revert", cmd_revert, RUN_SETUP | NEED_WORK_TREE }, + { "rm", cmd_rm, RUN_SETUP }, + { "send-pack", cmd_send_pack, RUN_SETUP }, + { "shortlog", cmd_shortlog, RUN_SETUP | USE_PAGER }, + { "show-branch", cmd_show_branch, RUN_SETUP }, + { "show", cmd_show, RUN_SETUP | USE_PAGER }, + { "status", cmd_status, RUN_SETUP | NEED_WORK_TREE }, + { "stripspace", cmd_stripspace }, + { "symbolic-ref", cmd_symbolic_ref, RUN_SETUP }, + { "tag", cmd_tag, RUN_SETUP }, + { "tar-tree", cmd_tar_tree }, + { "unpack-objects", cmd_unpack_objects, RUN_SETUP }, + { "update-index", cmd_update_index, RUN_SETUP }, + { "update-ref", cmd_update_ref, RUN_SETUP }, + { "upload-archive", cmd_upload_archive }, + { "verify-tag", cmd_verify_tag, RUN_SETUP }, + { "version", cmd_version }, + { "whatchanged", cmd_whatchanged, RUN_SETUP | USE_PAGER }, + { "write-tree", cmd_write_tree, RUN_SETUP }, + { "verify-pack", cmd_verify_pack }, + { "show-ref", cmd_show_ref, RUN_SETUP }, + { "pack-refs", cmd_pack_refs, RUN_SETUP }, + }; + int i; + + /* Turn "git cmd --help" into "git help cmd" */ + if (argv[0] && argv[1] && !strcmp(argv[1], "--help")) { + argv[1] = argv[0]; + argv[0] = cmd = "help"; + } + + for (i = 0; i < ARRAY_SIZE(commands); i++) { + int argc; + struct cmd_struct *p = commands+i; + if (strcmp(p->cmd, cmd)) + continue; + release_all_objects(); + discard_cache(); + for (argc = 0; argv[argc]; argc++) + ; /* do nothing */ + exit(run_command(p, argc, argv)); + } + return -1; +} + int execv_git_cmd(const char **argv) { struct strbuf cmd; const char *tmp; + /* Try builtin first... */ + execv_git_builtin(argv); + + /* ... and then external commands */ strbuf_init(&cmd, 0); strbuf_addf(&cmd, "git-%s", argv[0]); diff --git a/exec_cmd.h b/exec_cmd.h index a892355..bb15425 100644 --- a/exec_cmd.h +++ b/exec_cmd.h @@ -4,6 +4,7 @@ extern void git_set_argv_exec_path(const char *exec_path); extern const char* git_exec_path(void); extern void setup_path(const char *); +extern int execv_git_builtin(const char **argv); /* NULL terminated */ extern int execv_git_cmd(const char **argv); /* NULL terminated */ extern int execl_git_cmd(const char *cmd, ...); diff --git a/git.c b/git.c index 38b01ca..1523c4a 100644 --- a/git.c +++ b/git.c @@ -3,9 +3,6 @@ #include "cache.h" #include "quote.h" -const char git_usage_string[] = - "git [--version] [--exec-path[=GIT_EXEC_PATH]] [-p|--paginate|--no-pager] [--bare] [--git-dir=GIT_DIR] [--work-tree=GIT_WORK_TREE] [--help] COMMAND [ARGS]"; - static int handle_options(const char*** argv, int* argc, int* envchanged) { int handled = 0; @@ -231,169 +228,6 @@ static int handle_alias(int *argcp, const char ***argv) return ret; } -const char git_version_string[] = GIT_VERSION; - -#define RUN_SETUP (1<<0) -#define USE_PAGER (1<<1) -/* - * require working tree to be present -- anything uses this needs - * RUN_SETUP for reading from the configuration file. - */ -#define NEED_WORK_TREE (1<<2) - -struct cmd_struct { - const char *cmd; - int (*fn)(int, const char **, const char *); - int option; -}; - -static int run_command(struct cmd_struct *p, int argc, const char **argv) -{ - int status; - struct stat st; - const char *prefix; - - prefix = NULL; - if (p->option & RUN_SETUP) - prefix = setup_git_directory(); - if (p->option & USE_PAGER) - setup_pager(); - if (p->option & NEED_WORK_TREE) - setup_work_tree(); - - trace_argv_printf(argv, argc, "trace: built-in: git"); - - status = p->fn(argc, argv, prefix); - if (status) - return status & 0xff; - - /* Somebody closed stdout? */ - if (fstat(fileno(stdout), &st)) - return 0; - /* Ignore write errors for pipes and sockets.. */ - if (S_ISFIFO(st.st_mode) || S_ISSOCK(st.st_mode)) - return 0; - - /* Check for ENOSPC and EIO errors.. */ - if (fflush(stdout)) - die("write failure on standard output: %s", strerror(errno)); - if (ferror(stdout)) - die("unknown write failure on standard output"); - if (fclose(stdout)) - die("close failed on standard output: %s", strerror(errno)); - return 0; -} - -static void handle_internal_command(int argc, const char **argv) -{ - const char *cmd = argv[0]; - static struct cmd_struct commands[] = { - { "add", cmd_add, RUN_SETUP | NEED_WORK_TREE }, - { "annotate", cmd_annotate, RUN_SETUP }, - { "apply", cmd_apply }, - { "archive", cmd_archive }, - { "blame", cmd_blame, RUN_SETUP }, - { "branch", cmd_branch, RUN_SETUP }, - { "bundle", cmd_bundle }, - { "cat-file", cmd_cat_file, RUN_SETUP }, - { "checkout-index", cmd_checkout_index, - RUN_SETUP | NEED_WORK_TREE}, - { "check-ref-format", cmd_check_ref_format }, - { "check-attr", cmd_check_attr, RUN_SETUP | NEED_WORK_TREE }, - { "cherry", cmd_cherry, RUN_SETUP }, - { "cherry-pick", cmd_cherry_pick, RUN_SETUP | NEED_WORK_TREE }, - { "clean", cmd_clean, RUN_SETUP | NEED_WORK_TREE }, - { "commit", cmd_commit, RUN_SETUP | NEED_WORK_TREE }, - { "commit-tree", cmd_commit_tree, RUN_SETUP }, - { "config", cmd_config }, - { "count-objects", cmd_count_objects, RUN_SETUP }, - { "describe", cmd_describe, RUN_SETUP }, - { "diff", cmd_diff }, - { "diff-files", cmd_diff_files }, - { "diff-index", cmd_diff_index, RUN_SETUP }, - { "diff-tree", cmd_diff_tree, RUN_SETUP }, - { "fast-export", cmd_fast_export, RUN_SETUP }, - { "fetch", cmd_fetch, RUN_SETUP }, - { "fetch-pack", cmd_fetch_pack, RUN_SETUP }, - { "fetch--tool", cmd_fetch__tool, RUN_SETUP }, - { "fmt", cmd_fmt }, - { "fmt-merge-msg", cmd_fmt_merge_msg, RUN_SETUP }, - { "for-each-ref", cmd_for_each_ref, RUN_SETUP }, - { "format-patch", cmd_format_patch, RUN_SETUP }, - { "fsck", cmd_fsck, RUN_SETUP }, - { "fsck-objects", cmd_fsck, RUN_SETUP }, - { "gc", cmd_gc, RUN_SETUP }, - { "get-tar-commit-id", cmd_get_tar_commit_id }, - { "grep", cmd_grep, RUN_SETUP | USE_PAGER }, - { "help", cmd_help }, -#ifndef NO_CURL - { "http-fetch", cmd_http_fetch, RUN_SETUP }, -#endif - { "init", cmd_init_db }, - { "init-db", cmd_init_db }, - { "log", cmd_log, RUN_SETUP | USE_PAGER }, - { "ls-files", cmd_ls_files, RUN_SETUP }, - { "ls-tree", cmd_ls_tree, RUN_SETUP }, - { "ls-remote", cmd_ls_remote }, - { "mailinfo", cmd_mailinfo }, - { "mailsplit", cmd_mailsplit }, - { "merge-base", cmd_merge_base, RUN_SETUP }, - { "merge-file", cmd_merge_file }, - { "merge-ours", cmd_merge_ours, RUN_SETUP }, - { "mv", cmd_mv, RUN_SETUP | NEED_WORK_TREE }, - { "name-rev", cmd_name_rev, RUN_SETUP }, - { "pack-objects", cmd_pack_objects, RUN_SETUP }, - { "peek-remote", cmd_ls_remote }, - { "pickaxe", cmd_blame, RUN_SETUP }, - { "prune", cmd_prune, RUN_SETUP }, - { "prune-packed", cmd_prune_packed, RUN_SETUP }, - { "push", cmd_push, RUN_SETUP }, - { "read-tree", cmd_read_tree, RUN_SETUP }, - { "reflog", cmd_reflog, RUN_SETUP }, - { "repo-config", cmd_config }, - { "rerere", cmd_rerere, RUN_SETUP }, - { "reset", cmd_reset, RUN_SETUP }, - { "rev-list", cmd_rev_list, RUN_SETUP }, - { "rev-parse", cmd_rev_parse }, - { "revert", cmd_revert, RUN_SETUP | NEED_WORK_TREE }, - { "rm", cmd_rm, RUN_SETUP }, - { "send-pack", cmd_send_pack, RUN_SETUP }, - { "shortlog", cmd_shortlog, RUN_SETUP | USE_PAGER }, - { "show-branch", cmd_show_branch, RUN_SETUP }, - { "show", cmd_show, RUN_SETUP | USE_PAGER }, - { "status", cmd_status, RUN_SETUP | NEED_WORK_TREE }, - { "stripspace", cmd_stripspace }, - { "symbolic-ref", cmd_symbolic_ref, RUN_SETUP }, - { "tag", cmd_tag, RUN_SETUP }, - { "tar-tree", cmd_tar_tree }, - { "unpack-objects", cmd_unpack_objects, RUN_SETUP }, - { "update-index", cmd_update_index, RUN_SETUP }, - { "update-ref", cmd_update_ref, RUN_SETUP }, - { "upload-archive", cmd_upload_archive }, - { "verify-tag", cmd_verify_tag, RUN_SETUP }, - { "version", cmd_version }, - { "whatchanged", cmd_whatchanged, RUN_SETUP | USE_PAGER }, - { "write-tree", cmd_write_tree, RUN_SETUP }, - { "verify-pack", cmd_verify_pack }, - { "show-ref", cmd_show_ref, RUN_SETUP }, - { "pack-refs", cmd_pack_refs, RUN_SETUP }, - }; - int i; - - /* Turn "git cmd --help" into "git help cmd" */ - if (argc > 1 && !strcmp(argv[1], "--help")) { - argv[1] = argv[0]; - argv[0] = cmd = "help"; - } - - for (i = 0; i < ARRAY_SIZE(commands); i++) { - struct cmd_struct *p = commands+i; - if (strcmp(p->cmd, cmd)) - continue; - exit(run_command(p, argc, argv)); - } -} - int main(int argc, const char **argv) { const char *cmd = argv[0] ? argv[0] : "git-help"; @@ -425,7 +259,7 @@ int main(int argc, const char **argv) if (!prefixcmp(cmd, "git-")) { cmd += 4; argv[0] = cmd; - handle_internal_command(argc, argv); + execv_git_builtin(argv); die("cannot handle %s internally", cmd); } @@ -453,10 +287,6 @@ int main(int argc, const char **argv) setup_path(cmd_path); while (1) { - /* See if it's an internal command */ - handle_internal_command(argc, argv); - - /* .. then try the external ones */ execv_git_cmd(argv); /* It could be an alias -- this works around the insanity -- 1.5.3.6.2112.ge2263 ^ permalink raw reply related [flat|nested] 92+ messages in thread
* Re: [PATCH 3/3] Introduce execv_git_builtin() and use it 2007-12-02 2:55 ` [PATCH 3/3] Introduce execv_git_builtin() and use it Johannes Schindelin @ 2007-12-02 3:04 ` Johannes Schindelin 2007-12-02 3:16 ` [REPLACEMENT PATCH " Johannes Schindelin 0 siblings, 1 reply; 92+ messages in thread From: Johannes Schindelin @ 2007-12-02 3:04 UTC (permalink / raw) To: Junio C Hamano Cc: Eyvind Bernhardsen, Nicolas Pitre, Nguyen Thai Ngoc Duy, Jan Hudec, git Hi, On Sun, 2 Dec 2007, Johannes Schindelin wrote: > + { "fmt", cmd_fmt }, Ah, well. This slipped in by mistake. Will resend in a few minutes. Ciao, Dscho ^ permalink raw reply [flat|nested] 92+ messages in thread
* [REPLACEMENT PATCH 3/3] Introduce execv_git_builtin() and use it 2007-12-02 3:04 ` Johannes Schindelin @ 2007-12-02 3:16 ` Johannes Schindelin 0 siblings, 0 replies; 92+ messages in thread From: Johannes Schindelin @ 2007-12-02 3:16 UTC (permalink / raw) To: Junio C Hamano Cc: Eyvind Bernhardsen, Nicolas Pitre, Nguyen Thai Ngoc Duy, Jan Hudec, git You can call execv_git_builtin() to execute a builtin command. This function is a reborn handle_internal_command() from git.c, and has the semantics of execv_git_cmd(), i.e. it exits with the exit code of the builtin if there is a matching builtin, but it avoids the real execvp() call. This function calls release_all_objects() and discard_cache() to start from a clean slate (this, along with the calculation of argc, is the only difference from a straight code move). The test suite passes, which at least does not contradict the hypothesis that this is good enough. However, it might be necessary to de-initialize more global variables. The function execv_git_cmd() and git.c's main() function were changed to take advantage of execv_git_builtin(). Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de> --- On Sun, 2 Dec 2007, Johannes Schindelin wrote: > Hi, > > On Sun, 2 Dec 2007, Johannes Schindelin wrote: > > > + { "fmt", cmd_fmt }, > > Ah, well. This slipped in by mistake. Will resend in a few > minutes. Here we go. exec_cmd.c | 176 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ exec_cmd.h | 1 + git.c | 170 +--------------------------------------------------------- 3 files changed, 178 insertions(+), 169 deletions(-) diff --git a/exec_cmd.c b/exec_cmd.c index 2d0a758..745b951 100644 --- a/exec_cmd.c +++ b/exec_cmd.c @@ -1,6 +1,8 @@ #include "cache.h" #include "exec_cmd.h" #include "quote.h" +#include "builtin.h" +#include "object.h" #define MAX_ARGS 32 extern char **environ; @@ -63,11 +65,185 @@ void setup_path(const char *cmd_path) strbuf_release(&new_path); } +const char git_usage_string[] = + "git [--version] [--exec-path[=GIT_EXEC_PATH]] [-p|--paginate|--no-pager] [--bare] [--git-dir=GIT_DIR] [--work-tree=GIT_WORK_TREE] [--help] COMMAND [ARGS]"; + +const char git_version_string[] = GIT_VERSION; + +#define RUN_SETUP (1<<0) +#define USE_PAGER (1<<1) +/* + * require working tree to be present -- anything uses this needs + * RUN_SETUP for reading from the configuration file. + */ +#define NEED_WORK_TREE (1<<2) + +struct cmd_struct { + const char *cmd; + int (*fn)(int, const char **, const char *); + int option; +}; + +static int run_command(struct cmd_struct *p, int argc, const char **argv) +{ + int status; + struct stat st; + const char *prefix; + + prefix = NULL; + if (p->option & RUN_SETUP) + prefix = setup_git_directory(); + if (p->option & USE_PAGER) + setup_pager(); + if (p->option & NEED_WORK_TREE) + setup_work_tree(); + + trace_argv_printf(argv, argc, "trace: built-in: git"); + + status = p->fn(argc, argv, prefix); + if (status) + return status & 0xff; + + /* Somebody closed stdout? */ + if (fstat(fileno(stdout), &st)) + return 0; + /* Ignore write errors for pipes and sockets.. */ + if (S_ISFIFO(st.st_mode) || S_ISSOCK(st.st_mode)) + return 0; + + /* Check for ENOSPC and EIO errors.. */ + if (fflush(stdout)) + die("write failure on standard output: %s", strerror(errno)); + if (ferror(stdout)) + die("unknown write failure on standard output"); + if (fclose(stdout)) + die("close failed on standard output: %s", strerror(errno)); + return 0; +} + +int execv_git_builtin(const char **argv) +{ + const char *cmd = argv[0]; + static struct cmd_struct commands[] = { + { "add", cmd_add, RUN_SETUP | NEED_WORK_TREE }, + { "annotate", cmd_annotate, RUN_SETUP }, + { "apply", cmd_apply }, + { "archive", cmd_archive }, + { "blame", cmd_blame, RUN_SETUP }, + { "branch", cmd_branch, RUN_SETUP }, + { "bundle", cmd_bundle }, + { "cat-file", cmd_cat_file, RUN_SETUP }, + { "checkout-index", cmd_checkout_index, + RUN_SETUP | NEED_WORK_TREE}, + { "check-ref-format", cmd_check_ref_format }, + { "check-attr", cmd_check_attr, RUN_SETUP | NEED_WORK_TREE }, + { "cherry", cmd_cherry, RUN_SETUP }, + { "cherry-pick", cmd_cherry_pick, RUN_SETUP | NEED_WORK_TREE }, + { "clean", cmd_clean, RUN_SETUP | NEED_WORK_TREE }, + { "commit", cmd_commit, RUN_SETUP | NEED_WORK_TREE }, + { "commit-tree", cmd_commit_tree, RUN_SETUP }, + { "config", cmd_config }, + { "count-objects", cmd_count_objects, RUN_SETUP }, + { "describe", cmd_describe, RUN_SETUP }, + { "diff", cmd_diff }, + { "diff-files", cmd_diff_files }, + { "diff-index", cmd_diff_index, RUN_SETUP }, + { "diff-tree", cmd_diff_tree, RUN_SETUP }, + { "fetch", cmd_fetch, RUN_SETUP }, + { "fetch-pack", cmd_fetch_pack, RUN_SETUP }, + { "fetch--tool", cmd_fetch__tool, RUN_SETUP }, + { "fmt-merge-msg", cmd_fmt_merge_msg, RUN_SETUP }, + { "for-each-ref", cmd_for_each_ref, RUN_SETUP }, + { "format-patch", cmd_format_patch, RUN_SETUP }, + { "fsck", cmd_fsck, RUN_SETUP }, + { "fsck-objects", cmd_fsck, RUN_SETUP }, + { "gc", cmd_gc, RUN_SETUP }, + { "get-tar-commit-id", cmd_get_tar_commit_id }, + { "grep", cmd_grep, RUN_SETUP | USE_PAGER }, + { "help", cmd_help }, +#ifndef NO_CURL + { "http-fetch", cmd_http_fetch, RUN_SETUP }, +#endif + { "init", cmd_init_db }, + { "init-db", cmd_init_db }, + { "log", cmd_log, RUN_SETUP | USE_PAGER }, + { "ls-files", cmd_ls_files, RUN_SETUP }, + { "ls-tree", cmd_ls_tree, RUN_SETUP }, + { "ls-remote", cmd_ls_remote }, + { "mailinfo", cmd_mailinfo }, + { "mailsplit", cmd_mailsplit }, + { "merge-base", cmd_merge_base, RUN_SETUP }, + { "merge-file", cmd_merge_file }, + { "merge-ours", cmd_merge_ours, RUN_SETUP }, + { "mv", cmd_mv, RUN_SETUP | NEED_WORK_TREE }, + { "name-rev", cmd_name_rev, RUN_SETUP }, + { "pack-objects", cmd_pack_objects, RUN_SETUP }, + { "peek-remote", cmd_ls_remote }, + { "pickaxe", cmd_blame, RUN_SETUP }, + { "prune", cmd_prune, RUN_SETUP }, + { "prune-packed", cmd_prune_packed, RUN_SETUP }, + { "push", cmd_push, RUN_SETUP }, + { "read-tree", cmd_read_tree, RUN_SETUP }, + { "reflog", cmd_reflog, RUN_SETUP }, + { "repo-config", cmd_config }, + { "rerere", cmd_rerere, RUN_SETUP }, + { "reset", cmd_reset, RUN_SETUP }, + { "rev-list", cmd_rev_list, RUN_SETUP }, + { "rev-parse", cmd_rev_parse }, + { "revert", cmd_revert, RUN_SETUP | NEED_WORK_TREE }, + { "rm", cmd_rm, RUN_SETUP }, + { "send-pack", cmd_send_pack, RUN_SETUP }, + { "shortlog", cmd_shortlog, RUN_SETUP | USE_PAGER }, + { "show-branch", cmd_show_branch, RUN_SETUP }, + { "show", cmd_show, RUN_SETUP | USE_PAGER }, + { "status", cmd_status, RUN_SETUP | NEED_WORK_TREE }, + { "stripspace", cmd_stripspace }, + { "symbolic-ref", cmd_symbolic_ref, RUN_SETUP }, + { "tag", cmd_tag, RUN_SETUP }, + { "tar-tree", cmd_tar_tree }, + { "unpack-objects", cmd_unpack_objects, RUN_SETUP }, + { "update-index", cmd_update_index, RUN_SETUP }, + { "update-ref", cmd_update_ref, RUN_SETUP }, + { "upload-archive", cmd_upload_archive }, + { "verify-tag", cmd_verify_tag, RUN_SETUP }, + { "version", cmd_version }, + { "whatchanged", cmd_whatchanged, RUN_SETUP | USE_PAGER }, + { "write-tree", cmd_write_tree, RUN_SETUP }, + { "verify-pack", cmd_verify_pack }, + { "show-ref", cmd_show_ref, RUN_SETUP }, + { "pack-refs", cmd_pack_refs, RUN_SETUP }, + }; + int i; + + /* Turn "git cmd --help" into "git help cmd" */ + if (argv[0] && argv[1] && !strcmp(argv[1], "--help")) { + argv[1] = argv[0]; + argv[0] = cmd = "help"; + } + + for (i = 0; i < ARRAY_SIZE(commands); i++) { + int argc; + struct cmd_struct *p = commands+i; + if (strcmp(p->cmd, cmd)) + continue; + release_all_objects(); + discard_cache(); + for (argc = 0; argv[argc]; argc++) + ; /* do nothing */ + exit(run_command(p, argc, argv)); + } + return -1; +} + int execv_git_cmd(const char **argv) { struct strbuf cmd; const char *tmp; + /* Try builtin first... */ + execv_git_builtin(argv); + + /* ... and then external commands */ strbuf_init(&cmd, 0); strbuf_addf(&cmd, "git-%s", argv[0]); diff --git a/exec_cmd.h b/exec_cmd.h index a892355..bb15425 100644 --- a/exec_cmd.h +++ b/exec_cmd.h @@ -4,6 +4,7 @@ extern void git_set_argv_exec_path(const char *exec_path); extern const char* git_exec_path(void); extern void setup_path(const char *); +extern int execv_git_builtin(const char **argv); /* NULL terminated */ extern int execv_git_cmd(const char **argv); /* NULL terminated */ extern int execl_git_cmd(const char *cmd, ...); diff --git a/git.c b/git.c index 95296aa..1523c4a 100644 --- a/git.c +++ b/git.c @@ -3,9 +3,6 @@ #include "cache.h" #include "quote.h" -const char git_usage_string[] = - "git [--version] [--exec-path[=GIT_EXEC_PATH]] [-p|--paginate|--no-pager] [--bare] [--git-dir=GIT_DIR] [--work-tree=GIT_WORK_TREE] [--help] COMMAND [ARGS]"; - static int handle_options(const char*** argv, int* argc, int* envchanged) { int handled = 0; @@ -231,167 +228,6 @@ static int handle_alias(int *argcp, const char ***argv) return ret; } -const char git_version_string[] = GIT_VERSION; - -#define RUN_SETUP (1<<0) -#define USE_PAGER (1<<1) -/* - * require working tree to be present -- anything uses this needs - * RUN_SETUP for reading from the configuration file. - */ -#define NEED_WORK_TREE (1<<2) - -struct cmd_struct { - const char *cmd; - int (*fn)(int, const char **, const char *); - int option; -}; - -static int run_command(struct cmd_struct *p, int argc, const char **argv) -{ - int status; - struct stat st; - const char *prefix; - - prefix = NULL; - if (p->option & RUN_SETUP) - prefix = setup_git_directory(); - if (p->option & USE_PAGER) - setup_pager(); - if (p->option & NEED_WORK_TREE) - setup_work_tree(); - - trace_argv_printf(argv, argc, "trace: built-in: git"); - - status = p->fn(argc, argv, prefix); - if (status) - return status & 0xff; - - /* Somebody closed stdout? */ - if (fstat(fileno(stdout), &st)) - return 0; - /* Ignore write errors for pipes and sockets.. */ - if (S_ISFIFO(st.st_mode) || S_ISSOCK(st.st_mode)) - return 0; - - /* Check for ENOSPC and EIO errors.. */ - if (fflush(stdout)) - die("write failure on standard output: %s", strerror(errno)); - if (ferror(stdout)) - die("unknown write failure on standard output"); - if (fclose(stdout)) - die("close failed on standard output: %s", strerror(errno)); - return 0; -} - -static void handle_internal_command(int argc, const char **argv) -{ - const char *cmd = argv[0]; - static struct cmd_struct commands[] = { - { "add", cmd_add, RUN_SETUP | NEED_WORK_TREE }, - { "annotate", cmd_annotate, RUN_SETUP }, - { "apply", cmd_apply }, - { "archive", cmd_archive }, - { "blame", cmd_blame, RUN_SETUP }, - { "branch", cmd_branch, RUN_SETUP }, - { "bundle", cmd_bundle }, - { "cat-file", cmd_cat_file, RUN_SETUP }, - { "checkout-index", cmd_checkout_index, - RUN_SETUP | NEED_WORK_TREE}, - { "check-ref-format", cmd_check_ref_format }, - { "check-attr", cmd_check_attr, RUN_SETUP | NEED_WORK_TREE }, - { "cherry", cmd_cherry, RUN_SETUP }, - { "cherry-pick", cmd_cherry_pick, RUN_SETUP | NEED_WORK_TREE }, - { "clean", cmd_clean, RUN_SETUP | NEED_WORK_TREE }, - { "commit", cmd_commit, RUN_SETUP | NEED_WORK_TREE }, - { "commit-tree", cmd_commit_tree, RUN_SETUP }, - { "config", cmd_config }, - { "count-objects", cmd_count_objects, RUN_SETUP }, - { "describe", cmd_describe, RUN_SETUP }, - { "diff", cmd_diff }, - { "diff-files", cmd_diff_files }, - { "diff-index", cmd_diff_index, RUN_SETUP }, - { "diff-tree", cmd_diff_tree, RUN_SETUP }, - { "fetch", cmd_fetch, RUN_SETUP }, - { "fetch-pack", cmd_fetch_pack, RUN_SETUP }, - { "fetch--tool", cmd_fetch__tool, RUN_SETUP }, - { "fmt-merge-msg", cmd_fmt_merge_msg, RUN_SETUP }, - { "for-each-ref", cmd_for_each_ref, RUN_SETUP }, - { "format-patch", cmd_format_patch, RUN_SETUP }, - { "fsck", cmd_fsck, RUN_SETUP }, - { "fsck-objects", cmd_fsck, RUN_SETUP }, - { "gc", cmd_gc, RUN_SETUP }, - { "get-tar-commit-id", cmd_get_tar_commit_id }, - { "grep", cmd_grep, RUN_SETUP | USE_PAGER }, - { "help", cmd_help }, -#ifndef NO_CURL - { "http-fetch", cmd_http_fetch, RUN_SETUP }, -#endif - { "init", cmd_init_db }, - { "init-db", cmd_init_db }, - { "log", cmd_log, RUN_SETUP | USE_PAGER }, - { "ls-files", cmd_ls_files, RUN_SETUP }, - { "ls-tree", cmd_ls_tree, RUN_SETUP }, - { "ls-remote", cmd_ls_remote }, - { "mailinfo", cmd_mailinfo }, - { "mailsplit", cmd_mailsplit }, - { "merge-base", cmd_merge_base, RUN_SETUP }, - { "merge-file", cmd_merge_file }, - { "merge-ours", cmd_merge_ours, RUN_SETUP }, - { "mv", cmd_mv, RUN_SETUP | NEED_WORK_TREE }, - { "name-rev", cmd_name_rev, RUN_SETUP }, - { "pack-objects", cmd_pack_objects, RUN_SETUP }, - { "peek-remote", cmd_ls_remote }, - { "pickaxe", cmd_blame, RUN_SETUP }, - { "prune", cmd_prune, RUN_SETUP }, - { "prune-packed", cmd_prune_packed, RUN_SETUP }, - { "push", cmd_push, RUN_SETUP }, - { "read-tree", cmd_read_tree, RUN_SETUP }, - { "reflog", cmd_reflog, RUN_SETUP }, - { "repo-config", cmd_config }, - { "rerere", cmd_rerere, RUN_SETUP }, - { "reset", cmd_reset, RUN_SETUP }, - { "rev-list", cmd_rev_list, RUN_SETUP }, - { "rev-parse", cmd_rev_parse }, - { "revert", cmd_revert, RUN_SETUP | NEED_WORK_TREE }, - { "rm", cmd_rm, RUN_SETUP }, - { "send-pack", cmd_send_pack, RUN_SETUP }, - { "shortlog", cmd_shortlog, RUN_SETUP | USE_PAGER }, - { "show-branch", cmd_show_branch, RUN_SETUP }, - { "show", cmd_show, RUN_SETUP | USE_PAGER }, - { "status", cmd_status, RUN_SETUP | NEED_WORK_TREE }, - { "stripspace", cmd_stripspace }, - { "symbolic-ref", cmd_symbolic_ref, RUN_SETUP }, - { "tag", cmd_tag, RUN_SETUP }, - { "tar-tree", cmd_tar_tree }, - { "unpack-objects", cmd_unpack_objects, RUN_SETUP }, - { "update-index", cmd_update_index, RUN_SETUP }, - { "update-ref", cmd_update_ref, RUN_SETUP }, - { "upload-archive", cmd_upload_archive }, - { "verify-tag", cmd_verify_tag, RUN_SETUP }, - { "version", cmd_version }, - { "whatchanged", cmd_whatchanged, RUN_SETUP | USE_PAGER }, - { "write-tree", cmd_write_tree, RUN_SETUP }, - { "verify-pack", cmd_verify_pack }, - { "show-ref", cmd_show_ref, RUN_SETUP }, - { "pack-refs", cmd_pack_refs, RUN_SETUP }, - }; - int i; - - /* Turn "git cmd --help" into "git help cmd" */ - if (argc > 1 && !strcmp(argv[1], "--help")) { - argv[1] = argv[0]; - argv[0] = cmd = "help"; - } - - for (i = 0; i < ARRAY_SIZE(commands); i++) { - struct cmd_struct *p = commands+i; - if (strcmp(p->cmd, cmd)) - continue; - exit(run_command(p, argc, argv)); - } -} - int main(int argc, const char **argv) { const char *cmd = argv[0] ? argv[0] : "git-help"; @@ -423,7 +259,7 @@ int main(int argc, const char **argv) if (!prefixcmp(cmd, "git-")) { cmd += 4; argv[0] = cmd; - handle_internal_command(argc, argv); + execv_git_builtin(argv); die("cannot handle %s internally", cmd); } @@ -451,10 +287,6 @@ int main(int argc, const char **argv) setup_path(cmd_path); while (1) { - /* See if it's an internal command */ - handle_internal_command(argc, argv); - - /* .. then try the external ones */ execv_git_cmd(argv); /* It could be an alias -- this works around the insanity -- 1.5.3.6.2112.ge2263 ^ permalink raw reply related [flat|nested] 92+ messages in thread
* Re: [PATCH 0/3] Call builtin functions directly, was Re: [PATCH] transport.c: call dash-less form of receive-pack and upload-pack on remote 2007-12-02 2:52 ` [PATCH 0/3] Call builtin functions directly, was " Johannes Schindelin ` (2 preceding siblings ...) 2007-12-02 2:55 ` [PATCH 3/3] Introduce execv_git_builtin() and use it Johannes Schindelin @ 2007-12-02 5:19 ` Junio C Hamano 2007-12-02 11:35 ` Johannes Schindelin 3 siblings, 1 reply; 92+ messages in thread From: Junio C Hamano @ 2007-12-02 5:19 UTC (permalink / raw) To: Johannes Schindelin Cc: Eyvind Bernhardsen, Nicolas Pitre, Nguyen Thai Ngoc Duy, Jan Hudec, git Johannes Schindelin <Johannes.Schindelin@gmx.de> writes: > Okay, I bit the apple and tried to move the builtins into the library, and > rename handle_internal_command into execv_git_builtin(), moving it into > exec-cmd.c. > > Big mistake. I really feel this should not go in. Anything called exec _should_ assure the callers that the new command will start from a clean slate, and the way to give that assurance is by actually doing exec(), not introducing "clean-up" functions for random things we can think of (like cached objects) and risking of forgetting some others. I do not think the complexity is worth it. The first step we have decided to take is to move git-foo form out of users' PATH. This would reduce the cluttered PATH problem, and it means not all of external commands have to become built-ins on a single flag day. I also think it has always been a nice touch that we allowed users to drop their own custom git-foo script to their path and call "git foo" as if it is part of the official git suite, so spawning commands in git-foo form needs to be supported via GIT_EXEC_PATH even if everything eventually becomes built-in. So I would prefer doing something like this instead for v1.5.5 (see the top of updated release notes for 1.5.4 for deprecation notice). * execv_git_cmd() function will exec "git" with the given subcommand and its arguments; * The command dispatcher of git potty itself will first try the built-ins, and then try externals in dash form (which cannot be done with execv_git_cmd() anymore), and then aliases. * Just to be nice, we allow git-shell to treat "git foo arg" as if "git-foo arg" was given, but it continues to use execv_git_cmd(), and starts from a clean slate. --- exec_cmd.c | 31 ++++++++++++------------------- git.c | 32 +++++++++++++++++++++++++++++++- shell.c | 26 +++++++++++++++----------- 3 files changed, 58 insertions(+), 31 deletions(-) diff --git a/exec_cmd.c b/exec_cmd.c index 2d0a758..10b2908 100644 --- a/exec_cmd.c +++ b/exec_cmd.c @@ -65,32 +65,25 @@ void setup_path(const char *cmd_path) int execv_git_cmd(const char **argv) { - struct strbuf cmd; - const char *tmp; - - strbuf_init(&cmd, 0); - strbuf_addf(&cmd, "git-%s", argv[0]); + int argc; + const char **nargv; - /* - * argv[0] must be the git command, but the argv array - * belongs to the caller, and may be reused in - * subsequent loop iterations. Save argv[0] and - * restore it on error. - */ - tmp = argv[0]; - argv[0] = cmd.buf; + for (argc = 0; argv[argc]; argc++) + ; /* just counting */ + nargv = xmalloc(sizeof(*nargv) * (argc + 2)); - trace_argv_printf(argv, -1, "trace: exec:"); + nargv[0] = "git"; + for (argc = 0; argv[argc]; argc++) + nargv[argc + 1] = argv[argc]; + nargv[argc + 1] = NULL; + trace_argv_printf(nargv, -1, "trace: exec:"); /* execvp() can only ever return if it fails */ - execvp(cmd.buf, (char **)argv); + execvp("git", (char **)nargv); trace_printf("trace: exec failed: %s\n", strerror(errno)); - argv[0] = tmp; - - strbuf_release(&cmd); - + free(nargv); return -1; } diff --git a/git.c b/git.c index 01bbbc7..d690426 100644 --- a/git.c +++ b/git.c @@ -382,6 +382,36 @@ static void handle_internal_command(int argc, const char **argv) } } +static void execv_dashed_external(const char **argv) +{ + struct strbuf cmd; + const char *tmp; + + strbuf_init(&cmd, 0); + strbuf_addf(&cmd, "git-%s", argv[0]); + + /* + * argv[0] must be the git command, but the argv array + * belongs to the caller, and may be reused in + * subsequent loop iterations. Save argv[0] and + * restore it on error. + */ + tmp = argv[0]; + argv[0] = cmd.buf; + + trace_argv_printf(argv, -1, "trace: exec:"); + + /* execvp() can only ever return if it fails */ + execvp(cmd.buf, (char **)argv); + + trace_printf("trace: exec failed: %s\n", strerror(errno)); + + argv[0] = tmp; + + strbuf_release(&cmd); +} + + int main(int argc, const char **argv) { const char *cmd = argv[0] ? argv[0] : "git-help"; @@ -445,7 +475,7 @@ int main(int argc, const char **argv) handle_internal_command(argc, argv); /* .. then try the external ones */ - execv_git_cmd(argv); + execv_dashed_external(argv); /* It could be an alias -- this works around the insanity * of overriding "git log" with "git show" by having diff --git a/shell.c b/shell.c index 9826109..729797c 100644 --- a/shell.c +++ b/shell.c @@ -19,17 +19,13 @@ static int do_generic_cmd(const char *me, char *arg) return execv_git_cmd(my_argv); } -static int do_cvs_cmd(const char *me, char *arg) +static int do_cvs_cmd(void) { const char *cvsserver_argv[3] = { "cvsserver", "server", NULL }; - if (!arg || strcmp(arg, "server")) - die("git-cvsserver only handles server: %s", arg); - setup_path(NULL); - return execv_git_cmd(cvsserver_argv); } @@ -40,7 +36,6 @@ static struct commands { } cmd_list[] = { { "git-receive-pack", do_generic_cmd }, { "git-upload-pack", do_generic_cmd }, - { "cvs", do_cvs_cmd }, { NULL }, }; @@ -49,15 +44,24 @@ int main(int argc, char **argv) char *prog; struct commands *cmd; + /* + * Special hack to pretend to be a CVS server + */ if (argc == 2 && !strcmp(argv[1], "cvs server")) - argv--; - /* We want to see "-c cmd args", and nothing else */ - else if (argc != 3 || strcmp(argv[1], "-c")) + exit(do_cvs_cmd()); + + /* + * We do not accept anything but "-c" followed by "cmd arg", + * where "cmd" is a very limited subset of git commands. + */ + if (argc != 3 || strcmp(argv[1], "-c")) die("What do you think I am? A shell?"); prog = argv[2]; - argv += 2; - argc -= 2; + if (!strncmp(prog, "git", 3) && isspace(prog[3])) + /* Accept "git foo" as if the caller said "git-foo". */ + prog[3] = '-'; + for (cmd = cmd_list ; cmd->name ; cmd++) { int len = strlen(cmd->name); char *arg; ^ permalink raw reply related [flat|nested] 92+ messages in thread
* Re: [PATCH 0/3] Call builtin functions directly, was Re: [PATCH] transport.c: call dash-less form of receive-pack and upload-pack on remote 2007-12-02 5:19 ` [PATCH 0/3] Call builtin functions directly, was Re: [PATCH] transport.c: call dash-less form of receive-pack and upload-pack on remote Junio C Hamano @ 2007-12-02 11:35 ` Johannes Schindelin 0 siblings, 0 replies; 92+ messages in thread From: Johannes Schindelin @ 2007-12-02 11:35 UTC (permalink / raw) To: Junio C Hamano Cc: Eyvind Bernhardsen, Nicolas Pitre, Nguyen Thai Ngoc Duy, Jan Hudec, git Hi, On Sat, 1 Dec 2007, Junio C Hamano wrote: > Johannes Schindelin <Johannes.Schindelin@gmx.de> writes: > > > Okay, I bit the apple and tried to move the builtins into the library, > > and rename handle_internal_command into execv_git_builtin(), moving it > > into exec-cmd.c. > > > > Big mistake. > > I really feel this should not go in. Hmm. My rationale was not only avoiding an exec() (which I would find worth it on its own), but because this would be a non-verbal step towards libification. Ciao, Dscho ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 11:28 ` Eyvind Bernhardsen 2007-11-30 12:08 ` [PATCH] transport.c: call dash-less form of receive-pack and upload-pack on remote Johannes Schindelin @ 2007-11-30 12:19 ` Nguyen Thai Ngoc Duy 2007-11-30 13:35 ` Johannes Schindelin 1 sibling, 1 reply; 92+ messages in thread From: Nguyen Thai Ngoc Duy @ 2007-11-30 12:19 UTC (permalink / raw) To: Eyvind Bernhardsen Cc: Junio C Hamano, Nicolas Pitre, Jan Hudec, Johannes Schindelin, git On Nov 30, 2007 6:28 PM, Eyvind Bernhardsen <eyvind-git-list@orakel.ntnu.no> wrote: > On 29. nov. 2007, at 23.36, Junio C Hamano wrote: > > [...] > > > If people are really serious about reducing the number of commands in > > the path, I would expect fixes and bugreports saying "I am setting > > gitexecdir different from bindir in _my_ installation when I build > > git, > > and here are the things that does not work if I do so". Within the > > span > > of more than 20 months (77cb17e9 introduced gitexecdir in Jan 2006), I > > do not think there was a single such report or patch, other than the > > message from Nguyen that started this thread. > > I'm setting gitexecdir different from bindir in my installation, and > here are the things that don't work: > > - When pushing to my system over ssh, git-receive-pack and git-upload- > pack are expected to be in $PATH. I resolved the problem by putting > symlinks in /usr/local/bin. > > I haven't seen any other problems, but then again, I only use git > plumbing commands and my own scripts. You remind me my experience of making every external C-based command builtin. There is another case: git-merge. It calls something like git-merge-$strategy. -- Duy ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 12:19 ` [PATCH] Move all dashed form git commands to libexecdir Nguyen Thai Ngoc Duy @ 2007-11-30 13:35 ` Johannes Schindelin 0 siblings, 0 replies; 92+ messages in thread From: Johannes Schindelin @ 2007-11-30 13:35 UTC (permalink / raw) To: Nguyen Thai Ngoc Duy Cc: Eyvind Bernhardsen, Junio C Hamano, Nicolas Pitre, Jan Hudec, git Hi, On Fri, 30 Nov 2007, Nguyen Thai Ngoc Duy wrote: > On Nov 30, 2007 6:28 PM, Eyvind Bernhardsen > <eyvind-git-list@orakel.ntnu.no> wrote: > > On 29. nov. 2007, at 23.36, Junio C Hamano wrote: > > > > [...] > > > > > If people are really serious about reducing the number of commands in > > > the path, I would expect fixes and bugreports saying "I am setting > > > gitexecdir different from bindir in _my_ installation when I build > > > git, > > > and here are the things that does not work if I do so". Within the > > > span > > > of more than 20 months (77cb17e9 introduced gitexecdir in Jan 2006), I > > > do not think there was a single such report or patch, other than the > > > message from Nguyen that started this thread. > > > > I'm setting gitexecdir different from bindir in my installation, and > > here are the things that don't work: > > > > - When pushing to my system over ssh, git-receive-pack and git-upload- > > pack are expected to be in $PATH. I resolved the problem by putting > > symlinks in /usr/local/bin. > > > > I haven't seen any other problems, but then again, I only use git > > plumbing commands and my own scripts. > > You remind me my experience of making every external C-based command > builtin. There is another case: git-merge. It calls something like > git-merge-$strategy. Good catch! Ciao, Dscho ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-28 23:14 ` Junio C Hamano ` (2 preceding siblings ...) 2007-11-29 3:17 ` Nguyen Thai Ngoc Duy @ 2007-11-29 15:08 ` Jeff King 2007-11-29 20:05 ` Nguyen Thai Ngoc Duy 3 siblings, 1 reply; 92+ messages in thread From: Jeff King @ 2007-11-29 15:08 UTC (permalink / raw) To: Junio C Hamano; +Cc: Nguyen Thai Ngoc Duy, Jan Hudec, Johannes Schindelin, git On Wed, Nov 28, 2007 at 03:14:56PM -0800, Junio C Hamano wrote: > - Post v1.5.5, start cooking the change that does not install hardlinks > for built-in commands, aiming for inclusion in v1.6.0, by the end of > 2008. I am against this, unless it is configurable. I think the goal of reducing user-visible commands is fine, and moving things to $(libexecdir) is a good way of doing that. However, I personally still think the 'git-foo' forms are valuable (because fingers have already been trained, and because non-bash-programmable completions understand them). And I don't mind putting $(libexecdir)/git-core in my PATH to retain this behavior; it's a one-time configuration tweak, and it helps new users with the overwhelming command set. But I don't see a point to removing the links entirely. The annoyance factor for people who want git-* is much higher, and I don't see that it actually buys us any help for new users (who will no longer care after everything is hidden in $(libexecdir) anyway). -Peff ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-29 15:08 ` Jeff King @ 2007-11-29 20:05 ` Nguyen Thai Ngoc Duy 2007-11-29 21:14 ` Jeff King 0 siblings, 1 reply; 92+ messages in thread From: Nguyen Thai Ngoc Duy @ 2007-11-29 20:05 UTC (permalink / raw) To: Jeff King; +Cc: Junio C Hamano, Jan Hudec, Johannes Schindelin, git On Nov 29, 2007 10:08 PM, Jeff King <peff@peff.net> wrote: > On Wed, Nov 28, 2007 at 03:14:56PM -0800, Junio C Hamano wrote: > > > - Post v1.5.5, start cooking the change that does not install hardlinks > > for built-in commands, aiming for inclusion in v1.6.0, by the end of > > 2008. > > I am against this, unless it is configurable. I think the goal of > reducing user-visible commands is fine, and moving things to > $(libexecdir) is a good way of doing that. > > However, I personally still think the 'git-foo' forms are valuable > (because fingers have already been trained, and because > non-bash-programmable completions understand them). And I don't mind > putting $(libexecdir)/git-core in my PATH to retain this behavior; it's > a one-time configuration tweak, and it helps new users with the > overwhelming command set. > > But I don't see a point to removing the links entirely. The annoyance > factor for people who want git-* is much higher, and I don't see that it > actually buys us any help for new users (who will no longer care after > everything is hidden in $(libexecdir) anyway). Maybe only not install hardlinks on systems that do not support it like Windows? git.exe duplication takes a lot of space. -- Duy ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-29 20:05 ` Nguyen Thai Ngoc Duy @ 2007-11-29 21:14 ` Jeff King 2007-11-29 22:19 ` Johannes Schindelin 0 siblings, 1 reply; 92+ messages in thread From: Jeff King @ 2007-11-29 21:14 UTC (permalink / raw) To: Nguyen Thai Ngoc Duy; +Cc: Junio C Hamano, Jan Hudec, Johannes Schindelin, git On Fri, Nov 30, 2007 at 03:05:05AM +0700, Nguyen Thai Ngoc Duy wrote: > > But I don't see a point to removing the links entirely. The annoyance > > factor for people who want git-* is much higher, and I don't see that it > > actually buys us any help for new users (who will no longer care after > > everything is hidden in $(libexecdir) anyway). > > Maybe only not install hardlinks on systems that do not support it > like Windows? git.exe duplication takes a lot of space. I think that is totally reasonable, as on those platforms there is actually something to be gained from removing those hardlinks (you could also of course make a very thin wrapper for "git-foo" that called "git foo"; it would still be wasteful, but not as much as copying the whole git.exe. But that is not worth doing unless people on Windows really want the dash forms). -Peff ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-29 21:14 ` Jeff King @ 2007-11-29 22:19 ` Johannes Schindelin 2007-11-29 23:14 ` Jeff King 0 siblings, 1 reply; 92+ messages in thread From: Johannes Schindelin @ 2007-11-29 22:19 UTC (permalink / raw) To: Jeff King; +Cc: Nguyen Thai Ngoc Duy, Junio C Hamano, Jan Hudec, git Hi, On Thu, 29 Nov 2007, Jeff King wrote: > On Fri, Nov 30, 2007 at 03:05:05AM +0700, Nguyen Thai Ngoc Duy wrote: > > > > But I don't see a point to removing the links entirely. The annoyance > > > factor for people who want git-* is much higher, and I don't see that it > > > actually buys us any help for new users (who will no longer care after > > > everything is hidden in $(libexecdir) anyway). > > > > Maybe only not install hardlinks on systems that do not support it > > like Windows? git.exe duplication takes a lot of space. > > I think that is totally reasonable, as on those platforms there is > actually something to be gained from removing those hardlinks (you could > also of course make a very thin wrapper for "git-foo" that called "git > foo"; it would still be wasteful, but not as much as copying the whole > git.exe. But that is not worth doing unless people on Windows really > want the dash forms). Note that one big problem with a few platforms having dash forms and others not is that you _will_ get scripts and aliases that do not work everywhere. Consistency is good. Ciao, Dscho ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-29 22:19 ` Johannes Schindelin @ 2007-11-29 23:14 ` Jeff King 2007-11-29 23:30 ` Linus Torvalds 0 siblings, 1 reply; 92+ messages in thread From: Jeff King @ 2007-11-29 23:14 UTC (permalink / raw) To: Johannes Schindelin; +Cc: Nguyen Thai Ngoc Duy, Junio C Hamano, Jan Hudec, git On Thu, Nov 29, 2007 at 10:19:16PM +0000, Johannes Schindelin wrote: > > I think that is totally reasonable, as on those platforms there is > > actually something to be gained from removing those hardlinks (you could > > Note that one big problem with a few platforms having dash forms and > others not is that you _will_ get scripts and aliases that do not work > everywhere. > > Consistency is good. Yes, I am fine with the user having to go to extra lengths to use the dash forms (like adding $(libexecdir) to their path), which I think should address your consistency concern. -Peff ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-29 23:14 ` Jeff King @ 2007-11-29 23:30 ` Linus Torvalds 2007-11-30 0:13 ` Junio C Hamano 0 siblings, 1 reply; 92+ messages in thread From: Linus Torvalds @ 2007-11-29 23:30 UTC (permalink / raw) To: Jeff King Cc: Johannes Schindelin, Nguyen Thai Ngoc Duy, Junio C Hamano, Jan Hudec, git On Thu, 29 Nov 2007, Jeff King wrote: > > Yes, I am fine with the user having to go to extra lengths to use the > dash forms (like adding $(libexecdir) to their path), which I think > should address your consistency concern. I agree. If we actually start moving the subcommands into a separate directory, I suspect scripts will be fixed up soon enough. Of course people *can* do it by just adding the path, but more likely, we'll just see people start doign "git xyz" instead of "git-xyz". And from a consistency standpoint, that would be a *good* thing. There are many reasons why the git-xyz format *cannot* be the "consistent" form (ranging from the flags like --bare and -p to just aliases), so encouraging people to move to "git xyz" is just a good idea. Yeah, yeah, the man-pages need the "git-xyz" form, but on the other hand, rather than "man git-xyz", you can just do "git help xyz" instead, and now you're consistently avoiding the dash again! Linus ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-29 23:30 ` Linus Torvalds @ 2007-11-30 0:13 ` Junio C Hamano 2007-11-30 0:35 ` Jeff King ` (2 more replies) 0 siblings, 3 replies; 92+ messages in thread From: Junio C Hamano @ 2007-11-30 0:13 UTC (permalink / raw) To: Linus Torvalds Cc: Jeff King, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git Linus Torvalds <torvalds@linux-foundation.org> writes: > And from a consistency standpoint, that would be a *good* thing. There are > many reasons why the git-xyz format *cannot* be the "consistent" form > (ranging from the flags like --bare and -p to just aliases), so > encouraging people to move to "git xyz" is just a good idea. > > Yeah, yeah, the man-pages need the "git-xyz" form, but on the other hand, > rather than "man git-xyz", you can just do "git help xyz" instead, and now > you're consistently avoiding the dash again! Ok. So here is a revised roadmap that a panda brain (that is not so well working today due to fever) came up. - v1.5.4 will ship with gitexecdir=$(bindir) in Makefile. But the release notes for the version will warn users that: (1) using git-foo from the command line, and (2) using git-foo from your scripts without first prepending the return value of "git --exec-path" to the PATH is now officially deprecated (it has been deprecated for a long time since January 2006, v1.2.0~149) and upcoming v1.5.5 will ship with the default configuration that does not install git-foo form in user's PATH. If further will warn users that git-foo form will be removed in v1.5.6 for many commands and it will be merely an accident if some of them still work after that. - Post v1.5.4, start cooking gitexecdir=$(libexecdir)/git-core, aiming for inclusion in v1.5.5, perhaps in Feb-Mar 2008 timeframe. This will also affect the sample RPM spec and resulting RPM binary packages I will place on k.org, and I'll ask Gerrit to do the same on Debian side. The official binary packaging of individual distros are not under my control, but if there is a handy list of people I can send this notice to for other distros, that would help this process. - The release notes for v1.5.5 will warn users again that git-foo will be removed in v1.5.6 for many commands and it will be merely an accident if some of them still work. - Post v1.5.5, start cooking the change that does not install hardlinks for built-in commands, aiming for inclusion in v1.5.6, in May-Jun 2008 timeframe. ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 0:13 ` Junio C Hamano @ 2007-11-30 0:35 ` Jeff King 2007-11-30 0:49 ` Junio C Hamano 2007-11-30 0:52 ` Nicolas Pitre 2007-11-30 0:40 ` Nguyen Thai Ngoc Duy 2007-11-30 0:51 ` A Large Angry SCM 2 siblings, 2 replies; 92+ messages in thread From: Jeff King @ 2007-11-30 0:35 UTC (permalink / raw) To: Junio C Hamano Cc: Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Thu, Nov 29, 2007 at 04:13:29PM -0800, Junio C Hamano wrote: > - Post v1.5.5, start cooking the change that does not install hardlinks > for built-in commands, aiming for inclusion in v1.5.6, in May-Jun > 2008 timeframe. I am still against this step, for the reasons mentioned in the mails leading up to the one you just quoted. I am fine with "does not install hardlinks for builtin-commands on systems that don't support hardlinks" (and of course all such hardlinks are in $(libexecdir)/git-core at this point). -Peff ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 0:35 ` Jeff King @ 2007-11-30 0:49 ` Junio C Hamano 2007-11-30 0:58 ` Jeff King 2007-11-30 0:52 ` Nicolas Pitre 1 sibling, 1 reply; 92+ messages in thread From: Junio C Hamano @ 2007-11-30 0:49 UTC (permalink / raw) To: Jeff King Cc: Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git Jeff King <peff@peff.net> writes: > On Thu, Nov 29, 2007 at 04:13:29PM -0800, Junio C Hamano wrote: > >> - Post v1.5.5, start cooking the change that does not install hardlinks >> for built-in commands, aiming for inclusion in v1.5.6, in May-Jun >> 2008 timeframe. > > I am still against this step, for the reasons mentioned in the mails > leading up to the one you just quoted. I am fine with "does not install > hardlinks for builtin-commands on systems that don't support hardlinks" > (and of course all such hardlinks are in $(libexecdir)/git-core at this > point). I understand your point was primarily "git-a<tab>". I think it has been solved for bash and zsh but not for other shells. I think possible and sensible avenues are (1) punt -- cvs, svn nor hg people do not seem to have problem with it, or (2) implement completion in your other favorite shells. And I think the following from Linus makes sense. > And from a consistency standpoint, that would be a *good* thing. There are > many reasons why the git-xyz format *cannot* be the "consistent" form > (ranging from the flags like --bare and -p to just aliases), so > encouraging people to move to "git xyz" is just a good idea. > > Yeah, yeah, the man-pages need the "git-xyz" form, but on the other hand, > rather than "man git-xyz", you can just do "git help xyz" instead, and now > you're consistently avoiding the dash again! but I am feeling quite feverish today so I may be missing something obvious. ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 0:49 ` Junio C Hamano @ 2007-11-30 0:58 ` Jeff King 2007-11-30 1:13 ` Nicolas Pitre 2007-11-30 2:29 ` Linus Torvalds 0 siblings, 2 replies; 92+ messages in thread From: Jeff King @ 2007-11-30 0:58 UTC (permalink / raw) To: Junio C Hamano Cc: Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Thu, Nov 29, 2007 at 04:49:26PM -0800, Junio C Hamano wrote: > I understand your point was primarily "git-a<tab>". I think it has been > solved for bash and zsh but not for other shells. I think possible and > sensible avenues are (1) punt -- cvs, svn nor hg people do not seem to > have problem with it, or (2) implement completion in your other favorite > shells. My point is that (2) is already implemented for every program (shell or no) which understands filename completion, and there is a proposal for taking it away. I would consider that, except I haven't see any claimed advantages except that the hardlinks are awful under Windows. I am proposing to have those dashed forms on platforms where it makes sense, but to treat them as second-class citizens (by putting them in $(libexecdir), which will address consistency problems. > And I think the following from Linus makes sense. > > > And from a consistency standpoint, that would be a *good* thing. There are > > many reasons why the git-xyz format *cannot* be the "consistent" form > > (ranging from the flags like --bare and -p to just aliases), so > > encouraging people to move to "git xyz" is just a good idea. > > > > Yeah, yeah, the man-pages need the "git-xyz" form, but on the other hand, > > rather than "man git-xyz", you can just do "git help xyz" instead, and now > > you're consistently avoiding the dash again! > > but I am feeling quite feverish today so I may be missing something > obvious. I thought Linus' point was that moving the subcommands was sufficient for dealing with the consistency issue (i.e., all scripts would move to "git foo" and only those people who really wanted to would put the dashed forms in their path). From the same email you quoted, but just above: > On Thu, 29 Nov 2007, Jeff King wrote: > > > > Yes, I am fine with the user having to go to extra lengths to use the > > dash forms (like adding $(libexecdir) to their path), which I think > > should address your consistency concern. > > I agree. If we actually start moving the subcommands into a separate > directory, I suspect scripts will be fixed up soon enough. Of course > people *can* do it by just adding the path, but more likely, we'll just > see people start doign "git xyz" instead of "git-xyz". But now we are arguing about what Linus meant like it is scripture. ;) -Peff ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 0:58 ` Jeff King @ 2007-11-30 1:13 ` Nicolas Pitre 2007-11-30 1:17 ` Jeff King 2007-11-30 2:29 ` Linus Torvalds 1 sibling, 1 reply; 92+ messages in thread From: Nicolas Pitre @ 2007-11-30 1:13 UTC (permalink / raw) To: Jeff King Cc: Junio C Hamano, Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Thu, 29 Nov 2007, Jeff King wrote: > On Thu, Nov 29, 2007 at 04:49:26PM -0800, Junio C Hamano wrote: > > > I understand your point was primarily "git-a<tab>". I think it has been > > solved for bash and zsh but not for other shells. I think possible and > > sensible avenues are (1) punt -- cvs, svn nor hg people do not seem to > > have problem with it, or (2) implement completion in your other favorite > > shells. > > My point is that (2) is already implemented for every program (shell or > no) which understands filename completion, and there is a proposal for > taking it away. I would consider that, except I haven't see any claimed > advantages except that the hardlinks are awful under Windows. Weren't enough complaints about Git having waaaaaaaaaaay too many commands? Didn't those complaints come about often enough already? $ git-[tab] Display all 135 possibilities? (y or n) Nicolas ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 1:13 ` Nicolas Pitre @ 2007-11-30 1:17 ` Jeff King 2007-11-30 5:42 ` Steffen Prohaska 2007-11-30 7:18 ` Andreas Ericsson 0 siblings, 2 replies; 92+ messages in thread From: Jeff King @ 2007-11-30 1:17 UTC (permalink / raw) To: Nicolas Pitre Cc: Junio C Hamano, Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Thu, Nov 29, 2007 at 08:13:04PM -0500, Nicolas Pitre wrote: > > My point is that (2) is already implemented for every program (shell or > > no) which understands filename completion, and there is a proposal for > > taking it away. I would consider that, except I haven't see any claimed > > advantages except that the hardlinks are awful under Windows. > > Weren't enough complaints about Git having waaaaaaaaaaay too many > commands? Didn't those complaints come about often enough already? > > $ git-[tab] > Display all 135 possibilities? (y or n) Go back and read the thread to which you are responding. I am _not_ arguing against moving those commands to $(libexecdir) where no sane user will ever see them. That change addresses the issue you are talking about. I _am_ arguing against removing them entirely, for those of us who want to go to the trouble of enabling this (by putting a non-standard entry into our PATH). Because the issue you are talking about will already have been dealt with, it is no longer a compelling reason to remove the hardlinks entirely. The only reason I have heard to remove them entirely is that Windows doesn't properly support hardlinks, which I addressed in my other mails (and to which I have seen no rebuttal). -Peff ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 1:17 ` Jeff King @ 2007-11-30 5:42 ` Steffen Prohaska 2007-11-30 7:18 ` Andreas Ericsson 1 sibling, 0 replies; 92+ messages in thread From: Steffen Prohaska @ 2007-11-30 5:42 UTC (permalink / raw) To: Jeff King Cc: Nicolas Pitre, Junio C Hamano, Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Nov 30, 2007, at 2:17 AM, Jeff King wrote: > > The only reason I have heard to remove them entirely is that Windows > doesn't properly support hardlinks, which I addressed in my other > mails > (and to which I have seen no rebuttal). We don't have a problem with hardlinks for git-* commands in msysgit. The msysgit installer already creates hardlinks if installing on NTFS. On non-NTFS partitions, though, it needs to copy the files. Note, this doesn't mean we love hardlinks in msysgit. Actually, msys does _not_ support them in its Unix emulation layer. So, for daily work git does not have hardlinks. For examples, the test script skip all hardlink related tests. The installer handles hardlinks using the Windows API directly and not using the Unix emulation layer. We already have a setup that supports exporting only git and gitk to the a Windows Command Prompt (not the bash that comes with msysgit). If you choose this setup, a directory that contains only these two commands will be added to the system wide PATH. We use this indirection to hide all the the Unix tools that are included in msysgit (and needed by git) from the Windows Command Prompt. Steffen ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 1:17 ` Jeff King 2007-11-30 5:42 ` Steffen Prohaska @ 2007-11-30 7:18 ` Andreas Ericsson 2007-11-30 15:09 ` Jeff King 1 sibling, 1 reply; 92+ messages in thread From: Andreas Ericsson @ 2007-11-30 7:18 UTC (permalink / raw) To: Jeff King Cc: Nicolas Pitre, Junio C Hamano, Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git Jeff King wrote: > On Thu, Nov 29, 2007 at 08:13:04PM -0500, Nicolas Pitre wrote: > >>> My point is that (2) is already implemented for every program (shell or >>> no) which understands filename completion, and there is a proposal for >>> taking it away. I would consider that, except I haven't see any claimed >>> advantages except that the hardlinks are awful under Windows. >> Weren't enough complaints about Git having waaaaaaaaaaay too many >> commands? Didn't those complaints come about often enough already? >> >> $ git-[tab] >> Display all 135 possibilities? (y or n) > > Go back and read the thread to which you are responding. I am _not_ > arguing against moving those commands to $(libexecdir) where no sane > user will ever see them. That change addresses the issue you are talking > about. > > I _am_ arguing against removing them entirely, for those of us who want > to go to the trouble of enabling this (by putting a non-standard entry > into our PATH). Because the issue you are talking about will already > have been dealt with, it is no longer a compelling reason to remove the > hardlinks entirely. > > The only reason I have heard to remove them entirely is that Windows > doesn't properly support hardlinks, which I addressed in my other mails > (and to which I have seen no rebuttal). > It would provide a ui inconsistency between platforms. Several people pointed that out. It's decidedly a Bad Thing. -- Andreas Ericsson andreas.ericsson@op5.se OP5 AB www.op5.se Tel: +46 8-230225 Fax: +46 8-230231 ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 7:18 ` Andreas Ericsson @ 2007-11-30 15:09 ` Jeff King 2007-11-30 20:01 ` Junio C Hamano 0 siblings, 1 reply; 92+ messages in thread From: Jeff King @ 2007-11-30 15:09 UTC (permalink / raw) To: Andreas Ericsson Cc: Nicolas Pitre, Junio C Hamano, Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Fri, Nov 30, 2007 at 08:18:16AM +0100, Andreas Ericsson wrote: >> The only reason I have heard to remove them entirely is that Windows >> doesn't properly support hardlinks, which I addressed in my other mails >> (and to which I have seen no rebuttal). >> > It would provide a ui inconsistency between platforms. Several people > pointed that out. It's decidedly a Bad Thing. Which, as I said, I have already addressed (and which Linus has also expanded upon in this thread). Since those hardlinks would be hidden from users who did not go to some trouble to find them, there will not be inconsistency problems. Scripts will have to either go to some effort to change their PATH, or simply use the correct form, and I expect them to do the latter. -Peff ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 15:09 ` Jeff King @ 2007-11-30 20:01 ` Junio C Hamano 2007-11-30 21:25 ` Jeff King 0 siblings, 1 reply; 92+ messages in thread From: Junio C Hamano @ 2007-11-30 20:01 UTC (permalink / raw) To: Jeff King Cc: Andreas Ericsson, Nicolas Pitre, Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git Jeff King <peff@peff.net> writes: > On Fri, Nov 30, 2007 at 08:18:16AM +0100, Andreas Ericsson wrote: > ... >> It would provide a ui inconsistency between platforms. Several people >> pointed that out. It's decidedly a Bad Thing. > > Which, as I said, I have already addressed (and which Linus has also > expanded upon in this thread). Since those hardlinks would be hidden > from users who did not go to some trouble to find them, there will not > be inconsistency problems. I already can see exchanges in the user community after such a change you propose would happen: Newbie: Ay! why doesn't git-commit work anymore? Jeff: Stupid Junio and Linus decided that you should not use dash form but say "git commit" instead. Newbie: But my fingers are trained and I like the "git-<tab>" completion. Jeff: If you really like that, here is a hidden trick. Add /usr/libexec/git-core/ to your PATH. Newbie: Ah, that worked, thanks. A few days later... Newbie: Jeff, your trick does not work for my coworker. He also has the latest git. His installation does not even have that directory! What gives? Jeff: Ah, sorry, that trick works for some platforms but not others. Newbie: Stupid inconsistency. Who suggested that? ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 20:01 ` Junio C Hamano @ 2007-11-30 21:25 ` Jeff King 2007-11-30 23:10 ` Johannes Schindelin 2007-12-01 2:37 ` Junio C Hamano 0 siblings, 2 replies; 92+ messages in thread From: Jeff King @ 2007-11-30 21:25 UTC (permalink / raw) To: Junio C Hamano Cc: Andreas Ericsson, Nicolas Pitre, Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Fri, Nov 30, 2007 at 12:01:13PM -0800, Junio C Hamano wrote: > I already can see exchanges in the user community after such a change > you propose would happen: > [...] > Jeff: If you really like that, here is a hidden trick. Add > /usr/libexec/git-core/ to your PATH. What if I promise not to tell anyone? :) Anyway, I don't think it will be a problem. You think it might. But I suspect neither of us has anything more than a gut feeling to argue with. And now I have registered my complaint, so you can do what you think is best. I can, of course, always make my own hardlinks (which is really the same thing, except the "trick" is slightly harder to perform and perhaps less socially acceptable; OTOH, if such a trick is common, perhaps it means taking away the dash forms wasn't such a good idea after all). > Newbie: Stupid inconsistency. Who suggested that? Jeff [runs git-blame]: It must have been Junio! :) -Peff ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 21:25 ` Jeff King @ 2007-11-30 23:10 ` Johannes Schindelin 2007-12-02 15:02 ` Wincent Colaiuta 2007-12-01 2:37 ` Junio C Hamano 1 sibling, 1 reply; 92+ messages in thread From: Johannes Schindelin @ 2007-11-30 23:10 UTC (permalink / raw) To: Jeff King Cc: Junio C Hamano, Andreas Ericsson, Nicolas Pitre, Linus Torvalds, Nguyen Thai Ngoc Duy, Jan Hudec, git Hi, On Fri, 30 Nov 2007, Jeff King wrote: > On Fri, Nov 30, 2007 at 12:01:13PM -0800, Junio C Hamano wrote: > > > I already can see exchanges in the user community after such a change > > you propose would happen: > > [...] > > Jeff: If you really like that, here is a hidden trick. Add > > /usr/libexec/git-core/ to your PATH. > > What if I promise not to tell anyone? :) By the same reasoning you can invade an unsuspecting country, saying that everybody will be better off afterwards. But the risk is high, not because of the probability, but because of the cost to pay if it does not work out. Really, I'd rather have this be done right. So I am quite happy with Junio being "girly" (which I would have called cautious and nice-to-users, as well as considerate, though). In the end I would be so much happier not to have hard links at all, and it seems that all the "easy" SCMs out there are quite well off without hard links, too. To me, it is mighty annoying anybody brings up that "144 commands" argument Linus was referring to, and if there is _any_ way to shut up those bikeshedders, I am all for it. But if that is not possible, so be it. Ciao, Dscho ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 23:10 ` Johannes Schindelin @ 2007-12-02 15:02 ` Wincent Colaiuta 2007-12-02 16:39 ` Johannes Schindelin 0 siblings, 1 reply; 92+ messages in thread From: Wincent Colaiuta @ 2007-12-02 15:02 UTC (permalink / raw) To: Johannes Schindelin Cc: Jeff King, Junio C Hamano, Andreas Ericsson, Nicolas Pitre, Linus Torvalds, Nguyen Thai Ngoc Duy, Jan Hudec, git El 1/12/2007, a las 0:10, Johannes Schindelin escribió: > To me, it is mighty annoying anybody brings up that "144 commands" > argument Linus was referring to, and if there is _any_ way to shut up > those bikeshedders, I am all for it. This is not a bikeshed argument and it is not an "idiotic complaint" (to use Linus' phrase). It is a legitimate concern and a *real* UI problem. You and Linus don't care that there are 140+ Git commands and I imagine that you know exactly what each of them does. I don't really care either because although I don't know what every single command does, I know what the 20 or 30 commands I personally need for my own workflow do. The problem is for *newcomers* to Git who sit down for the first time and ask themselves, "Now, how do I...?". This is not an idiotic complaint but a legitimate concern about a real UI problem. Honestly, Johannes, do you think the following is a good UI? $ git Display all 148 possibilities? (y or n) git* git-cvsimport* git-local- fetch* git-peek-remote* git-show-index* git-add* git-cvsserver* git- log* git-prune* git-show-ref* git-add--interactive* git-daemon* git-lost- found* git-prune-packed* git-ssh-fetch* git-am* git-describe* git-ls- files* git-pull* git-ssh-pull* git-annotate* git-diff* git-ls- remote* git-push* git-ssh-push* git-apply* git-diff-files* git-ls- tree* git-quiltimport* git-ssh-upload* git-applymbox git-diff-index* git- mailinfo* git-read-tree* git-stash* git-applypatch git-diff-tree* git- mailsplit* git-rebase* git-status* git-archimport* git-fast-import* git- merge* git-rebase--interactive* git-stripspace* git-archive* git-fetch* git-merge- base* git-receive-pack* git-submodule* git-bisect* git-fetch--tool* git-merge- file* git-reflog* git-svn* git-blame* git-fetch-pack* git-merge- index* git-relink* git-svnimport git-branch* git-filter-branch* git-merge- octopus* git-remote* git-symbolic-ref* git-bundle* git-fmt-merge-msg* git-merge-one- file* git-repack* git-tag* git-cat-file* git-for-each-ref* git-merge- ours* git-repo-config* git-tar-tree* git-check-attr* git-format-patch* git-merge- recursive* git-request-pull* git-unpack-file* git-check-ref-format* git-fsck* git-merge- resolve* git-rerere* git-unpack-objects* git-checkout* git-fsck-objects* git-merge- stupid* git-reset* git-update-index* git-checkout-index* git-gc* git-merge- subtree* git-rev-list* git-update-ref* git-cherry* git-get-tar-commit-id* git-merge- tree* git-rev-parse* git-update-server-info* git-cherry-pick* git-grep* git- mergetool* git-revert* git-upload-archive* git-citool git-gui/ git- mktag* git-rm* git-upload-pack* git-clean* git-hash-object* git- mktree* git-runstatus* git-var* git-clone* git-http-fetch* git- mv* git-send-email* git-verify-pack* git-commit* git-http-push* git-name- rev* git-send-pack* git-verify-tag* git-commit-tree* git-imap-send* git-pack- objects* git-sh-setup* git-whatchanged* git-config* git-index-pack* git-pack- redundant* git-shell* git-write-tree* git-convert-objects git-init* git-pack- refs* git-shortlog* gitk git-count-objects* git-init-db* git-parse- remote* git-show* git-cvsexportcommit* git-instaweb* git-patch- id* git-show-branch* Would you argue that this screenshot shows a sane UI? <http://wincent.com/tmp/git-ui.png> Note: I am not complaining about the *number* of commands; I myself find them highly useful for scripting. I am saying that the *visibility* of those commands is the problem. That's why I support the efforts to move most of this stuff out of the default PATH. We're not talking about getting rid of it, just about putting it somewhere more appropriate in order to correct what is basically a *hideous* user interface for the beginner. Cheers, Wincent ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-12-02 15:02 ` Wincent Colaiuta @ 2007-12-02 16:39 ` Johannes Schindelin 2007-12-02 16:56 ` Pascal Obry 0 siblings, 1 reply; 92+ messages in thread From: Johannes Schindelin @ 2007-12-02 16:39 UTC (permalink / raw) To: Wincent Colaiuta Cc: Jeff King, Junio C Hamano, Andreas Ericsson, Nicolas Pitre, Linus Torvalds, Nguyen Thai Ngoc Duy, Jan Hudec, git Hi, On Sun, 2 Dec 2007, Wincent Colaiuta wrote: > El 1/12/2007, a las 0:10, Johannes Schindelin escribi?: > > > To me, it is mighty annoying anybody brings up that "144 commands" > > argument Linus was referring to, and if there is _any_ way to shut up > > those bikeshedders, I am all for it. > > This is not a bikeshed argument and it is not an "idiotic complaint" (to > use Linus' phrase). It is a legitimate concern and a *real* UI problem. > > You and Linus don't care that there are 140+ Git commands and I imagine > that you know exactly what each of them does. Okay, how many executables are there in your /usr/bin/? Here there are 2973. Guess what. I am not intimidated by that number. Ciao, Dscho ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-12-02 16:39 ` Johannes Schindelin @ 2007-12-02 16:56 ` Pascal Obry 2007-12-02 17:23 ` Johannes Schindelin 0 siblings, 1 reply; 92+ messages in thread From: Pascal Obry @ 2007-12-02 16:56 UTC (permalink / raw) To: Johannes Schindelin Cc: Wincent Colaiuta, Jeff King, Junio C Hamano, Andreas Ericsson, Nicolas Pitre, Linus Torvalds, Nguyen Thai Ngoc Duy, Jan Hudec, git Johannes Schindelin a écrit : > Okay, how many executables are there in your /usr/bin/? Here there are > 2973. > Guess what. I am not intimidated by that number. Good, and look in /usr/bin, all those 2973 binary are all disconnected. Here we are speaking about a tool as a whole : Git. And I agree that hiding some of them will probably help new comers. We can also argue that a new comers should read some documentation :) After all I'm not sure what's the right move ! At least let me say something constructive :) I'm a new comer to Git. I've read many documentations before grabbing the system and I've not been impressed by the number of binaries in /usr/bin... Because I've almost never looked there. Most of the time I'm using "git <tab>" and the bash completion feature is just right for me. Pascal. -- --|------------------------------------------------------ --| Pascal Obry Team-Ada Member --| 45, rue Gabriel Peri - 78114 Magny Les Hameaux FRANCE --|------------------------------------------------------ --| http://www.obry.net --| "The best way to travel is by means of imagination" --| --| gpg --keyserver wwwkeys.pgp.net --recv-key C1082595 ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-12-02 16:56 ` Pascal Obry @ 2007-12-02 17:23 ` Johannes Schindelin 0 siblings, 0 replies; 92+ messages in thread From: Johannes Schindelin @ 2007-12-02 17:23 UTC (permalink / raw) To: Pascal Obry Cc: Wincent Colaiuta, Jeff King, Junio C Hamano, Andreas Ericsson, Nicolas Pitre, Linus Torvalds, Nguyen Thai Ngoc Duy, Jan Hudec, git Hi, On Sun, 2 Dec 2007, Pascal Obry wrote: > Johannes Schindelin a ?crit : > > Okay, how many executables are there in your /usr/bin/? Here there > > are 2973. Guess what. I am not intimidated by that number. > > Good, and look in /usr/bin, all those 2973 binary are all disconnected. > > Here we are speaking about a tool as a whole : Git. No, we are speaking about different commands, such as commit, fetch, push, etc. I refuse to believe that you cannot see the equivalence. > I've read many documentations before grabbing the system and I've not > been impressed by the number of binaries in /usr/bin... Because I've > almost never looked there. Exactly my point. > Most of the time I'm using "git <tab>" and the bash completion feature > is just right for me. Bash completion is really something fine. But even without, I do not see a problem: many cvs users used only three out of 32 commands (most CVS users I personally know/knew only called add, commit and update). You could even see all 32 commands when calling the clunky command line "cvs --help-commands". I am convinced we're already more user-friendly than that. Ciao, Dscho ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 21:25 ` Jeff King 2007-11-30 23:10 ` Johannes Schindelin @ 2007-12-01 2:37 ` Junio C Hamano 2007-12-01 4:17 ` Jeff King 1 sibling, 1 reply; 92+ messages in thread From: Junio C Hamano @ 2007-12-01 2:37 UTC (permalink / raw) To: Jeff King Cc: Andreas Ericsson, Nicolas Pitre, Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git Jeff King <peff@peff.net> writes: > I can, of course, always make my own hardlinks (which is really the same > thing, except the "trick" is slightly harder to perform and perhaps less > socially acceptable; OTOH, if such a trick is common, perhaps it means > taking away the dash forms wasn't such a good idea after all). > >> Newbie: Stupid inconsistency. Who suggested that? > > Jeff [runs git-blame]: It must have been Junio! :) You found a bug in git-blame, then ;-). I think it should report Jeff. As Windows ports need to have their own difference _anyway_, I personally do not think it is a big deal if the Makefile I ship continues to install the dashed form in gitexecdir, and Windows ports omit the hardlinks if they feel copies are wasteful. However, that would introduce hard-to-track platform dependent bugs (e.g. "git-receive-pack" is asked for by "git-send-pack", but the other side does not have such a program anywhere). So my preference at this point is to move things out of PATH first (without removing the hardlinks), deal with possible fallout from that move. And after things stablize, discuss to either remove the hardlinks from all installations, or to keep them in all installations. I do not think "it's this way here but that way there" is a good thing in general. We do have "git-foo.exe" vs "git-foo" difference and there are some existing code (most notably, help.c::list_commands_in_dir()) that need to be aware of it. Let's try not to make things any worse. ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-12-01 2:37 ` Junio C Hamano @ 2007-12-01 4:17 ` Jeff King 0 siblings, 0 replies; 92+ messages in thread From: Jeff King @ 2007-12-01 4:17 UTC (permalink / raw) To: Junio C Hamano Cc: Andreas Ericsson, Nicolas Pitre, Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Fri, Nov 30, 2007 at 06:37:12PM -0800, Junio C Hamano wrote: > side does not have such a program anywhere). So my preference at this > point is to move things out of PATH first (without removing the > hardlinks), deal with possible fallout from that move. > > And after things stablize, discuss to either remove the hardlinks from > all installations, or to keep them in all installations. I do not think > "it's this way here but that way there" is a good thing in general. I think that it is a sensible course of action. -Peff ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 0:58 ` Jeff King 2007-11-30 1:13 ` Nicolas Pitre @ 2007-11-30 2:29 ` Linus Torvalds 2007-11-30 2:55 ` Nicolas Pitre 2007-11-30 5:51 ` Steffen Prohaska 1 sibling, 2 replies; 92+ messages in thread From: Linus Torvalds @ 2007-11-30 2:29 UTC (permalink / raw) To: Jeff King Cc: Junio C Hamano, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Thu, 29 Nov 2007, Jeff King wrote: > > I thought Linus' point was that moving the subcommands was sufficient > for dealing with the consistency issue (i.e., all scripts would move to > "git foo" and only those people who really wanted to would put the > dashed forms in their path). Yes. I meant that we might as well keep all the git-xyz forms around, but _only_ in the libexec directory (and make sure that the libexec directory by default is *not* a binary directory), so that they'd normally not be visible. So then, people who want to use the old-fashioned git-xyz forms, because they just really hate white-space or whatever, could choose to do one of two things: - either just change the default libexec directory to be the same as the binary install directory, and have all the git-xyz things in the same place they've always been. - or just add $(gitlibexec) into their path. but the default (which is what 99% of all people use) would be to not show them. I also think that it makes sense to avoid wasting diskspace with duplicate files, so in situations where you don't have hardlinks, just don't install the git-xyz files at all by default (and again, maybe we can have a option to the installer to do it for people who really are very attached to the git-xyz format, and prefer to waste even a lot of disk on it) So I just think that the whole idiotic complaint that some people have (that whole "git-<tab><tab>" shows "Display all 144 possibilities?" and people are somehow using that as an argument that git is "complex") should be something we strive to undo. I think the complaint is insane (because the answer is "well, nobody forces you to _use_ all the power and scripts we give you!"), but still, it's a complaint, so let's just assume the user is right, and try to fix it. So when you do "git-<tab><tab>" it should just beep at you and not show anything at all by default. And when you do "git <tab><tab>", we should make sure that the bash expansion (or zsh or whatever) shows a nice collection of common plumbing, not soemthing really scary. Linus ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 2:29 ` Linus Torvalds @ 2007-11-30 2:55 ` Nicolas Pitre 2007-11-30 5:51 ` Steffen Prohaska 1 sibling, 0 replies; 92+ messages in thread From: Nicolas Pitre @ 2007-11-30 2:55 UTC (permalink / raw) To: Linus Torvalds Cc: Jeff King, Junio C Hamano, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Thu, 29 Nov 2007, Linus Torvalds wrote: > Yes. I meant that we might as well keep all the git-xyz forms around, but > _only_ in the libexec directory (and make sure that the libexec directory > by default is *not* a binary directory), so that they'd normally not be > visible. > > So then, people who want to use the old-fashioned git-xyz forms, because > they just really hate white-space or whatever, could choose to do one of > two things: > - either just change the default libexec directory to be the same as the > binary install directory, and have all the git-xyz things in the same > place they've always been. > - or just add $(gitlibexec) into their path. > > but the default (which is what 99% of all people use) would be to not > show them. I also think that it makes sense to avoid wasting diskspace > with duplicate files, so in situations where you don't have hardlinks, > just don't install the git-xyz files at all by default (and again, maybe > we can have a option to the installer to do it for people who really are > very attached to the git-xyz format, and prefer to waste even a lot of > disk on it) > > So I just think that the whole idiotic complaint that some people have > (that whole "git-<tab><tab>" shows "Display all 144 possibilities?" and > people are somehow using that as an argument that git is "complex") should > be something we strive to undo. I think the complaint is insane (because > the answer is "well, nobody forces you to _use_ all the power and scripts > we give you!"), but still, it's a complaint, so let's just assume the user > is right, and try to fix it. Absolutely! And despite Junio's appearance of some cowardliness on this issue :-) I think we should have this right now instead of later. Like Junio said himself, this was planned for a while already, and poorly maintained external scripts are already failing due to other reasons anyway. Nicolas ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 2:29 ` Linus Torvalds 2007-11-30 2:55 ` Nicolas Pitre @ 2007-11-30 5:51 ` Steffen Prohaska 2007-11-30 15:12 ` Jeff King 1 sibling, 1 reply; 92+ messages in thread From: Steffen Prohaska @ 2007-11-30 5:51 UTC (permalink / raw) To: Linus Torvalds Cc: Jeff King, Junio C Hamano, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Nov 30, 2007, at 3:29 AM, Linus Torvalds wrote: > So I just think that the whole idiotic complaint that some people have > (that whole "git-<tab><tab>" shows "Display all 144 possibilities?" > and > people are somehow using that as an argument that git is "complex") > should > be something we strive to undo. I think the complaint is insane > (because > the answer is "well, nobody forces you to _use_ all the power and > scripts > we give you!"), but still, it's a complaint, so let's just assume > the user > is right, and try to fix it. > > So when you do "git-<tab><tab>" it should just beep at you and not > show > anything at all by default. And when you do "git <tab><tab>", we > should > make sure that the bash expansion (or zsh or whatever) shows a nice > collection of common plumbing, not soemthing really scary. What will happen to gitk? Shouldn't it be included in the nice collection? gitk is an essential command. Then, following your reasoning, "git <tab><tab>" should recommend it, no? Note, "git gui" already works. gitk would really be the last git "command" that can't be accessed through "git <command>" Steffen ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 5:51 ` Steffen Prohaska @ 2007-11-30 15:12 ` Jeff King 2007-11-30 15:28 ` Santi Béjar 0 siblings, 1 reply; 92+ messages in thread From: Jeff King @ 2007-11-30 15:12 UTC (permalink / raw) To: Steffen Prohaska Cc: Linus Torvalds, Junio C Hamano, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Fri, Nov 30, 2007 at 06:51:35AM +0100, Steffen Prohaska wrote: > What will happen to gitk? > > Shouldn't it be included in the nice collection? gitk is > an essential command. Then, following your reasoning, > "git <tab><tab>" should recommend it, no? > > Note, "git gui" already works. gitk would really be the last > git "command" that can't be accessed through "git <command>" Except for qgit, tig, etc. The only difference being that gitk actually ships with git. But I am not opposed to having some "git foo" form for gitk. -Peff ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 15:12 ` Jeff King @ 2007-11-30 15:28 ` Santi Béjar 2007-11-30 15:29 ` Jeff King 0 siblings, 1 reply; 92+ messages in thread From: Santi Béjar @ 2007-11-30 15:28 UTC (permalink / raw) To: Jeff King Cc: Steffen Prohaska, Linus Torvalds, Junio C Hamano, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Nov 30, 2007 4:12 PM, Jeff King <peff@peff.net> wrote: > On Fri, Nov 30, 2007 at 06:51:35AM +0100, Steffen Prohaska wrote: > > > What will happen to gitk? > > > > Shouldn't it be included in the nice collection? gitk is > > an essential command. Then, following your reasoning, > > "git <tab><tab>" should recommend it, no? > > > > Note, "git gui" already works. gitk would really be the last > > git "command" that can't be accessed through "git <command>" > > Except for qgit, tig, etc. The only difference being that gitk actually > ships with git. > > But I am not opposed to having some "git foo" form for gitk. In mercurial "hg view" is actually an old version of gitk modified for hg. And as "git view" it could be added to the "git help" list. Santi ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 15:28 ` Santi Béjar @ 2007-11-30 15:29 ` Jeff King 2007-11-30 15:50 ` Linus Torvalds 0 siblings, 1 reply; 92+ messages in thread From: Jeff King @ 2007-11-30 15:29 UTC (permalink / raw) To: Santi Béjar Cc: Steffen Prohaska, Linus Torvalds, Junio C Hamano, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Fri, Nov 30, 2007 at 04:28:21PM +0100, Santi Béjar wrote: > > But I am not opposed to having some "git foo" form for gitk. > > In mercurial "hg view" is actually an old version of gitk modified for hg. > > And as "git view" it could be added to the "git help" list. Unfortunately, there is already a "gitview" program similar to gitk, although it never made it out of contrib/. -Peff ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 15:29 ` Jeff King @ 2007-11-30 15:50 ` Linus Torvalds 2007-11-30 16:22 ` Jeff King [not found] ` <fcaeb9bf0711302234l32460a1fqbf9825fc8055f99d@mail.gmail.com> 0 siblings, 2 replies; 92+ messages in thread From: Linus Torvalds @ 2007-11-30 15:50 UTC (permalink / raw) To: Jeff King Cc: Santi B?jar, Steffen Prohaska, Junio C Hamano, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Fri, 30 Nov 2007, Jeff King wrote: > > On Fri, Nov 30, 2007 at 04:28:21PM +0100, Santi Béjar wrote: > > > But I am not opposed to having some "git foo" form for gitk. > > > > In mercurial "hg view" is actually an old version of gitk modified for hg. > > > > And as "git view" it could be added to the "git help" list. > > Unfortunately, there is already a "gitview" program similar to gitk, > although it never made it out of contrib/. Well, different people will want different viewers *anyway* (ie some will prefer qgit etc), so how about making "git view" be something that literally acts as a built-in alias that just defaults to running gitk (if for no other reason than the fact that gitk is the one that ships with git, and simply has most users). There's a few other things that I think we could consider to be good built-in aliases: things like "git cat" being an alias for "git -p cat-file -p" etc. The only difference between a "built-in alias" and a "built-in command" would be: - the alias has never even had the "git-xyz" format, and never will - the alias can be overridden by user aliases unlike "real" git commands Hmm? That way we can hide away gitk too (although I do suspect that we might as well just leave gitk in the path - it's different in naming from all the git-xyz commands anyway) Linus ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 15:50 ` Linus Torvalds @ 2007-11-30 16:22 ` Jeff King 2007-11-30 18:28 ` Johannes Schindelin [not found] ` <fcaeb9bf0711302234l32460a1fqbf9825fc8055f99d@mail.gmail.com> 1 sibling, 1 reply; 92+ messages in thread From: Jeff King @ 2007-11-30 16:22 UTC (permalink / raw) To: Linus Torvalds Cc: Santi B?jar, Steffen Prohaska, Junio C Hamano, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Fri, Nov 30, 2007 at 07:50:47AM -0800, Linus Torvalds wrote: > Well, different people will want different viewers *anyway* (ie some will > prefer qgit etc), so how about making "git view" be something that > literally acts as a built-in alias that just defaults to running gitk (if > for no other reason than the fact that gitk is the one that ships with > git, and simply has most users). I think that is a good idea, and here's a patch. -- >8 -- Support builtin aliases Builtin aliases are "default" alias values that can be overridden by user-configured aliases. For example, the first such alias is "view", an alias for gitk. A user with no further configuration can run "git view" to use gitk. However, they can also set the config option "alias.view" to "!tig" to run tig. --- git.c | 9 +++++++++ 1 files changed, 9 insertions(+), 0 deletions(-) diff --git a/git.c b/git.c index f220284..95296aa 100644 --- a/git.c +++ b/git.c @@ -151,6 +151,13 @@ static int split_cmdline(char *cmdline, const char ***argv) return count; } +static char *builtin_alias(const char *cmd) +{ + if (!strcmp(cmd, "view")) + return xstrdup("!gitk"); + return NULL; +} + static int handle_alias(int *argcp, const char ***argv) { int nongit = 0, envchanged = 0, ret = 0, saved_errno = errno; @@ -162,6 +169,8 @@ static int handle_alias(int *argcp, const char ***argv) alias_command = (*argv)[0]; git_config(git_alias_config); + if (!alias_string) + alias_string = builtin_alias(alias_command); if (alias_string) { if (alias_string[0] == '!') { if (*argcp > 1) { -- 1.5.3.6.2064.g2e22f-dirty ^ permalink raw reply related [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 16:22 ` Jeff King @ 2007-11-30 18:28 ` Johannes Schindelin 2007-11-30 18:37 ` Jeff King 0 siblings, 1 reply; 92+ messages in thread From: Johannes Schindelin @ 2007-11-30 18:28 UTC (permalink / raw) To: Jeff King Cc: Linus Torvalds, Santi B?jar, Steffen Prohaska, Junio C Hamano, Nguyen Thai Ngoc Duy, Jan Hudec, git Hi, On Fri, 30 Nov 2007, Jeff King wrote: > Support builtin aliases > > Builtin aliases are "default" alias values that can be > overridden by user-configured aliases. > > For example, the first such alias is "view", an alias for > gitk. A user with no further configuration can run > "git view" to use gitk. However, they can also set the > config option "alias.view" to "!tig" to run tig. > --- > git.c | 9 +++++++++ > 1 files changed, 9 insertions(+), 0 deletions(-) > > diff --git a/git.c b/git.c > index f220284..95296aa 100644 > --- a/git.c > +++ b/git.c > @@ -151,6 +151,13 @@ static int split_cmdline(char *cmdline, const char ***argv) > return count; > } > > +static char *builtin_alias(const char *cmd) > +{ > + if (!strcmp(cmd, "view")) > + return xstrdup("!gitk"); > + return NULL; > +} > + > static int handle_alias(int *argcp, const char ***argv) > { > int nongit = 0, envchanged = 0, ret = 0, saved_errno = errno; > @@ -162,6 +169,8 @@ static int handle_alias(int *argcp, const char ***argv) > > alias_command = (*argv)[0]; > git_config(git_alias_config); > + if (!alias_string) > + alias_string = builtin_alias(alias_command); > if (alias_string) { > if (alias_string[0] == '!') { > if (*argcp > 1) { Didn't you mean to put this _before_ the git_config() call? As you wrote it, the "soft" alias overrides the user-specified one. Ciao, Dscho ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 18:28 ` Johannes Schindelin @ 2007-11-30 18:37 ` Jeff King 2007-11-30 23:05 ` Johannes Schindelin 0 siblings, 1 reply; 92+ messages in thread From: Jeff King @ 2007-11-30 18:37 UTC (permalink / raw) To: Johannes Schindelin Cc: Linus Torvalds, Santi B?jar, Steffen Prohaska, Junio C Hamano, Nguyen Thai Ngoc Duy, Jan Hudec, git On Fri, Nov 30, 2007 at 06:28:50PM +0000, Johannes Schindelin wrote: > > @@ -162,6 +169,8 @@ static int handle_alias(int *argcp, const char ***argv) > > > > alias_command = (*argv)[0]; > > git_config(git_alias_config); > > + if (!alias_string) > > + alias_string = builtin_alias(alias_command); > > if (alias_string) { > > if (alias_string[0] == '!') { > > if (*argcp > 1) { > > Didn't you mean to put this _before_ the git_config() call? As you wrote > it, the "soft" alias overrides the user-specified one. No. The "if (!alias_string)" means we only do the lookup if no user alias was found. Try it. -Peff ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 18:37 ` Jeff King @ 2007-11-30 23:05 ` Johannes Schindelin 2007-11-30 23:21 ` Jeff King 0 siblings, 1 reply; 92+ messages in thread From: Johannes Schindelin @ 2007-11-30 23:05 UTC (permalink / raw) To: Jeff King Cc: Linus Torvalds, Santi B?jar, Steffen Prohaska, Junio C Hamano, Nguyen Thai Ngoc Duy, Jan Hudec, git Hi, On Fri, 30 Nov 2007, Jeff King wrote: > On Fri, Nov 30, 2007 at 06:28:50PM +0000, Johannes Schindelin wrote: > > > > @@ -162,6 +169,8 @@ static int handle_alias(int *argcp, const char ***argv) > > > > > > alias_command = (*argv)[0]; > > > git_config(git_alias_config); > > > + if (!alias_string) > > > + alias_string = builtin_alias(alias_command); > > > if (alias_string) { > > > if (alias_string[0] == '!') { > > > if (*argcp > 1) { > > > > Didn't you mean to put this _before_ the git_config() call? As you wrote > > it, the "soft" alias overrides the user-specified one. > > No. The "if (!alias_string)" means we only do the lookup if no user > alias was found. Try it. Ah. To me, that was rather easy to miss, though... Ciao, Dscho ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 23:05 ` Johannes Schindelin @ 2007-11-30 23:21 ` Jeff King 2007-11-30 23:38 ` Johannes Schindelin 0 siblings, 1 reply; 92+ messages in thread From: Jeff King @ 2007-11-30 23:21 UTC (permalink / raw) To: Johannes Schindelin Cc: Linus Torvalds, Santi B?jar, Steffen Prohaska, Junio C Hamano, Nguyen Thai Ngoc Duy, Jan Hudec, git On Fri, Nov 30, 2007 at 11:05:50PM +0000, Johannes Schindelin wrote: > > > > alias_command = (*argv)[0]; > > > > git_config(git_alias_config); > > > > + if (!alias_string) > > > > + alias_string = builtin_alias(alias_command); > > > > if (alias_string) { > > > > if (alias_string[0] == '!') { > > > > if (*argcp > 1) { > > > > > > Didn't you mean to put this _before_ the git_config() call? As you wrote > > > it, the "soft" alias overrides the user-specified one. > > > > No. The "if (!alias_string)" means we only do the lookup if no user > > alias was found. Try it. > > Ah. To me, that was rather easy to miss, though... I don't particularly care if it is re-written as: alias_string = builtin_alias(alias_command); git_config(git_alias_config); which should be equivalent. I wrote it the original way to avoid doing the O(n) search through builtin aliases when it was unnecessary, but obviously this isn't a performance critical code path. -Peff ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 23:21 ` Jeff King @ 2007-11-30 23:38 ` Johannes Schindelin 0 siblings, 0 replies; 92+ messages in thread From: Johannes Schindelin @ 2007-11-30 23:38 UTC (permalink / raw) To: Jeff King Cc: Linus Torvalds, Santi B?jar, Steffen Prohaska, Junio C Hamano, Nguyen Thai Ngoc Duy, Jan Hudec, git Hi, On Fri, 30 Nov 2007, Jeff King wrote: > On Fri, Nov 30, 2007 at 11:05:50PM +0000, Johannes Schindelin wrote: > > > > > > alias_command = (*argv)[0]; > > > > > git_config(git_alias_config); > > > > > + if (!alias_string) > > > > > + alias_string = builtin_alias(alias_command); > > > > > if (alias_string) { > > > > > if (alias_string[0] == '!') { > > > > > if (*argcp > 1) { > > > > > > > > Didn't you mean to put this _before_ the git_config() call? As you wrote > > > > it, the "soft" alias overrides the user-specified one. > > > > > > No. The "if (!alias_string)" means we only do the lookup if no user > > > alias was found. Try it. > > > > Ah. To me, that was rather easy to miss, though... > > I don't particularly care if it is re-written as: > > alias_string = builtin_alias(alias_command); > git_config(git_alias_config); > > which should be equivalent. I wrote it the original way to avoid doing > the O(n) search through builtin aliases when it was unnecessary, but > obviously this isn't a performance critical code path. Actually, I felt/feel quite dumb missing it. Ciao, Dscho ^ permalink raw reply [flat|nested] 92+ messages in thread
[parent not found: <fcaeb9bf0711302234l32460a1fqbf9825fc8055f99d@mail.gmail.com>]
* Re: [PATCH] Move all dashed form git commands to libexecdir [not found] ` <fcaeb9bf0711302234l32460a1fqbf9825fc8055f99d@mail.gmail.com> @ 2007-12-01 19:32 ` Junio C Hamano 2007-12-01 21:26 ` Jeff King 2007-12-02 5:50 ` Nguyen Thai Ngoc Duy 0 siblings, 2 replies; 92+ messages in thread From: Junio C Hamano @ 2007-12-01 19:32 UTC (permalink / raw) To: Nguyen Thai Ngoc Duy Cc: Linus Torvalds, Jeff King, Santi B?jar, Steffen Prohaska, Junio C Hamano, Johannes Schindelin, Jan Hudec, git "Nguyen Thai Ngoc Duy" <pclouds@gmail.com> writes: > On Nov 30, 2007 10:50 PM, Linus Torvalds <torvalds@linux-foundation.org> wrote: > >> Well, different people will want different viewers *anyway* (ie some will >> prefer qgit etc), so how about making "git view" be something that >> literally acts as a built-in alias that just defaults to running gitk (if >> for no other reason than the fact that gitk is the one that ships with >> git, and simply has most users). > > We already have "git show", now we gonna get "git view", git trainers > may have hard time explaining this one shows you a particular object > while the other one shows you history. How about "git lshistory" (from > clearcase land) or git show --history? Heh, we have "bisect visualize". How about "git visualize"? ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-12-01 19:32 ` Junio C Hamano @ 2007-12-01 21:26 ` Jeff King 2007-12-02 5:50 ` Nguyen Thai Ngoc Duy 1 sibling, 0 replies; 92+ messages in thread From: Jeff King @ 2007-12-01 21:26 UTC (permalink / raw) To: Junio C Hamano Cc: Nguyen Thai Ngoc Duy, Linus Torvalds, Santi B?jar, Steffen Prohaska, Johannes Schindelin, Jan Hudec, git On Sat, Dec 01, 2007 at 11:32:27AM -0800, Junio C Hamano wrote: > > We already have "git show", now we gonna get "git view", git trainers > > may have hard time explaining this one shows you a particular object > > while the other one shows you history. How about "git lshistory" (from > > clearcase land) or git show --history? > > Heh, we have "bisect visualize". How about "git visualize"? Yes, in retrospect "view" is probably not the best. "lshistory" just looks awful, and I think it's wrong for an option to "git show" to change it from a terminal application into a GUI application. "visualize" is actually pretty good, except that it would be painful to type. On the other hand, I will probably still just type "gitk". I actually think these sorts of aliases may be most useful for user-facing scripts to say "and now show the dataset in the user's graphical history browser of choice." -Peff ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-12-01 19:32 ` Junio C Hamano 2007-12-01 21:26 ` Jeff King @ 2007-12-02 5:50 ` Nguyen Thai Ngoc Duy 1 sibling, 0 replies; 92+ messages in thread From: Nguyen Thai Ngoc Duy @ 2007-12-02 5:50 UTC (permalink / raw) To: Junio C Hamano Cc: Linus Torvalds, Jeff King, Santi B?jar, Steffen Prohaska, Johannes Schindelin, Jan Hudec, git On Dec 2, 2007 2:32 AM, Junio C Hamano <gitster@pobox.com> wrote: > "Nguyen Thai Ngoc Duy" <pclouds@gmail.com> writes: > > > On Nov 30, 2007 10:50 PM, Linus Torvalds <torvalds@linux-foundation.org> wrote: > > > >> Well, different people will want different viewers *anyway* (ie some will > >> prefer qgit etc), so how about making "git view" be something that > >> literally acts as a built-in alias that just defaults to running gitk (if > >> for no other reason than the fact that gitk is the one that ships with > >> git, and simply has most users). > > > > We already have "git show", now we gonna get "git view", git trainers > > may have hard time explaining this one shows you a particular object > > while the other one shows you history. How about "git lshistory" (from > > clearcase land) or git show --history? > > Heh, we have "bisect visualize". How about "git visualize"? > "git visualize"++ -- Duy ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 0:35 ` Jeff King 2007-11-30 0:49 ` Junio C Hamano @ 2007-11-30 0:52 ` Nicolas Pitre 2007-11-30 1:00 ` Jeff King 1 sibling, 1 reply; 92+ messages in thread From: Nicolas Pitre @ 2007-11-30 0:52 UTC (permalink / raw) To: Jeff King Cc: Junio C Hamano, Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Thu, 29 Nov 2007, Jeff King wrote: > On Thu, Nov 29, 2007 at 04:13:29PM -0800, Junio C Hamano wrote: > > > - Post v1.5.5, start cooking the change that does not install hardlinks > > for built-in commands, aiming for inclusion in v1.5.6, in May-Jun > > 2008 timeframe. > > I am still against this step, for the reasons mentioned in the mails > leading up to the one you just quoted. I am fine with "does not install > hardlinks for builtin-commands on systems that don't support hardlinks" > (and of course all such hardlinks are in $(libexecdir)/git-core at this > point). But only for porcelain, right? You certainly don't need the dashed form of plumbing commands? Nicolas ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 0:52 ` Nicolas Pitre @ 2007-11-30 1:00 ` Jeff King 2007-11-30 1:19 ` Nicolas Pitre 0 siblings, 1 reply; 92+ messages in thread From: Jeff King @ 2007-11-30 1:00 UTC (permalink / raw) To: Nicolas Pitre Cc: Junio C Hamano, Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Thu, Nov 29, 2007 at 07:52:01PM -0500, Nicolas Pitre wrote: > > I am still against this step, for the reasons mentioned in the mails > > leading up to the one you just quoted. I am fine with "does not install > > hardlinks for builtin-commands on systems that don't support hardlinks" > > (and of course all such hardlinks are in $(libexecdir)/git-core at this > > point). > > But only for porcelain, right? You certainly don't need the dashed form > of plumbing commands? In principle, yes, though one man's porcelain is another man's plumbing, so determining the correct set is hard (and why bother if they are all hidden from mere mortals, anyway?). Perhaps because I am actively working on git, I tend to use a fair number of plumbing commands for under-the-hood inspection and experimentation. -Peff ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 1:00 ` Jeff King @ 2007-11-30 1:19 ` Nicolas Pitre 2007-11-30 1:25 ` Jeff King 0 siblings, 1 reply; 92+ messages in thread From: Nicolas Pitre @ 2007-11-30 1:19 UTC (permalink / raw) To: Jeff King Cc: Junio C Hamano, Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Thu, 29 Nov 2007, Jeff King wrote: > On Thu, Nov 29, 2007 at 07:52:01PM -0500, Nicolas Pitre wrote: > > > > I am still against this step, for the reasons mentioned in the mails > > > leading up to the one you just quoted. I am fine with "does not install > > > hardlinks for builtin-commands on systems that don't support hardlinks" > > > (and of course all such hardlinks are in $(libexecdir)/git-core at this > > > point). > > > > But only for porcelain, right? You certainly don't need the dashed form > > of plumbing commands? > > In principle, yes, though one man's porcelain is another man's plumbing, > so determining the correct set is hard (and why bother if they are all > hidden from mere mortals, anyway?). That would be a good reason not to bother determining which set to preserve and remove them all then. Sure you'll miss the dashed form for, say, one week? After that your fingers should be retrained. Nicolas ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 1:19 ` Nicolas Pitre @ 2007-11-30 1:25 ` Jeff King 2007-11-30 1:33 ` Nicolas Pitre 0 siblings, 1 reply; 92+ messages in thread From: Jeff King @ 2007-11-30 1:25 UTC (permalink / raw) To: Nicolas Pitre Cc: Junio C Hamano, Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Thu, Nov 29, 2007 at 08:19:38PM -0500, Nicolas Pitre wrote: > > In principle, yes, though one man's porcelain is another man's plumbing, > > so determining the correct set is hard (and why bother if they are all > > hidden from mere mortals, anyway?). > > That would be a good reason not to bother determining which set to > preserve and remove them all then. It clearly argues for putting all in the same boat, yes (but obviously we disagree on which boat). > Sure you'll miss the dashed form for, say, one week? After that your > fingers should be retrained. Perhaps, although that doesn't address my other point, about non-bash program in the world which already does filename completion (in my case, I am specifically thinking about vim's ":r!", but surely emacs users must have a similar issue). But that is just talking about the disadvantages; you can argue that they are small, but they are clearly non-zero. More importantly, what are the _advantages_ of removing the hardlinks (and if you haven't read the other message I just sent you, I am talking not about putting hardlinks into a non-PATH directory, but about removing them entirely once they are already in that alternate directory)? If there aren't any advantages, or they are also small, then it makes sense to keep the hardlinks. -Peff ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 1:25 ` Jeff King @ 2007-11-30 1:33 ` Nicolas Pitre 2007-11-30 1:53 ` Jeff King 0 siblings, 1 reply; 92+ messages in thread From: Nicolas Pitre @ 2007-11-30 1:33 UTC (permalink / raw) To: Jeff King Cc: Junio C Hamano, Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Thu, 29 Nov 2007, Jeff King wrote: > On Thu, Nov 29, 2007 at 08:19:38PM -0500, Nicolas Pitre wrote: > > > > In principle, yes, though one man's porcelain is another man's plumbing, > > > so determining the correct set is hard (and why bother if they are all > > > hidden from mere mortals, anyway?). > > > > That would be a good reason not to bother determining which set to > > preserve and remove them all then. > > It clearly argues for putting all in the same boat, yes (but obviously > we disagree on which boat). > > > Sure you'll miss the dashed form for, say, one week? After that your > > fingers should be retrained. > > Perhaps, although that doesn't address my other point, about non-bash > program in the world which already does filename completion (in my case, > I am specifically thinking about vim's ":r!", but surely emacs users > must have a similar issue). > > But that is just talking about the disadvantages; you can argue that > they are small, but they are clearly non-zero. More importantly, what > are the _advantages_ of removing the hardlinks (and if you haven't read > the other message I just sent you, I am talking not about putting > hardlinks into a non-PATH directory, but about removing them entirely > once they are already in that alternate directory)? If there aren't any > advantages, or they are also small, then it makes sense to keep the > hardlinks. So what you want is for the dashed hardlinks to exist _inside_ the libexec directory, even if most people won't "see" them due to that libexec directory not being in the shell path, right? If that is what you mean then I personally don't care at all. Nicolas ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 1:33 ` Nicolas Pitre @ 2007-11-30 1:53 ` Jeff King 2007-11-30 2:23 ` A Large Angry SCM 0 siblings, 1 reply; 92+ messages in thread From: Jeff King @ 2007-11-30 1:53 UTC (permalink / raw) To: Nicolas Pitre Cc: Junio C Hamano, Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Thu, Nov 29, 2007 at 08:33:39PM -0500, Nicolas Pitre wrote: > So what you want is for the dashed hardlinks to exist _inside_ the > libexec directory, even if most people won't "see" them due to that > libexec directory not being in the shell path, right? > > If that is what you mean then I personally don't care at all. That is exactly what I mean. -Peff ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 1:53 ` Jeff King @ 2007-11-30 2:23 ` A Large Angry SCM 0 siblings, 0 replies; 92+ messages in thread From: A Large Angry SCM @ 2007-11-30 2:23 UTC (permalink / raw) To: Nicolas Pitre Cc: Jeff King, Junio C Hamano, Linus Torvalds, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git Jeff King wrote: > On Thu, Nov 29, 2007 at 08:33:39PM -0500, Nicolas Pitre wrote: > >> So what you want is for the dashed hardlinks to exist _inside_ the >> libexec directory, even if most people won't "see" them due to that >> libexec directory not being in the shell path, right? >> >> If that is what you mean then I personally don't care at all. > > That is exactly what I mean. And that also works for me when I set libexec=$(bindir). ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 0:13 ` Junio C Hamano 2007-11-30 0:35 ` Jeff King @ 2007-11-30 0:40 ` Nguyen Thai Ngoc Duy 2007-11-30 0:51 ` A Large Angry SCM 2 siblings, 0 replies; 92+ messages in thread From: Nguyen Thai Ngoc Duy @ 2007-11-30 0:40 UTC (permalink / raw) To: Junio C Hamano Cc: Linus Torvalds, Jeff King, Johannes Schindelin, Jan Hudec, git On Nov 30, 2007 7:13 AM, Junio C Hamano <gitster@pobox.com> wrote: > - Post v1.5.4, start cooking gitexecdir=$(libexecdir)/git-core, aiming > for inclusion in v1.5.5, perhaps in Feb-Mar 2008 timeframe. This > will also affect the sample RPM spec and resulting RPM binary > packages I will place on k.org, and I'll ask Gerrit to do the same on > Debian side. The official binary packaging of individual distros are > not under my control, but if there is a handy list of people I can > send this notice to for other distros, that would help this process. You can find Gentoo maintainers here: http://sources.gentoo.org/viewcvs.py/gentoo-x86/dev-util/git/metadata.xml?rev=1.6&view=markup -- Duy ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 0:13 ` Junio C Hamano 2007-11-30 0:35 ` Jeff King 2007-11-30 0:40 ` Nguyen Thai Ngoc Duy @ 2007-11-30 0:51 ` A Large Angry SCM 2007-11-30 0:54 ` Johannes Schindelin 2007-11-30 1:01 ` Nicolas Pitre 2 siblings, 2 replies; 92+ messages in thread From: A Large Angry SCM @ 2007-11-30 0:51 UTC (permalink / raw) To: Junio C Hamano Cc: Linus Torvalds, Jeff King, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git Junio C Hamano wrote: [...] > Ok. So here is a revised roadmap that a panda brain (that is not so > well working today due to fever) came up. > > - v1.5.4 will ship with gitexecdir=$(bindir) in Makefile. But the > release notes for the version will warn users that: > > (1) using git-foo from the command line, and > > (2) using git-foo from your scripts without first prepending the > return value of "git --exec-path" to the PATH > > is now officially deprecated (it has been deprecated for a long time > since January 2006, v1.2.0~149) and upcoming v1.5.5 will ship with > the default configuration that does not install git-foo form in > user's PATH. > > If further will warn users that git-foo form will be removed in > v1.5.6 for many commands and it will be merely an accident if some of > them still work after that. > > - Post v1.5.4, start cooking gitexecdir=$(libexecdir)/git-core, aiming > for inclusion in v1.5.5, perhaps in Feb-Mar 2008 timeframe. This > will also affect the sample RPM spec and resulting RPM binary > packages I will place on k.org, and I'll ask Gerrit to do the same on > Debian side. The official binary packaging of individual distros are > not under my control, but if there is a handy list of people I can > send this notice to for other distros, that would help this process. > > - The release notes for v1.5.5 will warn users again that git-foo will > be removed in v1.5.6 for many commands and it will be merely an > accident if some of them still work. > > - Post v1.5.5, start cooking the change that does not install hardlinks > for built-in commands, aiming for inclusion in v1.5.6, in May-Jun > 2008 timeframe. Again, there needs to remain support in the Makefile to install the "dashed" versions of the commands for those that want it; and be able to set gitexecdir=$(binder) without editing the Makefile. ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 0:51 ` A Large Angry SCM @ 2007-11-30 0:54 ` Johannes Schindelin 2007-11-30 2:03 ` A Large Angry SCM 2007-11-30 1:01 ` Nicolas Pitre 1 sibling, 1 reply; 92+ messages in thread From: Johannes Schindelin @ 2007-11-30 0:54 UTC (permalink / raw) To: A Large Angry SCM Cc: Junio C Hamano, Linus Torvalds, Jeff King, Nguyen Thai Ngoc Duy, Jan Hudec, git Hi, On Thu, 29 Nov 2007, A Large Angry SCM wrote: > Junio C Hamano wrote: > [...] > > Ok. So here is a revised roadmap that a panda brain (that is not so > > well working today due to fever) came up. > > > > - v1.5.4 will ship with gitexecdir=$(bindir) in Makefile. But the > > release notes for the version will warn users that: > > > > (1) using git-foo from the command line, and > > > > (2) using git-foo from your scripts without first prepending the > > return value of "git --exec-path" to the PATH > > > > is now officially deprecated (it has been deprecated for a long time > > since January 2006, v1.2.0~149) and upcoming v1.5.5 will ship with > > the default configuration that does not install git-foo form in > > user's PATH. > > > > If further will warn users that git-foo form will be removed in > > v1.5.6 for many commands and it will be merely an accident if some of > > them still work after that. > > > > - Post v1.5.4, start cooking gitexecdir=$(libexecdir)/git-core, aiming > > for inclusion in v1.5.5, perhaps in Feb-Mar 2008 timeframe. This > > will also affect the sample RPM spec and resulting RPM binary > > packages I will place on k.org, and I'll ask Gerrit to do the same on > > Debian side. The official binary packaging of individual distros are > > not under my control, but if there is a handy list of people I can > > send this notice to for other distros, that would help this process. > > > > - The release notes for v1.5.5 will warn users again that git-foo will > > be removed in v1.5.6 for many commands and it will be merely an > > accident if some of them still work. > > > > - Post v1.5.5, start cooking the change that does not install hardlinks > > for built-in commands, aiming for inclusion in v1.5.6, in May-Jun > > 2008 timeframe. > > Again, there needs to remain support in the Makefile to install the "dashed" > versions of the commands for those that want it; and be able to set > gitexecdir=$(binder) without editing the Makefile. Umm. Why? If there is no compelling reason (and you named none, but there were quite a few reasons against it), why should the Makefile support the dash form after 1.5.6? Ciao, Dscho ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 0:54 ` Johannes Schindelin @ 2007-11-30 2:03 ` A Large Angry SCM 0 siblings, 0 replies; 92+ messages in thread From: A Large Angry SCM @ 2007-11-30 2:03 UTC (permalink / raw) To: Johannes Schindelin Cc: Junio C Hamano, Linus Torvalds, Jeff King, Nguyen Thai Ngoc Duy, Jan Hudec, git Johannes Schindelin wrote: > Hi, > > On Thu, 29 Nov 2007, A Large Angry SCM wrote: [...] >> Again, there needs to remain support in the Makefile to install the "dashed" >> versions of the commands for those that want it; and be able to set >> gitexecdir=$(binder) without editing the Makefile. > > Umm. Why? If there is no compelling reason (and you named none, but > there were quite a few reasons against it), why should the Makefile > support the dash form after 1.5.6? Not all shells support customized command completion (check the archives); "bang" history (check the archives); etc. ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 0:51 ` A Large Angry SCM 2007-11-30 0:54 ` Johannes Schindelin @ 2007-11-30 1:01 ` Nicolas Pitre 2007-11-30 2:17 ` A Large Angry SCM 1 sibling, 1 reply; 92+ messages in thread From: Nicolas Pitre @ 2007-11-30 1:01 UTC (permalink / raw) To: A Large Angry SCM Cc: Junio C Hamano, Linus Torvalds, Jeff King, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Thu, 29 Nov 2007, A Large Angry SCM wrote: > Again, there needs to remain support in the Makefile to install the "dashed" > versions of the commands for those that want it; and be able to set > gitexecdir=$(binder) without editing the Makefile. Well, if you want a "non standard" installation, maybe you just can edit a line or two in the Makefile? Nicolas ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 1:01 ` Nicolas Pitre @ 2007-11-30 2:17 ` A Large Angry SCM 2007-11-30 2:27 ` Nicolas Pitre 0 siblings, 1 reply; 92+ messages in thread From: A Large Angry SCM @ 2007-11-30 2:17 UTC (permalink / raw) To: Nicolas Pitre Cc: Junio C Hamano, Linus Torvalds, Jeff King, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git Nicolas Pitre wrote: > On Thu, 29 Nov 2007, A Large Angry SCM wrote: > >> Again, there needs to remain support in the Makefile to install the "dashed" >> versions of the commands for those that want it; and be able to set >> gitexecdir=$(binder) without editing the Makefile. > > Well, if you want a "non standard" installation, maybe you just can edit > a line or two in the Makefile? Why do you object to a "install-dashed" Makefile target? ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-30 2:17 ` A Large Angry SCM @ 2007-11-30 2:27 ` Nicolas Pitre 0 siblings, 0 replies; 92+ messages in thread From: Nicolas Pitre @ 2007-11-30 2:27 UTC (permalink / raw) To: A Large Angry SCM Cc: Junio C Hamano, Linus Torvalds, Jeff King, Johannes Schindelin, Nguyen Thai Ngoc Duy, Jan Hudec, git On Thu, 29 Nov 2007, A Large Angry SCM wrote: > Nicolas Pitre wrote: > > On Thu, 29 Nov 2007, A Large Angry SCM wrote: > > > > > Again, there needs to remain support in the Makefile to install the > > > "dashed" > > > versions of the commands for those that want it; and be able to set > > > gitexecdir=$(binder) without editing the Makefile. > > > > Well, if you want a "non standard" installation, maybe you just can edit a > > line or two in the Makefile? > > Why do you object to a "install-dashed" Makefile target? As long as it is not the default I don't object. Nicolas ^ permalink raw reply [flat|nested] 92+ messages in thread
* Re: [PATCH] Move all dashed form git commands to libexecdir 2007-11-28 8:36 ` Nguyen Thai Ngoc Duy 2007-11-28 23:14 ` Junio C Hamano @ 2007-11-29 0:14 ` Jakub Narebski 1 sibling, 0 replies; 92+ messages in thread From: Jakub Narebski @ 2007-11-29 0:14 UTC (permalink / raw) To: git Nguyen Thai Ngoc Duy wrote: > On Nov 28, 2007 8:13 AM, Junio C Hamano <gitster@pobox.com> wrote: >> In case somebody is thinking about 36e5e70e0f40 (Start deprecating >> "git-command" in favor of "git command"), that is a somewhat different >> issue. What Linus suggested is not installing git-foo link for built-in >> commands _anywhere_ on the filesystem. Not just "out of user's PATH". >> That is not deprecating dash form but removing the support for it. We >> need to give ample time for users to adjust to such a change. > > A little note on this one. I've been using git without builtin links > for a while with my git-box port. There are still some builtin fixups > needed. And because execv_git_cmd() always uses dash form, so it's > impossible to use vanilla git without builtin links. By the way, what is the status of your git-box port? -- Jakub Narebski Warsaw, Poland ShadeHawk on #git ^ permalink raw reply [flat|nested] 92+ messages in thread
end of thread, other threads:[~2007-12-02 17:24 UTC | newest] Thread overview: 92+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2007-11-27 15:02 [PATCH RFC] Move all dashed form git commands to libexecdir Nguyễn Thái Ngọc Duy 2007-11-27 15:12 ` Johannes Schindelin 2007-11-27 15:25 ` Nicolas Pitre 2007-11-27 16:04 ` [PATCH] " Nguyễn Thái Ngoc Duy 2007-11-27 16:18 ` Johannes Schindelin 2007-11-28 0:07 ` Jan Hudec 2007-11-28 1:13 ` Junio C Hamano 2007-11-28 8:18 ` Jan Hudec 2007-11-28 8:36 ` Nguyen Thai Ngoc Duy 2007-11-28 23:14 ` Junio C Hamano 2007-11-28 23:40 ` Johannes Schindelin 2007-11-28 23:48 ` Junio C Hamano 2007-11-29 0:01 ` Johannes Schindelin 2007-11-29 0:59 ` A Large Angry SCM 2007-11-29 1:02 ` Junio C Hamano 2007-11-29 3:17 ` Nguyen Thai Ngoc Duy 2007-11-29 14:09 ` Nicolas Pitre 2007-11-29 22:36 ` Junio C Hamano 2007-11-30 7:32 ` Wincent Colaiuta 2007-11-30 11:28 ` Eyvind Bernhardsen 2007-11-30 12:08 ` [PATCH] transport.c: call dash-less form of receive-pack and upload-pack on remote Johannes Schindelin 2007-12-01 2:36 ` Junio C Hamano 2007-12-01 10:17 ` Johannes Schindelin 2007-12-01 19:30 ` Junio C Hamano 2007-12-01 23:03 ` Johannes Schindelin 2007-12-01 23:15 ` Johannes Schindelin 2007-12-02 1:57 ` Junio C Hamano 2007-12-02 2:52 ` [PATCH 0/3] Call builtin functions directly, was " Johannes Schindelin 2007-12-02 2:54 ` [PATCH 1/3] Introduce release_all_objects() Johannes Schindelin 2007-12-02 2:54 ` [PATCH 2/3] Include the objects needed for the builtin functions into libgit.a Johannes Schindelin 2007-12-02 2:55 ` [PATCH 3/3] Introduce execv_git_builtin() and use it Johannes Schindelin 2007-12-02 3:04 ` Johannes Schindelin 2007-12-02 3:16 ` [REPLACEMENT PATCH " Johannes Schindelin 2007-12-02 5:19 ` [PATCH 0/3] Call builtin functions directly, was Re: [PATCH] transport.c: call dash-less form of receive-pack and upload-pack on remote Junio C Hamano 2007-12-02 11:35 ` Johannes Schindelin 2007-11-30 12:19 ` [PATCH] Move all dashed form git commands to libexecdir Nguyen Thai Ngoc Duy 2007-11-30 13:35 ` Johannes Schindelin 2007-11-29 15:08 ` Jeff King 2007-11-29 20:05 ` Nguyen Thai Ngoc Duy 2007-11-29 21:14 ` Jeff King 2007-11-29 22:19 ` Johannes Schindelin 2007-11-29 23:14 ` Jeff King 2007-11-29 23:30 ` Linus Torvalds 2007-11-30 0:13 ` Junio C Hamano 2007-11-30 0:35 ` Jeff King 2007-11-30 0:49 ` Junio C Hamano 2007-11-30 0:58 ` Jeff King 2007-11-30 1:13 ` Nicolas Pitre 2007-11-30 1:17 ` Jeff King 2007-11-30 5:42 ` Steffen Prohaska 2007-11-30 7:18 ` Andreas Ericsson 2007-11-30 15:09 ` Jeff King 2007-11-30 20:01 ` Junio C Hamano 2007-11-30 21:25 ` Jeff King 2007-11-30 23:10 ` Johannes Schindelin 2007-12-02 15:02 ` Wincent Colaiuta 2007-12-02 16:39 ` Johannes Schindelin 2007-12-02 16:56 ` Pascal Obry 2007-12-02 17:23 ` Johannes Schindelin 2007-12-01 2:37 ` Junio C Hamano 2007-12-01 4:17 ` Jeff King 2007-11-30 2:29 ` Linus Torvalds 2007-11-30 2:55 ` Nicolas Pitre 2007-11-30 5:51 ` Steffen Prohaska 2007-11-30 15:12 ` Jeff King 2007-11-30 15:28 ` Santi Béjar 2007-11-30 15:29 ` Jeff King 2007-11-30 15:50 ` Linus Torvalds 2007-11-30 16:22 ` Jeff King 2007-11-30 18:28 ` Johannes Schindelin 2007-11-30 18:37 ` Jeff King 2007-11-30 23:05 ` Johannes Schindelin 2007-11-30 23:21 ` Jeff King 2007-11-30 23:38 ` Johannes Schindelin [not found] ` <fcaeb9bf0711302234l32460a1fqbf9825fc8055f99d@mail.gmail.com> 2007-12-01 19:32 ` Junio C Hamano 2007-12-01 21:26 ` Jeff King 2007-12-02 5:50 ` Nguyen Thai Ngoc Duy 2007-11-30 0:52 ` Nicolas Pitre 2007-11-30 1:00 ` Jeff King 2007-11-30 1:19 ` Nicolas Pitre 2007-11-30 1:25 ` Jeff King 2007-11-30 1:33 ` Nicolas Pitre 2007-11-30 1:53 ` Jeff King 2007-11-30 2:23 ` A Large Angry SCM 2007-11-30 0:40 ` Nguyen Thai Ngoc Duy 2007-11-30 0:51 ` A Large Angry SCM 2007-11-30 0:54 ` Johannes Schindelin 2007-11-30 2:03 ` A Large Angry SCM 2007-11-30 1:01 ` Nicolas Pitre 2007-11-30 2:17 ` A Large Angry SCM 2007-11-30 2:27 ` Nicolas Pitre 2007-11-29 0:14 ` Jakub Narebski
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).