annotate .git/hooks/push-to-checkout.sample @ 781:68904fdaab71

te
author Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
date Mon, 10 Jul 2023 19:59:14 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
781
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 #!/bin/sh
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
2
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 # An example hook script to update a checked-out tree on a git push.
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 #
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
5 # This hook is invoked by git-receive-pack(1) when it reacts to git
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 # push and updates reference(s) in its repository, and when the push
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 # tries to update the branch that is currently checked out and the
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
8 # receive.denyCurrentBranch configuration variable is set to
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
9 # updateInstead.
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 #
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
11 # By default, such a push is refused if the working tree and the index
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
12 # of the remote repository has any difference from the currently
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
13 # checked out commit; when both the working tree and the index match
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
14 # the current commit, they are updated to match the newly pushed tip
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
15 # of the branch. This hook is to be used to override the default
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
16 # behaviour; however the code below reimplements the default behaviour
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
17 # as a starting point for convenient modification.
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
18 #
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
19 # The hook receives the commit with which the tip of the current
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
20 # branch is going to be updated:
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
21 commit=$1
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
22
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
23 # It can exit with a non-zero status to refuse the push (when it does
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
24 # so, it must not modify the index or the working tree).
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
25 die () {
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
26 echo >&2 "$*"
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
27 exit 1
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
28 }
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
29
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
30 # Or it can make any necessary changes to the working tree and to the
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
31 # index to bring them to the desired state when the tip of the current
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
32 # branch is updated to the new commit, and exit with a zero status.
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
33 #
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
34 # For example, the hook can simply run git read-tree -u -m HEAD "$1"
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
35 # in order to emulate git fetch that is run in the reverse direction
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
36 # with git push, as the two-tree form of git read-tree -u -m is
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
37 # essentially the same as git switch or git checkout that switches
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
38 # branches while keeping the local changes in the working tree that do
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
39 # not interfere with the difference between the branches.
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
40
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 # The below is a more-or-less exact translation to shell of the C code
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
42 # for the default behaviour for git's push-to-checkout hook defined in
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
43 # the push_to_deploy() function in builtin/receive-pack.c.
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
44 #
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
45 # Note that the hook will be executed from the repository directory,
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
46 # not from the working tree, so if you want to perform operations on
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
47 # the working tree, you will have to adapt your code accordingly, e.g.
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
48 # by adding "cd .." or using relative paths.
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
49
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
50 if ! git update-index -q --ignore-submodules --refresh
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
51 then
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
52 die "Up-to-date check failed"
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
53 fi
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
54
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
55 if ! git diff-files --quiet --ignore-submodules --
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
56 then
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
57 die "Working directory has unstaged changes"
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
58 fi
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
59
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
60 # This is a rough translation of:
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
61 #
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
62 # head_has_history() ? "HEAD" : EMPTY_TREE_SHA1_HEX
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
63 if git cat-file -e HEAD 2>/dev/null
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
64 then
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
65 head=HEAD
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
66 else
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
67 head=$(git hash-object -t tree --stdin </dev/null)
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
68 fi
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
69
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
70 if ! git diff-index --quiet --cached --ignore-submodules $head --
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
71 then
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
72 die "Working directory has staged changes"
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
73 fi
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
74
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
75 if ! git read-tree -u -m "$commit"
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
76 then
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
77 die "Could not update working tree to new HEAD"
Moririn < Moririn@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
78 fi