|
.\" generated with Ronn/v0.7.3 |
|
.\" http://github.com/rtomayko/ronn/tree/0.7.3 |
|
. |
|
.TH "GIT\-LFS\-MIGRATE" "1" "October 2021" "" "" |
|
. |
|
.SH "NAME" |
|
\fBgit\-lfs\-migrate\fR \- Migrate history to or from Git LFS |
|
. |
|
.SH "SYNOPSIS" |
|
\fBgit lfs migrate\fR \fImode\fR [options] [\-\-] [branch \.\.\.] |
|
. |
|
.SH "DESCRIPTION" |
|
Convert files in a Git repository to or from Git LFS pointers, or summarize Git file sizes by file type\. The \fBimport\fR mode converts Git files (i\.e\., blobs) to Git LFS, while the \fBexport\fR mode does the reverse, and the \fBinfo\fR mode provides an informational summary which may be useful in deciding which files to import or export\. |
|
. |
|
.P |
|
In all modes, by default \fBgit lfs migrate\fR operates only on the currently checked\-out branch, and only on files (of any size and type) added in commits which do not exist on any remote\. Multiple options are available to override these defaults\. |
|
. |
|
.P |
|
When converting files to or from Git LFS, the \fBgit lfs migrate\fR command will only make changes to your local repository and working copy, never any remotes\. This is intentional as the \fBimport\fR and \fBexport\fR modes are generally "destructive" in the sense that they rewrite your Git history, changing commits and generating new commit SHAs\. (The exception is the "no\-rewrite" \fBimport\fR sub\-mode; see [IMPORT (NO REWRITE)] for details\.) |
|
. |
|
.P |
|
You should therefore always first commit or stash any uncommitted work before using the \fBimport\fR or \fBexport\fR modes, and then validate the result of the migration before pushing the changes to your remotes, for instance by running the \fBinfo\fR mode and by examining your rewritten commit history\. |
|
. |
|
.P |
|
Once you are satisfied with the changes, you will need to force\-push the new Git history of any rewritten branches to all your remotes\. This is a step which should be taken with care, since you will be altering the Git history on your remotes\. |
|
. |
|
.P |
|
To examine or modify files in branches other than the currently checked\-out one, branch refs may be specified directly, or provided in one or more \fB\-\-include\-ref\fR options\. They may also be excluded by prefixing them with \fB^\fR or providing them in \fB\-\-exclude\-ref\fR options\. Use the \fB\-\-everything\fR option to specify that all refs should be examined, including all remote refs\. See [INCLUDE AND EXCLUDE (REFS)] for details\. |
|
. |
|
.P |
|
For the \fBinfo\fR and \fBimport\fR modes, all file types are considered by default; while useful in the \fBinfo\fR mode, this is often not desirable when importing, so either filename patterns (pathspecs) or the \fB\-\-fixup\fR option should normally be specified in that case\. (At least one include pathspec is required for the \fBexport\fR mode\.) Pathspecs may be defined using the \fB\-\-include\fR and \fB\-\-exclude\fR options (\fB\-I\fR and \fB\-X\fR for short), as described in \fIINCLUDE AND EXCLUDE\fR\. |
|
. |
|
.P |
|
As typical Git LFS usage depends on tracking specific file types using filename patterns defined in \fB\.gitattributes\fR files, the \fBgit lfs migrate\fR command will examine, create, and modify \fB\.gitattributes\fR files as necessary\. |
|
. |
|
.P |
|
The \fBimport\fR mode (see \fIIMPORT\fR) will convert Git objects of the file types specified (e\.g\., with \fB\-\-include\fR) to Git LFS pointers, and will add entries for those file types to \fB\.gitattributes\fR files, creating those files if they do not exist\. The result should be as if \fBgit lfs track\fR commands had been run at the points in your Git history corresponding to where each type of converted file first appears\. The exception is if the \fB\-\-fixup\fR option is given, in which case the \fBimport\fR mode will only examine any existing \fB\.gitattributes\fR files and then convert Git objects which should be tracked by Git LFS but are not yet\. |
|
. |
|
.P |
|
The \fBexport\fR mode (see \fIEXPORT\fR) works as the reverse operation to the \fBimport\fR mode, converting any Git LFS pointers that match the file types specified with \fB\-\-include\fR, which must be given at least once\. Note that \fB\.gitattributes\fR entries will not be removed, nor will the files; instead, the \fBexport\fR mode inserts "do not track" entries similar to those created by the \fBgit lfs untrack\fR command\. The \fB\-\-remote\fR option is available in the \fBexport\fR mode to specify the remote from which Git LFS objects should be fetched if they do not exist in the local Git LFS object cache; if not provided, \fBorigin\fR is used by default\. |
|
. |
|
.P |
|
The \fBinfo\fR mode (see \fIINFO\fR) summarizes by file type (i\.e\., by filename extension) the total number and size of files in a repository\. Note that like the other two modes, by default the \fBinfo\fR mode operates only on the currently checked\-out branch and only on commits which do not exist on any remote, so to get a summary of the entire repository across all branches, use the \fB\-\-everything\fR option\. If objects have already been converted to Git LFS pointers, then by default the size of the referenced objects is totaled and reported separately\. You may also choose to ignore them by using \fB\-\-pointers=ignore\fR or to treat the pointers as files by using \fB\-\-pointers=no\-follow\fR\. (The latter option is akin to how existing Git LFS pointers were handled by the \fBinfo\fR mode in prior versions of Git LFS)\. |
|
. |
|
.P |
|
When using the \fB\-\-everything\fR option, take note that it means all refs (local and remote) will be considered, but not necessarily all file types\. The \fBimport\fR and \fBinfo\fR modes consider all file types by default, although the \fB\-\-include\fR and \fB\-\-exclude\fR options constrain this behavior\. Also note that after importing across all branches with the \fB\-\-everything\fR option (and then checking to ensure the results are satisfactory!) it may be convenient to update multiple branches on your remotes by using the \fB\-\-all\fR option to \fBgit push\fR\. |
|
. |
|
.P |
|
Unless the \fB\-\-skip\-fetch\fR option is given, \fBgit lfs migrate\fR always begins by fetching updated lists of refs from all the remotes returned by \fBgit remote\fR, but as noted above, after making changes to your local Git history while converting objects, it will never automatically push those changes to your remotes\. |
|
. |
|
.SH "MODES" |
|
. |
|
.IP "\(bu" 4 |
|
\fBinfo\fR Show information about repository size\. See \fIINFO\fR\. |
|
. |
|
.IP "\(bu" 4 |
|
\fBimport\fR Convert Git objects to Git LFS pointers\. See \fIIMPORT\fR and [IMPORT (NO REWRITE)]\. |
|
. |
|
.IP "\(bu" 4 |
|
\fBexport\fR Convert Git LFS pointers to Git objects\. See \fIEXPORT\fR\. |
|
. |
|
.IP "" 0 |
|
. |
|
.SH "OPTIONS" |
|
. |
|
.TP |
|
\fB\-I\fR \fIpaths\fR \fB\-\-include=\fR\fIpaths\fR |
|
See \fIINCLUDE AND EXCLUDE\fR\. |
|
. |
|
.TP |
|
\fB\-X\fR \fIpaths\fR \fB\-\-exclude=\fR\fIpaths\fR |
|
See \fIINCLUDE AND EXCLUDE\fR\. |
|
. |
|
.TP |
|
\fB\-\-include\-ref\fR=\fIrefname\fR |
|
See [INCLUDE AND EXCLUDE (REFS)]\. |
|
. |
|
.TP |
|
\fB\-\-exclude\-ref\fR=\fIrefname\fR |
|
See [INCLUDE AND EXCLUDE (REFS)]\. |
|
. |
|
.TP |
|
\fB\-\-skip\-fetch\fR |
|
Assumes that the known set of remote references is complete, and should not be refreshed when determining the set of "un\-pushed" commits to migrate\. Has no effect when combined with \fB\-\-include\-ref\fR or \fB\-\-exclude\-ref\fR\. |
|
. |
|
.TP |
|
\fB\-\-everything\fR |
|
See [INCLUDE AND EXCLUDE (REFS)]\. |
|
. |
|
.IP |
|
Note: Git refs are "case\-sensitive" on all platforms in "packed from" (see \fBgit\-pack\-refs(1)\fR)\. On "case\-insensitive" file systems, e\.g\. NTFS on Windows or default APFS on macOS, \fBgit\-lfs\-migrate(1)\fR would only migrate the first ref if two or more refs are equal except for upper/lower case letters\. |
|
. |
|
.TP |
|
\fB\-\-yes\fR |
|
Assume a yes answer to any prompts, permitting noninteractive use\. Currently, the only such prompt is the one asking whether to overwrite (destroy) any working copy changes\. Thus, specifying this option may cause data loss if you are not careful\. |
|
. |
|
.TP |
|
[branch \.\.\.] |
|
Migrate only the set of branches listed\. If not given, \fBgit\-lfs\-migrate(1)\fR will migrate the currently checked out branch\. |
|
. |
|
.IP |
|
References beginning with \fB^\fR will be excluded, whereas branches that do not begin with \fB^\fR will be included\. |
|
. |
|
.IP |
|
If any of \fB\-\-include\-ref\fR or \fB\-\-exclude\-ref\fR are given, the checked out branch will not be appended, but branches given explicitly will be appended\. |
|
. |
|
.SS "INFO" |
|
The \fBinfo\fR mode summarizes the sizes of file objects present in the Git history\. It supports all the core \fBmigrate\fR options and these additional ones: |
|
. |
|
.IP "\(bu" 4 |
|
\fB\-\-above=<size>\fR Only count files whose individual filesize is above the given size\. \fBsize\fR may be specified as a number of bytes, or a number followed by a storage unit, e\.g\., "1b", "20 MB", "3 TiB", etc\. |
|
. |
|
.IP |
|
If a set of files sharing a common extension has no files in that set whose individual size is above the given \fB\-\-above\fR no files no entry for that set will be shown\. |
|
. |
|
.IP "\(bu" 4 |
|
\fB\-\-top=<n>\fR Only display the top \fBn\fR entries, ordered by how many total files match the given pathspec\. The default is to show only the top 5 entries\. When existing Git LFS objects are found, an extra, separate "LFS Objects" line is output in addition to the top \fBn\fR entries, unless the \fB\-\-pointers\fR option is used to change this behavior\. |
|
. |
|
.IP "\(bu" 4 |
|
\fB\-\-unit=<unit>\fR Format the number of bytes in each entry as a quantity of the storage unit provided\. Valid units include: |
|
. |
|
.IP "" 4 |
|
. |
|
.nf |
|
|
|
* b, kib, mib, gib, tib, pib \- for IEC storage units |
|
* b, kb, mb, gb, tb, pb \- for SI storage units |
|
. |
|
.fi |
|
. |
|
.IP "" 0 |
|
. |
|
.IP |
|
If a \fB\-\-unit\fR is not specified, the largest unit that can fit the number of counted bytes as a whole number quantity is chosen\. |
|
. |
|
.IP "\(bu" 4 |
|
\fB\-\-pointers=[follow|no\-follow|ignore]\fR Treat existing Git LFS pointers in the history according to one of three alternatives\. In the default \fBfollow\fR case, if any pointers are found, an additional separate "LFS Objects" line item is output which summarizes the total number and size of the Git LFS objects referenced by pointers\. In the \fBignore\fR case, any pointers are simply ignored, while the \fBno\-follow\fR case replicates the behavior of the \fBinfo\fR mode in older Git LFS versions and treats any pointers it finds as if they were regular files, so the output totals only include the contents of the pointers, not the contents of the objects to which they refer\. |
|
. |
|
.IP "\(bu" 4 |
|
\fB\-\-fixup\fR Infer \fB\-\-include\fR and \fB\-\-exclude\fR filters on a per\-commit basis based on the \.gitattributes files in a repository\. In practice, this option counts any filepaths which should be tracked by Git LFS according to the repository\'s \.gitattributes file(s), but aren\'t already pointers\. The \.gitattributes files are not reported, in contrast to the normal output of the \fBinfo\fR mode\. This option is incompatible with explicitly given \fB\-\-include\fR, \fB\-\-exclude\fR filters and with any \fB\-\-pointers\fR setting other than \fBignore\fR, hence \fB\-\-fixup\fR implies \fB\-\-pointers=ignore\fR if it is not explicitly set\. |
|
. |
|
.IP "" 0 |
|
. |
|
.P |
|
The format of the output shows the filename pattern, the total size of the file objects (excluding those below the \fB\-\-above\fR threshold, if one was defined), and the ratio of the number of files above the threshold to the total number of files; this ratio is also shown as a percentage\. For example: |
|
. |
|
.IP "" 4 |
|
. |
|
.nf |
|
|
|
*\.gif 93 MB 9480/10504 files(s) 90% |
|
*\.png 14 MB 1732/1877 files(s) 92% |
|
. |
|
.fi |
|
. |
|
.IP "" 0 |
|
. |
|
.P |
|
By default only the top five entries are shown, but \fB\-\-top\fR allows for more or fewer to be output as desired\. |
|
. |
|
.SS "IMPORT" |
|
The \fBimport\fR mode migrates objects present in the Git history to pointer files tracked and stored with Git LFS\. It supports all the core \fBmigrate\fR options and these additional ones: |
|
. |
|
.IP "\(bu" 4 |
|
\fB\-\-verbose\fR Print the commit oid and filename of migrated files to STDOUT\. |
|
. |
|
.IP "\(bu" 4 |
|
\fB\-\-above=<size>\fR Only migrate files whose individual filesize is above the given size\. \fBsize\fR may be specified as a number of bytes, or a number followed by a storage unit, e\.g\., "1b", "20 MB", "3 TiB", etc\. |
|
. |
|
.IP "\(bu" 4 |
|
\fB\-\-object\-map=<path>\fR Write to \fBpath\fR a file with the mapping of each rewritten commits\. The file format is CSV with this pattern: \fBOLD\-SHA\fR,\fBNEW\-SHA\fR |
|
. |
|
.IP "\(bu" 4 |
|
\fB\-\-no\-rewrite\fR Migrate objects to Git LFS in a new commit without rewriting Git history\. Please note that when this option is used, the \fBmigrate import\fR command will expect a different argument list, specialized options will become available, and the core \fBmigrate\fR options will be ignored\. See [IMPORT (NO REWRITE)]\. |
|
. |
|
.IP "\(bu" 4 |
|
\fB\-\-fixup\fR Infer \fB\-\-include\fR and \fB\-\-exclude\fR filters on a per\-commit basis based on the \fB\.gitattributes\fR files in a repository\. In practice, this option imports any filepaths which should be tracked by Git LFS according to the repository\'s \fB\.gitattributes\fR file(s), but aren\'t already pointers\. This option is incompatible with explicitly given \fB\-\-include\fR, \fB\-\-exclude\fR filters\. |
|
. |
|
.IP "" 0 |
|
. |
|
.P |
|
If \fB\-\-no\-rewrite\fR is not provided and \fB\-\-include\fR or \fB\-\-exclude\fR (\fB\-I\fR, \fB\-X\fR, respectively) are given, the \fB\.gitattributes\fR will be modified to include any new filepath patterns as given by those flags\. |
|
. |
|
.P |
|
If \fB\-\-no\-rewrite\fR is not provided and neither of those flags are given, the gitattributes will be incrementally modified to include new filepath extensions as they are rewritten in history\. |
|
. |
|
.SS "IMPORT (NO REWRITE)" |
|
The \fBimport\fR mode has a special sub\-mode enabled by the \fB\-\-no\-rewrite\fR flag\. This sub\-mode will migrate objects to pointers as in the base \fBimport\fR mode, but will do so in a new commit without rewriting Git history\. When using this sub\-mode, the base \fBmigrate\fR options, such as \fB\-\-include\-ref\fR, will be ignored, as will those for the base \fBimport\fR mode\. The \fBmigrate\fR command will also take a different argument list\. As a result of these changes, \fB\-\-no\-rewrite\fR will only operate on the current branch \- any other interested branches must have the generated commit merged in\. |
|
. |
|
.P |
|
The \fB\-\-no\-rewrite\fR sub\-mode supports the following options and arguments: |
|
. |
|
.IP "\(bu" 4 |
|
\fB\-m <message> \-\-message=<message>\fR Specifies a commit message for the newly created commit\. |
|
. |
|
.IP "\(bu" 4 |
|
[file \.\.\.] The list of files to import\. These files must be tracked by patterns specified in the gitattributes\. |
|
. |
|
.IP "" 0 |
|
. |
|
.P |
|
If \fB\-\-message\fR is given, the new commit will be created with the provided message\. If no message is given, a commit message will be generated based on the file arguments\. |
|
. |
|
.SS "EXPORT" |
|
The \fBexport\fR mode migrates Git LFS pointer files present in the Git history out of Git LFS, converting them into their corresponding object files\. It supports all the core \fBmigrate\fR options and these additional ones: |
|
. |
|
.IP "\(bu" 4 |
|
\fB\-\-verbose\fR Print the commit oid and filename of migrated files to STDOUT\. |
|
. |
|
.IP "\(bu" 4 |
|
\fB\-\-object\-map=<path>\fR Write to \fBpath\fR a file with the mapping of each rewritten commit\. The file format is CSV with this pattern: \fBOLD\-SHA\fR,\fBNEW\-SHA\fR |
|
. |
|
.IP "\(bu" 4 |
|
\fB\-\-remote=<git\-remote>\fR Download LFS objects from the provided \fBgit\-remote\fR during the export\. If not provided, defaults to \fBorigin\fR\. |
|
. |
|
.IP "" 0 |
|
. |
|
.P |
|
The \fBexport\fR mode requires at minimum a pattern provided with the \fB\-\-include\fR argument to specify which files to export\. Files matching the \fB\-\-include\fR patterns will be removed from Git LFS, while files matching the \fB\-\-exclude\fR patterns will retain their Git LFS status\. The export command will modify the \fB\.gitattributes\fR to set/unset any filepath patterns as given by those flags\. |
|
. |
|
.SH "INCLUDE AND EXCLUDE" |
|
You can specify that \fBgit lfs migrate\fR should only convert files whose pathspec matches the \fB\-\-include\fR glob patterns and does not match the \fB\-\-exclude\fR glob patterns, either to reduce total migration time or to only migrate part of your repo\. Multiple patterns may be given using commas as delimiters\. |
|
. |
|
.P |
|
Pattern matching is done so as to be functionally equivalent to the pattern matching format of \fB\.gitattributes\fR\. In addition to simple file extension matches (e\.g\., \fB*\.gif\fR) patterns may also specify directory paths, in which case the \fBpath |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|