给客户提供代码

给客户提供代码的要求

以下是我给客户提供代码时的个人准则. 仅供参考

  1. 默认不提供git信息.
  2. 为了减小体积, 不提供第三方子模块代码.
  3. 为了防止客户不加git信息, 然后几个版本之后出了问题, 告诉你只改了"A"而实际上把"BCDE"全改了, 用diff看都不知道哪些是想要的跟踪代码, 建议帮他们初始化git仓库, 后续有问题后git查看一清二楚.
  4. 帮客户初始化git仓库时, 可记录本地/内部的commit hash, 有问题时可以对着git知道修了哪些已知问题, 后面直接给补丁也不是不行. (客户要实在不懂git就还是给源码包吧)
  5. 提供代码之前自己本地试一下, 防止代码给出去后发生编译都过不去的低级问题, 丢死人.

游的工作流

假设有内部仓库A, A中有子仓库a及分支x, y, 还有标签tag1, tag2. 其中Ax分支中最新commit123456, 而现在要基于x分支上的654321并增加补丁product.patch给客户提供代码B.

游的流程如下:.

git clone https://git_path/A  B  -b x --depth=1 --no-tags
cd A
git fetch origin 654321--depth=1
git checkout FETCH_HEAD -b rel
git branch -D x
git remote remove origin
git apply product.patch   # am不一定能打上, 可以的话推荐am.
git add .
git commit -m "product release {654321} {today} {author}"

做完这些算是有了一份干净的代码, 但还保留两条reflog, 所以并不是最优的, 如果没那么严格, 这么给出去也不是不可以.

然后自己跑一下确定代码没问题:

git submodule update --init --recursive --depth 1
make  --dry-run  # 根据实际项目运行

此时代码验证没问题, 但多了编译运行的临时文件, 及子模块文件, 需要清理下:

git submodule deinit -f --all
git clean -xdf

最后清理git历史记录:

git reflog expire --expire=now --all

总结下:

git clone https://git_path/A  B  -b x --depth=1 --no-tags
cd A
git fetch origin 654321--depth=1
git checkout FETCH_HEAD -b rel
git branch -D x
git remote remove origin
git apply product.patch   # am不一定能打上, 可以的话推荐am.
git add .
git commit -m "product release {654321} {today} {author}" # ===============得到初版可提交代码
# git submodule update --init --recursive --depth 1
# make  --dry-run  # 根据实际项目运行
# git submodule deinit -f --all # =================这几条不测试的话就用不着.
git clean -xdf
git reflog expire --expire=now --all
posted @ 2026-02-10 15:49  游客aka孟游的博客  阅读(38)  评论(0)    收藏  举报