<?php
$revision_array = array(3099, 3339, 2573,3351); /* svn的版本号 */
$svnPeer = new svnPeer();
$filelist = $svnPeer->_get_file_list($revision_array);
if (!empty($filelist))
{
$lbv_export = $svnPeer->_svn_export_list($filelist, 'trunk889');
if (true === $lbv_export)
{
echo '导出成功';
}
else
{
echo '导出失败';
}
}
else
{
echo '获取文件列表失败';
}
/**
* php操作svn类,全部利用php内置的svn函数
*
* @author wengxianhu
* @date 2013-08-05
*/
class svnPeer
{
/* svn用户名 */
public $svn_user = 'wengxianhu';
/* svn密码 */
public $svn_password = 'wxh025';
/* 来源路径 */
public $source_path = '/var/www/trunk/';
/* 目标路径 */
public $dest_path = '/var/www/';
/**
* 构造函数
*
* @author wengxianhu
* @date 2013-08-05
* @return void
*/
public function __construct ()
{
$this->_svn_connect();
}
/**
* 配置SVN使用默认的用户名和密码
*
* @author wengxianhu
* @date 2013-08-05
* @return void
*/
public function _svn_connect ()
{
svn_auth_set_parameter(SVN_AUTH_PARAM_DEFAULT_USERNAME, $this->svn_user);
svn_auth_set_parameter(SVN_AUTH_PARAM_DEFAULT_PASSWORD, $this->svn_password);
}
/**
* 根据svn版本号获取所有的文件路径
*
* @author wengxianhu
* @date 2013-08-05
* @param array $revision_array 版本号列表
* @return array
*/
public function _get_file_list ($revision_array = array())
{
if (!empty($revision_array))
{
$filelist = array();
$log_list = array();
rsort($revision_array, SORT_NUMERIC);
foreach ($revision_array as $_k=>$_v)
{
$log_list = @svn_log($this->source_path, $_v, $_v);
if (false === $log_list)
{
return false;
}
else
{
$log_list = current($log_list);
foreach ($log_list['paths'] as $s_k=>$s_v)
{
$s_v['path'] = preg_replace('/^\/[^\/]+\/(.*)$/i', '$1', $s_v['path']);
$filetmp = $s_v['path'];
if (is_file($this->source_path . $s_v['path']))
{
if (false === $this->multidimensional_search($filelist, array('filepath'=>$s_v['path'])))
{
$filelist[] = array(
'revision_no' => $log_list['rev'],
'filepath' => $s_v['path']
);
}
}
}
}
}
return $filelist;
}
}
/**
* 对多维数组进行搜索
*
* @author wengxianhu
* @date 2013-08-05
* @param array $parents 被搜索数组
* @param array $searched 搜索数组
* @return boolean
*/
public function multidimensional_search ($parents = array(), $searched = array())
{
if (empty($searched) || empty($parents))
{
return false;
}
foreach ($parents as $key => $value)
{
$exists = true;
foreach ($searched as $skey => $svalue) {
$exists = ($exists && IsSet($parents[$key][$skey]) && $parents[$key][$skey] == $svalue);
}
if ($exists)
{
return $key;
}
}
return false;
}
/**
* 根据svn版本号导出相应的文件
*
* @author wengxianhu
* @date 2013-08-05
* @param array $file_array 文件路径名
* @param string $package_name 包名
* @return boolean 成功为true,失败为false
*/
public function _svn_export_list ($file_array = array(), $package_name = '')
{
$info = true;
$this->dest_path = $this->dest_path . $package_name;
if (file_exists($this->dest_path))
{
$this->delDirAndFile($this->dest_path);
}
foreach ($file_array as $_k=>$_v)
{
$source_files = $this->source_path . $_v['filepath'];
$dest_files = $this->dest_path . '/' . $_v['filepath'];
$revision_no = (int)$_v['revision_no'];
$this->_mkdirm(dirname($dest_files));
$lbv_export = @svn_export($source_files, $dest_files, false, $revision_no);
if (false === $lbv_export)
{
$info = false;
break;
}
}
return $info;
}
/**
* 创建文件夹
*
* @author wengxianhu
* @date 2013-08-05
* string $path 文件路径(不包括文件名)
* return void
*/
public function _mkdirm ($path)
{
if (!file_exists($path))
{
$this->_mkdirm(dirname($path));
mkdir($path, 0755);
}
}
/**
* 循环删除目录和文件函数
*
* @author wengxianhu
* @date 2013-08-15
* @param string $dirName 目录路径
* return array
*/
public function delDirAndFile($dirName)
{
if ( $handle = opendir( "$dirName" ) )
{
while ( false !== ( $item = readdir( $handle ) ) )
{
if ( $item != "." && $item != ".." )
{
if ( is_dir( "$dirName/$item" ) )
{
$this->delDirAndFile( "$dirName/$item" );
}
else
{
unlink( "$dirName/$item" );
}
}
}
closedir( $handle );
rmdir( $dirName );
}
}
}
分享到:
相关推荐
标题中提到的“PHP封装的svn类使用内置svn函数实现根据svn版本号导出相关文件示例”,说明了本文将围绕使用PHP语言编写的svn版本控制类库来实现通过特定的svn版本号,导出与之关联的所有文件。标题直接指出该类库...
2. **sqlite3.def**:这个文件是SQLite动态链接库(DLL)的定义文件,用于导出SQLite库中的函数,供其他程序调用。在Windows环境中,如果需要将SQLite集成到其他应用程序中,可以使用这个文件来生成相应的DLL。 3. ...
在实际应用中,配合18549这样的文件名,可能表示这是软件的版本号或者序列号,用户在安装或激活软件时可能需要用到。当然,具体含义需要根据实际情况来解读。 总之,SQL Server 数据库脚本导出器2.0是SQL Server...
标题中的"PLSQL Developer 8.0.3.1510.zip"表明这是一个版本号为8.0.3.1510的PLSQL Developer安装包,通常以ZIP格式压缩,方便用户下载和安装。 PL/SQL是Oracle数据库系统中的编程语言,结合了SQL(结构化查询语言...
PL/SQL Developer是一款由Allround Automations公司开发的专业Oracle数据库管理与开发工具,版本号7.0.3.1096代表着它在当时的技术成熟度和功能完善度。此软件为数据库管理员和开发人员提供了一个集成环境,方便编写...
6. **版本控制集成**:如果与版本控制系统(如Git或SVN)集成,PL/SQL Developer可以跟踪和管理数据库对象的版本,便于团队协作和代码管理。 7. **作业调度**:用户可以创建定时任务(也称为作业),安排SQL脚本或...
Linux下内核开发VIM环境基本配置 一、linux-vim C开发环境主要由下列文件组成: ...3、使用":VCSLog"查看当前文件变动,使用“:VCSDiff 上一个版本号”执行版本变动 4、其它命令见doc/vcscommand.txt
7. 版本控制集成:与常见的版本控制系统如Git、SVN等无缝对接,管理代码版本。 8. 自动备份和恢复功能:保护你的工作不被意外丢失。 "plsqldev1400x64.msi"是PLSQL Developer 14.0.0的安装程序文件,适用于64位操作...
版本号v8.0.0.1480代表着该软件的一个特定更新,可能包含性能优化、新功能或修复了已知问题。 PL/SQL是Oracle数据库系统中的过程化语言,全称为Procedural Language/SQL,它是SQL的扩展,增加了编程元素如流程控制...
6. **版本控制集成**:可与Git、SVN等版本控制系统集成,实现代码的版本管理和协同开发。 7. **报表和脚本执行**:可以创建自定义的报表,并批量执行SQL脚本,简化日常维护工作。 8. **导入导出功能**:方便地导入...
这个版本可能发布于2000年代中期,因为早期版本的命名方式通常会包含具体的版本号。 在描述中,"plsqldev703.zip"并未提供额外信息,但我们可以根据一般软件压缩包的理解,推测该文件包含了PL/SQL Developer的安装...
- 版本控制集成:与SVN、Git等版本控制系统无缝对接,实现数据库对象的版本控制。 - 多语言支持:提供多种语言界面,满足国际化需求。 总结,SQL Developer 19.2.1.247.2212作为Oracle数据库的强大辅助工具,其丰富...
6. **数据导入导出**:提供数据导入导出工具,支持从文件(如CSV、Excel)导入数据到表,或者将表数据导出到文件。 7. **调试器**:PL/SQL Developer的调试功能可以帮助开发者定位和修复代码错误,包括设置断点、...
描述中提到的是2017年6月7日的版本,这可能指的是PLSQL Developer的一个特定更新或版本号。通常,软件的更新会包含错误修复、性能提升和新功能的添加。对于 PLSQL Developer 来说,2017年的这个版本可能已经包含了对...
描述中的"LSQL+Developer10.0.5"可能是版本号的详细表示,暗示这是10.0.5.1710版的一个更新或补丁。 PL/SQL是Oracle数据库的编程语言,结合了SQL(结构化查询语言)的功能和过程式编程语言的特性。它允许开发者创建...
8.0.3.1510是该软件的一个具体版本号,通常意味着它包含了一系列的更新和改进,以提升性能和用户体验。 在PLSQL Developer中,你可以进行以下主要的数据库管理活动: 1. **SQL编辑与执行**:软件内置了强大的SQL...
7. **导入导出功能**:可以将数据库对象或数据导出为文件,或者从文件导入到数据库。 使用PLSQL Developer进行开发时,有以下几点需要注意: - **连接配置**:正确设置Oracle服务器的连接参数,包括服务名、主机名...
"plsqldev1105_x64.exe" 很可能是 PL/SQL Developer 的一个特定版本号(11.0.5),这表明它是64位版本的安装程序。 【标签】"plsqld" 是 PL/SQL Developer 的简写,用来标识该文件或话题与 PL/SQL 开发工具有关。 ...
"sqldeveloper-19.2.1.247.2212-no-jre.zip" 文件是 SQL Developer 的一个特定版本,该版本号表示它是在 2019 年发布,版本号为 19.2.1,构建号为 247,补丁号为 2212,且"no-jre"意味着这个压缩包不包含Java运行...