batch/library/Zend/File/ClassFileLocator.php

179 lines
6.2 KiB
PHP
Raw Normal View History

2013-06-19 09:13:51 +00:00
<?php
/**
* Zend Framework
*
* LICENSE
*
* This source file is subject to the new BSD license that is bundled
* with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* http://framework.zend.com/license/new-bsd
* If you did not receive a copy of the license and are unable to
* obtain it through the world-wide-web, please send an email
* to license@zend.com so we can send you a copy immediately.
*
* @category Zend
* @package Zend_File
2015-01-19 20:45:05 +00:00
* @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
2013-06-19 09:13:51 +00:00
* @license http://framework.zend.com/license/new-bsd New BSD License
*/
2014-05-01 17:52:31 +00:00
require_once 'Zend/File/PhpClassFile.php';
2013-06-19 09:13:51 +00:00
/**
* Locate files containing PHP classes, interfaces, or abstracts
2014-05-01 17:52:31 +00:00
*
2013-06-19 09:13:51 +00:00
* @package Zend_File
2015-01-19 20:45:05 +00:00
* @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
2013-06-19 09:13:51 +00:00
* @license New BSD {@link http://framework.zend.com/license/new-bsd}
*/
class Zend_File_ClassFileLocator extends FilterIterator
{
/**
* Create an instance of the locator iterator
2014-05-01 17:52:31 +00:00
*
* Expects either a directory, or a DirectoryIterator (or its recursive variant)
2013-06-19 09:13:51 +00:00
* instance.
2014-05-01 17:52:31 +00:00
*
* @param string|DirectoryIterator $dirOrIterator
2013-06-19 09:13:51 +00:00
*/
public function __construct($dirOrIterator = '.')
{
if (is_string($dirOrIterator)) {
if (!is_dir($dirOrIterator)) {
throw new InvalidArgumentException('Expected a valid directory name');
}
$dirOrIterator = new RecursiveDirectoryIterator($dirOrIterator);
}
if (!$dirOrIterator instanceof DirectoryIterator) {
throw new InvalidArgumentException('Expected a DirectoryIterator');
}
if ($dirOrIterator instanceof RecursiveIterator) {
$iterator = new RecursiveIteratorIterator($dirOrIterator);
} else {
$iterator = $dirOrIterator;
}
parent::__construct($iterator);
2014-05-01 17:52:31 +00:00
$this->setInfoClass('Zend_File_PhpClassFile');
2013-06-19 09:13:51 +00:00
// Forward-compat with PHP 5.3
if (version_compare(PHP_VERSION, '5.3.0', '<')) {
if (!defined('T_NAMESPACE')) {
define('T_NAMESPACE', 'namespace');
}
if (!defined('T_NS_SEPARATOR')) {
define('T_NS_SEPARATOR', '\\');
}
}
}
/**
* Filter for files containing PHP classes, interfaces, or abstracts
2014-05-01 17:52:31 +00:00
*
2013-06-19 09:13:51 +00:00
* @return bool
*/
public function accept()
{
$file = $this->getInnerIterator()->current();
2014-05-01 17:52:31 +00:00
// If we somehow have something other than an SplFileInfo object, just
2013-06-19 09:13:51 +00:00
// return false
if (!$file instanceof SplFileInfo) {
return false;
}
// If we have a directory, it's not a file, so return false
if (!$file->isFile()) {
return false;
}
// If not a PHP file, skip
if ($file->getBasename('.php') == $file->getBasename()) {
return false;
}
$contents = file_get_contents($file->getRealPath());
$tokens = token_get_all($contents);
$count = count($tokens);
2014-05-01 17:52:31 +00:00
$t_trait = defined('T_TRAIT') ? T_TRAIT : -1; // For preserve PHP 5.3 compatibility
for ($i = 0; $i < $count; $i++) {
2013-06-19 09:13:51 +00:00
$token = $tokens[$i];
if (!is_array($token)) {
// single character token found; skip
$i++;
continue;
}
2014-05-01 17:52:31 +00:00
switch ($token[0]) {
2013-06-19 09:13:51 +00:00
case T_NAMESPACE:
// Namespace found; grab it for later
$namespace = '';
2014-05-01 17:52:31 +00:00
for ($i++; $i < $count; $i++) {
2013-06-19 09:13:51 +00:00
$token = $tokens[$i];
if (is_string($token)) {
if (';' === $token) {
2014-05-01 17:52:31 +00:00
$saveNamespace = false;
break;
}
if ('{' === $token) {
$saveNamespace = true;
break;
2013-06-19 09:13:51 +00:00
}
continue;
}
list($type, $content, $line) = $token;
switch ($type) {
case T_STRING:
case T_NS_SEPARATOR:
$namespace .= $content;
break;
}
2014-05-01 17:52:31 +00:00
}
if ($saveNamespace) {
$savedNamespace = $namespace;
}
2013-06-19 09:13:51 +00:00
break;
2014-05-01 17:52:31 +00:00
case $t_trait:
2013-06-19 09:13:51 +00:00
case T_CLASS:
case T_INTERFACE:
2014-05-01 17:52:31 +00:00
// Abstract class, class, interface or trait found
2013-06-19 09:13:51 +00:00
// Get the classname
2014-05-01 17:52:31 +00:00
for ($i++; $i < $count; $i++) {
2013-06-19 09:13:51 +00:00
$token = $tokens[$i];
if (is_string($token)) {
continue;
}
list($type, $content, $line) = $token;
2014-05-01 17:52:31 +00:00
if (T_STRING == $type) {
// If a classname was found, set it in the object, and
2013-06-19 09:13:51 +00:00
// return boolean true (found)
2014-05-01 17:52:31 +00:00
if (!isset($namespace) || null === $namespace) {
if (isset($saveNamespace) && $saveNamespace) {
$namespace = $savedNamespace;
} else {
$namespace = null;
}
}
$class = (null === $namespace) ? $content : $namespace . '\\' . $content;
$file->addClass($class);
$namespace = null;
break;
}
2013-06-19 09:13:51 +00:00
}
break;
default:
break;
}
}
2014-05-01 17:52:31 +00:00
$classes = $file->getClasses();
if (!empty($classes)) {
return true;
}
2013-06-19 09:13:51 +00:00
// No class-type tokens found; return false
return false;
}
}