summaryrefslogtreecommitdiffstats
path: root/ssh-push.c
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@ppc970.osdl.org>2005-06-07 23:23:46 +0200
committerLinus Torvalds <torvalds@ppc970.osdl.org>2005-06-07 23:23:46 +0200
commit001d4a27dbfaaa59c25dc35dafc69bd9b9bc21d3 (patch)
treeb7b89d84be5025133535999f9c3644996ba6520a /ssh-push.c
parent[PATCH] Use ntohs instead of htons to convert ce_flags to host byte order (diff)
downloadgit-001d4a27dbfaaa59c25dc35dafc69bd9b9bc21d3.tar.xz
git-001d4a27dbfaaa59c25dc35dafc69bd9b9bc21d3.zip
git-ssh-push/pull: usability improvements
Allow traditional ssh path specifiers (host:path), and let the user override the command name on the other end. With this, I can push to kernel.org with this script export GIT_SSH_PULL=/home/torvalds/bin/git-ssh-pull git-ssh-push -a -v -w heads/master heads/master master.kernel.org:/pub/scm/linux/kernel/git/torvalds/linux-2.6.git which while not pretty is at least workable.
Diffstat (limited to 'ssh-push.c')
-rw-r--r--ssh-push.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/ssh-push.c b/ssh-push.c
index b67a95b9ab..18c0b65d5b 100644
--- a/ssh-push.c
+++ b/ssh-push.c
@@ -109,6 +109,8 @@ int main(int argc, char **argv)
char *commit_id;
char *url;
int fd_in, fd_out;
+ const char *prog = getenv("GIT_SSH_PULL") ? : "git-ssh-pull";
+
while (arg < argc && argv[arg][0] == '-') {
if (argv[arg][1] == 'w')
arg++;
@@ -120,7 +122,7 @@ int main(int argc, char **argv)
}
commit_id = argv[arg];
url = argv[arg + 1];
- if (setup_connection(&fd_in, &fd_out, "git-ssh-pull", url, arg, argv + 1))
+ if (setup_connection(&fd_in, &fd_out, prog, url, arg, argv + 1))
return 1;
service(fd_in, fd_out);