File size: 6,110 Bytes
353e225
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
.\" generated with Ronn/v0.7.3
.\" http://github.com/rtomayko/ronn/tree/0.7.3
.
.TH "GIT\-LFS\-PRUNE" "1" "October 2021" "" ""
.
.SH "NAME"
\fBgit\-lfs\-prune\fR \- Delete old LFS files from local storage
.
.SH "SYNOPSIS"
\fBgit lfs prune\fR \fIoptions\fR
.
.SH "DESCRIPTION"
Deletes local copies of LFS files which are old, thus freeing up disk space\. Prune operates by enumerating all the locally stored objects, and then deleting any which are not referenced by at least ONE of the following:
.
.IP "\(bu" 4
the current checkout
.
.IP "\(bu" 4
all existing stashes
.
.IP "\(bu" 4
a \'recent branch\'; see \fIRECENT FILES\fR
.
.IP "\(bu" 4
a \'recent commit\' on the current branch or recent branches; see \fIRECENT FILES\fR
.
.IP "\(bu" 4
a commit which has not been pushed; see \fIUNPUSHED LFS FILES\fR
.
.IP "\(bu" 4
any other worktree checkouts; see git\-worktree(1)
.
.IP "" 0
.
.P
In general terms, prune will delete files you\'re not currently using and which are not \'recent\', so long as they\'ve been pushed i\.e\. the local copy is not the only one\.
.
.P
The reflog is not considered, only commits\. Therefore LFS objects that are only referenced by orphaned commits are always deleted\.
.
.P
Note: you should not run \fBgit lfs prune\fR if you have different repositories sharing the same custom storage directory; see git\-lfs\-config(1) for more details about \fBlfs\.storage\fR option\.
.
.SH "OPTIONS"
.
.IP "\(bu" 4
\fB\-\-dry\-run\fR \fB\-d\fR Don\'t actually delete anything, just report on what would have been done
.
.IP "\(bu" 4
\fB\-\-force\fR \fB\-f\fR Prune all objects except unpushed objects, including objects required for currently checked out refs\. Implies \fB\-\-recent\fR\.
.
.IP "\(bu" 4
\fB\-\-recent\fR Prune even objects that would normally be preserved by the configuration options specified below in \fIRECENT FILES\fR\.
.
.IP "\(bu" 4
\fB\-\-verify\-remote\fR \fB\-c\fR Contact the remote and check that copies of the files we would delete definitely exist before deleting\. See \fIVERIFY REMOTE\fR\.
.
.IP "\(bu" 4
\fB\-\-no\-verify\-remote\fR Disables remote verification if lfs\.pruneverifyremotealways was enabled in settings\. See \fIVERIFY REMOTE\fR\.
.
.IP "\(bu" 4
\fB\-\-verbose\fR \fB\-v\fR Report the full detail of what is/would be deleted\.
.
.IP "" 0
.
.SH "RECENT FILES"
Prune won\'t delete LFS files referenced by \'recent\' commits, in case you want to use them again without having to download\. The definition of \'recent\' is derived from the one used by git\-lfs\-fetch(1) to download recent objects with the \fB\-\-recent\fR option, with an offset of a number of days (default 3) to ensure that we always keep files you download for a few days\.
.
.P
Here are the git\-config(1) settings that control this behaviour:
.
.IP "\(bu" 4
\fBlfs\.pruneoffsetdays\fR
.
.br
The number of extra days added to the fetch recent settings when using them to decide when to prune\. So for a reference to be considered old enough to prune, it has to be this many days older than the oldest reference that would be downloaded via \fBgit lfs fetch \-\-recent\fR\. Only used if the relevant fetch recent \'days\' setting is non\-zero\. Default 3 days\.
.
.IP "\(bu" 4
\fBlfs\.fetchrecentrefsdays\fR
.
.br
\fBlfs\.fetchrecentremoterefs\fR
.
.br
\fBlfs\.fetchrecentcommitsdays\fR
.
.br
These have the same meaning as git\-lfs\-fetch(1) with the \fB\-\-recent\fR option, they are used as a base for the offset above\. Anything which falls outside of this offsetted window is considered old enough to prune\. If a day value is zero, that condition is not used at all to retain objects and they will be pruned\.
.
.IP "" 0
.
.SH "UNPUSHED LFS FILES"
When the only copy of an LFS file is local, and it is still reachable from any reference, that file can never be pruned, regardless of how old it is\.
.
.P
To determine whether an LFS file has been pushed, we check the difference between local refs and remote refs; where the local ref is ahead, any LFS files referenced in those commits is unpushed and will not be deleted\. This works because the LFS pre\-push hook always ensures that LFS files are pushed before the remote branch is updated\.
.
.P
See \fIDEFAULT REMOTE\fR, for which remote is considered \'pushed\' for pruning purposes\.
.
.SH "VERIFY REMOTE"
The \fB\-\-verify\-remote\fR option calls the remote to ensure that any LFS files to be deleted have copies on the remote before actually deleting them\.
.
.P
Usually the check performed by \fIUNPUSHED LFS FILES\fR is enough to determine that files have been pushed, but if you want to be extra sure at the expense of extra overhead you can make prune actually call the remote API and verify the presence of the files you\'re about to delete locally\. See \fIDEFAULT REMOTE\fR for which remote is checked\.
.
.P
You can make this behaviour the default by setting \fBlfs\.pruneverifyremotealways\fR to true\.
.
.P
In addition to the overhead of calling the remote, using this option also requires prune to distinguish between totally unreachable files (e\.g\. those that were added to the index but never committed, or referenced only by orphaned commits), and files which are still referenced, but by commits which are prunable\. This makes the prune process take longer\.
.
.SH "DEFAULT REMOTE"
When identifying \fIUNPUSHED LFS FILES\fR and performing \fIVERIFY REMOTE\fR, a single remote, \'origin\', is normally used as the reference\. This one remote is considered canonical; even if you use multiple remotes, you probably want to retain your local copies until they\'ve made it to that remote\. \'origin\' is used by default because that will usually be a main central repo, or your fork of it \- in both cases that\'s a valid remote backup of your work\. If origin doesn\'t exist then by default nothing will be pruned because everything is treated as \'unpushed\'\.
.
.P
You can alter the remote via git config: \fBlfs\.pruneremotetocheck\fR\. Set this to a different remote name to check that one instead of \'origin\'\.
.
.SH "SEE ALSO"
git\-lfs\-fetch(1)
.
.P
Part of the git\-lfs(1) suite\.