Provided by: git-lfs_2.9.2-1_amd64 bug

NAME

       git-lfs-prune - Delete old LFS files from local storage

SYNOPSIS

       git lfs prune #OPTIONS

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:

       ○   the current checkout

       ○   a ´recent branch´; see #RECENT-FILES

       ○   a ´recent commit´ on the current branch or recent branches; see #RECENT-FILES

       ○   a commit which has not been pushed; see #UNPUSHED-LFS-FILES

       ○   any other worktree checkouts; see git-worktree(1)

       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.

       The reflog is not considered, only commits. Therefore LFS objects that are only  referenced  by  orphaned
       commits are always deleted.

       Note: you should not run git lfs prune if you have different repositories sharing the same custom storage
       directory; see git-lfs-config(1) for more details about lfs.storage option.

OPTIONS

--dry-run -d Don´t actually delete anything, just report on what would have been done

       ○   --verify-remote  -c  Contact the remote and check that copies of the files we would delete definitely
           exist before deleting. See #VERIFY-REMOTE.

       ○   --no-verify-remote  Disables  remote  verification  if  lfs.pruneverifyremotealways  was  enabled  in
           settings. See #VERIFY-REMOTE.

       ○   --verbose -v Report the full detail of what is/would be deleted.

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  --recent  option, with an offset of a number of days (default 3) to
       ensure that we always keep files you download for a few days.

       Here are the git-config(1) settings that control this behaviour:

       ○   lfs.pruneoffsetdays
           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 git lfs fetch --recent. Only used if the relevant fetch
           recent ´days´ setting is non-zero. Default 3 days.

       ○   lfs.fetchrecentrefsdays
           lfs.fetchrecentremoterefs
           lfs.fetchrecentcommitsdays
           These have the same meaning as git-lfs-fetch(1) with the --recent 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.

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.

       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.

       See #DEFAULT-REMOTE, for which remote is considered ´pushed´ for pruning purposes.

VERIFY REMOTE

       The --verify-remote option calls the remote to ensure that any LFS files to be deleted have copies on the
       remote before actually deleting them.

       Usually  the  check  performed by #UNPUSHED-LFS-FILES 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 #DEFAULT-REMOTE for
       which remote is checked.

       You can make this behaviour the default by setting lfs.pruneverifyremotealways to true.

       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.

DEFAULT REMOTE

       When  identifying  #UNPUSHED-LFS-FILES  and  performing  #VERIFY-REMOTE,  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 master 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´.

       You  can  alter the remote via git config: lfs.pruneremotetocheck. Set this to a different remote name to
       check that one instead of ´origin´.

SEE ALSO

       git-lfs-fetch(1)

       Part of the git-lfs(1) suite.

                                                  December 2019                                 GIT-LFS-PRUNE(1)