diff options
author | Daniel Barkalow <barkalow@iabervon.org> | 2005-04-30 16:53:56 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-04-30 16:53:56 -0700 |
commit | 4250a5e5b1755e45153248217fe1d5550c972c8d (patch) | |
tree | ec4e77e64d8db8f075c5e0a5023c243587b22a66 /rpull.c | |
parent | 5e7921e7c1a844974469a5f865ebf0001ff06311 (diff) | |
download | git-4250a5e5b1755e45153248217fe1d5550c972c8d.tar.gz |
[PATCH] Split out "pull" from particular methods
The method for deciding what to pull is useful separately from any of the
ways of actually fetching the objects.
So split out "pull" functionality from http-pull and rpull
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 | 89 |
1 files changed, 8 insertions, 81 deletions
@@ -7,15 +7,12 @@ #include <errno.h> #include <stdio.h> #include "rsh.h" - -static int tree = 0; -static int commits = 0; -static int all = 0; +#include "pull.h" static int fd_in; static int fd_out; -static int fetch(unsigned char *sha1) +int fetch(unsigned char *sha1) { if (has_sha1_file(sha1)) return 0; @@ -23,87 +20,21 @@ static int fetch(unsigned char *sha1) return write_sha1_from_fd(sha1, fd_in); } -static int process_tree(unsigned char *sha1) -{ - struct tree *tree = lookup_tree(sha1); - struct tree_entry_list *entries; - - if (parse_tree(tree)) - return -1; - - for (entries = tree->entries; entries; entries = entries->next) { - /* - fprintf(stderr, "Tree %s ", sha1_to_hex(sha1)); - fprintf(stderr, "needs %s\n", - sha1_to_hex(entries->item.tree->object.sha1)); - */ - if (fetch(entries->item.tree->object.sha1)) { - return error("Missing item %s", - sha1_to_hex(entries->item.tree->object.sha1)); - } - if (entries->directory) { - if (process_tree(entries->item.tree->object.sha1)) - return -1; - } - } - return 0; -} - -static int process_commit(unsigned char *sha1) -{ - struct commit *obj = lookup_commit(sha1); - - if (fetch(sha1)) { - return error("Fetching %s", sha1_to_hex(sha1)); - } - - if (parse_commit(obj)) - return -1; - - if (tree) { - if (fetch(obj->tree->object.sha1)) - return -1; - if (process_tree(obj->tree->object.sha1)) - return -1; - if (!all) - tree = 0; - } - if (commits) { - struct commit_list *parents = obj->parents; - for (; parents; parents = parents->next) { - if (has_sha1_file(parents->item->object.sha1)) - continue; - if (fetch(parents->item->object.sha1)) { - /* The server might not have it, and - * we don't mind. - */ - error("Missing tree %s; continuing", - sha1_to_hex(parents->item->object.sha1)); - continue; - } - if (process_commit(parents->item->object.sha1)) - return -1; - } - } - return 0; -} - int main(int argc, char **argv) { char *commit_id; char *url; int arg = 1; - unsigned char sha1[20]; while (arg < argc && argv[arg][0] == '-') { if (argv[arg][1] == 't') { - tree = 1; + get_tree = 1; } else if (argv[arg][1] == 'c') { - commits = 1; + get_history = 1; } else if (argv[arg][1] == 'a') { - all = 1; - tree = 1; - commits = 1; + get_all = 1; + get_tree = 1; + get_history = 1; } arg++; } @@ -117,11 +48,7 @@ int main(int argc, char **argv) if (setup_connection(&fd_in, &fd_out, "rpush", url, arg, argv + 1)) return 1; - get_sha1_hex(commit_id, sha1); - - if (fetch(sha1)) - return 1; - if (process_commit(sha1)) + if (pull(commit_id)) return 1; return 0; |