directory search
Guides gitattributes giteveryday gitglossary gitignore gitmodules gitrevisions gittutorial gitworkflows Administration git archive git bundle git clean git filter-branch git fsck git gc git instaweb git reflog Basic Snapshotting git add git commit git diff git mv git reset git rm git status Branching and Merging git branch git checkout git log git merge git mergetool git stash git tag Debugging git bisect git blame git grep Email git am git format-patch git request-pull git send-email External Systems git fast-import git svn Getting and Creating Projects git clone git init Git git annotate git archimport git bisect-lk2009 git check-attr git check-mailmap git check-ref-format git checkout-index git cherry git citool git column git credential git credential-cache git credential-store git cvsexportcommit git cvsimport git cvsserver git diff-files git diff-tree git difftool git fast-export git fetch-pack git fmt-merge-msg git get-tar-commit-id git gui git http-backend git http-fetch git http-push git imap-send git index-pack git interpret-trailers git ls-remote git ls-tree git mailinfo git mailsplit git merge-file git merge-index git merge-one-file git merge-tree git mktag git mktree git name-rev git notes git p4 git pack-objects git pack-redundant git pack-refs git parse-remote git patch-id git prune git prune-packed git quiltimport git receive-pack git remote-ext git remote-fd git remote-testgit git repack git replace git rerere git send-pack git sh-i18n git sh-setup git shell git show-branch git show-index git stripspace git unpack-file git unpack-objects git upload-archive git upload-pack git var git verify-commit git verify-tag git whatchanged git worktree Inspection and Comparison git describe git shortlog git show Miscellaneous api credentials api index gitcli gitcore tutorial gitcredentials gitcvs migration gitdiffcore githooks gitk gitnamespaces gitremote helpers gitrepository layout gitsubmodules gittutorial 2 gitweb gitweb.conf pack format User Manual Patching git apply git cherry-pick git rebase git revert Plumbing Commands git cat-file git check-ignore git commit-tree git count-objects git diff-index git for-each-ref git hash-object git ls-files git merge-base git read-tree git rev-list git rev-parse git show-ref git symbolic-ref git update-index git update-ref git verify-pack git write-tree Server Admin git daemon git update-server-info Setup and Config git git config git help Sharing and Updating Projects git fetch git pull git push git remote git submodule
characters

名称

git-cvsimport  - 将您的数据从另一个人们喜欢讨厌的 SCM 中拯救出来

概要

git cvsimport [-o <branch-for-HEAD>] [-h] [-v] [-d <CVSROOT>]              [-A <author-conv-file>] [-p <options-for-cvsps>] [-P <file>]              [-C <git_repository>] [-z <fuzz>] [-i] [-k] [-u] [-s <subst>]              [-a] [-m] [-M <regex>] [-S <regex>] [-L <commitlimit>]              [-r <remote>] [-R] [<CVS_module>]

描述

警告: git cvsimport使用 cvsps 版本2,这被视为弃用; 它不适用于 cvsps 版本3和更高版本。如果您正在执行 CVS 存储库的一次性导入,请考虑使用cvs2git或cvs-fast-export。

将 CVS 存储库导入 Git。它将创建一个新的存储库,或者增量导入到现有的存储库中。

将 CVS 日志分割成补丁集是由cvsps。至少需要2.1版本。

警告:对于某些情况下导入导致不正确的结果。请参阅“问题”一节以作进一步参考。

你应该永远不会做由创建的分支自己的任何工作git cvsimport。默认情况下,初始导入将创建并填充 CVS 存储库的主分支的“主”分支,您可以自由使用该分支; 之后,您需要git merge自行增量导入或任何 CVS 分支。建议通过-r指定一个命名的远程来分隔和保护传入的分支。

如果您打算建立一个所有开发人员都可以读/写的共享公共存储库,或者如果您想使用 git-cvsserver [1],那么您可能想要对导入的存储库进行裸克隆,并将克隆用作共享存储库。请参阅 gitcvs-migration [7]。

选项

-v

详细程度:让我们cvsimport报告它在做什么。

-d <CVSROOT>

CVS 存档的根。可能是本地(简单路径)或远程; 目前,仅支持:local :,:ext:和:pserver:访问方法。如果没有给出,git cvsimport将尝试读取它CVS/Root。如果不存在这样的文件,它检查CVSROOT环境变量。

<CVS_module>

您要导入的 CVS 模块。相对于<CVSROOT>。如果没有给出,git cvsimport尝试从CVS/Repository读取它。

-C <target-dir>

要导入到的 Git 存储库。如果该目录不存在,它将被创建。默认是当前目录。

-r <remote>

将此 CVS 存储库导入到远程的 Git。类似于默认使用origingit clone方式,将所有 CVS 分支移动到远程/ <远程> / <分支>中。

-o <branch-for-HEAD>

如果没有指定 remote(通过-r),则 CVS 的HEAD分支将被导入到 Git 存储库中的origin分支中,因为HEAD已经对 Git 有特殊意义。当指定远程时,HEAD分支命名为远程/远程/主镜像git clone行为。如果要导入到其他分支,请使用此选项。

使用-o master继续,最初由旧的 cvs2git 工具进行导入。

-i

仅导入:导入后不要执行检出切换。这个选项确保工作目录和索引保持不变,如果它们不存在,将不会创建它们。

-k

杀死关键字:将-kk文件从 CVS 存档中提取,以避免噪音变化集。强烈建议,但默认关闭以保持与早期导入树的兼容性。

-u

将标记和分支名称中的下划线转换为点。

-s <subst>

用<subst>替换分支名称中的字符“/”

-p <options-for-cvsps>

cvsps 的其他选项。选项-u-A是隐式的,不应该用在这里。

如果您需要传递多个选项,请用逗号分隔它们。

-z <fuzz>

以秒为单位将时间戳模糊因子传递给 cvsps。如果未设置,则 cvsps 默认为300秒。

-P <cvsps-output-file>

不要调用 cvsps,请阅读提供的 cvsps 输出文件。用于调试或在 cvsimport 之外处理cvsps时使用。

-m

尝试根据提交消息检测合并。此选项将启用试图从提交消息中捕获源分支名称的默认正则表达式。

-M <regex>

尝试使用自定义正则表达式检测基于提交消息的合并。它也可以用来-m启用默认的正则表达式。你必须逃避正斜杠。

正则表达式必须在$ 1中捕获源分支名称。

该选项可以多次使用以提供多个检测正则表达式。

-S <regex>

跳过与正则表达式匹配的路径。

-a

导入所有提交,包括最近的提交。默认情况下,cvsimport会跳过时间小于10分钟前的提交。

-L <limit>

限制导入的提交数量。解决 cvsimport 泄漏内存的问题。

-A <author-conv-file>

默认情况下,CVS 在编写提交日志时使用 Unix 用户名。使用此选项和 author-conv-file 将在 CVS 中记录的名称映射到作者姓名,电子邮件和可选时区:

        exon=Andreas Ericsson <ae@op5.se>
        spawn=Simon Pawn <spawn@frog-pond.org> America/Chicago

git cvsimport将使其显示为这些作者始终正确设置了其 GIT_AUTHOR_NAME和GIT_AUTHOR_EMAIL。如果指定了时区,则 GIT_AUTHOR_DATE 将应用相应的偏移量。

为方便起见,每次-A提供选项时都会保存此数据到$GIT_DIR/cvs-authors,并且每次git cvsimport运行时都会从同一文件中读取。

如果您打算稍后使用git cvsexportcommit再将更改导出回 CVS,则不推荐使用此功能。

-R

生成$GIT_DIR/cvs-revisions包含从 CVS 修订号到新创建的 Git 提交 ID 的映射的文件。生成的文件将为导入的每个(文件名,修订版)对包含一行; 每一行看起来像

src/widget.c 1.1 1d862f173cdc7325b6fa6d2ae1cfd61fd1b512b7

如果修订数据已经存在,则修改数据会附加到该文件,以便在执行增量导入时使用。

如果您将 CVS 修订号存储在提交消息,错误跟踪系统,电子邮件存档等中,则此选项可能很有用。

-h

打印一条简短的使用信息并退出。

输出

如果-v指定,脚本报告它正在做什么。

否则,成功表示为 Unix 方式,即通过简单地以零退出状态退出。

问题

与时间戳有关的问题:

  • 如果 CVS 存储库中的提交时间戳不够稳定,无法用于排序提交,则更改可能以错误的顺序显示。

  • 如果有任何文件曾多次“cvs import”编辑过(例如,导入多个供应商版本),则 HEAD 包含错误的内容。

  • 如果不同文件的时间戳顺序在提交匹配时间窗口内与修订订单相交,提交顺序可能是错误的。与分支有关的问题:

  • 未提交任何提交的分支未导入。

  • 即使从未添加到CVS中,分支点中的所有文件也会添加到分支中。

  • 这适用于创建子分支添加到源分支的文件:如果先前没有对子分支进行提交,它们将错误地添加到 git 中的子分支中。

与标签相关的问题:

  • 不会导入同一修订版中的多个标记。如果您怀疑这些问题中的任何一个可能适用于要导入的存储库,请考虑使用 cvs2git:

  • cvs2git (part of cvs2svn), http://subversion.apache.org/

Previous article: Next article: