我目前正在从事iOS项目。我有一个在构建时运行的脚本。该脚本更新内部版本号,并将其提交到git中并推送。但是,使用几天后,我意识到了副作用。我可以在不断增加版本号的情况下进行连续提交。因此,我的提交日志中充满了这些提交。由于该项目被分解为几个核心库,因此情况尤其恶化。因此,对库进行操作总是会导致构建增量(因为它是相同的工作空间)。
我现在意识到,我需要一个足够聪明的脚本来压缩连续的提交,这是内部版本号的更新。
运行
git log -20 --pretty=format:"%h - %s"
例如,将产生
6add12a1 - Update the package from handle
70f438be - Updated client version to 0.15.0.2152 and next version to 0.15.0.2153
7d84151f - Updated client version to 0.15.0.2151 and next version to 0.15.0.2152
eace113b - Updated client version to 0.15.0.2150 and next version to 0.15.0.2151
e72624dd - Updated client version to 0.15.0.2149 and next version to 0.15.0.2150
85d15b6c - Updated client version to 0.15.0.2148 and next version to 0.15.0.2149
a4e140cd - Updated client version to 0.15.0.2147 and next version to 0.15.0.2148
ffb18892 - Updated client version to 0.15.0.2146 and next version to 0.15.0.2147
ebd33432 - Updated client version to 0.15.0.2145 and next version to 0.15.0.2146
f0727ca7 - Updated client version to 0.15.0.2144 and next version to 0.15.0.2145
80ab2939 - Adjust balance if FB rewards popup is shown
0c04a1d7 - Updated client version to 0.15.0.2143 and next version to 0.15.0.2144
e89fd769 - Updated client version to 0.15.0.2142 and next version to 0.15.0.2143
c404f9ce - Updated client version to 0.15.0.2141 and next version to 0.15.0.2142
3911fb31 - Updated client version to 0.15.0.2140 and next version to 0.15.0.2141
ee3b7056 - Updated client version to 0.15.0.2139 and next version to 0.15.0.2140
cfb3b2a7 - Updated client version to 0.15.0.2138 and next version to 0.15.0.2139
a11fa3d9 - Add conditionals compilation to remove some logging
b9d0f75a - Disable backlight
ba4447ae - Updated client version to 0.15.0.2137 and next version to 0.15.0.2138
因此在此示例中,我想将70f438be压缩为f0727ca7,然后将提交更新为类似“将客户端版本从0.15.0.2138更新为0.15.0.2152”。
有两件事要做。
我自己编写脚本没有问题。而是该问题的重点是git命令本身。有关脚本的详细信息作为上下文提供。
我正在寻找的是如何非交互式地使用git来压缩不在HEAD处开始的特定连续范围的提交。到目前为止,我所看到的参考文献都已从HEAD压缩了。
诸如此类。
Is there a way to squash a number of commits non-interactively?。
今天晚些时候,我会再讲一遍,因为它可能会使答案保持不变。
是的,澄清一下,这些提交都已经推送了。
请注意,这是在Mac上。后一个脚本是从Xcode(构建阶段)运行的,并且是使用GitPython的Python脚本。
答案 0 :(得分:1)
好的,所以我做了一些实验并运行了一段时间,我提出了一个解决方案。
如果git-fu更好的人可以验证这确实是一个好的/安全的方法,那将很有帮助。
我放弃了尝试更改提交消息以反映更改的尝试。我确实找到了一种方法,但是由于我现在对这一切都对存储库有更好的了解,所以我选择不担心此细节。
此命令似乎可以解决一系列不是从HEAD开始的提交。
git rebase -Xtheirs --onto 80ab2939 7d84151f
这里的密钥为-Xtheirs
,因为至少在我的应用程序中,否则将导致冲突。请注意,我的情况很特殊,因为它依赖于已知的提交消息模式,并且文件是相同的。
我在这段历史上做了上述
6add12a1 - Update the package from handle
70f438be - Updated client version to 0.15.0.2152 and next version to 0.15.0.2153
7d84151f - Updated client version to 0.15.0.2151 and next version to 0.15.0.2152
eace113b - Updated client version to 0.15.0.2150 and next version to 0.15.0.2151
e72624dd - Updated client version to 0.15.0.2149 and next version to 0.15.0.2150
85d15b6c - Updated client version to 0.15.0.2148 and next version to 0.15.0.2149
a4e140cd - Updated client version to 0.15.0.2147 and next version to 0.15.0.2148
ffb18892 - Updated client version to 0.15.0.2146 and next version to 0.15.0.2147
ebd33432 - Updated client version to 0.15.0.2145 and next version to 0.15.0.2146
f0727ca7 - Updated client version to 0.15.0.2144 and next version to 0.15.0.2145
80ab2939 - Adjust balance if FB rewards popup is shown
0c04a1d7 - Updated client version to 0.15.0.2143 and next version to 0.15.0.2144
这会产生一些输出:
First, rewinding head to replay your work on top of it...
Auto-merging resources/plists/jks-info.plist
Auto-merging resources/next_build_version.txt
[detached HEAD 8beac4c7] Updated client version to 0.15.0.2152 and next version to 0.15.0.2153
Date: Mon Mar 4 02:01:15 2019 -0800
2 files changed, 2 insertions(+), 2 deletions(-)
Committed: 0001 Updated client version to 0.15.0.2152 and next version to 0.15.0.2153
[detached HEAD 4ede3d58] Update the package from handle
Date: Mon Mar 4 02:03:09 2019 -0800
1 file changed, 4 insertions(+), 2 deletions(-)
Committed: 0002 Update the package from handle
All done
但是结果记录(git log
)很好。
4ede3d58 - Update the package from handle
8beac4c7 - Updated client version to 0.15.0.2152 and next version to 0.15.0.2153
80ab2939 - Adjust balance if FB rewards popup is shown
0c04a1d7 - Updated client version to 0.15.0.2143 and next version to 0.15.0.2144
e89fd769 - Updated client version to 0.15.0.2142 and next version to 0.15.0.2143
我的最后一步是强制推送,因为已经推送了提交。请注意,强行推送将重写您的历史记录。我实际上使用git push --force-with-lease
是安全的。