【发布时间】:2013-09-12 01:35:50
【问题描述】:
我有一个不寻常的需求,我想知道 Git 是否可以满足它。
我想将我的 Python 包 python_toolbox 移植到 Python 3。但我不喜欢使用 2to3 的想法,也不支持使用相同代码的 Python 2 和 Python 3。 (因为我的代码要漂亮对我来说很重要,而且我发现为 Python 2 和 Python 3 编写的代码并不漂亮。)
我想要的是有 2 个单独的源文件夹,一个用于 Python 2.x,一个用于 Python 3.x。这将允许我编写针对各自主要 Python 版本量身定制的每个版本的代码。我希望这两个文件夹位于同一个仓库中,setup.py 将根据运行它的 Python 版本在它们之间动态选择。到现在为止还挺好。
现在,我需要帮助:我希望能够从我的 Python 2.x 源文件夹合并到我的 Python 3.x 源文件夹。为什么?当我在 Python 2.x 文件夹上开发一个功能时,我也希望在 Python 3.x 版本上拥有这些功能。我不想手动复制它们。我想将它们合并到 Python 3.x 文件夹中,并且我完全希望有美妙的合并失败,我将不得不使用我的判断来决定如何将为 Python 2.x 实现的功能合并到修改过的代码中对于 Python 3.x。
问题是:我该怎么做?这些文件夹是 Git 存储库中的文件夹,它们本身不是 Git 存储库。我曾考虑过使用以前从未使用过的 Git 子模块,但在网上阅读它们却描绘出一幅可怕的画面。 (“sobmodules”这个词已经被扔掉了。)
还有什么其他想法可以在我的 Git 存储库中合并这些文件夹吗?
【问题讨论】:
-
很久很久以前,有人写过“复杂胜于复杂”。 “实用胜于纯洁”。我会使用已知有效的东西
标签: python git python-3.x merge