- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在使用 Mercurial 时,我想听取您的意见,了解我应该使用以下哪些例程,或者哪些例程更可取。假设我有最新的代码。
第一个例程如下:
hg 提交
hg pull
,hg update
hg merge
, hg commit
Mercurial push
第二个是:
hg pull
,hg update
hg commit
, hg push
事实是,据我所知,第一种选择是大多数开发人员(应该)使用的选择,因为与第二种选择不同,它提供了使用本地存储库的机会,因为它是DVCS 的正常情况。
我的同事鼓励我使用第二种方式,因为那样我就避免了分支和以后可能出现的 merge 问题(因为在过去,不知何故,他们有这样的问题),所以我留在主干开发线上。我想第一个选项应该是更可取的选项,因为与 CVCS 不同,在 DVCS 中 merge 是不应该害怕的事情,它让我有机会使用本地存储库。
最佳答案
在这两种情况下,您将要做的工作没有任何区别:
对于第一个工作流程,您将在第 5 步中进行 merge 。
在第二个工作流中,您执行与步骤 2 中更新的一部分完全相同的 merge 。
第一个工作流程对许多人来说感觉更安全,因为您正在处理已经提交的工作。这意味着如果 merge 变得很复杂,回到干净状态是微不足道的:hg update -C .
。
但实际上,即使使用第二个工作流程,您也可以取回原始文件:hg resolve --all --tool internal:local
将重做 hg update
的 merge 启动并为所有文件选择原始版本。
真正的区别在于第一个工作流程更好地展示了实际发生的事情。使用该工作流程,您可以以更小、更合乎逻辑的步骤展示您的更改。当您的大学试图了解您所做的事情(代码审查)以及 future 的调试(使用 hg bisect
)时,这会很有帮助。
您可以使用 hg rebase
两全其美。这让你可以做出小而合乎逻辑的 promise ,然后最终将这些 promise 转移到你的大学所做的工作之上。在那种情况下不会有 merge 变更集——很好且丰富的线性历史。
因此,如果您在拉取后有此历史记录:
... [a] --- [b] --- [x] --- [y] --- [z]
\
[d] --- [e]
您在其中创建了 x
到 z
,然后正常 merge 将创建此历史记录:
... [a] --- [b] --- [x] --- [y] --- [z]
\ \
[d] --- [e] ----------- [f]
通过 rebase 你得到
... [a] --- [b] --- [d] --- [e] --- [x'] --- [y'] --- [z']
其中 x'
到 z'
是 x
到 z
的 rebase 版本(不同的变更集 ID,因为他们有不同的祖先)。
我一直都这样使用 rebase ,我觉得它提供了最好的整体历史记录。请记住不要对已经公开的变更集进行 rebase : rebase 会修改变更集,但是如果变更集已经公开,那么您就很难修改其他副本。结果是重复的变更集和困惑。
关于version-control - 使用 Mercurial Hg 时的替代例程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7104504/
我正在使用JQuery Mobile,有两个可用版本:稳定版和旧版。我不熟悉后者。 什么是旧版?或与稳定版有什么区别? 建议在生产现场中使用哪一个? 非常感谢 最佳答案 旧版本是一个旧的稳定版本,由于
Lotus Notes 具有“版本控制”功能。您可以将其设置为在用户需要单击 File->New->Version 以创建新版本的模式下工作。我想在表单上的按钮中使用该功能。 有没有办法(使用 Lot
关闭。这个问题是opinion-based 。目前不接受答案。 已关闭10 年前。 已锁定。这个问题及其答案是locked因为这个问题是题外话,但却具有历史意义。目前不接受新的答案或互动。 是否有任何
我对使用数据库和数据库设计/创建模式非常陌生,我非常感谢一些建议/建议。我正在创建一个应用程序,用户在其中输入数据,并向用户提供该数据的版本控制。用户可以进入并恢复更改或更新值(有点像 git)等,我
尝试启动带头 Selenium session 时出现此错误。 我使用的命令是driver = webdriver.Chrome(executable_path=r'C:\Users\Administ
Apple 的文档本来可以更清楚地说明如何提交更新版本。 正如标题所问,有什么区别 itunes connect 中的版本号(提交更新时必须提供) xcode 中的捆绑版本 捆绑版本字符串,短 它们有
当我在我的 Android 设备上运行我的应用程序时出现错误: meteor run android-device --settings settings.json --mobile-server=m
v = data.getValues(XP_PHONE); for (int i = 0; i alter 'table_foo', {NAME => 'column_fam_foo', V
我在Google CoLab中有这样一个错误:。以下是我的Cuda和Torch版本:。CUDA版本:。这是pytorch版本:2.0.1+cu118我试图安装Cuda 11.8,但没有成功。
我从其他用户那里发现了“类似”的问题,但没有一个答案有效。我正在尝试安装这些软件包: if (!require("BiocManager")) install.packages("BiocMana
我正在使用 Version Maven Plugin插件 use-latest-versions将 groupID=com.example* 内部依赖版本更新到最新版本的功能。这是使用 Jenkins
我是 Kotlin 应用程序开发的初学者。当我尝试构建应用程序时发生以下错误 - e: C:/Users/Lenovo/.gradle/caches/transforms-2/files-2.1/32
我正在尝试安装一个名为 metaBIT 的程序。我能够将它添加到我的路径中。但是当我执行时: metaBIT -h 它出错并给我这个: Traceback (most recent call last
在使用选项 -smt2 -in 启动 Z3 后,我可以获取 Z3 的版本吗?有点像 (get-z3-version) ; Z3 4.3.2 x64 // Desired reply 最佳答案 在SM
这个问题在这里已经有了答案: What is the difference between Version and 'Runtime Version' in .Net? (1 个回答) 关闭 9 年
new Version(AssemblyFileVersionAttribute.Version) 总是会成功吗? 这是我的代码。 Contract.Ensures(Contract.Result()
我正在尝试针对另一个使用 libcurl 共享库的共享库 (libtheirstuff.so) 交叉编译我自己的共享库 (libmystuff.so),但出现以下错误: libmystuff.so:
在 Bazaar 中,如果您在 foo.html 中有冲突,它将生成额外的 3 个文件 foo.html.BASE foo.html.OTHER foo.html.THIS 那么你可以 diff -N
我的 java 7 和 java 8 都安装在我的 Windows 系统的 C:\Program Files\Java 下 在环境的路径中我像这样指定了java 7的路径。 %JAVA_HOME%/b
#version 330 和 #version 330 core 有什么区别? 核心重要吗? 最佳答案 这两个版本声明是等价的。 核心 是默认值。来自 GLSL 3.30 规范: If no prof
我是一名优秀的程序员,十分优秀!