Documentation / githooks.txton commit Eighth batch of topics for 2.10 (8213178)
   1githooks(5)
   2===========
   3
   4NAME
   5----
   6githooks - Hooks used by Git
   7
   8SYNOPSIS
   9--------
  10$GIT_DIR/hooks/* (or \`git config core.hooksPath`/*)
  11
  12
  13DESCRIPTION
  14-----------
  15
  16Hooks are programs you can place in a hooks directory to trigger
  17actions at certain points in git's execution. Hooks that don't have
  18the executable bit set are ignored.
  19
  20By default the hooks directory is `$GIT_DIR/hooks`, but that can be
  21changed via the `core.hooksPath` configuration variable (see
  22linkgit:git-config[1]).
  23
  24Before Git invokes a hook, it changes its working directory to either
  25the root of the working tree in a non-bare repository, or to the
  26$GIT_DIR in a bare repository.
  27
  28Hooks can get their arguments via the environment, command-line
  29arguments, and stdin. See the documentation for each hook below for
  30details.
  31
  32'git init' may copy hooks to the new repository, depending on its
  33configuration. See the "TEMPLATE DIRECTORY" section in
  34linkgit:git-init[1] for details. When the rest of this document refers
  35to "default hooks" it's talking about the default template shipped
  36with Git.
  37
  38The currently supported hooks are described below.
  39
  40HOOKS
  41-----
  42
  43applypatch-msg
  44~~~~~~~~~~~~~~
  45
  46This hook is invoked by 'git am'.  It takes a single
  47parameter, the name of the file that holds the proposed commit
  48log message.  Exiting with a non-zero status causes 'git am' to abort
  49before applying the patch.
  50
  51The hook is allowed to edit the message file in place, and can
  52be used to normalize the message into some project standard
  53format. It can also be used to refuse the commit after inspecting
  54the message file.
  55
  56The default 'applypatch-msg' hook, when enabled, runs the
  57'commit-msg' hook, if the latter is enabled.
  58
  59pre-applypatch
  60~~~~~~~~~~~~~~
  61
  62This hook is invoked by 'git am'.  It takes no parameter, and is
  63invoked after the patch is applied, but before a commit is made.
  64
  65If it exits with non-zero status, then the working tree will not be
  66committed after applying the patch.
  67
  68It can be used to inspect the current working tree and refuse to
  69make a commit if it does not pass certain test.
  70
  71The default 'pre-applypatch' hook, when enabled, runs the
  72'pre-commit' hook, if the latter is enabled.
  73
  74post-applypatch
  75~~~~~~~~~~~~~~~
  76
  77This hook is invoked by 'git am'.  It takes no parameter,
  78and is invoked after the patch is applied and a commit is made.
  79
  80This hook is meant primarily for notification, and cannot affect
  81the outcome of 'git am'.
  82
  83pre-commit
  84~~~~~~~~~~
  85
  86This hook is invoked by 'git commit', and can be bypassed
  87with the `--no-verify` option.  It takes no parameters, and is
  88invoked before obtaining the proposed commit log message and
  89making a commit.  Exiting with a non-zero status from this script
  90causes the 'git commit' command to abort before creating a commit.
  91
  92The default 'pre-commit' hook, when enabled, catches introduction
  93of lines with trailing whitespaces and aborts the commit when
  94such a line is found.
  95
  96All the 'git commit' hooks are invoked with the environment
  97variable `GIT_EDITOR=:` if the command will not bring up an editor
  98to modify the commit message.
  99
 100prepare-commit-msg
 101~~~~~~~~~~~~~~~~~~
 102
 103This hook is invoked by 'git commit' right after preparing the
 104default log message, and before the editor is started.
 105
 106It takes one to three parameters.  The first is the name of the file
 107that contains the commit log message.  The second is the source of the commit
 108message, and can be: `message` (if a `-m` or `-F` option was
 109given); `template` (if a `-t` option was given or the
 110configuration option `commit.template` is set); `merge` (if the
 111commit is a merge or a `.git/MERGE_MSG` file exists); `squash`
 112(if a `.git/SQUASH_MSG` file exists); or `commit`, followed by
 113a commit SHA-1 (if a `-c`, `-C` or `--amend` option was given).
 114
 115If the exit status is non-zero, 'git commit' will abort.
 116
 117The purpose of the hook is to edit the message file in place, and
 118it is not suppressed by the `--no-verify` option.  A non-zero exit
 119means a failure of the hook and aborts the commit.  It should not
 120be used as replacement for pre-commit hook.
 121
 122The sample `prepare-commit-msg` hook that comes with Git comments
 123out the `Conflicts:` part of a merge's commit message.
 124
 125commit-msg
 126~~~~~~~~~~
 127
 128This hook is invoked by 'git commit', and can be bypassed
 129with the `--no-verify` option.  It takes a single parameter, the
 130name of the file that holds the proposed commit log message.
 131Exiting with a non-zero status causes the 'git commit' to
 132abort.
 133
 134The hook is allowed to edit the message file in place, and can be used
 135to normalize the message into some project standard format. It
 136can also be used to refuse the commit after inspecting the message
 137file.
 138
 139The default 'commit-msg' hook, when enabled, detects duplicate
 140"Signed-off-by" lines, and aborts the commit if one is found.
 141
 142post-commit
 143~~~~~~~~~~~
 144
 145This hook is invoked by 'git commit'. It takes no parameters, and is
 146invoked after a commit is made.
 147
 148This hook is meant primarily for notification, and cannot affect
 149the outcome of 'git commit'.
 150
 151pre-rebase
 152~~~~~~~~~~
 153
 154This hook is called by 'git rebase' and can be used to prevent a
 155branch from getting rebased.  The hook may be called with one or
 156two parameters.  The first parameter is the upstream from which
 157the series was forked.  The second parameter is the branch being
 158rebased, and is not set when rebasing the current branch.
 159
 160post-checkout
 161~~~~~~~~~~~~~
 162
 163This hook is invoked when a 'git checkout' is run after having updated the
 164worktree.  The hook is given three parameters: the ref of the previous HEAD,
 165the ref of the new HEAD (which may or may not have changed), and a flag
 166indicating whether the checkout was a branch checkout (changing branches,
 167flag=1) or a file checkout (retrieving a file from the index, flag=0).
 168This hook cannot affect the outcome of 'git checkout'.
 169
 170It is also run after 'git clone', unless the --no-checkout (-n) option is
 171used. The first parameter given to the hook is the null-ref, the second the
 172ref of the new HEAD and the flag is always 1.
 173
 174This hook can be used to perform repository validity checks, auto-display
 175differences from the previous HEAD if different, or set working dir metadata
 176properties.
 177
 178post-merge
 179~~~~~~~~~~
 180
 181This hook is invoked by 'git merge', which happens when a 'git pull'
 182is done on a local repository.  The hook takes a single parameter, a status
 183flag specifying whether or not the merge being done was a squash merge.
 184This hook cannot affect the outcome of 'git merge' and is not executed,
 185if the merge failed due to conflicts.
 186
 187This hook can be used in conjunction with a corresponding pre-commit hook to
 188save and restore any form of metadata associated with the working tree
 189(e.g.: permissions/ownership, ACLS, etc).  See contrib/hooks/setgitperms.perl
 190for an example of how to do this.
 191
 192pre-push
 193~~~~~~~~
 194
 195This hook is called by 'git push' and can be used to prevent a push from taking
 196place.  The hook is called with two parameters which provide the name and
 197location of the destination remote, if a named remote is not being used both
 198values will be the same.
 199
 200Information about what is to be pushed is provided on the hook's standard
 201input with lines of the form:
 202
 203  <local ref> SP <local sha1> SP <remote ref> SP <remote sha1> LF
 204
 205For instance, if the command +git push origin master:foreign+ were run the
 206hook would receive a line like the following:
 207
 208  refs/heads/master 67890 refs/heads/foreign 12345
 209
 210although the full, 40-character SHA-1s would be supplied.  If the foreign ref
 211does not yet exist the `<remote SHA-1>` will be 40 `0`.  If a ref is to be
 212deleted, the `<local ref>` will be supplied as `(delete)` and the `<local
 213SHA-1>` will be 40 `0`.  If the local commit was specified by something other
 214than a name which could be expanded (such as `HEAD~`, or a SHA-1) it will be
 215supplied as it was originally given.
 216
 217If this hook exits with a non-zero status, 'git push' will abort without
 218pushing anything.  Information about why the push is rejected may be sent
 219to the user by writing to standard error.
 220
 221[[pre-receive]]
 222pre-receive
 223~~~~~~~~~~~
 224
 225This hook is invoked by 'git-receive-pack' on the remote repository,
 226which happens when a 'git push' is done on a local repository.
 227Just before starting to update refs on the remote repository, the
 228pre-receive hook is invoked.  Its exit status determines the success
 229or failure of the update.
 230
 231This hook executes once for the receive operation. It takes no
 232arguments, but for each ref to be updated it receives on standard
 233input a line of the format:
 234
 235  <old-value> SP <new-value> SP <ref-name> LF
 236
 237where `<old-value>` is the old object name stored in the ref,
 238`<new-value>` is the new object name to be stored in the ref and
 239`<ref-name>` is the full name of the ref.
 240When creating a new ref, `<old-value>` is 40 `0`.
 241
 242If the hook exits with non-zero status, none of the refs will be
 243updated. If the hook exits with zero, updating of individual refs can
 244still be prevented by the <<update,'update'>> hook.
 245
 246Both standard output and standard error output are forwarded to
 247'git send-pack' on the other end, so you can simply `echo` messages
 248for the user.
 249
 250[[update]]
 251update
 252~~~~~~
 253
 254This hook is invoked by 'git-receive-pack' on the remote repository,
 255which happens when a 'git push' is done on a local repository.
 256Just before updating the ref on the remote repository, the update hook
 257is invoked.  Its exit status determines the success or failure of
 258the ref update.
 259
 260The hook executes once for each ref to be updated, and takes
 261three parameters:
 262
 263 - the name of the ref being updated,
 264 - the old object name stored in the ref,
 265 - and the new object name to be stored in the ref.
 266
 267A zero exit from the update hook allows the ref to be updated.
 268Exiting with a non-zero status prevents 'git-receive-pack'
 269from updating that ref.
 270
 271This hook can be used to prevent 'forced' update on certain refs by
 272making sure that the object name is a commit object that is a
 273descendant of the commit object named by the old object name.
 274That is, to enforce a "fast-forward only" policy.
 275
 276It could also be used to log the old..new status.  However, it
 277does not know the entire set of branches, so it would end up
 278firing one e-mail per ref when used naively, though.  The
 279<<post-receive,'post-receive'>> hook is more suited to that.
 280
 281In an environment that restricts the users' access only to git
 282commands over the wire, this hook can be used to implement access
 283control without relying on filesystem ownership and group
 284membership. See linkgit:git-shell[1] for how you might use the login
 285shell to restrict the user's access to only git commands.
 286
 287Both standard output and standard error output are forwarded to
 288'git send-pack' on the other end, so you can simply `echo` messages
 289for the user.
 290
 291The default 'update' hook, when enabled--and with
 292`hooks.allowunannotated` config option unset or set to false--prevents
 293unannotated tags to be pushed.
 294
 295[[post-receive]]
 296post-receive
 297~~~~~~~~~~~~
 298
 299This hook is invoked by 'git-receive-pack' on the remote repository,
 300which happens when a 'git push' is done on a local repository.
 301It executes on the remote repository once after all the refs have
 302been updated.
 303
 304This hook executes once for the receive operation.  It takes no
 305arguments, but gets the same information as the
 306<<pre-receive,'pre-receive'>>
 307hook does on its standard input.
 308
 309This hook does not affect the outcome of 'git-receive-pack', as it
 310is called after the real work is done.
 311
 312This supersedes the <<post-update,'post-update'>> hook in that it gets
 313both old and new values of all the refs in addition to their
 314names.
 315
 316Both standard output and standard error output are forwarded to
 317'git send-pack' on the other end, so you can simply `echo` messages
 318for the user.
 319
 320The default 'post-receive' hook is empty, but there is
 321a sample script `post-receive-email` provided in the `contrib/hooks`
 322directory in Git distribution, which implements sending commit
 323emails.
 324
 325[[post-update]]
 326post-update
 327~~~~~~~~~~~
 328
 329This hook is invoked by 'git-receive-pack' on the remote repository,
 330which happens when a 'git push' is done on a local repository.
 331It executes on the remote repository once after all the refs have
 332been updated.
 333
 334It takes a variable number of parameters, each of which is the
 335name of ref that was actually updated.
 336
 337This hook is meant primarily for notification, and cannot affect
 338the outcome of 'git-receive-pack'.
 339
 340The 'post-update' hook can tell what are the heads that were pushed,
 341but it does not know what their original and updated values are,
 342so it is a poor place to do log old..new. The
 343<<post-receive,'post-receive'>> hook does get both original and
 344updated values of the refs. You might consider it instead if you need
 345them.
 346
 347When enabled, the default 'post-update' hook runs
 348'git update-server-info' to keep the information used by dumb
 349transports (e.g., HTTP) up-to-date.  If you are publishing
 350a Git repository that is accessible via HTTP, you should
 351probably enable this hook.
 352
 353Both standard output and standard error output are forwarded to
 354'git send-pack' on the other end, so you can simply `echo` messages
 355for the user.
 356
 357push-to-checkout
 358~~~~~~~~~~~~~~~~
 359
 360This hook is invoked by 'git-receive-pack' on the remote repository,
 361which happens when a 'git push' is done on a local repository, when
 362the push tries to update the branch that is currently checked out
 363and the `receive.denyCurrentBranch` configuration variable is set to
 364`updateInstead`.  Such a push by default is refused if the working
 365tree and the index of the remote repository has any difference from
 366the currently checked out commit; when both the working tree and the
 367index match the current commit, they are updated to match the newly
 368pushed tip of the branch.  This hook is to be used to override the
 369default behaviour.
 370
 371The hook receives the commit with which the tip of the current
 372branch is going to be updated.  It can exit with a non-zero status
 373to refuse the push (when it does so, it must not modify the index or
 374the working tree).  Or it can make any necessary changes to the
 375working tree and to the index to bring them to the desired state
 376when the tip of the current branch is updated to the new commit, and
 377exit with a zero status.
 378
 379For example, the hook can simply run `git read-tree -u -m HEAD "$1"`
 380in order to emulate 'git fetch' that is run in the reverse direction
 381with `git push`, as the two-tree form of `read-tree -u -m` is
 382essentially the same as `git checkout` that switches branches while
 383keeping the local changes in the working tree that do not interfere
 384with the difference between the branches.
 385
 386
 387pre-auto-gc
 388~~~~~~~~~~~
 389
 390This hook is invoked by 'git gc --auto'. It takes no parameter, and
 391exiting with non-zero status from this script causes the 'git gc --auto'
 392to abort.
 393
 394post-rewrite
 395~~~~~~~~~~~~
 396
 397This hook is invoked by commands that rewrite commits (`git commit
 398--amend`, 'git-rebase'; currently 'git-filter-branch' does 'not' call
 399it!).  Its first argument denotes the command it was invoked by:
 400currently one of `amend` or `rebase`.  Further command-dependent
 401arguments may be passed in the future.
 402
 403The hook receives a list of the rewritten commits on stdin, in the
 404format
 405
 406  <old-sha1> SP <new-sha1> [ SP <extra-info> ] LF
 407
 408The 'extra-info' is again command-dependent.  If it is empty, the
 409preceding SP is also omitted.  Currently, no commands pass any
 410'extra-info'.
 411
 412The hook always runs after the automatic note copying (see
 413"notes.rewrite.<command>" in linkgit:git-config[1]) has happened, and
 414thus has access to these notes.
 415
 416The following command-specific comments apply:
 417
 418rebase::
 419        For the 'squash' and 'fixup' operation, all commits that were
 420        squashed are listed as being rewritten to the squashed commit.
 421        This means that there will be several lines sharing the same
 422        'new-sha1'.
 423+
 424The commits are guaranteed to be listed in the order that they were
 425processed by rebase.
 426
 427
 428GIT
 429---
 430Part of the linkgit:git[1] suite