给客户提供代码
给客户提供代码的要求
以下是我给客户提供代码时的个人准则. 仅供参考
- 默认不提供
git信息. - 为了减小体积, 不提供第三方子模块代码.
- 为了防止客户不加
git信息, 然后几个版本之后出了问题, 告诉你只改了"A"而实际上把"BCDE"全改了, 用diff看都不知道哪些是想要的跟踪代码, 建议帮他们初始化git仓库, 后续有问题后git查看一清二楚. - 帮客户初始化
git仓库时, 可记录本地/内部的commit hash, 有问题时可以对着git知道修了哪些已知问题, 后面直接给补丁也不是不行. (客户要实在不懂git就还是给源码包吧) - 提供代码之前自己本地试一下, 防止代码给出去后发生编译都过不去的低级问题, 丢死人.
游的工作流
假设有内部仓库A, A中有子仓库a及分支x, y, 还有标签tag1, tag2. 其中A的x分支中最新commit为123456, 而现在要基于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
本文来自博客园,作者:游客aka孟游的博客,转载请注明原文链接:https://www.cnblogs.com/mxdon/p/19600248

浙公网安备 33010602011771号