- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我可能滥用 git 并以它从未被设计使用的方式使用它。我是一个团队规模的唯一开发人员,我在多台机器上进行开发。比如我在机器A上写代码,需要在机器B和机器C上测试(并重新编译)代码。我做快速开发(例如,每分钟提交一次,然后跨到机器B/C上测试) .
因此,我的许多提交都有有意义的消息,特别是我经常这样做:
机器A
git add -u
git commit -m "work"
git push
机器B/C
git pull
make
./run_tests
哦不!它不起作用...回到机器 A 并在 1 分钟后再次提交。
因此,正如您想象的那样,我的 git --log 历史记录有很多毫无值(value)的评论,它们只包含“工作”。有没有一种方法可以自动 merge 所有具有相同消息的 git 提交,具体来说,所有带有 -m "work"的顺序提交将 merge 为一个大提交 -m "big work"。
谢谢。
明确地说,我的评论历史(回溯 2 年)是这样的:
work
work
work
work
OMG THIS actually works.
work
work
work
OMG we solved a huge problem... we should call this v1.0
work
work
work
我想自动压缩所有“工作”消息,使其变成类似这样的内容:
work
OMG THIS actually works.
work
OMG we solved a huge problem... we should call this v1.0
work
etc...
侧面,至于为什么我这样滥用 git,基本上我将它用作 ctrl-s 功能......我也在 20 台机器上开发并且需要一种有效的方式在每分钟左右更改后共享代码。 NFS 不是一个选项,因为我也在离线/硬防火墙/等机器上工作......
最佳答案
您描述的工作流程与 git-rebase 中描述的非常相似交互模式手册页:
Rebasing interactively means that you have a chance to edit the commits which are rebased. You can reorder the commits, and you can remove them (weeding out bad or otherwise unwanted patches).
[...]
If you want to fold two or more commits into one, replace the command "pick" for the second and subsequent commits with "squash" or "fixup". If the commits had different authors, the folded commit will be attributed to the author of the first commit. The suggested commit message for the folded commit is the concatenation of the commit messages of the first commit and of those with the "squash" command, but omits the commit messages of commits with the "fixup" command.
将 git-rebase 示例应用到你的案例中,你必须做类似的事情
$ git rebase --interactive HEAD~13 # to fix last 12 commits
编辑器将启动当前分支中的所有提交:
pick deadaaa work
pick deadbbb work
pick deadccc work
pick deadddd work
pick deadeee OMG THIS actually works.
pick deadfff work
pick dead000 work
...
您需要做的是将您想要加入上层提交的提交的“pick”更改为“fixup”:
pick deadaaa work
fixup deadbbb work
fixup deadccc work
fixup deadddd work
pick deadeee OMG THIS actually works.
pick deadfff work
fixup dead000 work
...
清理之后,最安全的做法是从您的其余机器上重新克隆此存储库。因为在共享存储库上搞乱提交(就像 git rebase 那样)是灾难的完美秘诀。特别是如果您将尝试自动化此过程。
编辑: 当您控制了存储库的所有副本时,这应该不是问题。在修改 master 分支之前,只需确保所有副本都同步即可。在你完成更新所有副本后,强制推/pull 再次同步。如果出现问题“从上游 Rebase 恢复”git-rebase man 部分应该有所帮助。
关于git - 将 git 提交与相同的消息结合起来?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19967534/
我有一张 Excel 表格,用于更新玩家评分。 播放器 配售 初始化 1 2 3 4 金融评级 一个 1 2.0 1.000 0.018 0.016 0.014 2.007 D 2 -2.0 54.5
我有一个 map = std::map ,其中 myItemModel继承QAbstractItemModel . 我现在要合并所有 myItemModel合一myItemModel (其他所有元素模
我大量使用“do.call”来生成函数调用。例如: myfun <- "rnorm"; myargs <- list(n=10, mean=5); do.call(myfun, myargs); 但是
想象一下 InputStream 的以下变体: trait FutureInputStream { //read bytes asynchronously. Empty array means E
这是我的 C 代码: #include void sum(); int newAlphabet; int main(void) { sum();
我只是想选择类“.last”之后的每个元素。 HTML: 1 2 Jquery
我正在为一个项目构建一个 XML 反序列化器,我经常遇到这种类型的代码情况: var myVariable = ParseNDecimal(xml.Element("myElement")) == n
这是来自 Selecting the highest salary 的继续问题 假设有一个表 'wagetable' name lowhours highhours wage pri
我正在为我的程序创建一个战舰程序;该程序运行良好,但我试图确保当用户将坐标超出范围时,程序会说他们输入的坐标不正确。这是代码: #include #include void
我有一个函数,它为每种情况返回不同的 DWORD 值,如果出现错误。所以我有以下定义: #define ERR_NO_DB_CONNECTION 0x90000 #define ERR_DB_N
在派生类中引发基类事件以下简单示例演示了在基类中声明可从派生类引发的事件的标准方法。此模式广泛应用于 .NET Framework 类库中的 Windows 窗体类。在创建可用作其他类的基类的类时,应
我只是想知道这是否可能: use Modern::Perl; my @list = ('a' .. 'j'); map { func($_) } each(@list); sub func { m
我一直在使用 =IF(L2="","Active",IF(K2I2,"Late"))) 有效,但现在我需要检查 F 上的多个条件 专栏 我试过了 OR 函数 =IF(OR(F2="Scheduled"
我有 2 个命令,如下所示。 在视频中添加介绍图片 ffmpeg -y -loop 1 -framerate 10 -t 3 -i intro.png -i video.mp4 -filter_com
好的,我有这个公式可以根据名字和姓氏列表生成用户名。现在,虽然这可行,但我希望单元格改为引用我自己的 VBA 函数。但是,由于代码少得多,我仍然想使用原始公式。 我有这个公式: =SUBSTITUTE
我有两个 HAProxy 实例。两个实例都启用了统计信息并且工作正常。 我正在尝试将两个实例的统计信息合并为一个,以便我可以使用单个 HAProxy 来查看前端/后端统计信息。我试图让两个 hapro
我有一个 Observable,其中每个新值都应该引起一个 HTTP 请求。在客户端,我只关心最新的响应值;但是,我希望每个请求都能完成以进行监控/等。目的。 我目前拥有的是这样的: function
我的网站上有 TinyMCE 插件。在 TinyMCE 插件的 textarea 中添加图像时,我希望这些图像包含延迟加载。我网站的缩略图具有特定类型的延迟加载,其中 src 图像是灰色背景。根据用户
我希望合并润滑间隔,以便如果它们重叠,则从内部第一个时间获取最小值和从内部最后一个时间获取最大值并总结以创建一个跨越整个时间段的新间隔。这是一个reprex: library(lubridate, w
我有一个应用程序,它本质上是一个页眉、主要内容和一个始终可见的页脚。页脚可以改变大小,我想在页脚上方的主内容面板上放置一些工具。主要布局是用 flex 完成的,我阅读文档的理解是绝对定位通过相对于最近
我是一名优秀的程序员,十分优秀!