b038d1e44796e53beb6b0d4e57a85cf392281d5a
[config/vcsh.git] / .config / vcsh / hooks-available / populate-fully.sh
1 #!/bin/sh
2
3 set -e
4
5 # If the vcsh repository does not exist, exit without doing anything.
6 [ -d "$GIT_DIR" ] || exit 0
7
8 # Only one vcsh instance at a time can have the working tree fully populated.
9 LOCKDIR=/run/lock/vcsh
10
11 # Kill the parent process because vcsh does not catch the hook exit value.
12 # See: https://github.com/RichiH/vcsh/issues/251
13 mkdir "$LOCKDIR" 2>/dev/null || { echo "An instance of vcsh already entered a repository." 1>&2; kill -- -$PPID;}
14
15 # Lock on the parent pid because the hooks are launched as children of vcsh.
16 echo $PPID > "$LOCKDIR/pid"
17
18 # git read-tree manual page says this is the proper way to fully repopulate
19 # the working tree.
20 git config core.sparseCheckout true
21 rm -f "$GIT_DIR/info/sparse-checkout"
22 echo "/*" > "$GIT_DIR/info/sparse-checkout"
23 git read-tree -mu HEAD
24 git config core.sparseCheckout false