diff options
author | Daniel Barkalow <barkalow@iabervon.org> | 2005-06-03 17:43:52 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-06-03 16:07:29 -0700 |
commit | dba385bb3ed541c4d18e2b8080960eee358394fa (patch) | |
tree | 5d261be8a54c55542223536a72c53fab564cc28a /rpull.c | |
parent | eeaa4603147974b988d7b958571628d6ecd697f3 (diff) | |
download | git-dba385bb3ed541c4d18e2b8080960eee358394fa.tar.gz |
[PATCH] ssh-protocol version, command types, response code
This patch makes an incompatible change to the protocol used by
rpull/rpush which will let it be extended in the future without
incompatible changes.
Signed-off-by: Daniel Barkalow <barkalow@iabervon.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'rpull.c')
-rw-r--r-- | rpull.c | 26 |
1 files changed, 26 insertions, 0 deletions
@@ -6,16 +6,39 @@ static int fd_in; static int fd_out; +static unsigned char remote_version = 0; +static unsigned char local_version = 1; + int fetch(unsigned char *sha1) { int ret; + signed char remote; + char type = 'o'; + if (has_sha1_file(sha1)) + return 0; + write(fd_out, &type, 1); write(fd_out, sha1, 20); + if (read(fd_in, &remote, 1) < 1) + return -1; + if (remote < 0) + return remote; ret = write_sha1_from_fd(sha1, fd_in); if (!ret) pull_say("got %s\n", sha1_to_hex(sha1)); return ret; } +int get_version(void) +{ + char type = 'v'; + write(fd_out, &type, 1); + write(fd_out, &local_version, 1); + if (read(fd_in, &remote_version, 1) < 1) { + return error("Couldn't read version from remote end"); + } + return 0; +} + int main(int argc, char **argv) { char *commit_id; @@ -48,6 +71,9 @@ int main(int argc, char **argv) if (setup_connection(&fd_in, &fd_out, "git-rpush", url, arg, argv + 1)) return 1; + if (get_version()) + return 1; + if (pull(commit_id)) return 1; |