2006-11-06 11:28:52 +03:00
|
|
|
git-pack-refs(1)
|
|
|
|
================
|
|
|
|
|
|
|
|
NAME
|
|
|
|
----
|
|
|
|
git-pack-refs - Pack heads and tags for efficient repository access
|
|
|
|
|
|
|
|
SYNOPSIS
|
|
|
|
--------
|
2011-07-02 06:38:26 +04:00
|
|
|
[verse]
|
2008-06-30 10:09:04 +04:00
|
|
|
'git pack-refs' [--all] [--no-prune]
|
2006-11-06 11:28:52 +03:00
|
|
|
|
|
|
|
DESCRIPTION
|
|
|
|
-----------
|
|
|
|
|
|
|
|
Traditionally, tips of branches and tags (collectively known as
|
2012-08-07 00:36:47 +04:00
|
|
|
'refs') were stored one file per ref in a (sub)directory
|
|
|
|
under `$GIT_DIR/refs`
|
2006-11-06 11:28:52 +03:00
|
|
|
directory. While many branch tips tend to be updated often,
|
|
|
|
most tags and some branch tips are never updated. When a
|
|
|
|
repository has hundreds or thousands of tags, this
|
|
|
|
one-file-per-ref format both wastes storage and hurts
|
|
|
|
performance.
|
|
|
|
|
|
|
|
This command is used to solve the storage and performance
|
2012-08-07 00:36:47 +04:00
|
|
|
problem by storing the refs in a single file,
|
2006-11-06 11:28:52 +03:00
|
|
|
`$GIT_DIR/packed-refs`. When a ref is missing from the
|
2012-08-07 00:36:47 +04:00
|
|
|
traditional `$GIT_DIR/refs` directory hierarchy, it is looked
|
|
|
|
up in this
|
2006-11-06 11:28:52 +03:00
|
|
|
file and used if found.
|
|
|
|
|
2009-04-04 14:35:22 +04:00
|
|
|
Subsequent updates to branches always create new files under
|
2012-08-07 00:36:47 +04:00
|
|
|
`$GIT_DIR/refs` directory hierarchy.
|
2006-11-06 11:28:52 +03:00
|
|
|
|
2007-01-26 09:51:49 +03:00
|
|
|
A recommended practice to deal with a repository with too many
|
2013-07-18 20:53:25 +04:00
|
|
|
refs is to pack its refs with `--all` once, and
|
|
|
|
occasionally run `git pack-refs`. Tags are by
|
2007-01-26 09:51:49 +03:00
|
|
|
definition stationary and are not expected to change. Branch
|
|
|
|
heads will be packed with the initial `pack-refs --all`, but
|
|
|
|
only the currently active branch heads will become unpacked,
|
2009-04-04 14:35:22 +04:00
|
|
|
and the next `pack-refs` (without `--all`) will leave them
|
2007-01-26 09:51:49 +03:00
|
|
|
unpacked.
|
|
|
|
|
|
|
|
|
2006-11-06 11:28:52 +03:00
|
|
|
OPTIONS
|
|
|
|
-------
|
|
|
|
|
2008-06-08 05:36:09 +04:00
|
|
|
--all::
|
2006-11-06 11:28:52 +03:00
|
|
|
|
2007-01-26 09:51:49 +03:00
|
|
|
The command by default packs all tags and refs that are already
|
|
|
|
packed, and leaves other refs
|
2006-11-06 11:28:52 +03:00
|
|
|
alone. This is because branches are expected to be actively
|
|
|
|
developed and packing their tips does not help performance.
|
|
|
|
This option causes branch tips to be packed as well. Useful for
|
|
|
|
a repository with many branches of historical interests.
|
|
|
|
|
2008-06-08 05:36:09 +04:00
|
|
|
--no-prune::
|
2007-01-09 01:40:33 +03:00
|
|
|
|
|
|
|
The command usually removes loose refs under `$GIT_DIR/refs`
|
|
|
|
hierarchy after packing them. This option tells it not to.
|
2006-11-06 11:28:52 +03:00
|
|
|
|
2012-08-07 00:36:47 +04:00
|
|
|
|
|
|
|
BUGS
|
|
|
|
----
|
|
|
|
|
|
|
|
Older documentation written before the packed-refs mechanism was
|
|
|
|
introduced may still say things like ".git/refs/heads/<branch> file
|
|
|
|
exists" when it means "branch <branch> exists".
|
|
|
|
|
|
|
|
|
2006-11-06 11:28:52 +03:00
|
|
|
GIT
|
|
|
|
---
|
2008-06-06 11:07:32 +04:00
|
|
|
Part of the linkgit:git[1] suite
|