summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 9182f89)
raw | patch | inline | side by side (parent: 9182f89)
author | Daniel Barkalow <barkalow@iabervon.org> | |
Mon, 6 Jun 2005 20:38:26 +0000 (16:38 -0400) | ||
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | |
Tue, 7 Jun 2005 00:11:11 +0000 (17:11 -0700) |
This adds support to pull.c for requesting a reference and writing it to a
file. All of the git-*-pull programs get stubs for now.
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
file. All of the git-*-pull programs get stubs for now.
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
http-pull.c | patch | blob | history | |
local-pull.c | patch | blob | history | |
pull.c | patch | blob | history | |
pull.h | patch | blob | history | |
ssh-pull.c | patch | blob | history |
diff --git a/http-pull.c b/http-pull.c
index ec7f66af8f368b53e9eb0044ac9a8e43cea9a1f5..f49525c00228b5db9dc2fbd4860883887bb7dbad 100644 (file)
--- a/http-pull.c
+++ b/http-pull.c
return 0;
}
+int fetch_ref(char *ref, unsigned char *sha1)
+{
+ return -1;
+}
+
int main(int argc, char **argv)
{
char *commit_id;
diff --git a/local-pull.c b/local-pull.c
index afdba9f527e2e78fcd62667cd17323e28a8ecb94..8bfe67b4071b6445210a06e51b0d5f1c5b1ba113 100644 (file)
--- a/local-pull.c
+++ b/local-pull.c
return -1;
}
+int fetch_ref(char *ref, unsigned char *sha1)
+{
+ return -1;
+}
+
static const char *local_pull_usage =
"git-local-pull [-c] [-t] [-a] [-l] [-s] [-n] [-v] [-d] [--recover] commit-id path";
index f4f1d8fcd38aa70a971c82e08fc08942f76f19bc..395ca45328d1f17c795839d3cbfd405852933f5a 100644 (file)
--- a/pull.c
+++ b/pull.c
#include "cache.h"
#include "commit.h"
#include "tree.h"
+#include "refs.h"
+
+const char *write_ref = NULL;
+
+const unsigned char *current_ref = NULL;
int get_tree = 0;
int get_history = 0;
return 0;
}
+static int interpret_target(char *target, unsigned char *sha1)
+{
+ if (!get_sha1_hex(target, sha1))
+ return 0;
+ if (!check_ref_format(target)) {
+ if (!fetch_ref(target, sha1)) {
+ return 0;
+ }
+ }
+ return -1;
+}
+
+
int pull(char *target)
{
- int retval;
unsigned char sha1[20];
- retval = get_sha1_hex(target, sha1);
- if (retval)
- return retval;
- retval = make_sure_we_have_it(commitS, sha1);
- if (retval)
- return retval;
- memcpy(current_commit_sha1, sha1, 20);
- return process_commit(sha1);
+ int fd = -1;
+
+ if (write_ref && current_ref) {
+ fd = lock_ref_sha1(write_ref, current_ref);
+ if (fd < 0)
+ return -1;
+ }
+
+ if (interpret_target(target, sha1))
+ return error("Could not interpret %s as something to pull",
+ target);
+ if (process_commit(sha1))
+ return -1;
+
+ if (write_ref) {
+ if (current_ref) {
+ write_ref_sha1(write_ref, fd, sha1);
+ } else {
+ write_ref_sha1_unlocked(write_ref, sha1);
+ }
+ }
+ return 0;
}
index 30086fdb12496a9da78aaf3969ca32fc5af98c5a..bd5e7bdeb316ecf1ccc01f0d23d710dcd7813242 100644 (file)
--- a/pull.h
+++ b/pull.h
/** To be provided by the particular implementation. **/
extern int fetch(unsigned char *sha1);
+extern int fetch_ref(char *ref, unsigned char *sha1);
+
+/** If set, the ref filename to write the target value to. **/
+extern const char *write_ref;
+
+/** If set, the hash that the current value of write_ref must be. **/
+extern const unsigned char *current_ref;
+
/** Set to fetch the target tree. */
extern int get_tree;
diff --git a/ssh-pull.c b/ssh-pull.c
index 3556d89a33cc68e8c369f2189bf068dc3ae3a96d..a426342590c6782792d39b85f266be537d9def76 100644 (file)
--- a/ssh-pull.c
+++ b/ssh-pull.c
return 0;
}
+int fetch_ref(char *ref, unsigned char *sha1)
+{
+ return -1;
+}
+
int main(int argc, char **argv)
{
char *commit_id;