ChatGPT解决这个技术问题 Extra ChatGPT

如何在 SVN 中创建分支?


D
Dave Jarvis

使用 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"

接下来使用 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 一起使用!
出于某种原因,我使用了这个 cmd,但它不起作用,但是当我将 svn+ssh 更改为 https 时,它确实起作用了。我做错什么了吗? svn+ssh 是什么意思?谢谢!
您必须首先在您的分支中创建一个新目录 -> svn mkdir host.example.com/repos/project/branches/NAME_OF_BRANCH -m "使分支目录包含所有分支"
如果我省略 -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)
A
Alexander Abakumov

Subversion 中的分支是由一个非常轻量级和高效的复制工具来促进的。

分支和标记实际上是相同的。只需使用 svn copy 命令将存储库中的整个文件夹复制到存储库中的其他位置。

基本上,这意味着按照惯例,复制文件夹意味着什么——无论是备份、标签、分支还是其他。根据您对事物的思考方式(通常取决于您过去使用的 SCM 工具),您需要在存储库中设置文件夹结构以支持您的风格。

常见的样式是在您的存储库顶部有一堆文件夹,称为 tagsbranchestrunk 等 - 允许您将整个 trunk(或子集)复制到 { 1} 和/或 branches 个文件夹。如果您有多个项目,您可能希望在每个项目下复制这种结构:

习惯这个概念可能需要一段时间 - 但它确实有效 - 只需确保您(和您的团队)清楚您将使用的约定。拥有一个好的命名约定也是一个好主意——它可以告诉你为什么创建分支/标签以及它是否仍然合适——考虑归档过时的分支的方法。


“svn copy”的优点是它将保留分支之前的历史记录。手动复制到另一个目录不会。
另请注意,标记或分支“主干”的子目录通常不是一个好主意。这使得很难跟踪哪个子目录被分支,并且大多数工具会被这些分支混淆(例如切换分支将意味着 WC 的目录结构发生变化,这会混淆 IDE 和构建工具)。只是总是分支“主干”。
@Will 实际上 svn cp 使用廉价副本,它确实在分支期间复制实际文件。请参阅svnbook.red-bean.com/en/1.1/ch04s02.html
D
Dave

如果你的 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"

P
Parag Bafna
svn cp /trunk/ /branch/NEW_Branch

如果您在主干中有一些本地更改,则使用 Rsync 同步更改

rsync -r -v -p --exclude ".svn" /trunk/ /branch/NEW_Branch

不需要以这种方式使用 rsyncsvn cp 还将复制任何本地更改。
@KevinPanko 它不会复制未提交的更改。
确实如此,用 svn 确认,版本 1.8.5
我想知道这个。这似乎是最简单的选择,AFAI 记得,这是我 3 年前使用 SVN 时所做的。但是,这与直接使用服务器 url 的有什么区别?
@KevinPanko你知道它是否也复制新创建的文件?
P
Peter Mortensen

假设您想从主干名称(如“TEST”)创建一个分支,然后使用:

svn cp -m "CREATE BRANCH TEST" $svn_url/trunk $svn_url/branches/TEST

P
Peter Mortensen

给新 SVN 用户的重要提示;这可能有助于快速获取正确的 URL。

运行 svn info 以显示有关当前签出分支的有用信息。

URL 应该(如果您在根文件夹中运行 svn)为您提供需要从中复制的 URL。

同样要切换到新创建的分支,请使用 svn switch 命令:

svn switch http://my.repo.url/myrepo/branches/newBranchName

您还可以使用 ^ 代替存储库根目录
p
pix0r

通常,您会将其复制到 svn+ssh://host.example.com/repos/project/branches/mybranch 以便您可以在存储库中保留多个分支,但您的语法是有效的。

以下是关于 how to set up your repository layout 的一些建议。


b
basszero

如果你甚至打算合并你的分支,我强烈建议你看看这个:

Svnmerge.py

我听说 Subversion 1.5 构建了更多的合并跟踪,我没有这方面的经验。我的项目在 1.4.x 上,svnmerge.py 是救生员!


P
Peter Mortensen

在当前项目之外创建一个新文件夹。你可以给它任何名字。 (例如:您有一个名为“Customization”的项目的结帐。它有许多项目,例如“Project1”、“Project2”......并且您想创建“Project1”的一个分支。所以首先打开“自定义”,右键单击并创建一个新文件夹并为其命名,“Project1Branch”)。

右键单击“Myproject1”.... TortoiseSVN -> 分支/标签。

选择工作副本。

打开浏览器....就在“To URL”上的平行右侧。

选择自定义.....右键单击然后添加文件夹。并浏览您创建的文件夹。这里是“Project1Branch”。现在单击确定按钮添加。

结帐这个新银行。

再次转到您要创建的项目的分支。右键单击 TorotoiseSVN -> 分支/标签。然后选择工作副本。您可以将 URL 作为您的分支名称。比如{你的 IP 地址/svn/AAAA/Customization/Project1Branch}。您可以在 URL 中设置名称,以便它只创建具有此名称的文件夹。像{您的 IP 地址/svn/AAAA/Customization/Project1Branch/MyProject1Branch}。

按确定按钮。现在您可以看到日志...您的工作副本将存储在您的分支中。

现在您可以结账了……让您享受您的工作。 :)


P
Prashanth

以下是在 Windows 机器中使用 TortoiseSVN 从主干创建分支的步骤。这显然需要安装 TortoiseSVN 客户端。

右键单击本地 Windows 机器更新的主干 选择 TortoiseSVN 单击分支/标记 选择 SVN 存储库中的 To 路径。请注意,目标 URL 是根据给定的路径和分支名称更新的。不要在存储库浏览器中的分支内创建文件夹添加分支路径。例如,branches/ 添加有意义的日志消息供您参考 单击确定,这将在本地系统上创建新文件夹 签出创建到新文件夹中的分支