当前位置: 首页 > news >正文

在git commit之前让其自动执行一次git pull命令

文章目录

  • 背景原因
  • 编写脚本
  • 测试效果

背景原因

有时候可以看到项目的git 提交日志里好多 Merge branch ‘master’ of …记录。这些记录是怎么产生的呢?
是因为在本地操作 git add . 、 git commit -m "xxxxx"时,没有提前进行git pull操作,而且此时远程仓库代码比本地仓库的新,就会在执行git commit -m "xxxxx"时提示,一堆信息(本地仓库代码版本滞后于远程仓库版本),总之不让提交(其实已经提交到本地仓库了),此时再使用git pull时,就会弹出一个编辑框,让输入合并分支的日志,此时一般就 :wq就可以了,完事后,就可以看到拉取代码成功了,再进行git push。推送成功了,此时git log,就可以看到提交记录里多了一条Merge branch ‘master’ of …的记录。如何避免出现这样的Merge branch ‘master’ of …的记录。下面进行操作。

编写脚本

在这里插入图片描述

通过git bash在 项目的.git/hooks目录下,创建脚本文件pre-commit

touch pre-commit

#!/bin/sh
# 检查是否有 staged 的更改
if [ -n "$(git diff-index --name-only --cached HEAD)" ]; thenecho "Running git pull to update your local changes before commiting..."git pullif [ $? -ne 0 ]; thenecho "Failed to pull changes. Fix conflicts and try again."exit 1fi
fi
exit 0

测试效果

在这里插入图片描述
可以看到,即使忘了在执行commit之前git pull下代码,通过与之关联的钩子脚本可以替我们自动完成此步骤。

http://www.lryc.cn/news/510473.html

相关文章:

  • 【Rust自学】6.3. 控制流运算符-match
  • 大模型应用技术系列(三): 深入理解大模型应用中的Cache:GPTCache
  • 『大模型笔记』评估大型语言模型的指标:ELO评分,BLEU,困惑度和交叉熵介绍以及举例解释
  • 深度解析:Maven 和 Gradle 的使用比较及常见仓库推荐
  • SQLite本地数据库的简介和适用场景——集成SpringBoot的图文说明
  • 管理面板Ajenti的在Windows10下Ubuntu24.04/Ubuntu22.04里的安装
  • 在Python如何用Type创建类
  • Android学习19 -- NDK4--共享内存(TODO)
  • 《Cocos Creator游戏实战》非固定摇杆实现原理
  • RabbitMQ工作模式(详解 工作模式:简单队列、工作队列、公平分发以及消息应答和消息持久化)
  • 【VScode】第三方GPT编程工具-CodeMoss安装教程
  • 在JavaScript中,let 和 const有什么不同
  • Mysq学习-Mysql查询(4)
  • 安装torch-geometric库
  • Java数组深入解析:定义、操作、常见问题与高频练习
  • Docker-构建自己的Web-Linux系统-镜像webtop:ubuntu-kde
  • 【C语言练习(17)—输出杨辉三角形】
  • SpringMVC学习(二)——RESTful API、拦截器、异常处理、数据类型转换
  • React 第二十节 useRef 用途使用技巧注意事项详解
  • VIVO Java开发面试题及参考答案
  • C# Winfrom chart图 实例练习
  • iOS从Matter的设备认证证书中获取VID和PID
  • 带着国标充电器出国怎么办? 适配器模式(Adapter Pattern)
  • 破解海外业务困局:新加坡服务器托管与跨境组网策略
  • Mybatis-Plus快速入门
  • Chrome被360导航篡改了怎么改回来?
  • Coding(Jenkinsfile)+ Docker 自动化部署 Springboot —— 图文细节和一些注意事项说明
  • docker django uwsgi 报错记录
  • 数据分析思维(五):分析方法——假设检验分析方法
  • 【ES6复习笔记】集合Set(13)