- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
假设有一个大型项目不遵守特定的 python 格式化标准,并且您想使用 python 格式化程序black 重新格式化所有 python 代码,并且假设大型项目非常大(假设约 2,000 个 python 文件),以及约 30 名从事该项目的人员,每个人都在多个分支上从事多个功能。也可能有不同的半卡住“主”分支,偶尔会与较新的代码 merge 。
在整个代码库上使用黑色会导致与任何打开的分支发生 super 冲突...您将如何着手执行此过程并最大程度地减少冲突?
最佳答案
我只是需要做一些类似的事情,所以我想我应该分享对我有用的东西。
假设您有一个主分支和一个功能分支,它们在许多提交前从主分支中分离出来。在某些时候你配置了 pre-commit在主分支上有 black、isort 和其他自动格式化程序。现在您想将功能分支 rebase 或 merge 到主分支并避免所有冲突。
这里的主要想法是用新的格式化程序重写功能分支中的提交,这样分支之间的任何差异都不会与格式相关。
首先,我们需要找到feature从master中分离出来的点:
git merge-base feature master
我们可以用一些 shell 技巧给它起一个名字:
git branch feature_base $(git merge-base feature master)
现在让我们将格式化程序应用于 feature_base。对我来说,这只涉及从 master 分支复制 .pre-commit-config.yaml 和 pyproject.toml。
git checkout feature_base
git checkout master -- .pre-commit-config.yaml pyproject.toml
pre-commit run --all-files
git commit -nam "Applied formatting"
预提交步骤可能需要一段时间,因为它会自动格式化存储库中的每个文件。请注意,我向 git commit
命令添加了 -n
选项,它会跳过再次运行预提交 Hook 。这只是为了节省一些时间。
现在我们准备好进行 rebase 了。为方便起见,让我们为重新定位的功能分支起一个新名称,以便在出现问题时可以轻松使用旧名称:
git branch feature_formatted feature
现在重写 feature_formatted 分支:
git rebase feature_base feature_formatted -Xtheirs --exec 'git reset --soft HEAD^; pre-commit run; git add -u; git commit -C HEAD@{1}'
让我们回顾一下这个命令的细节:
git rebase feature_base feature_formatted
告诉 git 将 feature_formatted 分支中的提交重写到 feature_base 分支之上。
通常,这会导致许多 merge 冲突,都是由我们在上面执行的格式更改引起的。 -Xtheirs
选项告诉 git 不要费心尝试实际 merge 任何东西,而只使用原始功能分支中的文件。
--exec
选项告诉 git 在 rebased 分支中的每次提交后运行特定的 shell 命令。我们在这里要做的是再次应用格式,因为 -Xtheirs
选项给我们留下了未格式化的文件。为了做到这一点,我们“撤消”最后一次提交,应用预配置,然后再次提交。
git reset --soft HEAD^
- 您之前可能使用过 git reset
来撤消提交。 --soft
选项意味着代码更改保留在暂存区中,准备再次提交。
pre-commit run
- 由于所有内容都已准备好提交,因此运行 pre-commit Hook 只会将格式应用于所有已更改的文件。
git add -u
- 此命令将预提交运行所做的任何更改添加到暂存区。
git commit -C HEAD@{1} --no-edit
- -C
参数告诉 git 从另一个提交复制提交细节。另一个提交是 HEAD@[1}
,意思是“HEAD 的最后一个地方”。在我们的例子中,这是我们在 git reset
命令之前进行的提交。
就是这样!我们完成了。现在 feature_formatted 分支可以 merge 到 master 中,而不会出现任何与格式相关的冲突。如果你想 rebase 到 master,你应该避免从功能库提交“Applied formatting”,所以你应该使用这个命令:
git rebase feature_base feature_formatted --onto master
关于git - 用黑色重新格式化整个 python 代码库后解决 git 冲突的最佳方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65304887/
我刚刚创建了一个带有几个表 Controller 和一个 View Controller 的 Storyboard。 一切正常,直到我的应用程序推送 View Controller :它显示为全黑。
我尝试通过添加一个名为“铀”的新元素来修改我的世界。因此,我在主包中创建了“Trauma.java”类以及下面列出的其他一些类。所有包和类: Package Explorer Trauma.java
我一直在学习如何使用 UICollection View 。我制作了一个新的 UICollectionView Controller ,并将 collectionview 单元格标识为 main.st
我想加一个超细的黑边 在这个环的边界上方和下方。 http://jsfiddle.net/PUBqA/5/ 目标是让这个戒指容易看 在白色背景上。 唯一的方法就是添加一些薄的 环外环内黑色边框。 这是
假设我有以下 python 文件 exclude_from_black.py在我的项目的根目录中: print('I want single quotes') 我试图从黑色重新格式化中排除此文件,但以
我的 Canvas 有问题。比方说,1/10 的时候我在 chrome 上有黑色方 block 而不是我的图像。我的代码如下,我该如何修改它以避免这种黑色显示? var canvas = docu
我正在尝试使用图案作为 SKScene 的背景颜色: override func didMoveToView(view: SKView) { let backgroundImage:
我正在尝试浏览一些 Collection View Swift 教程,但它们总是显示为空白/黑色页面,就好像我没有设置初始 View Controller 一样。不过,我只使用了 1 个 UIColl
我有一个标签栏应用程序。 标签栏中只有 2 个选项卡。第一个选项卡是 NavigationController,第二个选项卡是 TableViewController。第二个工作完美,但第一个则不然。
我正在通过串行端口(ttyO2)连接 BBB 和一组 arduino。我有一个数组要从 BBB 发送到一组 arduino。我需要让 BBB 发送请求并等待其中一个 arduino 的回复,但如果在一
附上图片。我能够摆脱边界上的背景区域,但图像中的背景区域仍然存在。有没有什么方法可以消除图像中的小背景区域。谢谢。 最佳答案 这个问题有一个简单的解决方法,基本思想是在 RGB 颜色空间中分割图像以过
我以前从未做过图像处理。 我现在需要检查来自相机的许多 jpeg 图像,以丢弃那些非常暗(几乎是黑色)的图像。 是否有我可以使用的免费库 (.NET)?谢谢。 最佳答案 Aforge是一个很棒的图像处
这个问题在这里已经有了答案: Background ListView becomes black when scrolling (12 个答案) 关闭 9 年前。 这是我第一次访问这个网站。我会请你
我在 iOS 上更改启动屏幕的背景颜色时遇到问题。当我第一次打开应用程序时,它会在黑色 viewcontroller 出现之前加载一个白页。如何将白色启动屏幕更改为黑色? 下面是我的应用程序的一般启动
我想检测字体的样式(粗体、粗体、黑色)。但我只能检测字体是否为粗体。 BOOL isBold = (font.fontDescriptor.symbolicTraits & UIFontDescrip
我正在尝试解决一个软件错误,在该错误中,我们认为某个应用可能不会在每次调用时都启动。为了对此进行测试,我创建了一系列计划任务来启动应用程序、截取屏幕截图,然后关闭应用程序。这些任务都是通过 .bat
完全被难住了。我已经遍地查看并实现了我能找到的每一个解决方案。我似乎无法让导航栏变得透明。 当尝试设置背景颜色时,我只在顶部看到一个黑条。就像我尝试设置背景图像一样。我已经尝试了所有这些以及所有这些变
我创建了一个 TextView ,如果文本太长,它将使其可滚动。但是,如果您单击它或将手指放在上面,它会像被单击一样变成黑色。有谁知道使它不能点击但仍然能够滚动的代码?谢谢! 在我的 xml 中定义其
我正在尝试将 DS1307 RTC 集成到 beaglebone black 上,其中我正在使用 rootfs 构建自定义内核,我使用了 beagle P9.17 和 P9.18 的 SCL 和 SD
线性渐变适用于图像,但文本不会出现在图像前景上。此外,渐变不应该出现在文本上。我哪里做错了? 任何帮助都感激不尽。 .glimage { display: flex; justify-cont
我是一名优秀的程序员,十分优秀!