Added isValidModelClass() static method and fixed getLoadedModels() in order to resort back to the (classical) approach of class inclusion as a fallback when record classes have different names than their file names. The fallback behaviour of getLoadedModels() is now similar to what is was before the changes introduced in rev 3002.
This commit is contained in:
parent
929273a0f1
commit
5d3b09524c
237
lib/Doctrine.php
237
lib/Doctrine.php
@ -37,7 +37,7 @@ final class Doctrine
|
||||
* VERSION
|
||||
*/
|
||||
const VERSION = '0.1.0';
|
||||
|
||||
|
||||
/**
|
||||
* ERROR CONSTANTS
|
||||
*/
|
||||
@ -361,7 +361,7 @@ final class Doctrine
|
||||
* HYDRATE_ARRAY
|
||||
*/
|
||||
const HYDRATE_ARRAY = 3;
|
||||
|
||||
|
||||
/**
|
||||
* HYDRATE_NONE
|
||||
*/
|
||||
@ -435,16 +435,16 @@ final class Doctrine
|
||||
* @var boolean $_debug
|
||||
*/
|
||||
private static $_debug = false;
|
||||
|
||||
|
||||
/**
|
||||
* _loadedModels
|
||||
*
|
||||
*
|
||||
* Array of all the loaded models and the path to each one for autoloading
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
private static $_loadedModels = array();
|
||||
|
||||
|
||||
/**
|
||||
* _validators
|
||||
*
|
||||
@ -467,7 +467,7 @@ final class Doctrine
|
||||
/**
|
||||
* debug
|
||||
*
|
||||
* @param string $bool
|
||||
* @param string $bool
|
||||
* @return void
|
||||
*/
|
||||
public static function debug($bool = null)
|
||||
@ -475,7 +475,7 @@ final class Doctrine
|
||||
if ($bool !== null) {
|
||||
self::$_debug = (bool) $bool;
|
||||
}
|
||||
|
||||
|
||||
return self::$_debug;
|
||||
}
|
||||
|
||||
@ -490,7 +490,7 @@ final class Doctrine
|
||||
if ( ! self::$_path) {
|
||||
self::$_path = dirname(__FILE__);
|
||||
}
|
||||
|
||||
|
||||
return self::$_path;
|
||||
}
|
||||
|
||||
@ -498,19 +498,18 @@ final class Doctrine
|
||||
* loadModels
|
||||
*
|
||||
* Recursively load all models from a directory or array of directories
|
||||
*
|
||||
* @param string $directory Path to directory of models or array of directory paths
|
||||
*
|
||||
* @param string $directory Path to directory of models or array of directory paths
|
||||
* @return array $loadedModels
|
||||
*/
|
||||
public static function loadModels($directory)
|
||||
{
|
||||
if ($directory !== null) {
|
||||
$manager = Doctrine_Manager::getInstance();
|
||||
|
||||
|
||||
foreach ((array) $directory as $dir) {
|
||||
$it = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($dir),
|
||||
RecursiveIteratorIterator::LEAVES_ONLY);
|
||||
|
||||
foreach ($it as $file) {
|
||||
$e = explode('.', $file->getFileName());
|
||||
if (end($e) === 'php' && strpos($file->getFileName(), '.inc') === false) {
|
||||
@ -527,12 +526,12 @@ final class Doctrine
|
||||
* getLoadedModels
|
||||
*
|
||||
* Get all the loaded models, you can provide an array of classes or it will use get_declared_classes()
|
||||
*
|
||||
*
|
||||
* Will filter through an array of classes and return the Doctrine_Records out of them.
|
||||
* If you do not specify $classes it will return all of the currently loaded Doctrine_Records
|
||||
*
|
||||
* @param $classes Array of classes to filter through, otherwise uses get_declared_classes()
|
||||
* @return array $loadedModels
|
||||
* @param classes Array of classes to filter through, otherwise uses get_declared_classes()
|
||||
* @return array $loadedModels
|
||||
*/
|
||||
public static function getLoadedModels($classes = null)
|
||||
{
|
||||
@ -540,51 +539,93 @@ final class Doctrine
|
||||
$classes = get_declared_classes();
|
||||
$classes = array_merge($classes, array_keys(self::$_loadedModels));
|
||||
}
|
||||
|
||||
$parent = new ReflectionClass('Doctrine_Record');
|
||||
|
||||
|
||||
$loadedModels = array();
|
||||
|
||||
|
||||
foreach ((array) $classes as $name) {
|
||||
$class = new ReflectionClass($name);
|
||||
|
||||
// Skip the following classes
|
||||
// - abstract classes
|
||||
// - not a subclass of Doctrine_Record
|
||||
// - don't have a setTableDefinition method
|
||||
if ($class->isAbstract() ||
|
||||
!$class->isSubClassOf($parent) ||
|
||||
!$class->hasMethod('setTableDefinition')) {
|
||||
continue;
|
||||
|
||||
try {
|
||||
$class = new ReflectionClass($name);
|
||||
if (self::isValidModelClass($class)) {
|
||||
$loadedModels[] = $name;
|
||||
}
|
||||
} catch (Exception $e) {
|
||||
// Determine class names by the actual inclusion of the model file
|
||||
// The possibility exists that the class name(s) contained in the model
|
||||
// file is not the same as the actual model file name itself
|
||||
if (isset(self::$_loadedModels[$name])) {
|
||||
$declaredBefore = get_declared_classes();
|
||||
try {
|
||||
require_once self::$_loadedModels[$name];
|
||||
$declaredAfter = get_declared_classes();
|
||||
// Using array_slice since array_diff is broken is some versions
|
||||
$foundClasses = array_slice($declaredAfter, count($declaredBefore)-1);
|
||||
if ($foundClasses) {
|
||||
foreach ($foundClasses as $name) {
|
||||
$class = new ReflectionClass($name);
|
||||
if (self::isValidModelClass($class)) {
|
||||
$loadedModels[] = $name;
|
||||
}
|
||||
}
|
||||
}
|
||||
} catch (Exception $e) {
|
||||
continue;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
$loadedModels[] = $name;
|
||||
|
||||
}
|
||||
|
||||
|
||||
return $loadedModels;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* isValidModelClass
|
||||
*
|
||||
* Checks whether a reflection class is a valid Doctrine model class
|
||||
*
|
||||
* @param class A reflection class to validate
|
||||
* @return boolean
|
||||
*/
|
||||
public static function isValidModelClass($class)
|
||||
{
|
||||
if ($class instanceof ReflectionClass) {
|
||||
// Skip the following classes
|
||||
// - abstract classes
|
||||
// - not a subclass of Doctrine_Record
|
||||
// - don't have a setTableDefinition method
|
||||
if (!$class->isAbstract() &&
|
||||
$class->isSubClassOf('Doctrine_Record') &&
|
||||
$class->hasMethod('setTableDefinition')) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* getConnectionByTableName
|
||||
*
|
||||
* Get the connection object for a table by the actual table name
|
||||
*
|
||||
* @param string $tableName
|
||||
*
|
||||
* @param string $tableName
|
||||
* @return object Doctrine_Connection
|
||||
*/
|
||||
public static function getConnectionByTableName($tableName)
|
||||
{
|
||||
$loadedModels = self::getLoadedModels();
|
||||
|
||||
|
||||
foreach ($loadedModels as $name) {
|
||||
$model = new $name();
|
||||
$table = $model->getTable();
|
||||
|
||||
|
||||
if ($table->getTableName() == $tableName) {
|
||||
return $table->getConnection();
|
||||
return $table->getConnection();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
return Doctrine_Manager::connection();
|
||||
}
|
||||
|
||||
@ -619,11 +660,11 @@ final class Doctrine
|
||||
Doctrine::generateModelsFromDb($directory);
|
||||
|
||||
$export = new Doctrine_Export_Schema();
|
||||
|
||||
|
||||
$result = $export->exportSchema($yamlPath, 'yml', $directory);
|
||||
|
||||
|
||||
exec('rm -rf ' . $directory);
|
||||
|
||||
|
||||
return $result;
|
||||
}
|
||||
|
||||
@ -641,7 +682,7 @@ final class Doctrine
|
||||
{
|
||||
$import = new Doctrine_Import_Schema();
|
||||
$import->setOptions($options);
|
||||
|
||||
|
||||
return $import->importSchema($yamlPath, 'yml', $directory);
|
||||
}
|
||||
|
||||
@ -674,18 +715,18 @@ final class Doctrine
|
||||
/**
|
||||
* generateSqlFromModels
|
||||
*
|
||||
* @param string $directory
|
||||
* @param string $directory
|
||||
* @return string $build String of sql queries. One query per line
|
||||
*/
|
||||
public static function generateSqlFromModels($directory = null)
|
||||
{
|
||||
$sql = Doctrine_Manager::connection()->export->exportSql($directory);
|
||||
|
||||
|
||||
$build = '';
|
||||
foreach ($sql as $query) {
|
||||
$build .= $query.";\n";
|
||||
}
|
||||
|
||||
|
||||
return $build;
|
||||
}
|
||||
|
||||
@ -701,7 +742,7 @@ final class Doctrine
|
||||
public static function generateYamlFromModels($yamlPath, $directory)
|
||||
{
|
||||
$export = new Doctrine_Export_Schema();
|
||||
|
||||
|
||||
return $export->exportSchema($yamlPath, 'yml', $directory);
|
||||
}
|
||||
|
||||
@ -718,43 +759,43 @@ final class Doctrine
|
||||
if ( ! is_array($specifiedConnections)) {
|
||||
$specifiedConnections = (array) $specifiedConnections;
|
||||
}
|
||||
|
||||
|
||||
$manager = Doctrine_Manager::getInstance();
|
||||
$connections = $manager->getConnections();
|
||||
|
||||
|
||||
$results = array();
|
||||
|
||||
|
||||
foreach ($connections as $name => $connection) {
|
||||
if ( ! empty($specifiedConnections) && !in_array($name, $specifiedConnections)) {
|
||||
continue;
|
||||
}
|
||||
|
||||
|
||||
$info = $manager->parsePdoDsn($connection->getOption('dsn'));
|
||||
$username = $connection->getOption('username');
|
||||
$password = $connection->getOption('password');
|
||||
|
||||
|
||||
// Make connection without database specified so we can create it
|
||||
$connect = $manager->openConnection(new PDO($info['scheme'] . ':host=' . $info['host'], $username, $password), 'tmp_connection', false);
|
||||
|
||||
|
||||
try {
|
||||
// Create database
|
||||
$connect->export->createDatabase($name);
|
||||
|
||||
|
||||
// Close the tmp connection with no database
|
||||
$manager->closeConnection($connect);
|
||||
|
||||
|
||||
// Close original connection
|
||||
$manager->closeConnection($connection);
|
||||
|
||||
|
||||
// Reopen original connection with newly created database
|
||||
$manager->openConnection(new PDO($info['dsn'], $username, $password), $name, true);
|
||||
|
||||
|
||||
$results[$name] = true;
|
||||
} catch (Exception $e) {
|
||||
$results[$name] = false;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
return $results;
|
||||
}
|
||||
|
||||
@ -771,27 +812,27 @@ final class Doctrine
|
||||
if ( ! is_array($specifiedConnections)) {
|
||||
$specifiedConnections = (array) $specifiedConnections;
|
||||
}
|
||||
|
||||
|
||||
$manager = Doctrine_Manager::getInstance();
|
||||
|
||||
|
||||
$connections = $manager->getConnections();
|
||||
|
||||
|
||||
$results = array();
|
||||
|
||||
|
||||
foreach ($connections as $name => $connection) {
|
||||
if ( ! empty($specifiedConnections) && !in_array($name, $specifiedConnections)) {
|
||||
continue;
|
||||
}
|
||||
|
||||
|
||||
try {
|
||||
$connection->export->dropDatabase($name);
|
||||
|
||||
|
||||
$results[$name] = true;
|
||||
} catch (Exception $e) {
|
||||
$results[$name] = false;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
return $results;
|
||||
}
|
||||
|
||||
@ -807,7 +848,7 @@ final class Doctrine
|
||||
public static function dumpData($yamlPath, $individualFiles = false)
|
||||
{
|
||||
$data = new Doctrine_Data();
|
||||
|
||||
|
||||
return $data->exportData($yamlPath, 'yml', array(), $individualFiles);
|
||||
}
|
||||
|
||||
@ -824,17 +865,17 @@ final class Doctrine
|
||||
public static function loadData($yamlPath, $append = false)
|
||||
{
|
||||
$data = new Doctrine_Data();
|
||||
|
||||
|
||||
if ( ! $append) {
|
||||
$data->purge();
|
||||
}
|
||||
|
||||
|
||||
return $data->importData($yamlPath, 'yml');
|
||||
}
|
||||
|
||||
/**
|
||||
* migrate
|
||||
*
|
||||
*
|
||||
* Migrate database to specified $to version. Migrates from current to latest if you do not specify.
|
||||
*
|
||||
* @param string $migrationsPath Path to migrations directory which contains your migration classes
|
||||
@ -845,7 +886,7 @@ final class Doctrine
|
||||
public static function migrate($migrationsPath, $to = null)
|
||||
{
|
||||
$migration = new Doctrine_Migration($migrationsPath);
|
||||
|
||||
|
||||
return $migration->migrate($to);
|
||||
}
|
||||
|
||||
@ -860,42 +901,42 @@ final class Doctrine
|
||||
public static function generateMigrationClass($className, $migrationsPath)
|
||||
{
|
||||
$builder = new Doctrine_Migration_Builder($migrationsPath);
|
||||
|
||||
|
||||
return $builder->generateMigrationClass($className);
|
||||
}
|
||||
|
||||
/**
|
||||
* generateMigrationsFromDb
|
||||
*
|
||||
* @param string $migrationsPath
|
||||
* @param string $migrationsPath
|
||||
* @return void
|
||||
* @throws new Doctrine_Migration_Exception
|
||||
*/
|
||||
public static function generateMigrationsFromDb($migrationsPath)
|
||||
{
|
||||
$builder = new Doctrine_Migration_Builder($migrationsPath);
|
||||
|
||||
|
||||
return $builder->generateMigrationsFromDb();
|
||||
}
|
||||
|
||||
/**
|
||||
* generateMigrationsFromModels
|
||||
*
|
||||
* @param string $migrationsPath
|
||||
* @param string $modelsPath
|
||||
* @param string $migrationsPath
|
||||
* @param string $modelsPath
|
||||
* @return void
|
||||
*/
|
||||
public static function generateMigrationsFromModels($migrationsPath, $modelsPath = null)
|
||||
{
|
||||
$builder = new Doctrine_Migration_Builder($migrationsPath);
|
||||
|
||||
|
||||
return $builder->generateMigrationsFromModels($modelsPath);
|
||||
}
|
||||
|
||||
/**
|
||||
* getTable
|
||||
*
|
||||
* @param string $tableName
|
||||
* @param string $tableName
|
||||
* @return void
|
||||
*/
|
||||
public static function getTable($tableName)
|
||||
@ -906,7 +947,7 @@ final class Doctrine
|
||||
/**
|
||||
* fileFinder
|
||||
*
|
||||
* @param string $type
|
||||
* @param string $type
|
||||
* @return void
|
||||
*/
|
||||
public static function fileFinder($type)
|
||||
@ -945,24 +986,24 @@ final class Doctrine
|
||||
if (class_exists($className, false)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
if ( ! self::$_path) {
|
||||
self::$_path = dirname(__FILE__);
|
||||
}
|
||||
|
||||
|
||||
$class = self::$_path . DIRECTORY_SEPARATOR . str_replace('_', DIRECTORY_SEPARATOR, $className) . '.php';
|
||||
|
||||
if (file_exists($class)) {
|
||||
require_once($class);
|
||||
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
$loadedModels = self::$_loadedModels;
|
||||
|
||||
|
||||
if (isset($loadedModels[$className]) && file_exists($loadedModels[$className])) {
|
||||
require_once($loadedModels[$className]);
|
||||
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
@ -987,7 +1028,7 @@ final class Doctrine
|
||||
$ret[] = 'Array(';
|
||||
$indent .= " ";
|
||||
foreach ($var as $k => $v) {
|
||||
|
||||
|
||||
$ret[] = $indent . $k . ' : ' . self::dump($v, false, $indent);
|
||||
}
|
||||
$indent = substr($indent,0, -4);
|
||||
@ -1034,10 +1075,10 @@ final class Doctrine
|
||||
/**
|
||||
* classifyCallback
|
||||
*
|
||||
* Callback function to classify a classname properly.
|
||||
* Callback function to classify a classname properly.
|
||||
*
|
||||
* @param array $matches An array of matches from a pcre_replace call
|
||||
* @return string A string with matches 1 and mathces 3 in upper case.
|
||||
* @return string A string with matches 1 and mathces 3 in upper case.
|
||||
*/
|
||||
public static function classifyCallback($matches)
|
||||
{
|
||||
@ -1060,13 +1101,13 @@ final class Doctrine
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* makeDirectories
|
||||
*
|
||||
*
|
||||
* Makes the directories for a path recursively
|
||||
*
|
||||
* @param string $path
|
||||
* @param string $path
|
||||
* @return void
|
||||
*/
|
||||
public static function makeDirectories($path, $mode = 0777)
|
||||
@ -1074,18 +1115,18 @@ final class Doctrine
|
||||
if (!$path) {
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
if (is_dir($path) || is_file($path)) {
|
||||
return true;
|
||||
}
|
||||
|
||||
return mkdir($path, $mode, true);
|
||||
return mkdir($path, $mode, true);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* removeDirectories
|
||||
*
|
||||
* @param string $folderPath
|
||||
* @param string $folderPath
|
||||
* @return void
|
||||
*/
|
||||
public static function removeDirectories($folderPath)
|
||||
@ -1111,7 +1152,7 @@ final class Doctrine
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* getValidators
|
||||
*
|
||||
@ -1123,19 +1164,19 @@ final class Doctrine
|
||||
{
|
||||
if (empty(self::$_validators)) {
|
||||
$dir = Doctrine::getPath() . DIRECTORY_SEPARATOR . 'Doctrine' . DIRECTORY_SEPARATOR . 'Validator';
|
||||
|
||||
|
||||
$files = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($dir), RecursiveIteratorIterator::LEAVES_ONLY);
|
||||
foreach ($files as $file) {
|
||||
$e = explode('.', $file->getFileName());
|
||||
|
||||
|
||||
if (end($e) == 'php') {
|
||||
$name = strtolower($e[0]);
|
||||
|
||||
|
||||
self::$_validators[$name] = $name;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
return self::$_validators;
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user