agx/git-buildpackage 项目:从 Git 仓库构建 Debian 软件包指南
前言
在 Debian 软件包开发过程中,git-buildpackage 工具(简称 gbp)是一个强大的工具集,它能够帮助开发者直接从 Git 仓库构建 Debian 软件包。本文将详细介绍如何使用 gbp 工具进行软件包构建的各种场景和技巧。
基础构建流程
常规构建命令
要从 Git 仓库构建 Debian 软件包,最基本的命令是:
gbp buildpackage
这个命令会自动完成以下操作:
- 构建上游源代码压缩包(tarball)
- 调用 debuild 工具构建软件包
在开发阶段(当你不处于 debian-branch 分支或有未提交的更改时),通常需要添加 --git-ignore-new
选项:
gbp buildpackage --git-ignore-new
上游源代码处理
当 gbp 找不到有效的上游源代码压缩包时,它会根据上游版本号匹配的标签自动创建一个。如果需要精确重建原始压缩包(使用 pristine-tar 分支中的信息),应该使用:
gbp buildpackage --git-pristine-tar
这是推荐的创建上游源代码压缩包的方式,可以确保与原始导入的压缩包完全一致。
发布构建
当你完成开发并准备发布时,应该先提交所有更改,然后使用:
gbp buildpackage --git-tag
这个命令会:
- 构建 Debian 软件包
- 根据 changelog 中的当前版本号创建标签
如果需要 GPG 签名标签,可以添加 --git-sign
和 --git-keyid
选项。默认的标签格式是 debian/<version>
,可以通过 debian-tag
选项修改。
使用独立构建目录
许多开发者习惯使用独立的构建目录,这可以通过 --git-export-dir
选项实现:
gbp buildpackage --git-export-dir=../build-area/
这会导出当前分支的 HEAD 到 ../build-area/package-version
目录并构建软件包。如果需要导出特定版本而非当前 HEAD,可以使用 --git-export
选项指定:
gbp buildpackage --git-export-dir=../build-area --git-export=debian/0.4.3
特殊参数说明:
INDEX
:导出当前索引状态(包含已暂存但未提交的更改)WC
:原样导出当前工作副本
可以在配置文件中设置默认构建目录:
[buildpackage]
export-dir=../build-area
构建成功后,gbp 会自动清理构建目录。如需保留,使用 --git-no-purge
选项。
构建钩子
gbp 提供了多种钩子(hooks),可以在构建过程的不同阶段执行自定义操作:
常用钩子类型
prebuild
:构建前执行postbuild
:构建成功后执行posttag
:创建标签后执行
自动运行 Lintian
构建后自动运行 Lintian 检查:
gbp buildpackage --git-postbuild='lintian $GBP_CHANGES_FILE'
或在配置文件中设置:
postbuild=lintian $GBP_CHANGES_FILE
自动推送更改
构建并创建标签后自动推送到远程仓库:
gbp buildpackage --git-tag --git-posttag="git push && git push --tags"
更安全的推送脚本示例:
#!/bin/sh -e
if ! REMOTE=$(git config --get branch."${GBP_BRANCH}".remote); then
REMOTE=origin
fi
if [ "$GBP_TAG" ]; then
echo "Pushing $GBP_TAG to $REMOTE"
git push "$REMOTE" "$GBP_TAG"
else
echo "GBP_TAG not set."
exit 1
fi
if [ "$GBP_SHA1" ] && [ "$GBP_BRANCH" ]; then
git push "$REMOTE" "$GBP_SHA1":"$GBP_BRANCH"
else
echo "GBP_SHA1 or GBP_BRANCH not set."
exit 1
fi
echo "done."
导出后处理(postexport)
postexport
钩子允许在构建前对导出的源代码进行最后调整。典型应用场景是从一个 Debian 分支创建多个不同的源代码和二进制包。
示例配置:
[buildpackage]
export-dir = ../build-area
cleaner =
postexport = crosstoolchain-expand.sh
示例脚本会处理 changelog 模板、lintian 覆盖文件以及 rules 和 control 文件,根据环境变量 PKG_FLAVOR
生成不同的包变体。
导出前处理(preexport)
preexport
钩子允许在准备和导出原始压缩包前执行自定义操作。例如,从单独的仓库检出大型二进制资源。
总结
git-buildpackage 提供了灵活而强大的工具链,支持从简单的开发构建到复杂的发布流程。通过合理使用构建目录和各种钩子,开发者可以构建出符合 Debian 标准的高质量软件包,同时保持高效的工作流程。
GLM-4.6
GLM-4.6在GLM-4.5基础上全面升级:200K超长上下文窗口支持复杂任务,代码性能大幅提升,前端页面生成更优。推理能力增强且支持工具调用,智能体表现更出色,写作风格更贴合人类偏好。八项公开基准测试显示其全面超越GLM-4.5,比肩DeepSeek-V3.1-Terminus等国内外领先模型。【此简介由AI生成】Jinja00- DDeepSeek-V3.2-ExpDeepSeek-V3.2-Exp是DeepSeek推出的实验性模型,基于V3.1-Terminus架构,创新引入DeepSeek Sparse Attention稀疏注意力机制,在保持模型输出质量的同时,大幅提升长文本场景下的训练与推理效率。该模型在MMLU-Pro、GPQA-Diamond等多领域公开基准测试中表现与V3.1-Terminus相当,支持HuggingFace、SGLang、vLLM等多种本地运行方式,开源内核设计便于研究,采用MIT许可证。【此简介由AI生成】Python00
openPangu-Ultra-MoE-718B-V1.1
昇腾原生的开源盘古 Ultra-MoE-718B-V1.1 语言模型Python00ops-transformer
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。C++0118AI内容魔方
AI内容专区,汇集全球AI开源项目,集结模块、可组合的内容,致力于分享、交流。02Spark-Chemistry-X1-13B
科大讯飞星火化学-X1-13B (iFLYTEK Spark Chemistry-X1-13B) 是一款专为化学领域优化的大语言模型。它由星火-X1 (Spark-X1) 基础模型微调而来,在化学知识问答、分子性质预测、化学名称转换和科学推理方面展现出强大的能力,同时保持了强大的通用语言理解与生成能力。Python00GOT-OCR-2.0-hf
阶跃星辰StepFun推出的GOT-OCR-2.0-hf是一款强大的多语言OCR开源模型,支持从普通文档到复杂场景的文字识别。它能精准处理表格、图表、数学公式、几何图形甚至乐谱等特殊内容,输出结果可通过第三方工具渲染成多种格式。模型支持1024×1024高分辨率输入,具备多页批量处理、动态分块识别和交互式区域选择等创新功能,用户可通过坐标或颜色指定识别区域。基于Apache 2.0协议开源,提供Hugging Face演示和完整代码,适用于学术研究到工业应用的广泛场景,为OCR领域带来突破性解决方案。00- HHowToCook程序员在家做饭方法指南。Programmer's guide about how to cook at home (Chinese only).Dockerfile011
- PpathwayPathway is an open framework for high-throughput and low-latency real-time data processing.Python00
项目优选









