forked from lix-project/lix
builtins.fetchgit: Respect tarball-ttl
I.e. if the local ref is more recent than tarball-ttl seconds, then don't check the remote.
This commit is contained in:
parent
69deca194e
commit
9f64cb89cb
1 changed files with 19 additions and 1 deletions
|
@ -4,6 +4,8 @@
|
|||
#include "store-api.hh"
|
||||
#include "pathlocks.hh"
|
||||
|
||||
#include <sys/time.h>
|
||||
|
||||
namespace nix {
|
||||
|
||||
Path exportGit(ref<Store> store, const std::string & uri, const std::string & rev)
|
||||
|
@ -24,7 +26,23 @@ Path exportGit(ref<Store> store, const std::string & uri, const std::string & re
|
|||
|
||||
Path localRefFile = cacheDir + "/refs/heads/" + localRef;
|
||||
|
||||
runProgram("git", true, { "-C", cacheDir, "fetch", "--force", uri, rev + ":" + localRef });
|
||||
/* If the local ref is older than ‘tarball-ttl’ seconds, do a git
|
||||
fetch to update the local ref to the remote ref. */
|
||||
time_t now = time(0);
|
||||
struct stat st;
|
||||
if (stat(localRefFile.c_str(), &st) != 0 ||
|
||||
st.st_mtime < now - settings.tarballTtl)
|
||||
{
|
||||
runProgram("git", true, { "-C", cacheDir, "fetch", "--force", uri, rev + ":" + localRef });
|
||||
|
||||
struct timeval times[2];
|
||||
times[0].tv_sec = now;
|
||||
times[0].tv_usec = 0;
|
||||
times[1].tv_sec = now;
|
||||
times[1].tv_usec = 0;
|
||||
|
||||
utimes(localRefFile.c_str(), times);
|
||||
}
|
||||
|
||||
std::string commitHash = chomp(readFile(localRefFile));
|
||||
|
||||
|
|
Loading…
Reference in a new issue