2005-09-08 02:26:23 +02:00
|
|
|
git-repack(1)
|
|
|
|
=============
|
2005-08-16 00:48:47 +02:00
|
|
|
|
|
|
|
NAME
|
|
|
|
----
|
2007-01-19 00:53:37 +01:00
|
|
|
git-repack - Pack unpacked objects in a repository
|
2005-08-16 00:48:47 +02:00
|
|
|
|
|
|
|
|
|
|
|
SYNOPSIS
|
|
|
|
--------
|
2008-06-30 08:09:04 +02:00
|
|
|
'git repack' [-a] [-A] [-d] [-f] [-l] [-n] [-q] [--window=N] [--depth=N]
|
2005-08-16 00:48:47 +02:00
|
|
|
|
|
|
|
DESCRIPTION
|
|
|
|
-----------
|
|
|
|
|
2005-08-30 02:21:06 +02:00
|
|
|
This script is used to combine all objects that do not currently
|
2007-08-24 02:44:13 +02:00
|
|
|
reside in a "pack", into a pack. It can also be used to re-organize
|
2007-06-30 10:56:12 +02:00
|
|
|
existing packs into a single, more efficient pack.
|
2005-08-30 02:21:06 +02:00
|
|
|
|
|
|
|
A pack is a collection of objects, individually compressed, with
|
|
|
|
delta compression applied, stored in a single file, with an
|
|
|
|
associated index file.
|
|
|
|
|
|
|
|
Packs are used to reduce the load on mirror systems, backup
|
|
|
|
engines, disk storage, etc.
|
|
|
|
|
|
|
|
OPTIONS
|
|
|
|
-------
|
|
|
|
|
|
|
|
-a::
|
|
|
|
Instead of incrementally packing the unpacked objects,
|
2007-06-30 10:56:12 +02:00
|
|
|
pack everything referenced into a single pack.
|
2005-08-30 02:21:06 +02:00
|
|
|
Especially useful when packing a repository that is used
|
2007-02-10 19:12:01 +01:00
|
|
|
for private development and there is no need to worry
|
2007-06-30 10:56:12 +02:00
|
|
|
about people fetching via dumb protocols from it. Use
|
|
|
|
with '-d'. This will clean up the objects that `git prune`
|
|
|
|
leaves behind, but `git fsck --full` shows as
|
|
|
|
dangling.
|
2005-08-30 02:21:06 +02:00
|
|
|
|
2008-05-16 04:37:31 +02:00
|
|
|
-A::
|
|
|
|
Same as `-a`, but any unreachable objects in a previous
|
|
|
|
pack become loose, unpacked objects, instead of being
|
|
|
|
left in the old pack. Unreachable objects are never
|
|
|
|
intentionally added to a pack, even when repacking.
|
|
|
|
When used with '-d', this option
|
|
|
|
prevents unreachable objects from being immediately
|
|
|
|
deleted by way of being left in the old pack and then
|
|
|
|
removed. Instead, the loose unreachable objects
|
|
|
|
will be pruned according to normal expiry rules
|
2008-07-03 07:41:41 +02:00
|
|
|
with the next 'git-gc' invocation. See linkgit:git-gc[1].
|
2008-05-16 04:37:31 +02:00
|
|
|
|
2005-08-30 02:21:06 +02:00
|
|
|
-d::
|
|
|
|
After packing, if the newly created packs make some
|
|
|
|
existing packs redundant, remove the redundant packs.
|
2008-07-03 07:41:41 +02:00
|
|
|
Also run 'git-prune-packed' to remove redundant
|
2008-06-30 20:56:34 +02:00
|
|
|
loose object files.
|
2005-08-16 00:48:47 +02:00
|
|
|
|
2005-12-09 00:28:05 +01:00
|
|
|
-l::
|
2008-07-03 07:41:41 +02:00
|
|
|
Pass the `--local` option to 'git-pack-objects'. See
|
2007-12-29 07:20:38 +01:00
|
|
|
linkgit:git-pack-objects[1].
|
2005-12-09 00:28:05 +01:00
|
|
|
|
2006-02-16 20:57:18 +01:00
|
|
|
-f::
|
2008-09-19 15:43:48 +02:00
|
|
|
Pass the `--no-reuse-object` option to `git-pack-objects`, see
|
2007-12-29 07:20:38 +01:00
|
|
|
linkgit:git-pack-objects[1].
|
2006-02-16 20:57:18 +01:00
|
|
|
|
|
|
|
-q::
|
2008-07-03 07:41:41 +02:00
|
|
|
Pass the `-q` option to 'git-pack-objects'. See
|
2007-12-29 07:20:38 +01:00
|
|
|
linkgit:git-pack-objects[1].
|
2006-02-16 20:57:18 +01:00
|
|
|
|
2005-12-09 00:28:05 +01:00
|
|
|
-n::
|
2008-05-22 14:47:19 +02:00
|
|
|
Do not update the server information with
|
2008-07-03 07:41:41 +02:00
|
|
|
'git-update-server-info'. This option skips
|
2008-05-22 14:47:19 +02:00
|
|
|
updating local catalog files needed to publish
|
|
|
|
this repository (or a direct copy of it)
|
2008-07-03 06:54:38 +02:00
|
|
|
over HTTP or FTP. See linkgit:git-update-server-info[1].
|
2005-08-16 00:48:47 +02:00
|
|
|
|
2008-06-08 03:36:09 +02:00
|
|
|
--window=[N]::
|
|
|
|
--depth=[N]::
|
2006-10-06 11:15:03 +02:00
|
|
|
These two options affect how the objects contained in the pack are
|
2006-09-17 13:02:59 +02:00
|
|
|
stored using delta compression. The objects are first internally
|
|
|
|
sorted by type, size and optionally names and compared against the
|
|
|
|
other objects within `--window` to see if using delta compression saves
|
|
|
|
space. `--depth` limits the maximum delta depth; making it too deep
|
|
|
|
affects the performance on the unpacker side, because delta data needs
|
|
|
|
to be applied that many times to get to the necessary object.
|
2007-05-08 15:28:26 +02:00
|
|
|
The default value for --window is 10 and --depth is 50.
|
2006-09-17 13:02:59 +02:00
|
|
|
|
2007-07-12 14:55:52 +02:00
|
|
|
--window-memory=[N]::
|
|
|
|
This option provides an additional limit on top of `--window`;
|
|
|
|
the window size will dynamically scale down so as to not take
|
|
|
|
up more than N bytes in memory. This is useful in
|
|
|
|
repositories with a mix of large and small objects to not run
|
|
|
|
out of memory with a large window, but still be able to take
|
|
|
|
advantage of the large window for the smaller objects. The
|
|
|
|
size can be suffixed with "k", "m", or "g".
|
|
|
|
`--window-memory=0` makes memory usage unlimited, which is the
|
|
|
|
default.
|
|
|
|
|
2007-05-13 21:47:09 +02:00
|
|
|
--max-pack-size=<n>::
|
|
|
|
Maximum size of each output packfile, expressed in MiB.
|
|
|
|
If specified, multiple packfiles may be created.
|
|
|
|
The default is unlimited.
|
|
|
|
|
2006-09-17 13:02:59 +02:00
|
|
|
|
2006-10-14 06:28:58 +02:00
|
|
|
Configuration
|
|
|
|
-------------
|
|
|
|
|
|
|
|
When configuration variable `repack.UseDeltaBaseOffset` is set
|
|
|
|
for the repository, the command passes `--delta-base-offset`
|
2008-07-03 07:41:41 +02:00
|
|
|
option to 'git-pack-objects'; this typically results in slightly
|
2006-10-14 06:28:58 +02:00
|
|
|
smaller packs, but the generated packs are incompatible with
|
|
|
|
versions of git older than (and including) v1.4.3; do not set
|
|
|
|
the variable in a repository that older version of git needs to
|
|
|
|
be able to read (this includes repositories from which packs can
|
|
|
|
be copied out over http or rsync, and people who obtained packs
|
|
|
|
that way can try to use older git with it).
|
|
|
|
|
|
|
|
|
2005-08-16 00:48:47 +02:00
|
|
|
Author
|
|
|
|
------
|
|
|
|
Written by Linus Torvalds <torvalds@osdl.org>
|
|
|
|
|
|
|
|
Documentation
|
|
|
|
--------------
|
|
|
|
Documentation by Ryan Anderson <ryan@michonline.com>
|
|
|
|
|
2008-05-29 01:55:27 +02:00
|
|
|
SEE ALSO
|
2005-08-16 00:48:47 +02:00
|
|
|
--------
|
2007-12-29 07:20:38 +01:00
|
|
|
linkgit:git-pack-objects[1]
|
|
|
|
linkgit:git-prune-packed[1]
|
2005-08-16 00:48:47 +02:00
|
|
|
|
|
|
|
GIT
|
|
|
|
---
|
2008-06-06 09:07:32 +02:00
|
|
|
Part of the linkgit:git[1] suite
|