- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我是 git 和 mercurial 的新手,正在尝试使用这些工具。我在工作中使用 perforce 作为源代码控制,所以最终比较了它的功能。
现在,我有一个如下所示的存储库:
Repo_1:
DummyProject:
Master/Default - branch
Release - branch
AnotherBranch - branch
对于Git/Mercurial,我使用的是Atlassian的SourceTree GUI客户端进行操作。我已经在本地克隆了这个完整的存储库,并且可以在 GUI 客户端中看到分支。要在分支机构之间切换,我可以使用此工具 checkout 。
假设我在 Master/Default 分支中工作并对一些文件进行了一些更改。当我仍在这个分支上工作时,出现了一些关键问题,我需要在 Release 分支中进行更改。此时,如果我从 Master/Default 分支切换到 release 分支,SourceTree 基本上会使用 release 分支的内容更新工作目录.它警告我有一些未保存的更改,我应该在切换到 release 分支之前提交或搁置/存储这些更改。
在 perforce 中,我通常会有 3 个带有分支名称的文件夹,我可以从 release 分支获取最新的并在 release 分支上进行更改而不用担心 < em>master/default 分支被覆盖,因为两个分支位于不同的目录中。完成后,我可以在 release 分支中提交更改并在 master/default 分支中继续工作。
我可以在 git/mercurial 中做些什么吗?
我能想到的最接近的选择是再次克隆存储库(可能从本地而不是远程来节省网络开销)然后在发布分支上工作并将更改推送回本地和远程存储库.
我认为这可能会浪费本地空间,因为存储库为此目的必须再次克隆所有历史记录和元数据。
最佳答案
Git 有 https://git-scm.com/docs/git-worktree这允许您为 repo 创建多个本地工作树。
我使用从远程克隆存储库两次的方法,在本地保留两个或多个副本。对我来说,这非常有效。我在一个商业软件环境中工作,在这个环境中,我们总是有待发布的版本支持、当前版本的发布标题、提前工作的分支等。任何时候至少有三个活跃的团队共享分支,并且有很多成对或三人之间的共享功能分支上的开发人员。
在某些情况下,另一个有用的工具是 git stash
。这对我来说是一个常规的 goto,因为由于工具我必须在本地进行修改,但永远无法提交。但它对于中断任务和切换分支也很有用。
本地存储,是的,从数量上讲这是一种浪费,但是,我不在乎。我关心的是 pull 和推送的传输时间,以及摆弄源代码控制所花费的时间。
这里的其他人可以提供更多关于 Git 的知识。我对 Mercurial 了解为零。
关于git - Mercurial/Git : Different directories for different branches in same repository,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34114278/
如果你做一个 hg pull然后是 hg update (或 hg merge ),有没有办法解决这个问题?即:将您的存储库恢复到执行 hg pull 之前的状态? 我相信你可以做到hg update
我有一台带有 ssh 的服务器,我想将其用作中央存储库。但是我不能在上面安装 mercurial。因此,客户端如何在服务器上没有安装 mercurial 的情况下通过 ssh 推送到服务器。 谢谢 最
我们有一个专门的问题跟踪 (Redmine) 机器,它有一个 Mercurial 存储库(称为“Redmine 存储库”)。 Redmine 设置为使用该存储库,据我了解,Redmine 从未对该存储
一个 hg 存储库可以存在于我的本地文件系统上的另一个 hg 存储库中吗? 我正在拉取“sandbox”的 bitbucket wiki,我想知道是否应该将其放置在 repos/sandbox/wik
我有一个项目,我使用 Bitbucket 作为我的 HG 服务器,但我最近发现,作为一个单独的开发人员,我可以免费使用 Fogbugz/Kiln。我想将我的文件移至 Kiln,但我不想丢失我的历史记录
Mercurial 如何判断文件已被修改? 我问的原因是因为当我运行时 hg status它告诉我有几个文件被修改了。 但是,当我运行 hg diff 时没有变化要报告。 我有一个关于为什么会发生这种
我需要获取本地存储库中文件的特定版本/节点的内容,并将其写入临时文件。 我知道可以通过内部Mercurial API进行操作。 有内置命令或扩展名吗? 最佳答案 您可以使用 hg cat : hg c
这两个命令有什么区别(我想回滚到修订版 1): hg update -r 1 hg backout -r 1 --merge (在示例中提示修订为 3) 最佳答案 首先, update -r 1 将撤
我看到 mercurial 有效地压缩了存储库中的文件 (repo/.hg/store/data) 有人知道存储库文件使用哪种压缩吗? 谢谢。 最佳答案 Mercurial 存储库中有两个压缩级别:增
如果 Mercurial does not track file permissions默认情况下,它如何决定它创建的任何文件/目录的权限? 是否使用umask ?如果不是,它有什么用? 我有 rea
我已经阅读了很多关于 Mercurial 及其分支的信息,但是,我仍然是一个版本控制新手。 我目前正在做一个项目,我的任务是开发一个新模块。 我有一个“主”存储库,其中包含项目其余部分的最新代码,以及
尝试运行 hg update 时出现以下错误: abort: Operation not permitted: /var/www/simira/web/public/images/nomination
mercurial 如何处理拆分的文件?如果我创建一个分支并拆分一个文件会发生什么。我可以轻松地从修改原始未拆分文件的另一个分支中提取更改吗? 最佳答案 我只是做了一个小实验。我用一个大文件创建了一个
我想使用hg graft将变更集从一个分支复制到另一个分支。 但是,在变更集中修改的文件已在源分支中重命名(使用hg rename)-在要移植的变更集之前。 当我尝试时,我得到: scanning f
Annotate可以使您看到该行的最新更改,如果该更改是合并,那么我别无选择,只能浏览修订历史记录并查找下一次对其进行修改的情况。 我也尝试过hg grep -l '[contents of line
我有一个小项目,我从集市开始,作为练习bzr的练习。从那以后,我决定选择 Mercurial 。我如何将这个项目迁移到Hg? 最佳答案 我相信您的答案可以在here中找到。 本质上,您只需要运行 $
什么决定分支是否处于非事件状态?是否有客户使用的特定时间段? 我们有很多不活跃的分支。值得我们花时间关闭它们吗? 该文档似乎没有指定如何确定非事件分支: https://www.mercurial-s
假设我创建了一个存储库,添加 x 文件并提交。说大小是 初始提交后的 Mb。 有什么方法可以估计存储库在一年内会有多大? 如果代码行数增加了 10%,存储库会相应增长吗? 提交、分支、标签等的数量如何
我正在使用 Mercurial(特别是 Windows 上的 TortoiseHg)对 VBA 代码进行版本控制。任何尝试过这个的人都知道,只要在项目中的任何地方更改了该变量的任何声明(无论范围如何)
不幸的是,我已经清理了我的 Mercurial 货架,忘记了我需要进行一些更改。我有定期的文件系统备份,但不知道 Mercurial 在哪里存储搁置文件。有人可以告诉我在哪里看吗? Mercurial
我是一名优秀的程序员,十分优秀!