 576162a45f
			
		
	
	576162a45f
	
	
	
		
			
			This makes both git-fetch and git-push (fetch-pack and receive-pack) safe against a possible race with aparallel git-repack -a -d that could prune the new pack while it is not yet referenced, and remove the .keep file after refs have been updated. Signed-off-by: Nicolas Pitre <nico@cam.org> Signed-off-by: Junio C Hamano <junkio@cox.net>
		
			
				
	
	
		
			95 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			95 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| git-index-pack(1)
 | |
| =================
 | |
| 
 | |
| NAME
 | |
| ----
 | |
| git-index-pack - Build pack index file for an existing packed archive
 | |
| 
 | |
| 
 | |
| SYNOPSIS
 | |
| --------
 | |
| 'git-index-pack' [-v] [-o <index-file>] <pack-file>
 | |
| 'git-index-pack' --stdin [--fix-thin] [--keep] [-v] [-o <index-file>] [<pack-file>]
 | |
| 
 | |
| 
 | |
| DESCRIPTION
 | |
| -----------
 | |
| Reads a packed archive (.pack) from the specified file, and
 | |
| builds a pack index file (.idx) for it.  The packed archive
 | |
| together with the pack index can then be placed in the
 | |
| objects/pack/ directory of a git repository.
 | |
| 
 | |
| 
 | |
| OPTIONS
 | |
| -------
 | |
| -v::
 | |
| 	Be verbose about what is going on, including progress status.
 | |
| 
 | |
| -o <index-file>::
 | |
| 	Write the generated pack index into the specified
 | |
| 	file.  Without this option the name of pack index
 | |
| 	file is constructed from the name of packed archive
 | |
| 	file by replacing .pack with .idx (and the program
 | |
| 	fails if the name of packed archive does not end
 | |
| 	with .pack).
 | |
| 
 | |
| --stdin::
 | |
| 	When this flag is provided, the pack is read from stdin
 | |
| 	instead and a copy is then written to <pack-file>. If
 | |
| 	<pack-file> is not specified, the pack is written to
 | |
| 	objects/pack/ directory of the current git repository with
 | |
| 	a default name determined from the pack content.  If
 | |
| 	<pack-file> is not specified consider using --keep to
 | |
| 	prevent a race condition between this process and
 | |
| 	gitlink::git-repack[1] .
 | |
| 
 | |
| --fix-thin::
 | |
| 	It is possible for gitlink:git-pack-objects[1] to build
 | |
| 	"thin" pack, which records objects in deltified form based on
 | |
| 	objects not included in the pack to reduce network traffic.
 | |
| 	Those objects are expected to be present on the receiving end
 | |
| 	and they must be included in the pack for that pack to be self
 | |
| 	contained and indexable. Without this option any attempt to
 | |
| 	index a thin pack will fail. This option only makes sense in
 | |
| 	conjunction with --stdin.
 | |
| 
 | |
| --keep::
 | |
| 	Before moving the index into its final destination
 | |
| 	create an empty .keep file for the associated pack file.
 | |
| 	This option is usually necessary with --stdin to prevent a
 | |
| 	simultaneous gitlink:git-repack[1] process from deleting
 | |
| 	the newly constructed pack and index before refs can be
 | |
| 	updated to use objects contained in the pack.
 | |
| 
 | |
| --keep='why'::
 | |
| 	Like --keep create a .keep file before moving the index into
 | |
| 	its final destination, but rather than creating an empty file
 | |
| 	place 'why' followed by an LF into the .keep file.  The 'why'
 | |
| 	message can later be searched for within all .keep files to
 | |
| 	locate any which have outlived their usefulness.
 | |
| 
 | |
| 
 | |
| Note
 | |
| ----
 | |
| 
 | |
| Once the index has been created, the list of object names is sorted
 | |
| and the SHA1 hash of that list is printed to stdout. If --stdin was
 | |
| also used then this is prefixed by either "pack\t", or "keep\t" if a
 | |
| new .keep file was successfully created. This is useful to remove a
 | |
| .keep file used as a lock to prevent the race with gitlink:git-repack[1]
 | |
| mentioned above.
 | |
| 
 | |
| 
 | |
| Author
 | |
| ------
 | |
| Written by Sergey Vlasov <vsu@altlinux.ru>
 | |
| 
 | |
| Documentation
 | |
| -------------
 | |
| Documentation by Sergey Vlasov
 | |
| 
 | |
| GIT
 | |
| ---
 | |
| Part of the gitlink:git[7] suite
 | |
| 
 |