自研导出 git 版本差异到剪贴板工具

简介: 由于项目组规定每次发布版本需要记录文件变动差异,于是乎自学了一些 Windows 批处理内容,写了个批处理脚本方便统计。

由于项目组规定每次发布版本需要记录文件变动差异,于是乎自学了一些 Windows 批处理内容,写了个批处理脚本方便统计。

介绍



导出 git 版本差异到剪贴板


使用说明



支持交互式或 cmd 命令行中执行: 导出 git 版本差异到剪贴板.cmd


示例


D:\gitlab\abcProject "669ae28118f1b67fd45^^" 669ae28118f1b67fd


项目地址



ac86/my-cmd - 码云


https://gitee.com/kaiLee/my-cmd/


源码展示


@REM ----------------------------------------------------------------------------
@REM 导出git版本差异到剪贴板 Start Up Batch script
@REM
@REM Required vars:
@REM g_dir - git 仓库地址; 注意在交互式使用中该路径不能前后带空格!
@REM g_src - 原 commit ID; 注意在cmd命令行使用^等特殊符号需要整个字符串用双引号包裹,本身使用需要使用进行转义!
@REM g_target - 目标 commit ID;
@REM
@REM fixed 缺陷 1: git 导出命令,解决 git diff 导出文本会乱码的问题;
@REM 缺陷 2: 通过命令行启动,不支持带有空格的项目名。需要使用 subst w: "D:\Program Files\" 这种折中方案;
@REM 
@REM e.g. 支持交互式或cmd命令行中执行: 导出git版本差异到剪贴板V3.cmd D:\gitlab\preser-warn "669ae28118f1b67fd45^^" 669ae28118f1b67fd 
@REM ----------------------------------------------------------------------------
@REM Begin all REM lines with '@' in case ECHO is 'on'
@ECHO OFF
@setlocal EnableDelayedExpansion
CHCP 65001 >NUL
@REM set title of command window
title %0
SET g_dir=%1
IF "%g_dir%" == "" (
  SET /p g_dir="请输入 git 仓库地址:[默认=%CD%]"
  @REM 录入不为空则应用
  IF "!g_dir!" == "" SET g_dir="%CD%"
)
:loop1
IF NOT EXIST "%g_dir%" (
  SET /p g_dir="%g_dir% 非有效目录, 请重录仓库地址: "
  GOTO :loop1
)
IF NOT EXIST "%g_dir%\.git\" (
  SET /p g_dir="%g_dir% 非有效项目, 请重录仓库地址: "
  GOTO :loop1
) 
cd /d %g_dir%
ECHO 仓库地址=%g_dir% & ECHO.
SET g_src=%2
IF "%g_src%" == "" SET /p g_src="请输入原分支名或commit ID[默认=dev]: "
IF "%g_src%" == "" SET g_src="dev"
:loop2
git log %g_src% -1 --pretty=format:%h >NUL 2>NUL
IF ERRORLEVEL 1 (
  SET /p g_src="%g_src% 原节点非有效, 请重新录入: "
  GOTO :loop2
)
ECHO 原分支名=%g_src% & ECHO.
SET g_target=%3
IF "%g_target%" == "" SET /p g_target="请输入目标分支名或commit ID[默认=HEAD]: 
IF "%g_target%" == "" SET g_target="HEAD"
:loop3
git log %g_target% -1 --pretty=format:%h >NUL 2>NUL
IF ERRORLEVEL 1 (
  SET /p g_target="%g_target% 目标节点非有效, 请重新录入: "
  GOTO :loop3
)
ECHO 目标分支名=%g_target% & ECHO.
FOR /f "delims=" %%a IN ('git config remote.origin.url') DO @set theValue=%%a
SET t=%theValue%
:loop4
FOR /f "tokens=1* delims=/" %%a IN ("%t%") DO (
 SET g_pref=%%a
 @REM 将截取剩下的部分赋给t,其实这里可以使用延迟变量开关
 SET t=%%b
)
IF DEFINED t GOTO :loop4
@REM 如果后四位为 .git 则去掉后四位
SET "g_pref=%g_pref:.git=%"
ECHO git项目名=%g_pref% & ECHO.
ECHO -------------输出结果-------------
git diff %g_src% %g_target% --shortstat
git diff %g_src% %g_target% --line-prefix=%g_pref%/ --name-only | clip
ECHO -------------文本已复制到剪切板,程序 3 秒后将自动退出-------------
ping 127.0.0.1 -n 3 >NUL 2>NUL
exit




目录
相关文章
|
3月前
|
开发工具 数据安全/隐私保护 git
记录一次使用git工具拉取coding上代码密码账号错误的经历
这篇文章记录了作者在使用Git工具从Coding平台克隆项目时遇到的账号密码错误问题,并分享了通过清除电脑凭证中错误记录的账号密码来解决这个问题的方法。
记录一次使用git工具拉取coding上代码密码账号错误的经历
|
14天前
|
存储 开发工具 git
git工具使用教程全讲解
本文介绍了版本控制的概念及其重要性,详细对比了多种版本控制工具,如VSS、CVS、SVN和Git,重点讲解了Git的基本使用方法、工作原理及与SVN的区别。此外,文章还介绍了GitHub、GitLab和Gitee等流行的代码托管平台,以及如何在这些平台上注册账号、创建和管理仓库。最后,文章还提供了如何在IntelliJ IDEA中配置和使用Git的具体步骤。
35 1
|
1月前
|
开发工具 git
git显示开发日志+WinSW——将.exe文件注册为服务的一个工具+图床PicGo+kubeconfig 多个集群配置 如何切换
git显示开发日志+WinSW——将.exe文件注册为服务的一个工具+图床PicGo+kubeconfig 多个集群配置 如何切换
38 1
|
2月前
|
安全 开发工具 git
git合并错了,我想回退到之前的版本
git合并错了,我想回退到之前的版本
|
1月前
|
存储 开发工具 C#
Git Extensions:一个.NET开源的 Git 图形用户界面(GUI)工具
Git Extensions:一个.NET开源的 Git 图形用户界面(GUI)工具
102 0
|
2月前
|
SQL 缓存 测试技术
代码管理工具之GIT:重新温习一下
代码管理工具之GIT:重新温习一下
|
3月前
|
JavaScript IDE 前端开发
前端开发工具配置 nodejs & git & IDE
前端开发工具配置 nodejs & git & IDE
|
3月前
|
开发工具 git
成功解决:fatal: detected dubious ownership in repository at ‘E:/workspace/CSMarket‘。如何使用git工具通过命令行的形式
这篇文章分享了作者在使用Git工具初始化本地仓库时遇到的权限问题,提供了通过命令行解决Git仓库权限问题的方案,并介绍了如何使用Git命令行初始化项目、添加文件、提交以及关联远程仓库的步骤。
成功解决:fatal: detected dubious ownership in repository at ‘E:/workspace/CSMarket‘。如何使用git工具通过命令行的形式
|
4月前
|
开发工具 git
unable to index file ‘~$git提交版本号.xlsx‘
unable to index file ‘~$git提交版本号.xlsx‘
|
5月前
|
开发工具 git
技巧分享:Git怎么修改已经提交版本的版本注释
技巧分享:Git怎么修改已经提交版本的版本注释
60 4