X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=ssh-pull.c;h=27484126dd899cd9a6d4a14d2f41a60fc3a36a52;hb=aeac6681250440bc9801d6d6cc293cc708895b46;hp=a426342590c6782792d39b85f266be537d9def76;hpb=cd541a68b38cead87f5fa69d5331c467bce71656;p=git.git diff --git a/ssh-pull.c b/ssh-pull.c index a42634259..27484126d 100644 --- a/ssh-pull.c +++ b/ssh-pull.c @@ -2,6 +2,7 @@ #include "commit.h" #include "rsh.h" #include "pull.h" +#include "refs.h" static int fd_in; static int fd_out; @@ -41,7 +42,15 @@ int get_version(void) int fetch_ref(char *ref, unsigned char *sha1) { - return -1; + signed char remote; + char type = 'r'; + write(fd_out, &type, 1); + write(fd_out, ref, strlen(ref) + 1); + read(fd_in, &remote, 1); + if (remote < 0) + return remote; + read(fd_in, sha1, 20); + return 0; } int main(int argc, char **argv) @@ -49,6 +58,7 @@ int main(int argc, char **argv) char *commit_id; char *url; int arg = 1; + const char *prog = getenv("GIT_SSH_PUSH") ? : "git-ssh-push"; while (arg < argc && argv[arg][0] == '-') { if (argv[arg][1] == 't') { @@ -65,17 +75,20 @@ int main(int argc, char **argv) get_history = 1; } else if (argv[arg][1] == 'v') { get_verbosely = 1; + } else if (argv[arg][1] == 'w') { + write_ref = argv[arg + 1]; + arg++; } arg++; } if (argc < arg + 2) { - usage("git-ssh-pull [-c] [-t] [-a] [-v] [-d] [--recover] commit-id url"); + usage("git-ssh-pull [-c] [-t] [-a] [-v] [-d] [--recover] [-w ref] commit-id url"); return 1; } commit_id = argv[arg]; url = argv[arg + 1]; - if (setup_connection(&fd_in, &fd_out, "git-ssh-push", url, arg, argv + 1)) + if (setup_connection(&fd_in, &fd_out, prog, url, arg, argv + 1)) return 1; if (get_version())