From 2025461b69ab7f8547a5072c263b89fbef18da0a Mon Sep 17 00:00:00 2001 From: ctrlaltca Date: Wed, 15 Mar 2023 16:35:50 +0100 Subject: [PATCH] Make Prado::using able to autoload traits defined as prado3 namespaces (#876) --- framework/Prado.php | 27 ++++++++++++++++++++------- 1 file changed, 20 insertions(+), 7 deletions(-) diff --git a/framework/Prado.php b/framework/Prado.php index 197fd52a2..be29b4b61 100644 --- a/framework/Prado.php +++ b/framework/Prado.php @@ -375,15 +375,20 @@ public static function using($namespace): void if (isset(self::$_usings[$namespace]) || class_exists($namespace, false) || - interface_exists($namespace, false)) { + interface_exists($namespace, false) || + trait_exists($namespace, false)) { return; } if (array_key_exists($namespace, self::$classMap)) { // fast autoload a Prado3 class name $phpNamespace = self::$classMap[$namespace]; - if (class_exists($phpNamespace, true) || interface_exists($phpNamespace, true)) { - if (!class_exists($namespace) && !interface_exists($namespace)) { + if (class_exists($phpNamespace, true) || + interface_exists($phpNamespace, true) || + trait_exists($phpNamespace, true)) { + if (!class_exists($namespace) && + !interface_exists($namespace) && + !trait_exists($namespace)) { class_alias($phpNamespace, $namespace); } return; @@ -394,8 +399,12 @@ class_alias($phpNamespace, $namespace); $path = $v . DIRECTORY_SEPARATOR . $namespace . self::CLASS_FILE_EXT; if (file_exists($path)) { $phpNamespace = '\\' . $k . '\\' . $namespace; - if (class_exists($phpNamespace, true) || interface_exists($phpNamespace, true)) { - if (!class_exists($namespace) && !interface_exists($namespace)) { + if (class_exists($phpNamespace, true) || + interface_exists($phpNamespace, true) || + trait_exists($phpNamespace, true)) { + if (!class_exists($namespace) && + !interface_exists($namespace) && + !trait_exists($namespace)) { class_alias($phpNamespace, $namespace); } return; @@ -407,13 +416,17 @@ class_alias($phpNamespace, $namespace); if ($className === '*') { // a directory self::$_usings[substr($namespace, 0, $pos)] = $path; } else { // a file - if (class_exists($className, false) || interface_exists($className, false)) { + if (class_exists($className, false) || + interface_exists($className, false) || + trait_exists($className, false)) { return; } if (file_exists($path)) { include_once($path); - if (!class_exists($className, false) && !interface_exists($className, false)) { + if (!class_exists($className, false) && + !interface_exists($className, false) && + !trait_exists($className, false)) { class_alias($namespace, $className); } }