git cvsimport

优质
小牛编辑
126浏览
2023-12-01

名称

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/