aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Linus Torvalds <torvalds@linux-foundation.org>2015-06-10 18:03:37 -0700
committerGravatar Dirk Hohndel <dirk@hohndel.org>2015-06-10 20:57:57 -0700
commit39a0ac965bf9af50ffc898dfa898b4b52dbfa943 (patch)
treed4a71045599aebcf850363e1ee896986d7e0fb7e
parent971f1c66742508161c023623aef260d9b777f55c (diff)
downloadsubsurface-39a0ac965bf9af50ffc898dfa898b4b52dbfa943.tar.gz
git storage: actually update the remote repository if the local cache is more recent
Again, note that this currently only happens when you initially open the repository. So if you do subsurface https://.../repo[myubranch] it will start up by fetching the remote information, and updating the local cache. If you then download new dives, and do a save-and-exit, it will save to the local cache, but it doesn't do the fetch at this point, so the remote is now begind. The *next* time you start subsurface, and load that git branch again, it will fetch the remote, and now notice that the local cache is ahead of it (because you downloaded new dives and saved them locally), and *then* it will try to update the remote with the new information. This is obviously bogus, but we will need to decide exactly how we want to sync with the remote repository. But now the core functionality is there, it's just that we need some interface to say "sync now". Especially in the face of spotty (or non-working) internet, you want a GUI etc for this whole remote sync, rather than doing it unconditionally and silently whenever you load the local cache initially. With that caveat: Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--git-access.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/git-access.c b/git-access.c
index ded065e01..0cfd27483 100644
--- a/git-access.c
+++ b/git-access.c
@@ -101,6 +101,17 @@ static int reset_to_remote(git_repository *repo, git_reference *local, const git
static int update_remote(git_repository *repo, git_remote *origin, git_reference *local, git_reference *remote)
{
+ git_push_options opts = GIT_PUSH_OPTIONS_INIT;
+ git_strarray refspec;
+ const char *name = git_reference_name(local);
+
+ refspec.count = 1;
+ refspec.strings = (char **)&name;
+
+ if (git_remote_push(origin, &refspec, &opts))
+ return report_error("Unable to update remote with current local cache state (%s)", giterr_last()->message);
+
+ // Not actually an error, just informational
report_error("Local cache more recent than remote");
return 0;
}