给客户提供代码

给客户提供代码的要求

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

  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

总结下:

bash 复制代码
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
相关推荐
小白同学_C11 小时前
Lab4-Lab: traps && MIT6.1810操作系统工程【持续更新】 _
linux·c/c++·操作系统os
今天只学一颗糖11 小时前
1、《深入理解计算机系统》--计算机系统介绍
linux·笔记·学习·系统架构
不做无法实现的梦~13 小时前
ros2实现路径规划---nav2部分
linux·stm32·嵌入式硬件·机器人·自动驾驶
默|笙15 小时前
【Linux】fd_重定向本质
linux·运维·服务器
陈苏同学15 小时前
[已解决] Solving environment: failed with repodata from current_repodata.json (python其实已经被AutoDL装好了!)
linux·python·conda
“αβ”15 小时前
网络层协议 -- ICMP协议
linux·服务器·网络·网络协议·icmp·traceroute·ping
艺杯羹16 小时前
Git版本控制深度复盘:从入门到精通的完整指南
git·wpf·版本控制·git学习·git复盘
不爱学习的老登16 小时前
Windows客户端与Linux服务器配置ssh无密码登录
linux·服务器·windows
小王C语言17 小时前
进程状态和进程优先级
linux·运维·服务器
菩提小狗17 小时前
第7天:信息打点-资产泄漏&CMS识别&Git监控&SVN&DS_Store&备份|【小迪安全】web安全|渗透测试|网络安全-2021
git·安全·svn