114 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
| git-archimport(1)
 | |
| =================
 | |
| 
 | |
| NAME
 | |
| ----
 | |
| git-archimport - Import a GNU Arch repository into Git
 | |
| 
 | |
| 
 | |
| SYNOPSIS
 | |
| --------
 | |
| [verse]
 | |
| 'git archimport' [-h] [-v] [-o] [-a] [-f] [-T] [-D depth] [-t tempdir]
 | |
|                <archive/branch>[:<git-branch>] ...
 | |
| 
 | |
| DESCRIPTION
 | |
| -----------
 | |
| Imports a project from one or more GNU Arch repositories.
 | |
| It will follow branches
 | |
| and repositories within the namespaces defined by the <archive/branch>
 | |
| parameters supplied. If it cannot find the remote branch a merge comes from
 | |
| it will just import it as a regular commit. If it can find it, it will mark it
 | |
| as a merge whenever possible (see discussion below).
 | |
| 
 | |
| The script expects you to provide the key roots where it can start the import
 | |
| from an 'initial import' or 'tag' type of Arch commit. It will follow and
 | |
| import new branches within the provided roots.
 | |
| 
 | |
| It expects to be dealing with one project only. If it sees
 | |
| branches that have different roots, it will refuse to run. In that case,
 | |
| edit your <archive/branch> parameters to define clearly the scope of the
 | |
| import.
 | |
| 
 | |
| 'git archimport' uses `tla` extensively in the background to access the
 | |
| Arch repository.
 | |
| Make sure you have a recent version of `tla` available in the path. `tla` must
 | |
| know about the repositories you pass to 'git archimport'.
 | |
| 
 | |
| For the initial import, 'git archimport' expects to find itself in an empty
 | |
| directory. To follow the development of a project that uses Arch, rerun
 | |
| 'git archimport' with the same parameters as the initial import to perform
 | |
| incremental imports.
 | |
| 
 | |
| While 'git archimport' will try to create sensible branch names for the
 | |
| archives that it imports, it is also possible to specify Git branch names
 | |
| manually.  To do so, write a Git branch name after each <archive/branch>
 | |
| parameter, separated by a colon.  This way, you can shorten the Arch
 | |
| branch names and convert Arch jargon to Git jargon, for example mapping a
 | |
| "PROJECT{litdd}devo{litdd}VERSION" branch to "master".
 | |
| 
 | |
| Associating multiple Arch branches to one Git branch is possible; the
 | |
| result will make the most sense only if no commits are made to the first
 | |
| branch, after the second branch is created.  Still, this is useful to
 | |
| convert Arch repositories that had been rotated periodically.
 | |
| 
 | |
| 
 | |
| MERGES
 | |
| ------
 | |
| Patch merge data from Arch is used to mark merges in Git as well. Git
 | |
| does not care much about tracking patches, and only considers a merge when a
 | |
| branch incorporates all the commits since the point they forked. The end result
 | |
| is that Git will have a good idea of how far branches have diverged. So the
 | |
| import process does lose some patch-trading metadata.
 | |
| 
 | |
| Fortunately, when you try and merge branches imported from Arch,
 | |
| Git will find a good merge base, and it has a good chance of identifying
 | |
| patches that have been traded out-of-sequence between the branches.
 | |
| 
 | |
| OPTIONS
 | |
| -------
 | |
| 
 | |
| -h::
 | |
| 	Display usage.
 | |
| 
 | |
| -v::
 | |
| 	Verbose output.
 | |
| 
 | |
| -T::
 | |
| 	Many tags. Will create a tag for every commit, reflecting the commit
 | |
| 	name in the Arch repository.
 | |
| 
 | |
| -f::
 | |
| 	Use the fast patchset import strategy.  This can be significantly
 | |
| 	faster for large trees, but cannot handle directory renames or
 | |
| 	permissions changes.  The default strategy is slow and safe.
 | |
| 
 | |
| -o::
 | |
| 	Use this for compatibility with old-style branch names used by
 | |
| 	earlier versions of 'git archimport'.  Old-style branch names
 | |
| 	were category{litdd}branch, whereas new-style branch names are
 | |
| 	archive,category{litdd}branch{litdd}version.  In both cases, names given
 | |
| 	on the command-line will override the automatically-generated
 | |
| 	ones.
 | |
| 
 | |
| -D <depth>::
 | |
| 	Follow merge ancestry and attempt to import trees that have been
 | |
| 	merged from.  Specify a depth greater than 1 if patch logs have been
 | |
| 	pruned.
 | |
| 
 | |
| -a::
 | |
| 	Attempt to auto-register archives at `http://mirrors.sourcecontrol.net`
 | |
| 	This is particularly useful with the -D option.
 | |
| 
 | |
| -t <tmpdir>::
 | |
| 	Override the default tempdir.
 | |
| 
 | |
| 
 | |
| <archive/branch>::
 | |
| 	Archive/branch identifier in a format that `tla log` understands.
 | |
| 
 | |
| 
 | |
| GIT
 | |
| ---
 | |
| Part of the linkgit:git[1] suite
 |