git推送前HOOK pre-push判断版本号增加再推送

我写了一个C++程序,然后每次编译后,记不得当时的版本是哪个源代码,对于core dump复现调试很麻烦。

为此我想了一个办法,首先在include/git_version.hpp 创建一个版本的文件

复制代码
/*
 * @Description:
 * @Author: jiangsheng
 * @Date: 2024-01-11 10:59:53
 * @LastEditors: jiangsheng
 * @LastEditTime: 2024-01-11 20:07:28
 */
#ifndef __JS_GIT_VERSION__H
#define __JS_GIT_VERSION__H
#include <iostream>
namespace JS_GIT_VERSION
{
const char *VERSION_STRING = "v1.5.1";
void cout_version()
{
    std::cout << "VERSION_STRING  " << VERSION_STRING << std::endl;
}
}; // namespace JS_GIT_VERSION
#endif

然后在单例模式下,上来就调用cout_version()函数,这样一启动就有输出,我就知道现在是哪个版本号。

然后我在master分支和develop分支之间 每次master发布版本号 都写上比当前tag大的版本号,

例如最新tag是V1.5.1,那么我下次就写V1.5.2 或者 V1.6什么的。

然后我在develop分支下 需要判断一下 最后push时候的HPP里头记录的TAG,是否不等于git tag里头的TAG,这样就可以保证自己不会忘记更新HPP文件里的TAG就直接push了。

然后master分支pull request develop的代码,这样在发布新版本时候 只要指定的版本和刚刚代码HPP里头的版本一致就可以了

下面是pre-push的代码

复制代码
#!/bin/bash
while read local_ref local_sha remote_ref remote_sha
do
    if [ "$remote_ref" == "refs/heads/develop" ]; then
        # Get the latest version number from the git_version.hpp file
        current_version=$(grep -oP 'const char \*VERSION_STRING = "\K[^"]+' include/git_version.hpp)
        echo "hpp version : $current_version"
        # Get the latest tag on the develop branch
        latest_tag=$(git tag -l --sort=-v:refname | head -n 1)
        
        if [ $? -ne 0 ]; then
            echo "Error getting latest tag: $latest_tag"
            # Continue with the push even if tag retrieval fails
            continue
        fi

        echo "git tag: $latest_tag"

        if [ -n "$latest_tag" ] && [ "$latest_tag" == "$current_version" ]; then
            echo "版本号未更新,停止上传"
            exit 1
        else
            echo "保存的版本号与上传版本号不同,允许上传"
        fi
    fi
done
相关推荐
Lunar*2 小时前
告别臃肿!使用 git-filter-repo 优雅清理 Git 历史记录
git
tq10862 小时前
agent 记忆 = markdown + json + git
人工智能·git
何以不说话4 小时前
DevOps、Git 和 GitLab
git·gitlab·devops
最最菜的菜鸟5 小时前
本地环境通过 SSH 协议访问 GitHub 上的仓库时,SSH 公钥认证失败,配置 Git SSH 密钥
git·ssh·github
无限进步_20 小时前
21. 合并两个有序链表 - 题解与详细分析
c语言·开发语言·数据结构·git·链表·github·visual studio
宁静致远202120 小时前
STM32CubeMX、MDK(Keil MDK)、git、vscode等工具中统一编码设置(UTF-8),确保中文支持,避免乱码问题
git·vscode·stm32
love530love1 天前
Windows 多 Git 环境冲突:一个环境变量优先级引发的血案
人工智能·windows·git·环境变量·scoop
无限进步_1 天前
面试题 02.04. 分割链表 - 题解与详细分析
c语言·开发语言·数据结构·git·链表·github·visual studio
甲枫叶2 天前
【claude】Claude Code正式引入Git Worktree原生支持:Agent全面实现并行独立工作
java·人工智能·git·python·ai编程
0xwang2 天前
Deepin25社区版修改Git编码
git