From: "Ciprian Dorin Craciun" <ciprian.craciun@gmail.com>
To: git@vger.kernel.org
Subject: Re: Repository specific git commands
Date: Fri, 23 May 2008 17:20:25 +0300 [thread overview]
Message-ID: <8e04b5820805230720p2117fa9cp5a44c16c99457c69@mail.gmail.com> (raw)
In-Reply-To: <8e04b5820801070415j5166c2eco53760cffe1ab1efb@mail.gmail.com>
Hello all!
A few months ago, I've proposed a feature (and accompaning patch)
that would enable users to create a "bin" folder inside the .git
folder, where they were allowed to put special git commands, that
would be accessible just like any other git command, but only for that
specific repository.
Now the problem is that in the new Git v1.5.5.1 something has
changed, and I can not figure out what I shall do...
In previous versions it was easy: just add a new path in the array
inside the execv_git_cmd function.
But now the paths were moved to the setup_path function, and I'm
not able to make it work (see my patch bellow). The problem is that
all the commands start with the current folder being the top worktree
folder...
Any suggestions, help, documentation?
Thanks all,
Ciprian.
diff --git a/exec_cmd.c b/exec_cmd.c
index e189cac..2166ae3 100644
--- a/exec_cmd.c
+++ b/exec_cmd.c
@@ -41,6 +41,28 @@ static void add_path(struct strbuf *out, const char *path)
}
}
+static const char *git_repo_exec_path(void)
+{
+ static char path_buffer[PATH_MAX + 1];
+ static char *path = NULL;
+ char *git_dir;
+ int nongit_ok = 1; // ????
+
+ if (!path) {
+ path = path_buffer;
+ path[0] = '\0';
+ setup_git_directory_gently(&nongit_ok);
+ git_dir = get_git_dir();
+ if (!nongit_ok && git_dir) {
+ strncat(path, git_dir, PATH_MAX);
+ strncat(path, "/", PATH_MAX);
+ strncat(path, "bin", PATH_MAX);
+ }
+ }
+
+ return path;
+}
+
void setup_path(const char *cmd_path)
{
const char *old_path = getenv("PATH");
@@ -48,6 +70,7 @@ void setup_path(const char *cmd_path)
strbuf_init(&new_path, 0);
+ add_path(&new_path, git_repo_exec_path());
add_path(&new_path, argv_exec_path);
add_path(&new_path, getenv(EXEC_PATH_ENVIRONMENT));
add_path(&new_path, builtin_exec_path);
On Mon, Jan 7, 2008 at 3:15 PM, Ciprian Dorin Craciun
<ciprian.craciun@gmail.com> wrote:
> Hello all!
>
> I have a question / proposal: I see on the mailing list a lot of
> situations when some commands (or group of commands) are very often
> used and the users demand (or would like to have) a special "git xxx"
> command for them. But adding such a command -- in almost all cases --
> is not worth the effort or increases the number of available commands
> (thus confusing even more the users).
>
> Thus the users are left with only two possibilities:
> -- either define an alias -- but usually it is very restrictive in
> terms of what the alias can do;
> -- create a custom git command "git-xxx" and place it in the
> executable path -- but this requires root access.
> (-- or write a custom script but this can not be invoked as "git xxx")
> => Thus neither option is very useful.
>
> So my proposal is to let the users create a special folder inside
> the .git directory, for example ".git/bin" where they can place custom
> built git files like "git-xxx", and when they issue "git xxx" this
> folder is searched first, and if the command is found it will be
> executed as any other "git-xxx".
>
> For this I attach a very simple patch that implements it. (It
> modifies the execv_git_cmd function by adding a new path in the paths
> array.)
>
> Comments? Opinions? Other solutions that I am not aware of?
>
> (Please note that I am a git user for only a couple of months, and
> this is the first time I look over git source code...)
>
> Thanks,
> Ciprian Craciun.
>
prev parent reply other threads:[~2008-05-23 14:21 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-01-07 12:15 Repository specific git commands Ciprian Dorin Craciun
2008-01-07 12:55 ` Johannes Schindelin
2008-01-07 13:14 ` Ciprian Dorin Craciun
2008-05-23 14:20 ` Ciprian Dorin Craciun [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=8e04b5820805230720p2117fa9cp5a44c16c99457c69@mail.gmail.com \
--to=ciprian.craciun@gmail.com \
--cc=git@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).