Signed-off-by: Markus Heidelberg <markus.heidelberg@web.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			166 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			166 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
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
 |