使用 SVN 作为版本控制的时候,整理过一个 导出文件脚本:利用 PHP 导出 SVN 新增或修改过的文件

现在换成了 Git,整理出类似的脚本:

【第一版】git.php

<?php
/**
* 导出指定版本之间的差异文件,如 100 和 200 之间的差异则导出 100(不包括) - 200(包括) 的所有修改
* 【Git 命令行】
* 1、查看版本间差异
* git diff b361dbd323dbfc442ddbdc43b00cba3e66c50214 988526fa12dfcbddc2462e232eae7f614ff28976 --name-status
*
* @example git.php old版本号 new版本号
* @author phpgo.cnblogs.com
*/ // 根目录
define('SITE_PATH', '/Users/jianbao/123'); // Git 工作区
define('GIT_WORK_PATH', '/Users/jianbao/PhpStormProjects/fiisoo/git_sjf_web'); // 项目路径前缀
$prefix = 'sjf_'; $error_msg = "You must useage like {$_SERVER['argv'][0]} old_version(不包括) new_version(包括)\n";
if ($_SERVER['argc'] != 3) {
echo $error_msg;
exit(1);
} $old_version = $_SERVER['argv'][1];
$new_version = $_SERVER['argv'][2]; //$export_path = SITE_PATH . "/${prefix}${old_version}_${new_version}";
$export_path = SITE_PATH . "/${prefix}" . date('H:i:s'); // 切换至 Git 工作区
chdir(GIT_WORK_PATH); echo "开始分析版本差异...\n";
$diff_cmd = "git diff ${old_version} ${new_version} --name-status"; exec($diff_cmd, $diff_list, $return);
$diff_list = (array)$diff_list;
foreach ($diff_list as $diff_info) {
echo $diff_info . "\n";
} // 清空旧数据
@system('rm -rf ' . SITE_PATH . "/${prefix}*"); // 新建文件夹
dir_mkdir($export_path); $diff_count = count($diff_list);
if ($diff_count < 1) {
echo "版本间没有差异\n";
exit(1);
} $diff_count = 0; // 导出版本差异文件
echo "开始导出...\n";
foreach ($diff_list as $diff_info) {
if (preg_match('/([\w]+)\s+(.+)/', $diff_info, $matches)) {
$git_file_mode = $matches[1];
$git_file_name = $matches[2]; // A、M、D、AM(即增加且修改)
// 文件被删除
if ($git_file_mode == 'D') {
continue;
}
$diff_count++; // 复制到导出目录
$from_file_path = GIT_WORK_PATH . '/' . $git_file_name;
$to_file_path = $export_path . '/' . $git_file_name;
$to_file_dir = dirname($to_file_path);
dir_mkdir($to_file_dir); copy($from_file_path, $to_file_path);
}
} echo "共导出${diff_count}个差异文件\n";
exit(0); /**
* 创建文件夹
*
* @param string $path 文件夹路径
* @param int $mode 访问权限
* @param bool $recursive 是否递归创建
* @return bool
*/
function dir_mkdir($path = '', $mode = 0777, $recursive = true) {
clearstatcache();
if (!is_dir($path)) {
mkdir($path, $mode, $recursive);
return chmod($path, $mode);
} return true;
} /**
* 写文件
*
* @param string $filename 文件名
* @param string $text 要写入的文本字符串
* @param string $openmod 文本写入模式('w':覆盖重写,'a':文本追加)
* @return bool
*/
function file_write($filename = '', $text = '', $openmod = 'w') {
if (@$fp = fopen($filename, $openmod)) {
flock($fp, 2);
fwrite($fp, $text);
fclose($fp);
return true;
} else {
return false;
}
} /**
*【本地调试用】写对象(包括 数字、字符串、数组)
*
* @param string $text 要写入的文本字符串
* @param string $type 文本写入类型('w':覆盖重写,'a':文本追加)
* @return bool
*/
function write2($text, $type = 'a') {
$filename = SITE_PATH . '/write2.txt'; $text = "\n++++++++++++++++++++++++++++++++++++++++++\n"
. date('Y-m-d H:i:s') . "\n"
. print_r($text, true);
return file_write($filename, $text, $type);
}

【第二版】git_sjf_mas.php

<?php
/**
* 导出 某个分支(如:master/develop) 下,指定版本之间的差异文件,
* 如 100 和 200 之间的差异则导出 100(不包括) - 200(包括) 的所有修改
*
* @example git_sjf_mas.php old版本号 new版本号
* @author phpgo.cnblogs.com
*/ // 检查参数
$errorMsg = "【出错】You must useage like {$_SERVER['argv'][0]} old_version(不包括) new_version(包括)\n";
if ($_SERVER['argc'] != 3) {
echo $errorMsg;
exit(1);
} //++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ // 项目路径
$projectUrl = 'git@git.cnblogs.com:phpgo/sjf_web.git'; // 分支名
$branchName = 'master'; // 开发分支 改为 develop // 本地项目名
$projectName = 'git_sjf_mas'; // 开发分支 改为 git_sjf_dev // 输出路径
$exportPath = '/Users/jianbao/123'; // Git 工作区
$gitWorkPath = '/Users/jianbao/1/projects'; //++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ $subGitWorkPath = $gitWorkPath . "/${projectName}"; // 克隆 远程 develop 分支
if (!is_dir($subGitWorkPath)) {
// 切换至 Git 工作区
chdir($gitWorkPath); // 克隆 分支
system("git clone ${projectUrl} --branch ${branchName} ${subGitWorkPath}"); // 新建本地分支 develop
chdir($subGitWorkPath);
system("git branch ${branchName}");
} else {
chdir($subGitWorkPath);
} // 切换分支 develop
system("git checkout ${branchName}"); // 更新分支
system("git pull origin ${branchName}"); $oldVersion = $_SERVER['argv'][1];
$newVersion = $_SERVER['argv'][2]; // 检查 版本号
$oldVersionCmd = "git log --pretty='%h' -1 ${oldVersion}";
$newVersionCmd = "git log --pretty='%h' -1 ${newVersion}";
$ret = 0;
system($oldVersionCmd, $ret);
if ($ret !== 0) {
echo "【出错】版本号 ${oldVersion} 不存在\n";
exit(1);
} system($newVersionCmd, $ret);
if ($ret !== 0) {
echo "【出错】版本号 ${newVersion} 不存在\n";
exit(1);
} // 输出路径
$subExportPath = $exportPath . "/${projectName}_" . date('H:i:s'); echo "开始分析版本差异...\n";
$diffCmd = "git diff --name-status ${oldVersion} ${newVersion}"; exec($diffCmd, $diffList, $return);
$diffList = (array)$diffList;
foreach ($diffList as $diffInfo) {
echo $diffInfo . "\n";
} // 清空旧数据
//@system('DELTREE ' . $exportPath . "/${projectName}*"); $dh = opendir($exportPath);
while ($file = readdir($dh)) {
if ($file != "." && $file != "..") {
$fullpath = $exportPath . "/" . $file;
if (is_dir($fullpath) && (strpos($file, $projectName) !== false)) {
dir_rmdir($fullpath);
}
}
}
closedir($dh); // 新建文件夹
dir_mkdir($subExportPath); $diffCount = count($diffList);
if ($diffCount < 1) {
echo "版本间没有差异\n";
exit(1);
} $diffCount = 0; // 导出版本差异文件
echo "开始导出...\n";
foreach ($diffList as $diffInfo) {
if (preg_match('/([\w]+)\s+(.+)/', $diffInfo, $matches)) {
$gitFileMode = $matches[1];
$gitFileName = $matches[2]; // A、M、D、AM(即增加且修改)
// 文件被删除
if ($gitFileMode == 'D') {
continue;
}
$diffCount++; // 复制到导出目录
$fromFilePath = $subGitWorkPath . '/' . $gitFileName;
$toFilePath = $subExportPath . '/' . $gitFileName;
$toFileDir = dirname($toFilePath);
dir_mkdir($toFileDir); copy($fromFilePath, $toFilePath);
}
} echo "共导出 ${diffCount} 个差异文件\n";
exit(0); //++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ /**
* 创建文件夹
*
* @param string $path 文件夹路径
* @param int $mode 访问权限
* @param bool $recursive 是否递归创建
* @return bool
*/
function dir_mkdir($path = '', $mode = 0777, $recursive = true) {
clearstatcache();
if (!is_dir($path)) {
mkdir($path, $mode, $recursive);
return chmod($path, $mode);
} return true;
} /**
* 清空/删除 文件夹
*
* @param string $dir 文件夹路径
* @param bool $self 是否删除自己
* @return bool
*/
function dir_rmdir($dir, $self = true) {
$dh = opendir($dir);
while ($file = readdir($dh)) {
if ($file != "." && $file != "..") {
$fullpath = $dir . "/" . $file;
if (!is_dir($fullpath)) {
unlink($fullpath);
} else {
dir_rmdir($fullpath);
}
}
}
closedir($dh);
if ($self&& rmdir($dir)) {
return true;
} else {
return false;
}
} /**
* 写文件
*
* @param string $filename 文件名
* @param string $text 要写入的文本字符串
* @param string $openmod 文本写入模式('w':覆盖重写,'a':文本追加)
* @return bool
*/
function file_write($filename = '', $text = '', $openmod = 'w') {
if (@$fp = fopen($filename, $openmod)) {
flock($fp, 2);
fwrite($fp, $text);
fclose($fp);
return true;
} else {
return false;
}
} /**
*【本地调试用】写对象(包括 数字、字符串、数组)
*
* @param string $text 要写入的文本字符串
* @param string $type 文本写入类型('w':覆盖重写,'a':文本追加)
* @return bool
*/
function write2($text, $type = 'a') {
$filename = $GLOBALS['exportPath'] . '/write2.txt'; $text = "\n++++++++++++++++++++++++++++++++++++++++++\n"
. date('Y-m-d H:i:s') . "\n"
. print_r($text, true);
return file_write($filename, $text, $type);
}

利用 PHP 导出 Git 某个分支下,新增或修改过的文件的更多相关文章

  1. Mac Pro 利用PHP导出SVN新增或修改过的文件

    先前在 Windows 操作系统下,习惯用 TortoiseSVN 导出新增或修改过的文件([相当实用]如何让TortoiseSVN导出新增或修改过的文件 ),最近换成了 Mac Pro 笔记本电脑, ...

  2. 如何让TortoiseSVN导出新增或修改过的文件

    利用Windows系统下的TortoiseSVN客户端,可以导出指定版本之间修改过的文件,并保留完整的文件夹结构.下面我就来说说操作的步骤: 1.在网站项目的根目录下右键选择 “TortoiseSVN ...

  3. 【相当实用】如何让TortoiseSVN导出新增或修改过的文件

    当一个网站项目进入运营维护阶段以后,不会再频繁地更新全部源文件到服务器,这个时间的修改大多是局部的,因此更新文件只需更新修改过的文件,其他没有修改过的文件就没有必要上载到服务器.但一个稍微上规模的网站 ...

  4. 在git多分支repo仓库中彻底清除大文件

    坑的由来 repo中不小心上传了许多测试生成的data.结果可想而知,原本只有代码的仓库突然间变得无比臃肿(或者是慢慢臃肿),从早期的几十MB,迅速飙升至1G. 到底发生了什么 早些时候我对git的原 ...

  5. Linux系统下查找最近修改过的文件

    Linux的终端上,没有windows的搜索那样好用的图形界面工具,但find命令确是很强大的. 比如按名字查找一个文件,可以用 find / -name targetfilename . 唉,如果只 ...

  6. Git查看两个版本之间修改了哪些文件

    gdiff 63e3b647d55fcc643e793e650c893be8601719b1 548cdaf01dbc2f08d1ca0b697a24afe512b75a2f --stat git l ...

  7. Lunix/Mac下根据最后修改时间复制文件和文件夹,保持原有的目录结构

    度娘知道:http://zhidao.baidu.com/link?url=DD47jm6qDgT7yxsnz9e-NC4Fqd33oRoiIwcGLkw5TL4cbf50VKY2IONbHKH0IE ...

  8. git的介绍、git的功能特性、git工作流程、git 过滤文件、git多分支管理、远程仓库、把路飞项目传到远程仓库(非空的)、ssh链接远程仓库,协同开发

    Git(读音为/gɪt/)是一个开源的分布式版本控制系统,可以有效.高速地处理从很小到非常大的项目版本管理. [1] 也是Linus Torvalds为了帮助管理Linux内核开发而开发的一个开放源码 ...

  9. 使用git创建分支

    Git大法好--3.Git分支本地操作详解 这时已经切换到了dingBranch分支下面了,在项目文件夹下添加一个dingBranchtest.txt文件,然后提交到本地仓库和远程仓库: git ad ...

随机推荐

  1. [转]Linux联网问题

    一.Kali联网问题 首先ifconfig,可以看到没有正在工作的网卡,只有localhost 然后ifconfig -a,可以看到eth0这块网卡并没有离家出走,只是罢工了而已 打开/etc/net ...

  2. jmeter的环境配置

    工具/原料   WIN7 Jmeter安装包 JDK 一.安装JDK   1 [步骤一]安装jdk 1.下载jdk,到官网下载jdk,地址:http://www.oracle.com/technetw ...

  3. mysql学习------错误日志和通用查询日志

    一.启动错误日志 1.在不同情况下,错误日志会记录在不同的位置.如果没有在配置文件中指定文件名,则文件名默认为hostname.err 2.在mysql5.6的rpm发布方式中,错误的日志默认的放置在 ...

  4. 【linux kernel】 中断处理-中断下半部【转】

    转自:http://www.cnblogs.com/embedded-tzp/p/4453987.html 欢迎转载,转载时需保留作者信息,谢谢. 邮箱:tangzhongp@163.com 博客园地 ...

  5. [转]html网页 swf播放器使用代码

    <object id="player" height="240" width="275" classid="CLSID:6B ...

  6. http跨域时的options请求

    1.背景 在前后端分离的项目中经常会遇到跨域请求的问题,如果没有进行跨域配置,会浏览器请求失败.我一般采用两种解决方案: 1.采用nginx进行转发,是前后端服务处于同一个域下面,从根本上避免跨域问题 ...

  7. 使用Golang编写优化算法 (1)

    动手写点东西是学习新知识很重要的一个阶段.之前用 Python 和 JavaScript 实现优化算法,现在用 Golang 来实现.语法上略有不爽,某些C语言的思维又回来了. - Golang 用 ...

  8. 【LOJ】#2277. 「HAOI2017」方案数

    题解 这个出题人完美诠释了什么叫 用心出题,用脚造数据 算完复杂度怎么也得\(O(o^2 * 200)\)略微跑不满,但是有8个测试点虽然有障碍但是一个障碍都不在路径上,2个测试点只有10来个点在路径 ...

  9. 【Atcoder】ARC102 题解

    C - Triangular Relationship 题解 枚举一个数%K的值然后统计另两个 代码 #include <bits/stdc++.h> #define enter putc ...

  10. Argument 1 passed to Illuminate\Auth\SessionGuard::login() must be an instance of Illuminate\Contracts\Auth\Authenticatable, instance of App\User given,

    使用laravel内置的注册认证系统,注册账号,提示如下错误.Google之后,发现github的一个答案,解决了.分享一下 Argument 1 passed to Illuminate\Auth\ ...