Added missing exclusion flags

Put them into class
This commit is contained in:
斟酌 鵬兄 2014-02-04 09:58:45 +08:00
parent 541b71e9ac
commit ecf187ffb6

View File

@ -12,122 +12,19 @@ if ( !$argv[1] )
-s <str ...> Strings that will replace the matches
Optional:
*-e <patterns> Exclude defined pattern
*-l <File> Output log file
-e <patterns> Exclude defined pattern
-l <File> Output log file
-t Test without modifying anything
*Not available yet.
" ) ;
//------- End Usage -----------
//Define globals
$test = false;
$recursive = false;
$searchDirs = array();
$patterns = array();
$replaceStrs = array();
//------- Main Functions --------
function getDirName ( $dir ) {
return is_dir ( $dir ) ? $dir : dirname ( $dir ) ;
}
function getFileList ( $dir ) {
$fileList = array();
$iterator = new DirectoryIterator ( getDirName ( $dir ) ) ;
foreach ( $iterator as $fileinfo ) {
if ( $fileinfo->isFile() ) {
$fileList[] = $dir."/".$fileinfo->getFilename();
}
}
return $fileList;
}
function getDirList ( $dir ) {
$dirList = array();
$iterator = new DirectoryIterator ( getDirName ( $dir ) ) ;
foreach ( $iterator as $fileinfo ) {
if ( $fileinfo->isDir() && !$fileinfo->isDot()) {
$dirList[] = $fileinfo->getFilename();
}
}
return $dirList;
}
function getWholeDirList ( $dir ) {
$wholeDirList = array();
//getWholeDirList will stop untill getDirList return an empty array.
foreach ( getDirList ( $dir ) as $file ) {
//Store found path
$wholeDirList[] = "$dir/$file";
//Method getWholeDirList will self-iterate if sub-directories exist.
$wholeDirList = array_merge ( $wholeDirList, getWholeDirList ( "$dir/$file" ) ) ;
}
return $wholeDirList;
}
function getWholeFileList ( $dir ) {
//Get the first level list.
$wholeFileList = getFileList( $dir );
//getWholeDirList and search its files.
foreach ( getWholeDirList ( $dir ) as $dir ) {
$wholeFileList = array_merge ( $wholeFileList, getFileList ( $dir ) ) ;
}
return $wholeFileList;
}
function validateOptions ( ) {
global $searchDirs, $patterns, $replaceStrs;
try {
if(count($searchDirs) == 0)
throw new Exception("Search directory is missing");
else if(count($patterns) == 0)
throw new Exception("Search pattern is missing");
else if(count($replaceStrs) == 0)
throw new Exception("Replacement string is missing");
else if(count($replaceStrs) != count($patterns))
throw new Exception("Replacement string and pattern count not match");
} catch(Exception $e) {
var_dump( $GLOBALS );
die("Error: $e.\n");
}
}
function setOptions( $item, $value = NULL ) {
global $test, $recursive, $searchDirs, $patterns, $replaceStrs;
switch($item) {
case "-d":
if($value)
$searchDirs[] = $value;
break;
case "-p":
if($value)
$patterns[] = $value;
break;
case "-r":
$recursive = true;
break;
case "-s":
if($value)
$replaceStrs[] = $value;
break;
case "-t":
$test = true;
break;
default:
//Do nothing
}
}
class ArgvParser
{
//parseOptions utilitiese by tgckpg
function parseOptions ( $argStream, $handler ) {
static function PARSE ( $argStream, $handler ) {
//Chop first useless argument -- argv[0]
array_shift ( $argStream ) ;
//Initiate ArrayObject for iterator
@ -165,24 +62,35 @@ function parseOptions ( $argStream, $handler ) {
//Try other approach.
}// End if
}
}
//------- End Main Functions --------
class RegRename
{
//Define globals
private $test = false;
private $recursive = false;
private $searchDirs = array();
private $patterns = array();
private $replaceStrs = array();
private $excludes = array();
parseOptions ( $argv, 'setOptions' ) ;
validateOptions();
private $logfile = NULL;
public function begin()
{
$this->validateOptions();
//------- Begin Operations -------
foreach ( $searchDirs as $dir ) {
echo "Directory: $dir\nBuilding file list ...\n";
if ( $recursive ) {
$fileList = getWholeFileList($dir);
foreach ( $this->searchDirs as $dir ) {
$this->elog("Directory: $dir\nBuilding file list ...");
if ( $this->recursive ) {
$fileList = $this->getWholeFileList($dir);
} else {
$fileList = getFileList($dir);
$fileList = $this->getFileList($dir);
}
echo "Searching ...\n";
$this->elog("Searching ...");
foreach ( $fileList as $file ) {
//
// Get the file name
@ -198,29 +106,154 @@ foreach ( $searchDirs as $dir ) {
//
preg_match_all('/^(.+?)([^\/\\\\]+)$/', $file, $matches );
$newName = $matches[2][0];
foreach ( $patterns as $key => $pattern ) {
foreach ( $this->patterns as $key => $pattern ) {
//Rename over the patterns
$newName = preg_replace( $pattern, $replaceStrs[$key], $newName );
$newName = preg_replace( $pattern, $this->replaceStrs[$key], $newName );
}
if( $matches[2][0] != $newName ) {
if( $test ) {
echo "File \"{$matches[2][0]}\" will be renamed to \"$newName\"\n";
// Excluede any matches
foreach ( $this->excludes as $key => $pattern ) {
if(preg_match_all($pattern, $file)) {
$this->elog("S File \"{$matches[2][0]}\" excluded on $pattern");
continue 2;
}
}
if( $this->test ) {
$this->elog("R File \"{$matches[2][0]}\" will be renamed to \"$newName\"");
} else {
rename ( $file, "{$matches[1][0]}$newName" );
}
if ( $logfile ) {
if ( $this->logfile ) {
file_put_contents($this->logfile, $this->log);
}
}/* else {
echo "File \"{$matches[0][0]}\" will not be renamed\n";
}
//*/
}
echo "\n";
$this->elog();
}
if ( $test ) echo "*** Test enabled ***\n\n";
if ( $this->test ) $this->elog("*** Test enabled ***\n");
//------- End Operations -------*/
}
public function setOption( $item, $value = NULL ) {
switch($item) {
case "-d":
if($value)
$this->searchDirs[] = $value;
break;
case "-p":
if($value)
$this->patterns[] = $value;
break;
case "-r":
$this->recursive = true;
break;
case "-s":
if($value)
$this->replaceStrs[] = $value;
break;
case "-t":
$this->test = true;
break;
case "-e":
$this->excludes[] = $value;
break;
case "-l":
$this->logfile = $value;
break;
default:
//Do nothing
}
}
//------- Main Functions --------
function elog( $line = "" ) {
$this->log .= $line;
$this->log .= "\n";
echo "$line\n";
}
private function getDirName ( $dir ) {
return is_dir ( $dir ) ? $dir : dirname ( $dir ) ;
}
private function getFileList ( $dir ) {
$fileList = array();
$iterator = new DirectoryIterator ( $this->getDirName ( $dir ) ) ;
foreach ( $iterator as $fileinfo ) {
if ( $fileinfo->isFile() ) {
$fileList[] = $dir."/".$fileinfo->getFilename();
}
}
return $fileList;
}
private function getDirList ( $dir ) {
$dirList = array();
$iterator = new DirectoryIterator ( $this->getDirName ( $dir ) ) ;
foreach ( $iterator as $fileinfo ) {
if ( $fileinfo->isDir() && !$fileinfo->isDot()) {
$dirList[] = $fileinfo->getFilename();
}
}
return $dirList;
}
private function getWholeDirList ( $dir ) {
$wholeDirList = array();
//getWholeDirList will stop untill getDirList return an empty array.
foreach ( $this->getDirList ( $dir ) as $file ) {
//Store found path
$wholeDirList[] = "$dir/$file";
//Method getWholeDirList will self-iterate if sub-directories exist.
$wholeDirList = array_merge ( $wholeDirList, $this->getWholeDirList ( "$dir/$file" ) ) ;
}
return $wholeDirList;
}
private function getWholeFileList ( $dir ) {
//Get the first level list.
$wholeFileList = $this->getFileList( $dir );
//getWholeDirList and search its files.
foreach ( $this->getWholeDirList ( $dir ) as $dir ) {
$wholeFileList = array_merge ( $wholeFileList, $this->getFileList ( $dir ) ) ;
}
return $wholeFileList;
}
private function validateOptions ( ) {
try {
if(count($this->searchDirs) == 0)
throw new Exception("Search directory is missing");
else if(count($this->patterns) == 0)
throw new Exception("Search pattern is missing");
else if(count($this->replaceStrs) == 0)
throw new Exception("Replacement string is missing");
else if(count($this->replaceStrs) != count($this->patterns))
throw new Exception("Replacement string and pattern count not match");
} catch(Exception $e) {
var_dump( $GLOBALS );
die("Error: $e.\n");
}
}
//------- End Main Functions --------
}
$rrgr = new RegRename();
ArgvParser::PARSE ( $argv, array($rrgr, 'setOption') ) ;
$rrgr->begin();
?>