Skip to content

Commit

Permalink
Rewrite fetchgitLocal
Browse files Browse the repository at this point in the history
For practical purposes, here are the changes in behavior:
 - When fetching from a subdirectory of a repo, do not rebuild because of
   changes elsewhere in the repo
 - Fetch (not-ignored) untracked files too

It does this by letting git hash and export the directory in question,
which I believes makes for a cleaner implementation than the ad-hoc copying
and hashing that was there before.
  • Loading branch information
Ericson2314 committed Oct 2, 2015
1 parent e916273 commit 7266040
Showing 1 changed file with 38 additions and 21 deletions.
59 changes: 38 additions & 21 deletions pkgs/build-support/fetchgitlocal/default.nix
Original file line number Diff line number Diff line change
@@ -1,23 +1,40 @@
{ runCommand, git, nix }: src:

let hash = import (runCommand "head-hash.nix"
{ dummy = builtins.currentTime;
preferLocalBuild = true; }
''
cd ${toString src}
(${git}/bin/git show && ${git}/bin/git diff) > $out
hash=$(${nix}/bin/nix-hash $out)
echo "\"$hash\"" > $out
''); in

runCommand "local-git-export"
{ dummy = hash;
preferLocalBuild = true; }
''
cd ${toString src}
mkdir -p "$out"
for file in $(${git}/bin/git ls-files); do
mkdir -p "$out/$(dirname $file)"
cp -d $file "$out/$file" || true # don't fail when trying to copy a directory
done
''
let
srcStr = toString src;

# Adds the current directory (respecting ignored files) to the git store, and returns the hash
gitHashFile = runCommand "put-in-git" {
nativeBuildInputs = [ git ];
dummy = builtins.currentTime; # impure, do every time
preferLocalBuild = true;
} ''
cd ${srcStr}
ROOT=$(git rev-parse --show-toplevel) # path to repo
cp $ROOT/.git/index $ROOT/.git/index-user # backup index
git reset # reset index
git add . # add current directory
# hash of current directory
# remove trailing newline
git rev-parse $(git write-tree) \
| tr -d '\n' > $out
mv $ROOT/.git/index-user $ROOT/.git/index # restore index
'';

gitHash = builtins.readFile gitHashFile; # cache against git hash

nixPath = runCommand "put-in-nix" {
nativeBuildInputs = [ git ];
preferLocalBuild = true;
} ''
mkdir $out
# dump tar of *current directory* at given revision
git -C ${srcStr} archive --format=tar ${gitHash} \
| tar xvf - -C $out
'';

in nixPath

0 comments on commit 7266040

Please sign in to comment.