src/Propel/Generator/Builder/Om/ClassTools.php
<?php
/**
* MIT License. This file is part of the Propel package.
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Propel\Generator\Builder\Om;
use Propel\Generator\Model\Table;
/**
* Tools to support class & package inclusion and referencing.
*
* @author Hans Lellelid <hans@xmpl.org>
*/
class ClassTools
{
/**
* Gets just classname, given a dot-path to class.
*
* @param string|null $qualifiedName
*
* @return string|null
*/
public static function classname(?string $qualifiedName): ?string
{
if ($qualifiedName === null) {
return null;
}
$pos = strrpos($qualifiedName, '.');
if ($pos !== false) {
return substr($qualifiedName, $pos + 1); // start just after '.'
}
$pos = strrpos($qualifiedName, '\\');
if ($pos !== false) {
return substr($qualifiedName, $pos + 1);
}
return $qualifiedName; // there is no '.' in the qualified name
}
/**
* This method replaces the `getFilePath()` method in OMBuilder as we consider `$path` as
* a real path instead of a dot-notation value. `$path` is generated by the `getPackagePath()`
* method.
*
* @param string $path path to class or to package prefix.
* @param string|null $classname class name
* @param string $extension The extension to use on the file.
*
* @return string The constructed file path.
*/
public static function createFilePath(string $path, ?string $classname = null, string $extension = '.php'): string
{
if ($classname === null) {
return $path . $extension;
}
if ($path) {
$path .= '/';
}
return $path . $classname . $extension;
}
/**
* Gets the baseClass path if specified for table/db.
*
* @param \Propel\Generator\Model\Table $table
*
* @return string|null
*/
public static function getBaseClass(Table $table): ?string
{
return $table->getBaseClass();
}
/**
* Gets the interface path if specified for table.
*
* @param \Propel\Generator\Model\Table $table
*
* @return string|null
*/
public static function getInterface(Table $table): ?string
{
return $table->getInterface();
}
/**
* Gets a list of PHP reserved words.
*
* @return array<string>
*/
public static function getPhpReservedWords(): array
{
return [
'and', 'or', 'xor', 'exception', '__FILE__', '__LINE__',
'array', 'as', 'break', 'case', 'class', 'const', 'continue',
'declare', 'default', 'die', 'do', 'echo', 'else', 'elseif', 'empty',
'enddeclare', 'endfor', 'endforeach', 'endif', 'endswitch', 'endwhile',
'eval', 'exit', 'extends', 'for', 'foreach', 'function', 'global',
'if', 'include', 'include_once', 'isset', 'list', 'new', 'print', 'require',
'require_once', 'return', 'static', 'switch', 'unset', 'use', 'var', 'while',
'__FUNCTION__', '__CLASS__', '__METHOD__', '__DIR__', '__NAMESPACE__', 'final', 'php_user_filter', 'interface',
'implements', 'extends', 'public', 'protected', 'private', 'abstract', 'clone', 'try', 'catch',
'throw', 'this', 'namespace',
];
}
/**
* @return array<string>
*/
public static function getPropelReservedMethods(): array
{
return [
'isModified', 'isColumnModified', 'isNew', 'isDeleted',
];
}
}