Clarify and expand some hook documentation.
Clarify update and post-update hooks. Made a few references to the hooks documentation. Signed-off-by: Jon Loeliger <jdl@jdl.com> Signed-off-by: Junio C Hamano <junkio@cox.net>
This commit is contained in:
parent
7561d9f544
commit
6250ad1e7a
@ -531,6 +531,8 @@ File/Directory Structure
|
|||||||
|
|
||||||
Please see link:repository-layout.html[repository layout] document.
|
Please see link:repository-layout.html[repository layout] document.
|
||||||
|
|
||||||
|
Read link:hooks.html[hooks] for more details about each hook.
|
||||||
|
|
||||||
Higher level SCMs may provide and manage additional information in the
|
Higher level SCMs may provide and manage additional information in the
|
||||||
`$GIT_DIR`.
|
`$GIT_DIR`.
|
||||||
|
|
||||||
|
@ -97,16 +97,31 @@ send out a commit notification e-mail.
|
|||||||
update
|
update
|
||||||
------
|
------
|
||||||
|
|
||||||
This hook is invoked by `git-receive-pack`, which is invoked
|
This hook is invoked by `git-receive-pack` on the remote repository,
|
||||||
when a `git push` is done against the repository. It takes
|
which is happens when a `git push` is done on a local repository.
|
||||||
three parameters, name of the ref being updated, old object name
|
Just before updating the ref on the remote repository, the update hook
|
||||||
stored in the ref, and the new objectname to be stored in the
|
is invoked. It's exit status determins the success or failure of
|
||||||
ref. Exiting with non-zero status from this hook prevents
|
the ref update.
|
||||||
`git-receive-pack` from updating the ref.
|
|
||||||
|
|
||||||
This can be used to prevent 'forced' update on certain refs by
|
The hook executes once for each ref to be updated, and takes
|
||||||
|
three parameters:
|
||||||
|
- the name of the ref being updated,
|
||||||
|
- the old object name stored in the ref,
|
||||||
|
- and the new objectname to be stored in the ref.
|
||||||
|
|
||||||
|
A zero exit from the update hook allows the ref to be updated.
|
||||||
|
Exiting with a non-zero status prevents `git-receive-pack`
|
||||||
|
from updating the ref.
|
||||||
|
|
||||||
|
This hook can be used to prevent 'forced' update on certain refs by
|
||||||
making sure that the object name is a commit object that is a
|
making sure that the object name is a commit object that is a
|
||||||
descendant of the commit object named by the old object name.
|
descendant of the commit object named by the old object name.
|
||||||
|
That is, to enforce a "fast forward only" policy.
|
||||||
|
|
||||||
|
It could also be used to log the old..new status. However, it
|
||||||
|
does not know the entire set of branches, so it would end up
|
||||||
|
firing one e-mail per ref when used naively, though.
|
||||||
|
|
||||||
Another use suggested on the mailing list is to use this hook to
|
Another use suggested on the mailing list is to use this hook to
|
||||||
implement access control which is finer grained than the one
|
implement access control which is finer grained than the one
|
||||||
based on filesystem group.
|
based on filesystem group.
|
||||||
@ -115,20 +130,30 @@ The standard output of this hook is sent to /dev/null; if you
|
|||||||
want to report something to the git-send-pack on the other end,
|
want to report something to the git-send-pack on the other end,
|
||||||
you can redirect your output to your stderr.
|
you can redirect your output to your stderr.
|
||||||
|
|
||||||
|
|
||||||
post-update
|
post-update
|
||||||
-----------
|
-----------
|
||||||
|
|
||||||
This hook is invoked by `git-receive-pack`, which is invoked
|
This hook is invoked by `git-receive-pack` on the remote repository,
|
||||||
when a `git push` is done against the repository. It takes
|
which is happens when a `git push` is done on a local repository.
|
||||||
variable number of parameters; each of which is the name of ref
|
It executes on the remote repository once after all the refs have
|
||||||
that was actually updated.
|
been updated.
|
||||||
|
|
||||||
|
It takes a variable number of parameters, each of which is the
|
||||||
|
name of ref that was actually updated.
|
||||||
|
|
||||||
This hook is meant primarily for notification, and cannot affect
|
This hook is meant primarily for notification, and cannot affect
|
||||||
the outcome of `git-receive-pack`.
|
the outcome of `git-receive-pack`.
|
||||||
|
|
||||||
|
The post-update hook can tell what are the heads that were pushed,
|
||||||
|
but it does not know what their original and updated values are,
|
||||||
|
so it is a poor place to do log old..new.
|
||||||
|
|
||||||
The default post-update hook, when enabled, runs
|
The default post-update hook, when enabled, runs
|
||||||
`git-update-server-info` to keep the information used by dumb
|
`git-update-server-info` to keep the information used by dumb
|
||||||
transport up-to-date.
|
transports (eg, http) up-to-date. If you are publishing
|
||||||
|
a git repository that is accessible via http, you should
|
||||||
|
probably enable this hook.
|
||||||
|
|
||||||
The standard output of this hook is sent to /dev/null; if you
|
The standard output of this hook is sent to /dev/null; if you
|
||||||
want to report something to the git-send-pack on the other end,
|
want to report something to the git-send-pack on the other end,
|
||||||
|
@ -89,6 +89,8 @@ hooks::
|
|||||||
commands. A handful of sample hooks are installed when
|
commands. A handful of sample hooks are installed when
|
||||||
`git init-db` is run, but all of them are disabled by
|
`git init-db` is run, but all of them are disabled by
|
||||||
default. To enable, they need to be made executable.
|
default. To enable, they need to be made executable.
|
||||||
|
Read link:hooks.html[hooks] for more details about
|
||||||
|
each hook.
|
||||||
|
|
||||||
index::
|
index::
|
||||||
The current index file for the repository. It is
|
The current index file for the repository. It is
|
||||||
|
Loading…
Reference in New Issue
Block a user