X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=ssh-pull.c;fp=ssh-pull.c;h=c2cb59a65571fa25a7c0f5334c29d4562f0e2383;hb=c7c4bbe63193f580abd2460e96dd7e65f2d4904c;hp=a426342590c6782792d39b85f266be537d9def76;hpb=cd541a68b38cead87f5fa69d5331c467bce71656;p=git.git diff --git a/ssh-pull.c b/ssh-pull.c index a4263425..c2cb59a6 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) @@ -65,11 +74,14 @@ 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];