write_index(): update index_state->timestamp after flushing to disk
[gitweb.git] / builtin-fetch-pack.c
index fa3c936493cc0b139edf3e4e8154569f453afc02..3b210c7fdfd0e5a75e5627099fc8fa183b8c0269 100644 (file)
@@ -780,7 +780,8 @@ struct ref *fetch_pack(struct fetch_pack_args *my_args,
        struct ref *ref_cpy;
 
        fetch_pack_setup();
-       memcpy(&args, my_args, sizeof(args));
+       if (&args != my_args)
+               memcpy(&args, my_args, sizeof(args));
        if (args.depth > 0) {
                if (stat(git_path("shallow"), &st))
                        st.st_mtime = 0;
@@ -801,19 +802,20 @@ struct ref *fetch_pack(struct fetch_pack_args *my_args,
 
                mtime.sec = st.st_mtime;
 #ifdef USE_NSEC
-               mtime.usec = st.st_mtim.usec;
+               mtime.nsec = st.st_mtim.tv_nsec;
 #endif
                if (stat(shallow, &st)) {
                        if (mtime.sec)
                                die("shallow file was removed during fetch");
                } else if (st.st_mtime != mtime.sec
 #ifdef USE_NSEC
-                               || st.st_mtim.usec != mtime.usec
+                               || st.st_mtim.tv_nsec != mtime.nsec
 #endif
                          )
                        die("shallow file was changed during fetch");
 
-               fd = hold_lock_file_for_update(&lock, shallow, 1);
+               fd = hold_lock_file_for_update(&lock, shallow,
+                                              LOCK_DIE_ON_ERROR);
                if (!write_shallow_commits(fd, 0)) {
                        unlink(shallow);
                        rollback_lock_file(&lock);