gpt4 book ai didi

git - 如何自动将源代码和编译代码(不包括 git 历史记录)部署给第三方开发人员?

转载 作者:太空狗 更新时间:2023-10-29 14:06:02 24 4
gpt4 key购买 nike

我将设置一些工具/技术/环境,这样当我需要为第三方开发人员提供源代码时,我可以在没有 git 历史的情况下使用一些已经编译和剥离的敏感代码。所以我想自动化这个过程,这样我就可以始终提供它的最新版本,而不必每次都手动完成所有必要的步骤。我使用 bitbucket 和 git。

如何使用 bitbucket 和 git 实现我的目标?我需要一些其他工具吗?

附言如果问题没有说明清楚,请随时编辑问题。我希望这个问题不要太宽泛,也不要受到限制

最佳答案

听起来你想写一些 post-commit 钩子(Hook)。但这对你来说可能太细了。只需将自动步骤写入 .git/hooks/post-commit 并使其可执行即可。你可以

git --work-tree PATH_FOR_THIRD_PARTY checkout HEAD -- PUBLIC_FILES

在 PATH_FOR_THIRD_PARTY 中为您的第三方开发人员更新 PUBLIC_FILES,我假设您在其中发布了第三方开发人员的数据。

然后要更新编译结果,您应该编写一些 Makefile(或类似文件)以从 stash 文件中生成 PATH_FOR_THIRD_PARTY 中的输出。

如果您为存储库选择了正确的布局,可以只使用 PUBLIC_FILES 目录,将所有 PUBLIC_FILES check out 到 PATH_FOR_THIRD_PARTY/PUBLIC_FILES

请注意,使用此方法时,发布目录和存储库中的目录布局将相同。

顺便说一句:如果第三方开发人员更改了他们目录中的 PUBLIC_FILE,您可以简单地

git --work-tree PATH_FOR_THIRD_PARTY add -u

我经常使用这种方法从 git 存储库发布文件。你可以简单地

git config -g alias.public '!git --work-tree $(git config --get public.root) '
git config public.root 'PATH_FOR_THIRD_PARTY'

所以你可以说

git public diff --name-only

git public status -s -uno

我认为这种方法被称为或类似于分离的工作树。

如果您使用此方法,则需要在进行公开提交后 check out 本地存储库中的文件:

git public add -u; git public commit -m "John Doe changed something"
git checkout HEAD -- .

最后一行更新您的本地工作树以与您在上面所做的提交保持一致。

关于git - 如何自动将源代码和编译代码(不包括 git 历史记录)部署给第三方开发人员?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30939511/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com