如何在 SVN 中创建分支?
使用 svn copy
命令创建一个新分支,如下所示:
$ svn copy svn+ssh://host.example.com/repos/project/trunk \
svn+ssh://host.example.com/repos/project/branches/NAME_OF_BRANCH \
-m "Creating a branch of project"
Subversion 中的分支是由一个非常轻量级和高效的复制工具来促进的。
分支和标记实际上是相同的。只需使用 svn copy
命令将存储库中的整个文件夹复制到存储库中的其他位置。
基本上,这意味着按照惯例,复制文件夹意味着什么——无论是备份、标签、分支还是其他。根据您对事物的思考方式(通常取决于您过去使用的 SCM 工具),您需要在存储库中设置文件夹结构以支持您的风格。
常见的样式是在您的存储库顶部有一堆文件夹,称为 tags
、branches
、trunk
等 - 允许您将整个 trunk
(或子集)复制到 { 1} 和/或 branches
个文件夹。如果您有多个项目,您可能希望在每个项目下复制这种结构:
习惯这个概念可能需要一段时间 - 但它确实有效 - 只需确保您(和您的团队)清楚您将使用的约定。拥有一个好的命名约定也是一个好主意——它可以告诉你为什么创建分支/标签以及它是否仍然合适——考虑归档过时的分支的方法。
svn cp
使用廉价副本,它确实不在分支期间复制实际文件。请参阅svnbook.red-bean.com/en/1.1/ch04s02.html
如果你的 repo 可以通过 https 获得,你可以使用这个命令来分支 ...
svn copy https://host.example.com/repos/project/trunk \
https://host.example.com/repos/project/branches/branch-name \
-m "Creating a branch of project"
svn cp /trunk/ /branch/NEW_Branch
如果您在主干中有一些本地更改,则使用 Rsync
同步更改
rsync -r -v -p --exclude ".svn" /trunk/ /branch/NEW_Branch
rsync
。 svn cp
还将复制任何本地更改。
假设您想从主干名称(如“TEST”)创建一个分支,然后使用:
svn cp -m "CREATE BRANCH TEST" $svn_url/trunk $svn_url/branches/TEST
给新 SVN 用户的重要提示;这可能有助于快速获取正确的 URL。
运行 svn info
以显示有关当前签出分支的有用信息。
URL 应该(如果您在根文件夹中运行 svn)为您提供需要从中复制的 URL。
同样要切换到新创建的分支,请使用 svn switch
命令:
svn switch http://my.repo.url/myrepo/branches/newBranchName
通常,您会将其复制到 svn+ssh://host.example.com/repos/project/branches/mybranch 以便您可以在存储库中保留多个分支,但您的语法是有效的。
以下是关于 how to set up your repository layout 的一些建议。
如果你甚至打算合并你的分支,我强烈建议你看看这个:
我听说 Subversion 1.5 构建了更多的合并跟踪,我没有这方面的经验。我的项目在 1.4.x 上,svnmerge.py 是救生员!
在当前项目之外创建一个新文件夹。你可以给它任何名字。 (例如:您有一个名为“Customization”的项目的结帐。它有许多项目,例如“Project1”、“Project2”......并且您想创建“Project1”的一个分支。所以首先打开“自定义”,右键单击并创建一个新文件夹并为其命名,“Project1Branch”)。
右键单击“Myproject1”.... TortoiseSVN -> 分支/标签。
选择工作副本。
打开浏览器....就在“To URL”上的平行右侧。
选择自定义.....右键单击然后添加文件夹。并浏览您创建的文件夹。这里是“Project1Branch”。现在单击确定按钮添加。
结帐这个新银行。
再次转到您要创建的项目的分支。右键单击 TorotoiseSVN -> 分支/标签。然后选择工作副本。您可以将 URL 作为您的分支名称。比如{你的 IP 地址/svn/AAAA/Customization/Project1Branch}。您可以在 URL 中设置名称,以便它只创建具有此名称的文件夹。像{您的 IP 地址/svn/AAAA/Customization/Project1Branch/MyProject1Branch}。
按确定按钮。现在您可以看到日志...您的工作副本将存储在您的分支中。
现在您可以结账了……让您享受您的工作。 :)
以下是在 Windows 机器中使用 TortoiseSVN 从主干创建分支的步骤。这显然需要安装 TortoiseSVN 客户端。
右键单击本地 Windows 机器更新的主干 选择 TortoiseSVN 单击分支/标记 选择 SVN 存储库中的 To 路径。请注意,目标 URL 是根据给定的路径和分支名称更新的。不要在存储库浏览器中的分支内创建文件夹添加分支路径。例如,branches/ 添加有意义的日志消息供您参考 单击确定,这将在本地系统上创建新文件夹 签出创建到新文件夹中的分支
不定期副业成功案例分享
svn switch svn+ssh://host.example.com/repos/project/branches/NAME_OF_BRANCH .
(如果您想将当前结帐切换到新分支)或svn checkout svn+ssh://host.example.com/repos/project/branches/NAME_OF_BRANCH
(如果您想在单独的目录中拥有新分支)开始处理新创建的分支。--parents
选项与svn copy
一起使用!-m
选项,它会显示为svn: E155010: Path '/home/constantine/someDirectory/svn+ssh:https:/myhost.com/svn/dir1/dir2/trunk/dir3/dir4/dir5' does not exist
。-m
表示svn: E205009: Local, non-commit operations do not take a log message or revision properties
。 (我替换了地址,但它们确实存在,除了ofc,新的分支目录,以及SVN出于某种原因合并到错误中的整个路径+url)。