From 39a0ac965bf9af50ffc898dfa898b4b52dbfa943 Mon Sep 17 00:00:00 2001 From: Linus Torvalds Date: Wed, 10 Jun 2015 18:03:37 -0700 Subject: 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 Signed-off-by: Dirk Hohndel --- git-access.c | 11 +++++++++++ 1 file changed, 11 insertions(+) (limited to 'git-access.c') 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; } -- cgit v1.2.3-70-g09d2