|  | git-receive-pack(1) | 
|  | =================== | 
|  |  | 
|  | NAME | 
|  | ---- | 
|  | git-receive-pack - Receive what is pushed into the repository | 
|  |  | 
|  |  | 
|  | SYNOPSIS | 
|  | -------- | 
|  | 'git receive-pack' <directory> | 
|  |  | 
|  | DESCRIPTION | 
|  | ----------- | 
|  | Invoked by 'git-send-pack' and updates the repository with the | 
|  | information fed from the remote end. | 
|  |  | 
|  | This command is usually not invoked directly by the end user. | 
|  | The UI for the protocol is on the 'git-send-pack' side, and the | 
|  | program pair is meant to be used to push updates to remote | 
|  | repository.  For pull operations, see linkgit:git-fetch-pack[1]. | 
|  |  | 
|  | The command allows for creation and fast forwarding of sha1 refs | 
|  | (heads/tags) on the remote end (strictly speaking, it is the | 
|  | local end 'git-receive-pack' runs, but to the user who is sitting at | 
|  | the send-pack end, it is updating the remote.  Confused?) | 
|  |  | 
|  | There are other real-world examples of using update and | 
|  | post-update hooks found in the Documentation/howto directory. | 
|  |  | 
|  | 'git-receive-pack' honours the receive.denyNonFastForwards config | 
|  | option, which tells it if updates to a ref should be denied if they | 
|  | are not fast-forwards. | 
|  |  | 
|  | OPTIONS | 
|  | ------- | 
|  | <directory>:: | 
|  | The repository to sync into. | 
|  |  | 
|  | pre-receive Hook | 
|  | ---------------- | 
|  | Before any ref is updated, if $GIT_DIR/hooks/pre-receive file exists | 
|  | and is executable, it will be invoked once with no parameters.  The | 
|  | standard input of the hook will be one line per ref to be updated: | 
|  |  | 
|  | sha1-old SP sha1-new SP refname LF | 
|  |  | 
|  | The refname value is relative to $GIT_DIR; e.g. for the master | 
|  | head this is "refs/heads/master".  The two sha1 values before | 
|  | each refname are the object names for the refname before and after | 
|  | the update.  Refs to be created will have sha1-old equal to 0\{40}, | 
|  | while refs to be deleted will have sha1-new equal to 0\{40}, otherwise | 
|  | sha1-old and sha1-new should be valid objects in the repository. | 
|  |  | 
|  | This hook is called before any refname is updated and before any | 
|  | fast-forward checks are performed. | 
|  |  | 
|  | If the pre-receive hook exits with a non-zero exit status no updates | 
|  | will be performed, and the update, post-receive and post-update | 
|  | hooks will not be invoked either.  This can be useful to quickly | 
|  | bail out if the update is not to be supported. | 
|  |  | 
|  | update Hook | 
|  | ----------- | 
|  | Before each ref is updated, if $GIT_DIR/hooks/update file exists | 
|  | and is executable, it is invoked once per ref, with three parameters: | 
|  |  | 
|  | $GIT_DIR/hooks/update refname sha1-old sha1-new | 
|  |  | 
|  | The refname parameter is relative to $GIT_DIR; e.g. for the master | 
|  | head this is "refs/heads/master".  The two sha1 arguments are | 
|  | the object names for the refname before and after the update. | 
|  | Note that the hook is called before the refname is updated, | 
|  | so either sha1-old is 0\{40} (meaning there is no such ref yet), | 
|  | or it should match what is recorded in refname. | 
|  |  | 
|  | The hook should exit with non-zero status if it wants to disallow | 
|  | updating the named ref.  Otherwise it should exit with zero. | 
|  |  | 
|  | Successful execution (a zero exit status) of this hook does not | 
|  | ensure the ref will actually be updated, it is only a prerequisite. | 
|  | As such it is not a good idea to send notices (e.g. email) from | 
|  | this hook.  Consider using the post-receive hook instead. | 
|  |  | 
|  | post-receive Hook | 
|  | ----------------- | 
|  | After all refs were updated (or attempted to be updated), if any | 
|  | ref update was successful, and if $GIT_DIR/hooks/post-receive | 
|  | file exists and is executable, it will be invoked once with no | 
|  | parameters.  The standard input of the hook will be one line | 
|  | for each successfully updated ref: | 
|  |  | 
|  | sha1-old SP sha1-new SP refname LF | 
|  |  | 
|  | The refname value is relative to $GIT_DIR; e.g. for the master | 
|  | head this is "refs/heads/master".  The two sha1 values before | 
|  | each refname are the object names for the refname before and after | 
|  | the update.  Refs that were created will have sha1-old equal to | 
|  | 0\{40}, while refs that were deleted will have sha1-new equal to | 
|  | 0\{40}, otherwise sha1-old and sha1-new should be valid objects in | 
|  | the repository. | 
|  |  | 
|  | Using this hook, it is easy to generate mails describing the updates | 
|  | to the repository.  This example script sends one mail message per | 
|  | ref listing the commits pushed to the repository: | 
|  |  | 
|  | #!/bin/sh | 
|  | # mail out commit update information. | 
|  | while read oval nval ref | 
|  | do | 
|  | if expr "$oval" : '0*$' >/dev/null | 
|  | then | 
|  | echo "Created a new ref, with the following commits:" | 
|  | git rev-list --pretty "$nval" | 
|  | else | 
|  | echo "New commits:" | 
|  | git rev-list --pretty "$nval" "^$oval" | 
|  | fi | | 
|  | mail -s "Changes to ref $ref" commit-list@mydomain | 
|  | done | 
|  | exit 0 | 
|  |  | 
|  | The exit code from this hook invocation is ignored, however a | 
|  | non-zero exit code will generate an error message. | 
|  |  | 
|  | Note that it is possible for refname to not have sha1-new when this | 
|  | hook runs.  This can easily occur if another user modifies the ref | 
|  | after it was updated by 'git-receive-pack', but before the hook was able | 
|  | to evaluate it.  It is recommended that hooks rely on sha1-new | 
|  | rather than the current value of refname. | 
|  |  | 
|  | post-update Hook | 
|  | ---------------- | 
|  | After all other processing, if at least one ref was updated, and | 
|  | if $GIT_DIR/hooks/post-update file exists and is executable, then | 
|  | post-update will be called with the list of refs that have been updated. | 
|  | This can be used to implement any repository wide cleanup tasks. | 
|  |  | 
|  | The exit code from this hook invocation is ignored; the only thing | 
|  | left for 'git-receive-pack' to do at that point is to exit itself | 
|  | anyway. | 
|  |  | 
|  | This hook can be used, for example, to run `git update-server-info` | 
|  | if the repository is packed and is served via a dumb transport. | 
|  |  | 
|  | #!/bin/sh | 
|  | exec git update-server-info | 
|  |  | 
|  |  | 
|  | SEE ALSO | 
|  | -------- | 
|  | linkgit:git-send-pack[1] | 
|  |  | 
|  |  | 
|  | Author | 
|  | ------ | 
|  | Written by Linus Torvalds <torvalds@osdl.org> | 
|  |  | 
|  | Documentation | 
|  | -------------- | 
|  | Documentation by Junio C Hamano. | 
|  |  | 
|  | GIT | 
|  | --- | 
|  | Part of the linkgit:git[1] suite |