diff --git a/Account/Account.php b/Account/Account.php index 33f9ae6ec..597ea510c 100644 --- a/Account/Account.php +++ b/Account/Account.php @@ -292,7 +292,7 @@ class Account implements ArrayableInterface, \JsonSerializable /** * Get permissions. * - * @return array + * @return PermissionAbstract[] * * @since 1.0.0 */ @@ -603,7 +603,7 @@ class Account implements ArrayableInterface, \JsonSerializable */ public function __toString() : string { - return json_encode($this->toArray()); + return \json_encode($this->toArray()); } /** @@ -630,7 +630,7 @@ class Account implements ArrayableInterface, \JsonSerializable /** * Json serialize. * - * @return array + * @return array * * @since 1.0.0 */ diff --git a/Account/Group.php b/Account/Group.php index 1a8f874b4..8bcd3e429 100644 --- a/Account/Group.php +++ b/Account/Group.php @@ -189,7 +189,7 @@ class Group implements ArrayableInterface, \JsonSerializable */ public function __toString() : string { - return json_encode($this->toArray()); + return \json_encode($this->toArray()); } /** @@ -209,7 +209,7 @@ class Group implements ArrayableInterface, \JsonSerializable /** * Json serialize. * - * @return array + * @return array * * @since 1.0.0 */ diff --git a/Autoloader.php b/Autoloader.php index 08e8506db..9ee328ee4 100644 --- a/Autoloader.php +++ b/Autoloader.php @@ -77,8 +77,8 @@ final class Autoloader */ public static function defaultAutoloader(string $class) : void { - $class = ltrim($class, '\\'); - $class = str_replace(['_', '\\'], '/', $class); + $class = \ltrim($class, '\\'); + $class = \str_replace(['_', '\\'], '/', $class); foreach (self::$paths as $path) { if (file_exists($file = $path . $class . '.php')) { @@ -102,8 +102,8 @@ final class Autoloader */ public static function exists(string $class) : bool { - $class = ltrim($class, '\\'); - $class = str_replace(['_', '\\'], '/', $class); + $class = \ltrim($class, '\\'); + $class = \str_replace(['_', '\\'], '/', $class); foreach (self::$paths as $path) { if (file_exists($file = $path . $class . '.php')) { diff --git a/Config/SettingsAbstract.php b/Config/SettingsAbstract.php index d26c8356c..042805f76 100644 --- a/Config/SettingsAbstract.php +++ b/Config/SettingsAbstract.php @@ -77,7 +77,7 @@ abstract class SettingsAbstract implements OptionsInterface /** * Get option by key. * - * @param string|string[] $columns Column values for filtering + * @param string|string[]|int|int[] $columns Column values for filtering * * @return mixed Option value * diff --git a/DataStorage/Cache/Connection/FileCache.php b/DataStorage/Cache/Connection/FileCache.php index 550d3a57c..7ad8ccadf 100644 --- a/DataStorage/Cache/Connection/FileCache.php +++ b/DataStorage/Cache/Connection/FileCache.php @@ -219,7 +219,7 @@ class FileCache extends ConnectionAbstract if ($type === CacheValueType::_INT || $type === CacheValueType::_FLOAT || $type === CacheValueType::_STRING || $type === CacheValueType::_BOOL) { return (string) $value; } elseif ($type === CacheValueType::_ARRAY) { - return json_encode($value); + return \json_encode($value); } elseif ($type === CacheValueType::_SERIALIZABLE) { return get_class($value) . self::DELIM . $value->serialize(); } elseif ($type === CacheValueType::_JSONSERIALIZABLE) { @@ -315,7 +315,7 @@ class FileCache extends ConnectionAbstract $value = substr($raw, $expireEnd + 1); break; case CacheValueType::_ARRAY: - $value = json_decode(substr($raw, $expireEnd + 1)); + $value = \json_decode(substr($raw, $expireEnd + 1)); break; case CacheValueType::_NULL: $value = null; @@ -353,7 +353,7 @@ class FileCache extends ConnectionAbstract if ($expire >= 0) { $created = Directory::created(File::sanitize($key, self::SANITIZE))->getTimestamp(); $now = time(); - $raw = file_get_contents($path); + $raw = \file_get_contents($path); $expireStart = strpos($raw, self::DELIM); $expireEnd = strpos($raw, self::DELIM, $expireStart + 1); $cacheExpire = substr($raw, $expireStart + 1, $expireEnd - ($expireStart + 1)); diff --git a/DataStorage/Database/Connection/MysqlConnection.php b/DataStorage/Database/Connection/MysqlConnection.php index 3e41ba8ab..a05fc19b3 100644 --- a/DataStorage/Database/Connection/MysqlConnection.php +++ b/DataStorage/Database/Connection/MysqlConnection.php @@ -59,7 +59,7 @@ final class MysqlConnection extends ConnectionAbstract $this->dbdata = isset($dbdata) ? $dbdata : $this->dbdata; if (!isset($this->dbdata['db'], $this->dbdata['host'], $this->dbdata['port'], $this->dbdata['database'], $this->dbdata['login'], $this->dbdata['password'])) { - throw new InvalidConnectionConfigException(json_encode($this->dbdata)); + throw new InvalidConnectionConfigException(\json_encode($this->dbdata)); } $this->close(); diff --git a/DataStorage/Database/Connection/PostgresConnection.php b/DataStorage/Database/Connection/PostgresConnection.php index 447829736..33fa94d48 100644 --- a/DataStorage/Database/Connection/PostgresConnection.php +++ b/DataStorage/Database/Connection/PostgresConnection.php @@ -58,7 +58,7 @@ final class PostgresConnection extends ConnectionAbstract $this->dbdata = isset($dbdata) ? $dbdata : $this->dbdata; if (!isset($this->dbdata['db'], $this->dbdata['host'], $this->dbdata['port'], $this->dbdata['database'], $this->dbdata['login'], $this->dbdata['password'])) { - throw new InvalidConnectionConfigException(json_encode($this->dbdata)); + throw new InvalidConnectionConfigException(\json_encode($this->dbdata)); } $this->close(); diff --git a/DataStorage/Database/DataMapperAbstract.php b/DataStorage/Database/DataMapperAbstract.php index 0894da0a1..df7b51ad7 100644 --- a/DataStorage/Database/DataMapperAbstract.php +++ b/DataStorage/Database/DataMapperAbstract.php @@ -14,7 +14,7 @@ declare(strict_types=1); namespace phpOMS\DataStorage\Database; -use phpOMS\DataStorage\Database\Connection\ConnectionAbstract; +use phpOMS\DataStorage\DataStorageConnectionInterface; use phpOMS\DataStorage\Database\Query\Builder; use phpOMS\DataStorage\DataMapperInterface; use phpOMS\Message\RequestAbstract; @@ -37,7 +37,7 @@ class DataMapperAbstract implements DataMapperInterface /** * Database connection. * - * @var ConnectionAbstract + * @var DataStorageConnectionInterface * @since 1.0.0 */ protected static $db = null; @@ -77,7 +77,7 @@ class DataMapperAbstract implements DataMapperInterface /** * Columns. * - * @var array + * @var array> * @since 1.0.0 */ protected static $columns = []; @@ -195,13 +195,13 @@ class DataMapperAbstract implements DataMapperInterface /** * Set database connection. * - * @param ConnectionAbstract $con Database connection + * @param DataStorageConnectionInterface $con Database connection * * @return void * * @since 1.0.0 */ - public static function setConnection(ConnectionAbstract $con) : void + public static function setConnection(DataStorageConnectionInterface $con) : void { self::$db = $con; } @@ -402,7 +402,7 @@ class DataMapperAbstract implements DataMapperInterface $query->prefix(self::$db->getPrefix())->into(static::$table); foreach (static::$columns as $key => $column) { - $propertyName = stripos($column['internal'], '/') !== false ? explode('/', $column['internal'])[0] : $column['internal']; + $propertyName = \stripos($column['internal'], '/') !== false ? explode('/', $column['internal'])[0] : $column['internal']; if (isset(static::$hasMany[$propertyName]) || isset(static::$hasOne[$propertyName])) { continue; } @@ -426,7 +426,7 @@ class DataMapperAbstract implements DataMapperInterface } elseif ($column['name'] !== static::$primaryField) { $tValue = $property->getValue($obj); if (stripos($column['internal'], '/') !== false) { - $path = explode('/', $column['internal']); + $path = \explode('/', $column['internal']); array_shift($path); $path = implode('/', $path); @@ -476,7 +476,7 @@ class DataMapperAbstract implements DataMapperInterface $path = $column['internal']; if (stripos($column['internal'], '/') !== false) { - $path = explode('/', $column['internal']); + $path = \explode('/', $column['internal']); array_shift($path); $path = implode('/', $path); @@ -890,11 +890,11 @@ class DataMapperAbstract implements DataMapperInterface } elseif ($type === 'DateTime') { return $value->format('Y-m-d H:i:s'); } elseif ($type === 'Json' || $type === 'jsonSerializable') { - return json_encode($value); + return \json_encode($value); } elseif ($type === 'Serializable') { return $value->serialize(); } elseif ($value instanceof \JsonSerializable) { - return json_encode($value->jsonSerialize()); + return \json_encode($value->jsonSerialize()); } elseif (is_object($value) && method_exists($value, 'getId')) { return $value->getId(); } @@ -1118,7 +1118,7 @@ class DataMapperAbstract implements DataMapperInterface ->where(static::$table . '.' . static::$primaryField, '=', $objId); foreach (static::$columns as $key => $column) { - $propertyName = stripos($column['internal'], '/') !== false ? explode('/', $column['internal'])[0] : $column['internal']; + $propertyName = \stripos($column['internal'], '/') !== false ? explode('/', $column['internal'])[0] : $column['internal']; if (isset(static::$hasMany[$propertyName]) || isset(static::$hasOne[$propertyName]) || $column['internal'] === static::$primaryField @@ -1147,7 +1147,7 @@ class DataMapperAbstract implements DataMapperInterface } elseif ($column['name'] !== static::$primaryField) { $tValue = $property->getValue($obj); if (stripos($column['internal'], '/') !== false) { - $path = explode('/', $column['internal']); + $path = \explode('/', $column['internal']); array_shift($path); $path = implode('/', $path); @@ -1480,10 +1480,10 @@ class DataMapperAbstract implements DataMapperInterface public static function populate(array $result, $obj = null) { $class = static::class; - $class = str_replace('Mapper', '', $class); + $class = \str_replace('Mapper', '', $class); if (empty($result)) { - $parts = explode('\\', $class); + $parts = \explode('\\', $class); $name = $parts[$c = (count($parts) - 1)]; $parts[$c] = 'Null' . $name; $class = implode('\\', $parts); @@ -1779,7 +1779,7 @@ class DataMapperAbstract implements DataMapperInterface if (stripos(static::$columns[$column]['internal'], '/') !== false) { $hasPath = true; - $path = explode('/', static::$columns[$column]['internal']); + $path = \explode('/', static::$columns[$column]['internal']); $refProp = $refClass->getProperty($path[0]); if (!($accessible = $refProp->isPublic())) { @@ -1797,7 +1797,7 @@ class DataMapperAbstract implements DataMapperInterface } } - if (in_array(static::$columns[$column]['type'], ['string', 'int', 'float', 'bool'])) { + if (\in_array(static::$columns[$column]['type'], ['string', 'int', 'float', 'bool'])) { // todo: what is this or condition for? seems to be wrong if obj null then it doesn't work anyways if ($value !== null || $refProp->getValue($obj) !== null) { settype($value, static::$columns[$column]['type']); @@ -1820,7 +1820,7 @@ class DataMapperAbstract implements DataMapperInterface $value = ArrayUtils::setArray($path, $aValue, $value, '/', true); } - $refProp->setValue($obj, json_decode($value, true)); + $refProp->setValue($obj, \json_decode($value, true)); } elseif (static::$columns[$column]['type'] === 'Serializable') { $member = $refProp->getValue($obj); $member->unserialize($value); @@ -1852,18 +1852,18 @@ class DataMapperAbstract implements DataMapperInterface if (isset(static::$columns[$column]['internal'])) { $path = static::$columns[$column]['internal']; if (stripos($path, '/') !== false) { - $path = explode('/', $path); + $path = \explode('/', $path); array_shift($path); $path = implode('/', $path); } - if (in_array(static::$columns[$column]['type'], ['string', 'int', 'float', 'bool'])) { + if (\in_array(static::$columns[$column]['type'], ['string', 'int', 'float', 'bool'])) { settype($value, static::$columns[$column]['type']); } elseif (static::$columns[$column]['type'] === 'DateTime') { $value = new \DateTime($value ?? ''); } elseif (static::$columns[$column]['type'] === 'Json') { - $value = json_decode($value, true); + $value = \json_decode($value, true); } $obj = ArrayUtils::setArray($path, $obj, $value, '/', true); @@ -1949,8 +1949,8 @@ class DataMapperAbstract implements DataMapperInterface private static function getNullModelObj() { $class = static::class; - $class = str_replace('Mapper', '', $class); - $parts = explode('\\', $class); + $class = \str_replace('Mapper', '', $class); + $parts = \explode('\\', $class); $name = $parts[$c = (count($parts) - 1)]; $parts[$c] = 'Null' . $name; $class = implode('\\', $parts); @@ -1965,7 +1965,7 @@ class DataMapperAbstract implements DataMapperInterface * @param int $relations Load relations * @param int $depth Relation depth * - * @return mixed + * @return array * * @since 1.0.0 */ @@ -2574,7 +2574,7 @@ class DataMapperAbstract implements DataMapperInterface $result = static::getAll(); } elseif ($filter === 'list') { $list = $request->getData('list'); - $result = static::get(json_decode($list, true)); + $result = static::get(\json_decode($list, true)); } else { $limit = (int) ($request->getData('limit') ?? 1); $from = $request->getData('from') === null ? null : new \DateTime((string) $request->getData('from')); diff --git a/DataStorage/Database/GrammarAbstract.php b/DataStorage/Database/GrammarAbstract.php index a02be1092..ecd7c91c0 100644 --- a/DataStorage/Database/GrammarAbstract.php +++ b/DataStorage/Database/GrammarAbstract.php @@ -245,7 +245,7 @@ abstract class GrammarAbstract } // todo: move remaining * test also here not just if .* but also if * (should be done in else?) - if (count($split = explode('.', $system)) === 2) { + if (count($split = \explode('.', $system)) === 2) { $system = $split[1] === '*' ? $split[1] : $this->compileSystem($split[1]); return $this->compileSystem($prefix . $split[0]) . '.' . $system; diff --git a/DataStorage/Database/Query/Builder.php b/DataStorage/Database/Query/Builder.php index 1cae96965..ad37a3625 100644 --- a/DataStorage/Database/Query/Builder.php +++ b/DataStorage/Database/Query/Builder.php @@ -38,7 +38,7 @@ final class Builder extends BuilderAbstract /** * Columns. * - * @var array + * @var array> * @since 1.0.0 */ public $selects = []; @@ -46,7 +46,7 @@ final class Builder extends BuilderAbstract /** * Columns. * - * @var array + * @var array> * @since 1.0.0 */ public $updates = []; @@ -486,7 +486,7 @@ final class Builder extends BuilderAbstract */ public function where($columns, $operator = null, $values = null, $boolean = 'and') : Builder { - if ($operator !== null && !is_array($operator) && !in_array(strtolower($operator), self::OPERATORS)) { + if ($operator !== null && !is_array($operator) && !\in_array(strtolower($operator), self::OPERATORS)) { throw new \InvalidArgumentException('Unknown operator.'); } @@ -499,7 +499,7 @@ final class Builder extends BuilderAbstract $i = 0; foreach ($columns as $key => $column) { - if (isset($operator[$i]) && !in_array(strtolower($operator[$i]), self::OPERATORS)) { + if (isset($operator[$i]) && !\in_array(strtolower($operator[$i]), self::OPERATORS)) { throw new \InvalidArgumentException('Unknown operator.'); } diff --git a/DataStorage/Session/HttpSession.php b/DataStorage/Session/HttpSession.php index 4eabb1397..2d66dc3a2 100644 --- a/DataStorage/Session/HttpSession.php +++ b/DataStorage/Session/HttpSession.php @@ -80,29 +80,29 @@ class HttpSession implements SessionInterface throw new LockException('HttpSession'); } - if (session_id()) { - session_write_close(); + if (\session_id()) { + \session_write_close(); } - if (!is_bool($sid)) { - session_id($sid); + if (!\is_bool($sid)) { + \session_id($sid); } $this->inactivityInterval = $inactivityInterval; if (session_status() !== PHP_SESSION_ACTIVE && !headers_sent()) { - session_set_cookie_params($liftetime, '/', '', false, true); - session_start(); + \session_set_cookie_params($liftetime, '/', '', false, true); + \session_start(); } - if ($this->inactivityInterval > 0 && ($this->inactivityInterval + ($_SESSION['lastActivity'] ?? 0) < time())) { + if ($this->inactivityInterval > 0 && ($this->inactivityInterval + ($_SESSION['lastActivity'] ?? 0) < \time())) { $this->destroy(); } $this->sessionData = $_SESSION; $_SESSION = null; - $this->sessionData['lastActivity'] = time(); - $this->sid = session_id(); + $this->sessionData['lastActivity'] = \time(); + $this->sid = \session_id(); $this->setCsrfProtection(); } @@ -175,7 +175,7 @@ class HttpSession implements SessionInterface { if (!self::$isLocked) { $_SESSION = $this->sessionData; - session_write_close(); + \session_write_close(); } } @@ -218,9 +218,9 @@ class HttpSession implements SessionInterface */ private function destroy() : void { - session_destroy(); + \session_destroy(); $this->sessionData = []; - session_start(); + \session_start(); } /** diff --git a/DataStorage/Web/Builder.php b/DataStorage/Web/Builder.php index 3455ff376..268029182 100644 --- a/DataStorage/Web/Builder.php +++ b/DataStorage/Web/Builder.php @@ -11,7 +11,7 @@ * @link http://website.orange-management.de */ declare(strict_types=1); -namespace phpOMS\Utils\Crawler; +namespace phpOMS\DataStorage\Web; use phpOMs\DataStorage\Database\Query\Builder as DatabaseQueryBuilder; use phpOMS\Localization\Localization; @@ -26,7 +26,7 @@ use phpOMS\Uri\Http; * @link http://website.orange-management.de * @since 1.0.0 */ -class Builder extends DatabaseQueryBuilder +class Builder { private function download($uri) diff --git a/Dispatcher/Dispatcher.php b/Dispatcher/Dispatcher.php index 8cdfaf961..3db81f3ad 100644 --- a/Dispatcher/Dispatcher.php +++ b/Dispatcher/Dispatcher.php @@ -103,9 +103,9 @@ final class Dispatcher private function dispatchString(string $controller, array $data = null) : array { $views = []; - $dispatch = explode(':', $controller); + $dispatch = \explode(':', $controller); - if (!file_exists($path = __DIR__ . '/../../' . str_replace('\\', '/', $dispatch[0]) . '.php')) { + if (!\file_exists($path = __DIR__ . '/../../' . \str_replace('\\', '/', $dispatch[0]) . '.php')) { throw new PathException($path); } @@ -174,7 +174,7 @@ final class Dispatcher if (!isset($this->controllers[$controller])) { // If module controller use module manager for initialization if (strpos('\Modules\Controller', $controller) === 0) { - $split = explode('\\', $controller); + $split = \explode('\\', $controller); $this->controllers[$controller] = $this->app->moduleManager->get($split[2]); } else { $this->controllers[$controller] = new $controller($this->app); diff --git a/Math/Optimization/TSP/City.php b/Localization/Defaults/City.php similarity index 51% rename from Math/Optimization/TSP/City.php rename to Localization/Defaults/City.php index a99b3f43f..a868da69f 100644 --- a/Math/Optimization/TSP/City.php +++ b/Localization/Defaults/City.php @@ -4,7 +4,7 @@ * * PHP Version 7.2 * - * @package TBD + * @package phpOMS\Localization\Defaults * @copyright Dennis Eichhorn * @license OMS License 1.0 * @version 1.0.0 @@ -12,22 +12,44 @@ */ declare(strict_types=1); -namespace phpOMS\Math\Optimization\TSP; - -use phpOMS\Math\Geometry\Shape\D3\Sphere; +namespace phpOMS\Localization\Defaults; /** * City class. * - * @package Framework + * @package phpOMS\Localization\Defaults * @license OMS License 1.0 * @link http://website.orange-management.de * @since 1.0.0 */ -class City +final class City { /** - * City name + * City id. + * + * @var int + * @since 1.0.0 + */ + private $id = 0; + + /** + * Country code. + * + * @var string + * @since 1.0.0 + */ + private $countryCode = ''; + + /** + * State code. + * + * @var string + * @since 1.0.0 + */ + private $state = ''; + + /** + * City name. * * @var string * @since 1.0.0 @@ -35,15 +57,15 @@ class City private $name = ''; /** - * City longitude + * Postal code. * - * @var float + * @var int * @since 1.0.0 */ - private $long = 0.0; + private $postal = 0; /** - * City latitude + * Latitude. * * @var float * @since 1.0.0 @@ -51,37 +73,15 @@ class City private $lat = 0.0; /** - * Constructor. + * Longitude. * - * @param float $lat Latitude - * @param float $long Longitude - * @param string $name City name - * - * @since 1.0.0 + * @var float + * @since 1.0.0 */ - public function __construct(float $lat = 0, float $long = 0, string $name = '') - { - $this->long = $long; - $this->lat = $lat; - $this->name = $name; - } + private $long = 0.0; /** - * Is equals to. - * - * @param City $city City - * - * @return bool - * - * @since 1.0.0 - */ - public function equals(City $city) : bool - { - return $this->name === $city->getName() && $this->lat === $city->getLatitude() && $this->long === $city->getLatitude(); - } - - /** - * Get name. + * Get city name * * @return string * @@ -93,39 +93,61 @@ class City } /** - * Get latitude. + * Get country code + * + * @return string + * + * @since 1.0.0 + */ + public function getCountryCode() : string + { + return $this->countryCode; + } + + /** + * Get city state + * + * @return string + * + * @since 1.0.0 + */ + public function getState() : string + { + return $this->state; + } + + /** + * Get city postal + * + * @return int + * + * @since 1.0.0 + */ + public function getPostal() : int + { + return $this->postal; + } + + /** + * Get city latitude * * @return float * * @since 1.0.0 */ - public function getLatitude() : float + public function getLat() : float { return $this->lat; } /** - * Distance to city in meter - * - * @param City $city City + * Get city longitude * * @return float * * @since 1.0.0 */ - public function getDistanceTo(City $city) : float - { - return Sphere::distance2PointsOnSphere($this->lat, $this->long, $city->getLatitude(), $city->getLongitude()); - } - - /** - * Get longitude. - * - * @return float - * - * @since 1.0.0 - */ - public function getLongitude() : float + public function getLong() : float { return $this->long; } diff --git a/Localization/Defaults/CityMapper.php b/Localization/Defaults/CityMapper.php new file mode 100644 index 000000000..e0d0337f4 --- /dev/null +++ b/Localization/Defaults/CityMapper.php @@ -0,0 +1,64 @@ +> + * @since 1.0.0 + */ + protected static $columns = [ + 'city_id' => ['name' => 'city_id', 'type' => 'int', 'internal' => 'id'], + 'city_city' => ['name' => 'city_city', 'type' => 'string', 'internal' => 'name'], + 'city_country' => ['name' => 'city_country', 'type' => 'string', 'internal' => 'countryCode'], + 'city_state' => ['name' => 'city_state', 'type' => 'string', 'internal' => 'state'], + 'city_postal' => ['name' => 'city_postal', 'type' => 'int', 'internal' => 'postal'], + 'city_lat' => ['name' => 'city_lat', 'type' => 'float', 'internal' => 'lat'], + 'city_long' => ['name' => 'city_long', 'type' => 'float', 'internal' => 'long'], + ]; + + /** + * Primary table. + * + * @var string + * @since 1.0.0 + */ + protected static $table = 'city'; + + /** + * Primary field name. + * + * @var string + * @since 1.0.0 + */ + protected static $primaryField = 'city_id'; +} diff --git a/Localization/Defaults/Country.php b/Localization/Defaults/Country.php new file mode 100644 index 000000000..7d2c5209e --- /dev/null +++ b/Localization/Defaults/Country.php @@ -0,0 +1,134 @@ +name; + } + + /** + * Get country code + * + * @return string + * + * @since 1.0.0 + */ + public function getCode2() : string + { + return $this->code2; + } + + /** + * Get country code + * + * @return string + * + * @since 1.0.0 + */ + public function getCode3() : string + { + return $this->code3; + } + + /** + * Get country numeric + * + * @return int + * + * @since 1.0.0 + */ + public function getNumeric() : int + { + return $this->numeric; + } + + /** + * Get country subdevision + * + * @return string + * + * @since 1.0.0 + */ + public function getSubdevision() : string + { + return $this->subdevision; + } +} diff --git a/Localization/Defaults/CountryMapper.php b/Localization/Defaults/CountryMapper.php new file mode 100644 index 000000000..5f5f3c5e8 --- /dev/null +++ b/Localization/Defaults/CountryMapper.php @@ -0,0 +1,63 @@ +> + * @since 1.0.0 + */ + protected static $columns = [ + 'country_id' => ['name' => 'country_id', 'type' => 'int', 'internal' => 'id'], + 'country_name' => ['name' => 'country_name', 'type' => 'string', 'internal' => 'name'], + 'country_code2' => ['name' => 'country_code2', 'type' => 'string', 'internal' => 'code2'], + 'country_code3' => ['name' => 'country_code3', 'type' => 'string', 'internal' => 'code3'], + 'country_numeric' => ['name' => 'country_numeric', 'type' => 'int', 'internal' => 'numeric'], + 'country_subdevision' => ['name' => 'country_subdevision', 'type' => 'float', 'internal' => 'subdevision'], + ]; + + /** + * Primary table. + * + * @var string + * @since 1.0.0 + */ + protected static $table = 'country'; + + /** + * Primary field name. + * + * @var string + * @since 1.0.0 + */ + protected static $primaryField = 'country_id'; +} diff --git a/Localization/Defaults/Currency.php b/Localization/Defaults/Currency.php new file mode 100644 index 000000000..225d3c00e --- /dev/null +++ b/Localization/Defaults/Currency.php @@ -0,0 +1,134 @@ +name; + } + + /** + * Get currency code + * + * @return string + * + * @since 1.0.0 + */ + public function getCode() : string + { + return $this->code; + } + + /** + * Get currency code + * + * @return int + * + * @since 1.0.0 + */ + public function getNumber() : int + { + return $this->number; + } + + /** + * Get currency decimals + * + * @return int + * + * @since 1.0.0 + */ + public function getDecimals() : int + { + return $this->decimals; + } + + /** + * Get currency countries + * + * @return string + * + * @since 1.0.0 + */ + public function getCountries() : string + { + return $this->countries; + } +} diff --git a/Localization/Defaults/CurrencyMapper.php b/Localization/Defaults/CurrencyMapper.php new file mode 100644 index 000000000..93f45c6e1 --- /dev/null +++ b/Localization/Defaults/CurrencyMapper.php @@ -0,0 +1,63 @@ +> + * @since 1.0.0 + */ + protected static $columns = [ + 'currency_id' => ['name' => 'currency_id', 'type' => 'int', 'internal' => 'id'], + 'currency_name' => ['name' => 'currency_name', 'type' => 'string', 'internal' => 'name'], + 'currency_code' => ['name' => 'currency_code', 'type' => 'string', 'internal' => 'code'], + 'currency_number' => ['name' => 'currency_number', 'type' => 'int', 'internal' => 'number'], + 'currency_decimal' => ['name' => 'currency_decimal', 'type' => 'int', 'internal' => 'decimal'], + 'currency_countries' => ['name' => 'currency_countries', 'type' => 'string', 'internal' => 'countries'], + ]; + + /** + * Primary table. + * + * @var string + * @since 1.0.0 + */ + protected static $table = 'currency'; + + /** + * Primary field name. + * + * @var string + * @since 1.0.0 + */ + protected static $primaryField = 'currency_id'; +} diff --git a/Localization/Defaults/Iban.php b/Localization/Defaults/Iban.php new file mode 100644 index 000000000..27e6f6979 --- /dev/null +++ b/Localization/Defaults/Iban.php @@ -0,0 +1,114 @@ +country; + } + + /** + * Get iban chars + * + * @return string + * + * @since 1.0.0 + */ + public function getChars() : string + { + return $this->chars; + } + + /** + * Get iban bban + * + * @return string + * + * @since 1.0.0 + */ + public function getBban() : string + { + return $this->bban; + } + + /** + * Get iban fields + * + * @return string + * + * @since 1.0.0 + */ + public function getFields() : string + { + return $this->fields; + } +} diff --git a/Localization/Defaults/IbanMapper.php b/Localization/Defaults/IbanMapper.php new file mode 100644 index 000000000..886827542 --- /dev/null +++ b/Localization/Defaults/IbanMapper.php @@ -0,0 +1,62 @@ +> + * @since 1.0.0 + */ + protected static $columns = [ + 'iban_id' => ['name' => 'iban_id', 'type' => 'int', 'internal' => 'id'], + 'iban_country' => ['name' => 'iban_country', 'type' => 'string', 'internal' => 'country'], + 'iban_chars' => ['name' => 'iban_chars', 'type' => 'string', 'internal' => 'chars'], + 'iban_bban' => ['name' => 'iban_bban', 'type' => 'string', 'internal' => 'bban'], + 'iban_fields' => ['name' => 'iban_fields', 'type' => 'string', 'internal' => 'fields'], + ]; + + /** + * Primary table. + * + * @var string + * @since 1.0.0 + */ + protected static $table = 'iban'; + + /** + * Primary field name. + * + * @var string + * @since 1.0.0 + */ + protected static $primaryField = 'iban_id'; +} diff --git a/Localization/Defaults/Language.php b/Localization/Defaults/Language.php new file mode 100644 index 000000000..e87a3f358 --- /dev/null +++ b/Localization/Defaults/Language.php @@ -0,0 +1,114 @@ +name; + } + + /** + * Get language native + * + * @return string + * + * @since 1.0.0 + */ + public function getNative() : string + { + return $this->native; + } + + /** + * Get language code + * + * @return string + * + * @since 1.0.0 + */ + public function getCode2() : string + { + return $this->code2; + } + + /** + * Get language code + * + * @return string + * + * @since 1.0.0 + */ + public function getCode3() : string + { + return $this->code3; + } +} diff --git a/Localization/Defaults/LanguageMapper.php b/Localization/Defaults/LanguageMapper.php new file mode 100644 index 000000000..359dc941f --- /dev/null +++ b/Localization/Defaults/LanguageMapper.php @@ -0,0 +1,62 @@ +> + * @since 1.0.0 + */ + protected static $columns = [ + 'language_id' => ['name' => 'language_id', 'type' => 'int', 'internal' => 'id'], + 'language_name' => ['name' => 'language_name', 'type' => 'string', 'internal' => 'name'], + 'language_native' => ['name' => 'language_native', 'type' => 'string', 'internal' => 'native'], + 'language_639_2T' => ['name' => 'language_639_2T', 'type' => 'string', 'internal' => 'code2'], + 'language_639_3' => ['name' => 'language_639_3', 'type' => 'string', 'internal' => 'code3'], + ]; + + /** + * Primary table. + * + * @var string + * @since 1.0.0 + */ + protected static $table = 'language'; + + /** + * Primary field name. + * + * @var string + * @since 1.0.0 + */ + protected static $primaryField = 'language_id'; +} diff --git a/Localization/Default/en_US.json b/Localization/Defaults/en_US.json similarity index 100% rename from Localization/Default/en_US.json rename to Localization/Defaults/en_US.json diff --git a/Localization/Default/Location/localization.sqlite b/Localization/Defaults/localization.sqlite similarity index 99% rename from Localization/Default/Location/localization.sqlite rename to Localization/Defaults/localization.sqlite index b2cdedb9c..9f7cab4d4 100644 Binary files a/Localization/Default/Location/localization.sqlite and b/Localization/Defaults/localization.sqlite differ diff --git a/Localization/Money.php b/Localization/Money.php index f09878f33..d3534fc8e 100644 --- a/Localization/Money.php +++ b/Localization/Money.php @@ -106,9 +106,9 @@ final class Money implements \Serializable */ public static function toInt(string $value, string $thousands = ',', string $decimal = '.') : int { - $split = explode($decimal, $value); + $split = \explode($decimal, $value); $left = $split[0]; - $left = str_replace($thousands, '', $left); + $left = \str_replace($thousands, '', $left); $right = ''; if (count($split) > 1) { diff --git a/Log/FileLogger.php b/Log/FileLogger.php index ef3fce48b..34e2aeed1 100644 --- a/Log/FileLogger.php +++ b/Log/FileLogger.php @@ -119,7 +119,7 @@ final class FileLogger implements LoggerInterface */ private function createFile() : void { - if (!$this->created && !file_exists($this->path)) { + if (!$this->created && !\file_exists($this->path)) { File::create($this->path); $this->created = true; } @@ -186,7 +186,7 @@ final class FileLogger implements LoggerInterface return false; } - $mtime = explode(' ', microtime()); + $mtime = \explode(' ', microtime()); $mtime = $mtime[1] + $mtime[0]; self::$timings[$id] = ['start' => $mtime]; @@ -205,7 +205,7 @@ final class FileLogger implements LoggerInterface */ public static function endTimeLog($id = '') : float { - $mtime = explode(' ', microtime()); + $mtime = \explode(' ', microtime()); $mtime = $mtime[1] + $mtime[0]; self::$timings[$id]['end'] = $mtime; @@ -241,7 +241,7 @@ final class FileLogger implements LoggerInterface } } - $backtrace = json_encode($backtrace); + $backtrace = \json_encode($backtrace); $replace['{backtrace}'] = $backtrace; $replace['{datetime}'] = sprintf('%--19s', (new \DateTime('NOW'))->format('Y-m-d H:i:s')); @@ -382,7 +382,7 @@ final class FileLogger implements LoggerInterface { $levels = []; - if (!file_exists($this->path)) { + if (!\file_exists($this->path)) { return $levels; } @@ -418,7 +418,7 @@ final class FileLogger implements LoggerInterface { $connection = []; - if (!file_exists($this->path)) { + if (!\file_exists($this->path)) { return $connection; } @@ -457,7 +457,7 @@ final class FileLogger implements LoggerInterface $logs = []; $id = 0; - if (!file_exists($this->path)) { + if (!\file_exists($this->path)) { return $logs; } @@ -506,7 +506,7 @@ final class FileLogger implements LoggerInterface $log = []; $current = 0; - if (!file_exists($this->path)) { + if (!\file_exists($this->path)) { return $log; } diff --git a/Math/Geometry/Shape/D2/Triangle.php b/Math/Geometry/Shape/D2/Triangle.php index 003683718..d1dff54fb 100644 --- a/Math/Geometry/Shape/D2/Triangle.php +++ b/Math/Geometry/Shape/D2/Triangle.php @@ -14,6 +14,8 @@ declare(strict_types=1); namespace phpOMS\Math\Geometry\Shape\D2; +use phpOMS\Math\Functions\Functions; + /** * Triangle shape. * @@ -76,4 +78,23 @@ final class Triangle implements D2ShapeInterface { return 2 * $area / $b; } + + /** + * Calculate the hypothenuse + * + * @param mixed ...$vec Vector of values + * + * @return float + * + * @since 1.0.0 + */ + public static function getHypot(...$vec) : float + { + $hypot = 0.0; + foreach ($vec as $val) { + $hypot += $val * $val; + } + + return \sqrt($hypot); + } } diff --git a/Math/Matrix/CholeskyDecomposition.php b/Math/Matrix/CholeskyDecomposition.php index 3de6933b6..8b19164e4 100644 --- a/Math/Matrix/CholeskyDecomposition.php +++ b/Math/Matrix/CholeskyDecomposition.php @@ -18,6 +18,8 @@ use phpOMS\Math\Matrix\Exception\InvalidDimensionException; /** * Cholesky decomposition + * + * A is syymetric, positive definite then A = L*L' * * @package phpOMS\Math\Matrix * @license OMS License 1.0 diff --git a/Math/Matrix/EigenvalueDecomposition.php b/Math/Matrix/EigenvalueDecomposition.php index 12281785e..9a32d4910 100644 --- a/Math/Matrix/EigenvalueDecomposition.php +++ b/Math/Matrix/EigenvalueDecomposition.php @@ -14,14 +14,347 @@ declare(strict_types=1); namespace phpOMS\Math\Matrix; +use phpOMS\Math\Geometry\Shape\D2\Triangle; + /** * Eigenvalue decomposition + * + * A symmetric then A = V*D*V' + * A not symmetric then (potentially) A = V*D*inverse(V) * * @package phpOMS\Math\Matrix * @license OMS License 1.0 * @link http://website.orange-management.de * @since 1.0.0 */ -final class EigenValueDecomposition +final class EigenvalueDecomposition { + /** + * Dimension m + * + * @var int + * @since 1.0.0 + */ + private $m = 0; + + /** + * Is symmetric + * + * @var bool + * @since 1.0.0 + */ + private $isSymmetric = true; + + /** + * A square matrix. + * + * @var array + * @since 1.0.0 + */ + private $A = []; + + /** + * Eigenvectors + * + * @var array + * @since 1.0.0 + */ + private $V = []; + + /** + * Eigenvalues + * + * @var array + * @since 1.0.0 + */ + private $D = []; + + /** + * Eigenvalues + * + * @var array + * @since 1.0.0 + */ + private $E = []; + + /** + * Hessenberg form + * + * @var array + * @since 1.0.0 + */ + private $H = []; + + /** + * Non-symmetric storage + * + * @var array + * @since 1.0.0 + */ + private $ort = []; + + /** + * Constructor. + * + * @param Matrix $M Matrix + * + * @since 1.0.0 + */ + public function __construct(Matrix $M) + { + $this->m = $M->getM(); + $this->A = $M->toArray(); + } + + /** + * Housholder tridiagonal form reduction. + * + * @return void + * + * @since 1.0.0 + */ + private function tred2() : void + { + for ($j = 0; $j < $this->m; ++$j) { + $this->D[$j] = $this->V[$this->m - 1][$j]; + } + + for ($i = $this->m - 1; $i > 0; --$i) { + $scale = 0.0; + $h = 0.0; + + for ($k = 0; $k < $i; ++$k) { + $scale += \abs($this->D[$k]); + } + + if ($scale === 0.0) { + $this->E[$i] = $this->D[$i - 1]; + for ($j = 0; $j > $i; ++$j) { + $this->D[$j] = $this->V[$i - 1][$j]; + $this->V[$i][$j] = 0.0; + $this->V[$j][$i] = 0.0; + } + } else { + for ($k = 0; $k < $i; ++$k) { + $this->D[$k] /= $scale; + $h += $this->D[$k] * $this->D[$k]; + } + + $f = $this->D[$i - 1]; + $g = \sqrt($h); + + if ($f > 0) { + $g = -$g; + } + + $this->E[$i] = $scale * $g; + $h -= $f * $g; + $this->D[$i - 1] = $f - $g; + + for ($j = 0; $j < $i; ++$j) { + $this->E[$j] = 0.0; + } + + for ($j = 0; $j < $i; ++$j) { + $f = $this->D[$j]; + $this->V[$j][$i] = $f; + $g = $this->E[$j] + $this->V[$j][$j] * $f; + + for ($k = $j + 1; $k <= $i - 1; ++$k) { + $g += $this->V[$k][$j] * $this->D[$k]; + $this->E[$k] += $this->V[$k][$j] * $f; + } + + $this->E[$j] = $g; + } + + $f = 0.0; + for ($j = 0; $j < $i; ++$j) { + $this->E[$j] /= $h; + $f += $this->E[$j] * $this->D[$j]; + } + + $hh = $f / ($h + $h); + for ($j = 0; $j < $i; ++$j) { + $this->E[$j] -= $hh * $this->D[$j]; + } + + for ($j = 0; $j < $i; ++$j) { + $f = $this->D[$j]; + $g = $this->E[$j]; + + for ($k = $j; $k <= $i - 1; ++$k) { + $this->V[$k][$j] -= ($f * $this->E[$k] + $g * $this->D[$k]); + } + + $this->D[$j] = $this->V[$i - 1][$j]; + $this->V[$i][$j] = 0.0; + } + } + + $this->D[$i] = $h; + } + + for ($i = 0; $i < $this->m - 1; ++$i) { + $this->V[$this->m - 1][$i] = $this->V[$i][$i]; + $this->V[$i][$i] = 1.0; + $h = $this->D[$i + 1]; + + if ($h !== 0.0) { + for ($k = 0; $k <= $i; ++$k) { + $this->D[$k] = $this->V[$k][$i + 1] / $h; + } + + for ($j = 0; $j <= $i; ++$j) { + $g = 0.0; + for ($k = 0; $k <= $i; ++$k) { + $g += $this->V[$k][$i + 1] * $this->V[$k][$j]; + } + + for ($k = 0; $k <= $i; ++$k) { + $this->V[$k][$j] -= $g * $this->D[$k]; + } + } + } + + for ($k = 0; $k <= $i; ++$k) { + $this->V[$k][$i + 1] = 0.0; + } + } + + for ($j = 0; $j < $this->m; ++$j) { + $this->D[$j] = $this->V[$this->m - 1][$j]; + $this->V[$this->m - 1][$j] = 0.0; + } + + $this->V[$this->m - 1][$j] = 1.0; + $this->E[0] = 0.0; + } + + /** + * Symmetric tridiagonal QL + * + * @return void + * + * @since 1.0.0 + */ + private function tql2() : void + { + for ($i = 1; $i < $this->m; ++$i) { + $this->E[$i - 1] = $this->E[$i]; + } + + $this->E[$this->m - 1] = 0.0; + + $f = 0.0; + $tst1 = 0.0; + $eps = 0.00001; + + for ($l = 0; $l < $this->m; ++$l) { + $tst1 = \max($tst1, \abs($this->D[$l]) + \abs($this->E[$l])); + $m = $l; + + while ($m < $this->m) { + if (\abs($this->E[$m]) <= $eps * $tst1) { + break; + } + + ++$m; + } + + if ($m > $l) { + $iter = 0; + + do { + $iter = $iter + 1; + + $g = $this->D[$l]; + $p = ($this->D[$l + 1] - $g) / (2.0 * $this->E[$l]); + $r = Triangle::getHypot($p, 1); + + if ($p > 0) { + $r = -$r; + } + + $this->D[$l] = $this->E[$l] / ($p + $r); + $this->D[$l + 1] = $this->E[$l] * ($p + $r); + $dl1 = $this->D[$l + 1]; + $h = $g - $this->D[$l]; + + for ($i = $l + 2; $i < $this->m; ++$i) { + $this->D[$i] -= $h; + } + + $f += $h; + $p = $this->D[$m]; + $c = 1.0; + $c2 = 1.0; + $c3 = 1.0; + $el1 = $this->E[$l + 1]; + $s = 0.0; + $s2 = 0.0; + + for ($i = $m - 1; $i >= $l; --$i) { + $c3 = $c2; + $c2 = $c; + $s2 = $s; + $g = $c * $this->E[$i]; + $h = $c * $p; + $r = Triangle::getHypot($p, $this->E[$i]); + $this->E[$i + 1] = $s * $r; + $s = $this->E[$i] / $r; + $c = $p / $r; + $p = $c * $this->D[$i] - $s * $g; + $this->D[$i + 1] = $h + $s * ($c * $g + $s * $this->D[$i]); + + for ($k = 0; $k < $this->m; ++$k) { + $h = $this->V[$k][$i + 1]; + $this->V[$k][$i + 1] = $s * $this->V[$k][$i] + $c * $h; + $this->V[$k][$i] = $c * $this->V[$k][$i] - $s * $h; + } + } + + $p = -$s * $s2 * $c3 * $el1 * $this->E[$l] / $dl1; + $this->E[$l] = $s * $p; + $this->D[$l] = $c * $p; + } while (\abs($this->E[$l]) > $eps * $tst1); + } + + $this->D[$l] += $f; + $this->E[$l] = 0.0; + } + + for ($i = 0; $i < $this->m - 1; ++$i) { + $k = $i; + $p = $this->D[$i]; + + for ($j = $i + 1; $j < $this->m; ++$j) { + if ($this->D[$j] < $p) { + $k = $j; + $p = $this->D[$j]; + } + } + + if ($k !== $i) { + $this->D[$k] = $this->D[$i]; + $this->D[$i] = $p; + + for ($j = 0; $j < $this->m; ++$j) { + $p = $this->V[$j][$i]; + $this->V[$j][$i] = $this->V[$j][$k]; + $this->V[$j][$k] = $p; + } + } + } + } + + private function orthes() : void + { + + } + + public function isSymmetric() : bool + { + return $this->isSymmetric; + } } diff --git a/Math/Matrix/LUDecomposition.php b/Math/Matrix/LUDecomposition.php index 59ceaa9dd..9a3dbe97f 100644 --- a/Math/Matrix/LUDecomposition.php +++ b/Math/Matrix/LUDecomposition.php @@ -18,6 +18,8 @@ use phpOMS\Math\Matrix\Exception\InvalidDimensionException; /** * LU decomposition + * + * A(piv,:) = L*U * * @package phpOMS\Math\Matrix * @license OMS License 1.0 @@ -253,8 +255,7 @@ final class LUDecomposition } $n = $B->getN(); - $X = $B->getMatrix($this->piv, 0, $n - 1); - // todo: fix get extract + $X = $B->getSubMatrixByRows($this->piv, 0, $n - 1)->toArray(); // Solve L*Y = B(piv,:) for ($k = 0; $k < $this->n; ++$k) { diff --git a/Math/Matrix/Matrix.php b/Math/Matrix/Matrix.php index e5f982c6a..504fbc4be 100644 --- a/Math/Matrix/Matrix.php +++ b/Math/Matrix/Matrix.php @@ -137,7 +137,7 @@ class Matrix implements \ArrayAccess, \Iterator /** * Get matrix array. * - * @return array + * @return array> * * @since 1.0.0 */ @@ -146,10 +146,121 @@ class Matrix implements \ArrayAccess, \Iterator return $this->matrix; } + /** + * Get sub matrix array. + * + * @param int $iRow Start row + * @param int $lRow End row + * @param int $iCol Start col + * @param int $lCol End col + * + * @return Matrix + * + * @since 1.0.0 + */ + public function getSubMatrix(int $iRow, int $lRow, int $iCol, int $lCol) : Matrix + { + $X = [[]]; + for ($i = $iRow; $i <= $lRow; ++$i) { + for ($j = $iCol; $j <= $lCol; ++$j) { + $X[$i - $iRow][$j - $iCol] = $this->matrix[$i][$j]; + } + } + + $matrix = new self(); + $matrix->setMatrix($X); + + return $matrix; + } + + /** + * Get sub matrix array. + * + * @param array $rows Row indices + * @param array $cols Row indices + * + * @return Matrix + * + * @since 1.0.0 + */ + public function getSubMatrixByColumnsRows(array $rows, array $cols) : Matrix + { + $X = [[]]; + $rlength = count($rows); + $clength = count($cols); + + for ($i = 0; $i <= $rlength; ++$i) { + for ($j = 0; $j <= $clength; ++$j) { + $X[$i][$j] = $this->matrix[$rows[$i]][$cols[$j]]; + } + } + + $matrix = new self(); + $matrix->setMatrix($X); + + return $matrix; + } + + /** + * Get sub matrix array. + * + * @param int $iRow Start row + * @param int $lRow End row + * @param array $cols Row indices + * + * @return Matrix + * + * @since 1.0.0 + */ + public function getSubMatrixByColumns(int $iRow, int $lRow, array $cols) : Matrix + { + $X = [[]]; + $length = count($cols); + + for ($i = $iRow; $i <= $lRow; ++$i) { + for ($j = 0; $j <= $length; ++$j) { + $X[$i - $iRow][$j] = $this->matrix[$i][$cols[$j]]; + } + } + + $matrix = new self(); + $matrix->setMatrix($X); + + return $matrix; + } + + /** + * Get sub matrix array. + * + * @param array $rows Row indices + * @param int $iCol Start col + * @param int $lCol End col + * + * @return Matrix + * + * @since 1.0.0 + */ + public function getSubMatrixByRows(array $rows, int $iCol, int $lCol) : Matrix + { + $X = [[]]; + $length = count($rows); + + for ($i = 0; $i < $length; ++$i) { + for ($j = $iCol; $j <= $lCol; ++$j) { + $X[$i][$j - $iCol] = $this->matrix[$rows[$i]][$j]; + } + } + + $matrix = new self(); + $matrix->setMatrix($X); + + return $matrix; + } + /** * Get matrix array. * - * @return array + * @return array> * * @since 1.0.0 */ @@ -158,6 +269,18 @@ class Matrix implements \ArrayAccess, \Iterator return $this->matrix; } + /** + * Is symmetric. + * + * @return bool + * + * @since 1.0.0 + */ + public function isSymmetric() : bool + { + return (new EigenvalueDecomposition($this))->isSymmetric(); + } + /** * Get matrix rank. * @@ -574,7 +697,7 @@ class Matrix implements \ArrayAccess, \Iterator /** * Solve matrix * - * @param Matix $B Matrix/Vector b + * @param Matrix $B Matrix/Vector b * * @return Matrix * diff --git a/Math/Matrix/QRDecomposition.php b/Math/Matrix/QRDecomposition.php index 8677ee381..ae2e1557c 100644 --- a/Math/Matrix/QRDecomposition.php +++ b/Math/Matrix/QRDecomposition.php @@ -14,8 +14,13 @@ declare(strict_types=1); namespace phpOMS\Math\Matrix; +use phpOMS\Math\Matrix\Exception\InvalidDimensionException; +use phpOMS\Math\Geometry\Shape\D2\Triangle; + /** * QR decomposition + * + * For every matrix A = Q*R * * @package phpOMS\Math\Matrix * @license OMS License 1.0 @@ -24,26 +29,58 @@ namespace phpOMS\Math\Matrix; */ final class QRDecomposition { + /** + * QR matrix. + * + * @var array[] + * @since 1.0.0 + */ private $QR = []; + /** + * Dimension m + * + * @var int + * @since 1.0.0 + */ private $m = 0; + + /** + * Dimension n + * + * @var int + * @since 1.0.0 + */ private $n = 0; + /** + * R diagonal + * + * @var array + * @since 1.0.0 + */ private $Rdiag = []; + /** + * Constructor. + * + * @param Matrix $M Matrix + * + * @since 1.0.0 + */ public function __construct(Matrix $M) { // Initialize. $this->QR = $M->toArray(); - $this->m = $M->getRowDimension(); - $this->n = $M->getColumnDimension(); + $this->m = $M->getM(); + $this->n = $M->getN(); // Main loop. for ($k = 0; $k < $this->n; ++$k) { // Compute 2-norm of k-th column without under/overflow. $nrm = 0.0; for ($i = $k; $i < $this->m; ++$i) { - $nrm = hypo($nrm, $this->QR[$i][$k]); + $nrm = Triangle::getHypot($nrm, $this->QR[$i][$k]); } if ($nrm != 0.0) { @@ -57,6 +94,7 @@ final class QRDecomposition } $this->QR[$k][$k] += 1.0; + // Apply transformation to remaining columns. for ($j = $k + 1; $j < $this->n; ++$j) { $s = 0.0; @@ -75,6 +113,13 @@ final class QRDecomposition } } + /** + * Matrix has full rank + * + * @return bool + * + * @since 1.0.0 + */ public function isFullRank() : bool { for ($j = 0; $j < $this->n; ++$j) { @@ -86,6 +131,13 @@ final class QRDecomposition return true; } + /** + * Get H matrix + * + * @return Matrix + * + * @since 1.0.0 + */ public function getH() : Matrix { $H = [[]]; @@ -101,11 +153,18 @@ final class QRDecomposition } $matrix = new Matrix(); - $matrix->setArray($H); + $matrix->setMatrix($H); return $matrix; } + /** + * Get R matrix + * + * @return Matrix + * + * @since 1.0.0 + */ public function getR() : Matrix { $R = [[]]; @@ -123,11 +182,18 @@ final class QRDecomposition } $matrix = new Matrix(); - $matrix->setArray($R); + $matrix->setMatrix($R); return $matrix; } + /** + * Get Q matrix + * + * @return Matrix + * + * @since 1.0.0 + */ public function getQ() : Matrix { $Q = [[]]; @@ -144,6 +210,7 @@ final class QRDecomposition for ($i = $k; $i < $this->m; ++$i) { $s += $this->QR[$i][$k] * $Q[$i][$j]; } + $s = -$s / $this->QR[$k][$k]; for ($i = $k; $i < $this->m; ++$i) { $Q[$i][$j] += $s * $this->QR[$i][$k]; @@ -153,21 +220,33 @@ final class QRDecomposition } $matrix = new Matrix(); - $matrix->setArray($Q); + $matrix->setMatrix($Q); return $matrix; } + /** + * Solve Ax = b + * + * @param Matrix $B Matrix + * + * @return Matrix + * + * @since 1.0.0 + */ public function solve(Matrix $B) : Matrix { - if ($B->getRowDimension() !== $this->m) { + if ($B->getM() !== $this->m) { + throw new InvalidDimensionException($B->getM()); } if (!$this->isFullRank()) { + throw new \Exception('Rank'); } - $nx = $B->getColumnDimension(); - $X = $B->getArrayCopy(); + $nx = $B->getN(); + $X = $B->toArray(); + // Compute Y = transpose(Q)*B for ($k = 0; $k < $this->n; ++$k) { for ($j = 0; $j < $nx; ++$j) { @@ -175,17 +254,20 @@ final class QRDecomposition for ($i = $k; $i < $this->m; ++$i) { $s += $this->QR[$i][$k] * $X[$i][$j]; } + $s = -$s / $this->QR[$k][$k]; for ($i = $k; $i < $this->m; ++$i) { $X[$i][$j] += $s * $this->QR[$i][$k]; } } } + // Solve R*X = Y; for ($k = $this->n - 1; $k >= 0; --$k) { for ($j = 0; $j < $nx; ++$j) { $X[$k][$j] /= $this->Rdiag[$k]; } + for ($i = 0; $i < $k; ++$i) { for ($j = 0; $j < $nx; ++$j) { $X[$i][$j] -= $X[$k][$j] * $this->QR[$i][$k]; @@ -194,8 +276,8 @@ final class QRDecomposition } $matrix = new Matrix(); - $matrix->setArray($X); + $matrix->setMatrix($X); - return $matrix; + return $matrix->getSubMatrix(0, $this->n - 1, 0, $nx - 1); } } diff --git a/Math/Optimization/AssignmentProblem.php b/Math/Optimization/AssignmentProblem.php deleted file mode 100644 index 8b1378917..000000000 --- a/Math/Optimization/AssignmentProblem.php +++ /dev/null @@ -1 +0,0 @@ - diff --git a/Math/Optimization/GeneticAlgorithmInterface.php b/Math/Optimization/GeneticAlgorithmInterface.php deleted file mode 100644 index 3087df302..000000000 --- a/Math/Optimization/GeneticAlgorithmInterface.php +++ /dev/null @@ -1,30 +0,0 @@ -getEdges(); - - foreach ($graphArray as $edge) { - array_push($vertices, $edge[0], $edge[1]); - $neighbours[$edge[0]][] = ["end" => $edge[1], "cost" => $edge[2]]; - $neighbours[$edge[1]][] = ["end" => $edge[0], "cost" => $edge[2]]; - } - - $vertices = array_unique($vertices); - - $dist = []; - $previous = []; - foreach ($vertices as $vertex) { - $dist[$vertex] = INF; - $previous[$vertex] = null; - } - - $dist[$source] = 0; - $Q = $vertices; - - while (count($Q) > 0) { - - // TODO - Find faster way to get minimum - $min = INF; - - foreach ($Q as $vertex) { - if ($dist[$vertex] < $min) { - $min = $dist[$vertex]; - $u = $vertex; - } - } - - $Q = array_diff($Q, [$u]); - - if ($dist[$u] == INF || $u == $target) { - break; - } - - if (isset($neighbours[$u])) { - foreach ($neighbours[$u] as $arr) { - $alt = $dist[$u] + $arr["cost"]; - - if ($alt < $dist[$arr["end"]]) { - $dist[$arr["end"]] = $alt; - $previous[$arr["end"]] = $u; - } - } - } - } - - $path = []; - $u = $target; - - while (isset($previous[$u])) { - array_unshift($path, $u); - $u = $previous[$u]; - } - - array_unshift($path, $u); - - return $path; - } -} diff --git a/Math/Optimization/Graph/EdgeInterface.php b/Math/Optimization/Graph/EdgeInterface.php deleted file mode 100644 index ee7e34468..000000000 --- a/Math/Optimization/Graph/EdgeInterface.php +++ /dev/null @@ -1,76 +0,0 @@ -cityPool = $pool; - - if ($this->cityPool->count() > self::LIMIT) { - throw new \Exception('Overflow'); - } - } - - /** - * Calculate best routes. - * - * @param int $limit Amount of best routes - * - * @return Population - * - * @since 1.0.0 - */ - public function getSolution(int $limit = 1) : Population - { - $population = new Population($this->cityPool, $limit, true); - $cities = $this->cityPool->getCities(); - - $this->bruteForce($cities, new Tour($this->cityPool, false), $population); - - return $population; - } - - /** - * Bruteforce best solutions. - * - * @param array $cities Cities - * @param Tour $tour Current (potential) optimal tour - * @param Population $population Population of tours - * - * @return Population - * - * @since 1.0.0 - */ - private function bruteForce(array $cities, Tour $tour, Population $population) - { - if (empty($cities)) { - $population->addTour($tour); - } - - $count = count($cities); - for ($i = 0; $i < $count; ++$i) { - $extended = clone $tour; - $extended->addCity($cities[$i]); - unset($cities[$i]); - - if ($population->getUnfittest()->getFitness() > $extended->getFitness()) { - continue; - } - - $this->bruteForce($cities, $extended, $population); - } - } -} diff --git a/Math/Optimization/TSP/CityPool.php b/Math/Optimization/TSP/CityPool.php deleted file mode 100644 index ddfc64f86..000000000 --- a/Math/Optimization/TSP/CityPool.php +++ /dev/null @@ -1,118 +0,0 @@ -cities = $cities; - } - - /** - * Add city. - * - * @param City $city City - * - * @return void - * - * @since 1.0.0 - */ - public function addCity(City $city) : void - { - $this->cities[$city->getName() . $city->getLatitude() . $city->getLongitude()] = $city; - } - - /** - * Get city. - * - * @param int $index City index - * - * @return City - * - * @since 1.0.0 - */ - public function getCity(int $index) : City - { - return array_values($this->cities)[$index]; - } - - /** - * Get cities. - * - * @return array - * - * @since 1.0.0 - */ - public function getCities() : array - { - return $this->cities; - } - - /** - * Has city. - * - * @param City $city City - * - * @return bool - * - * @since 1.0.0 - */ - public function hasCity(City $city) : bool - { - foreach ($this->cities as $c) { - if ($c->equals($city)) { - return true; - } - } - - return false; - } - - /** - * Count cities - * - * @return int - * - * @since 1.0.0 - */ - public function count() : int - { - return count($this->cities); - } -} diff --git a/Math/Optimization/TSP/GA.php b/Math/Optimization/TSP/GA.php deleted file mode 100644 index ff85ee681..000000000 --- a/Math/Optimization/TSP/GA.php +++ /dev/null @@ -1,195 +0,0 @@ -cityPool = $pool; - } - - /** - * Evolve population. - * - * @param Population $population Population to eveolve - * - * @return Population - * - * @since 1.0.0 - */ - public function evolvePopulation(Population $population) : Population - { - $shift = self::ELITISM ? 1 : 0; - $newPopulation = new Population($this->cityPool, $count = $population->count(), false); - - $newPopulation->add($population->getFittest()); - - for ($i = $shift; $i < $count; ++$i) { - $parent1 = $this->tournamentSelection($population); - $parent2 = $this->tournamentSelection($population); - $child = $this->crossover($parent1, $parent2); - - $newPopulation->set($i, $child); - } - - $count2 = $newPopulation->count(); - - for ($i = $shift; $i < $count2; ++$i) { - $this->mutate($newPopulation->get($i)); - } - - return $newPopulation; - } - - /** - * Find fittest - * - * @param Population $population Population to evaluate - * - * @return Tour - * - * @since 1.0.0 - */ - private function tournamentSelection(Population $population) : Tour - { - $tournament = new Population($this->cityPool, self::TOURNAMENT, false); - $populationSize = $population->count() - 1; - - for ($i = 0; $i < self::TOURNAMENT; ++$i) { - $tournament->add($population->get(mt_rand(0, $populationSize))); - } - - return $tournament->getFittest(); - } - - /** - * Crossover tours - * - * @param Tour $tour1 Tour 1 - * @param Tour $tour2 Tour 2 - * - * @return Tour - * - * @since 1.0.0 - */ - public function crossover(Tour $tour1, Tour $tour2) : Tour - { - $child = new Tour($this->cityPool, false); - - $start = mt_rand(0, $tour1->count() - 1); - $end = mt_rand(0, $tour1->count() - 1); - - $count = $child->count(); /* $tour1->count() ???!!!! */ - - for ($i = 0; $i < $count; ++$i) { - if ($start < $end && $i > $start && $i < $end) { - $child->setCity($i, $tour1->getCity($i)); - } elseif ($start > $end && !($i < $start && $i > $end)) { - $child->setCity($i, $tour1->getCity($i)); - } - } - - $count = $tour2->count(); - - for ($i = 0; $i < $count; ++$i) { - if (!$child->hasCity($tour2->getCity($i))) { - for ($j = 0; $j < $child->count(); ++$j) { - if ($child->getCity($j) === null) { - $child->setCity($j, $tour2->getCity($i)); - break; - } - } - } - } - - return $child; - } - - /** - * Mutate tour - * - * @param Tour $tour Tour to mutate - * - * @return void - * - * @since 1.0.0 - */ - private function mutate(Tour $tour) - { - $count = $tour->count(); - - for ($pos1 = 0; $pos1 < $count; $pos1++) { - if (mt_rand(0, 1000) < self::MUTATION) { - $pos2 = mt_rand(0, $tour->count() - 1); - - /* Could be same pos! */ - $city1 = $tour->getCity($pos1); - $city2 = $tour->getCity($pos2); - - /* swapping */ - $tour->setCity($pos1, $city2); - $tour->setCity($pos2, $city1); - } - } - } -} diff --git a/Math/Optimization/TSP/Population.php b/Math/Optimization/TSP/Population.php deleted file mode 100644 index 448b5fb2c..000000000 --- a/Math/Optimization/TSP/Population.php +++ /dev/null @@ -1,165 +0,0 @@ -tours[] = new Tour($pool, true); - } - } - } - - /** - * Insert Tour at position. - * - * @param int $index Position to insert at - * @param Tour $tour Tour to insert - * - * @return void - * - * @since 1.0.0 - */ - public function insertAt(int $index, Tour $tour) : void - { - $this->tours = array_slice($this->tours, 0, $index) + [$tour] + array_slice($this->tours, $index); - } - - /** - * Set tour at position - * - * @param int $index Position to set/replace - * @param Tour $tour Tour to set - * - * @return void - * - * @since 1.0.0 - */ - public function set(int $index, Tour $tour) : void - { - $this->tours[$index] = $tour; - asort($this->tours); - } - - /** - * Add tour - * - * @param Tour $tour Tour to add - * - * @return void - * - * @since 1.0.0 - */ - public function add(Tour $tour) : void - { - $this->tours[] = $tour; - } - - /** - * Get tour - * - * @param int $index Index of tour - * - * @return null|Tour - * - * @since 1.0.0 - */ - public function get(int $index) - { - return $this->tours[$index] ?? null; - } - - /** - * Get fittest tour - * - * @return Tour - * - * @since 1.0.0 - */ - public function getFittest() : Tour - { - $fittest = $this->tours[0]; - $count = count($this->tours); - - for ($i = 1; $i < $count; ++$i) { - if ($fittest->getFitness() <= $this->tours[$i]->getFitness()) { - $fittest = $this->tours[$i]; - } - } - - return $fittest; - } - - /** - * Get unfittest tour - * - * @return Tour - * - * @since 1.0.0 - */ - public function getUnfittest() : Tour - { - $unfittest = $this->tours[0]; - $count = count($this->tours); - - for ($i = 1; $i < $count; ++$i) { - if ($unfittest->getFitness() >= $this->tours[$i]->getFitness()) { - $unfittest = $this->tours[$i]; - } - } - - return $unfittest; - } - - /** - * Get tour count - * - * @return int - * - * @since 1.0.0 - */ - public function count() : int - { - return count($this->tours); - } -} diff --git a/Math/Optimization/TSP/Tour.php b/Math/Optimization/TSP/Tour.php deleted file mode 100644 index 7b065e556..000000000 --- a/Math/Optimization/TSP/Tour.php +++ /dev/null @@ -1,200 +0,0 @@ -cityPool = $pool; - - if ($initialize) { - $this->cities = $this->cityPool->getCities(); - shuffle($this->cities); - } - } - - /** - * Get city. - * - * @param int $index Index - * - * @return null|City - * - * @since 1.0.0 - */ - public function getCity($index) - { - return array_values($this->cities)[$index] ?? null; - } - - /** - * Get fitness. - * - * @return float - * - * @since 1.0.0 - */ - public function getFitness() : float - { - if ($this->fitness === 0.0 && ($distance = $this->getDistance()) !== 0.0) { - $this->fitness = 1 / $distance; - } - - return $this->fitness; - } - - /** - * Get tour distance - * - * @return float - * - * @since 1.0.0 - */ - public function getDistance() : float - { - if ($this->distance === 0.0) { - $distance = 0.0; - - $count = count($this->cities); - - for ($i = 0; $i < $count; ++$i) { - $dest = ($i + 1 < $count) ? $this->cities[$i + 1] : $this->cities[0]; - - $distance += $this->cities[$i]->getDistanceTo($dest); - } - - $this->distance = $distance; - } - - return $this->distance; - } - - /** - * Add city to tour. - * - * @param City $city City - * - * @return void - * - * @since 1.0.0 - */ - public function addCity(City $city) : void - { - $this->cities[] = $city; - - $this->fitness = 0.0; - $this->distance = 0.0; - } - - /** - * Set city - * - * @param int $index Index to set/replace - * @param City $city City - * - * @return void - * - * @since 1.0.0 - */ - public function setCity(int $index, City $city) : void - { - $this->cities[$index] = $city; - asort($this->cities); - - $this->fitness = 0.0; - $this->distance = 0.0; - } - - /** - * Has city. - * - * @param City $city City - * - * @return bool - * - * @since 1.0.0 - */ - public function hasCity(City $city) : bool - { - foreach ($this->cities as $c) { - if ($c->equals($city)) { - return true; - } - } - - return false; - } - - /** - * Get city count - * - * @return int - * - * @since 1.0.0 - */ - public function count() : int - { - return count($this->cities); - } -} diff --git a/Math/Optimization/TransportationProblem.php b/Math/Optimization/TransportationProblem.php deleted file mode 100644 index 8b1378917..000000000 --- a/Math/Optimization/TransportationProblem.php +++ /dev/null @@ -1 +0,0 @@ - diff --git a/Math/Parser/Evaluator.php b/Math/Parser/Evaluator.php index a057bf5e0..2aab74418 100644 --- a/Math/Parser/Evaluator.php +++ b/Math/Parser/Evaluator.php @@ -41,10 +41,10 @@ class Evaluator public static function evaluate(string $formula, array $vars) : float { // todo: do i need array_values here? - $formula = str_replace(array_keys($vars), array_values($vars), $formula); + $formula = \str_replace(array_keys($vars), array_values($vars), $formula); // todo: this is horrible in case things like mod etc. need to be supported - if (preg_match('#[^0-9\+\-\*\/\(\)]#', $formula)) { + if (\preg_match('#[^0-9\+\-\*\/\(\)]#', $formula)) { throw new \Exception('Bad elements'); } diff --git a/Math/Stochastic/Distribution/PoissonDistribution.php b/Math/Stochastic/Distribution/PoissonDistribution.php index 1c7b2e747..438982080 100644 --- a/Math/Stochastic/Distribution/PoissonDistribution.php +++ b/Math/Stochastic/Distribution/PoissonDistribution.php @@ -15,6 +15,7 @@ declare(strict_types=1); namespace phpOMS\Math\Stochastic\Distribution; use phpOMS\Math\Functions\Functions; +use phpOMS\Math\Functions\Gamma; /** * Well known functions class. @@ -40,7 +41,7 @@ class PoissonDistribution */ public static function getPmf(int $k, float $lambda) : float { - return exp($k * log($lambda) - $lambda - log(Functions::getGammaInteger($k + 1))); + return exp($k * log($lambda) - $lambda - log(Gamma::getGammaInteger($k + 1))); } /** diff --git a/Message/Http/Header.php b/Message/Http/Header.php index 8851c23e1..84a5d3a7e 100644 --- a/Message/Http/Header.php +++ b/Message/Http/Header.php @@ -150,7 +150,7 @@ final class Header extends HeaderAbstract $headers = []; foreach ($_SERVER as $name => $value) { if (substr($name, 0, 5) == 'HTTP_') { - $headers[str_replace(' ', '-', ucwords(strtolower(str_replace('_', ' ', substr($name, 5)))))] = $value; + $headers[\str_replace(' ', '-', ucwords(strtolower(\str_replace('_', ' ', substr($name, 5)))))] = $value; } } diff --git a/Message/Http/Request.php b/Message/Http/Request.php index 693eb4c1a..df55e2ea7 100644 --- a/Message/Http/Request.php +++ b/Message/Http/Request.php @@ -126,7 +126,7 @@ final class Request extends RequestAbstract if (isset($_SERVER['CONTENT_TYPE'])) { if (strpos($_SERVER['CONTENT_TYPE'], 'application/json') !== false) { - if (($json = json_decode(($input = file_get_contents('php://input')), true)) === false || $json === null) { + if (($json = \json_decode(($input = \file_get_contents('php://input')), true)) === false || $json === null) { throw new \Exception('Is not valid json ' . $input); } @@ -153,8 +153,8 @@ final class Request extends RequestAbstract return 'EN'; } - $lang = explode(';', $_SERVER['HTTP_ACCEPT_LANGUAGE']); - $lang = explode('-', $lang[0]); + $lang = \explode(';', $_SERVER['HTTP_ACCEPT_LANGUAGE']); + $lang = \explode('-', $lang[0]); return $lang[0]; } @@ -252,7 +252,7 @@ final class Request extends RequestAbstract // TODO: maybe replace this with smart media queries... checked gets handled in reverse!!! $useragent = $_SERVER['HTTP_USER_AGENT'] ?? ''; - if (preg_match('/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows (ce|phone)|xda|xiino/i', $useragent) || preg_match('/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i', $useragent)) { + if (\preg_match('/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows (ce|phone)|xda|xiino/i', $useragent) || \preg_match('/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i', $useragent)) { return true; } @@ -388,7 +388,7 @@ final class Request extends RequestAbstract */ public function getBody() : string { - return file_get_contents('php://input'); + return \file_get_contents('php://input'); } /** diff --git a/Message/Http/Response.php b/Message/Http/Response.php index 91bfe56b7..55458efb7 100644 --- a/Message/Http/Response.php +++ b/Message/Http/Response.php @@ -106,7 +106,7 @@ final class Response extends ResponseAbstract implements RenderableInterface foreach ($types as $type) { if (stripos($type, MimeType::M_JSON) !== false) { - return json_encode($this->jsonSerialize()); + return \json_encode($this->jsonSerialize()); } } @@ -132,7 +132,7 @@ final class Response extends ResponseAbstract implements RenderableInterface } elseif (is_string($response) || is_numeric($response)) { $render .= $response; } elseif (is_array($response)) { - $render .= json_encode($response); + $render .= \json_encode($response); // TODO: remove this. This should never happen since then someone forgot to set the correct header. it should be json header! } else { throw new \Exception('Wrong response type'); diff --git a/Model/Html/Meta.php b/Model/Html/Meta.php index 4f7fbcd75..10ec2d500 100644 --- a/Model/Html/Meta.php +++ b/Model/Html/Meta.php @@ -71,7 +71,7 @@ class Meta implements RenderableInterface */ public function addKeyword(string $keyword) : void { - if (!in_array($keyword, $this->keywords)) { + if (!\in_array($keyword, $this->keywords)) { $this->keywords[] = $keyword; } } diff --git a/Module/InfoManager.php b/Module/InfoManager.php index 35c8ecc69..1518f2cb2 100644 --- a/Module/InfoManager.php +++ b/Module/InfoManager.php @@ -81,11 +81,11 @@ final class InfoManager */ public function load() : void { - if (!file_exists($this->path)) { + if (!\file_exists($this->path)) { throw new PathException($this->path); } - $this->info = json_decode(file_get_contents($this->path), true); + $this->info = \json_decode(file_get_contents($this->path), true); } /** @@ -97,11 +97,11 @@ final class InfoManager */ public function update() : void { - if (!file_exists($this->path)) { + if (!\file_exists($this->path)) { throw new PathException($this->path); } - file_put_contents($this->path, json_encode($this->info, JSON_PRETTY_PRINT)); + \file_put_contents($this->path, \json_encode($this->info, JSON_PRETTY_PRINT)); } /** diff --git a/Module/InstallerAbstract.php b/Module/InstallerAbstract.php index fe3ceb7ff..4a347780e 100644 --- a/Module/InstallerAbstract.php +++ b/Module/InstallerAbstract.php @@ -68,7 +68,7 @@ class InstallerAbstract $load = $info->getLoad(); foreach ($load as $val) { foreach ($val['pid'] as $pid) { - $sth->bindValue(':pid', sha1(str_replace('/', '', $pid)), \PDO::PARAM_STR); + $sth->bindValue(':pid', sha1(\str_replace('/', '', $pid)), \PDO::PARAM_STR); $sth->bindValue(':type', $val['type'], \PDO::PARAM_INT); $sth->bindValue(':from', $val['from'], \PDO::PARAM_STR); $sth->bindValue(':for', $val['for'], \PDO::PARAM_STR); @@ -148,7 +148,7 @@ class InstallerAbstract */ private static function initRoutes(InfoManager $info) : void { - $directories = new Directory(dirname($info->getPath()) . '/Admin/Routes'); + $directories = new Directory(\dirname($info->getPath()) . '/Admin/Routes'); foreach ($directories as $key => $subdir) { if ($subdir instanceof Directory) { @@ -173,15 +173,15 @@ class InstallerAbstract */ private static function installRoutes(string $destRoutePath, string $srcRoutePath) : void { - if (!file_exists($destRoutePath)) { - file_put_contents($destRoutePath, 'getPath()) . '/Admin/Hooks'); + $directories = new Directory(\dirname($info->getPath()) . '/Admin/Hooks'); foreach ($directories as $key => $subdir) { if ($subdir instanceof Directory) { @@ -237,15 +237,15 @@ class InstallerAbstract */ private static function installHooks(string $destHookPath, string $srcHookPath) : void { - if (!file_exists($destHookPath)) { - file_put_contents($destHookPath, 'getActiveModules(false)); + return \in_array($module, $this->getActiveModules(false)); } /** @@ -241,12 +241,12 @@ final class ModuleManager for ($i = 0; $i < $c; ++$i) { $path = $this->modulePath . '/' . $files[$i] . '/info.json'; - if (!file_exists($path)) { + if (!\file_exists($path)) { continue; // throw new PathException($path); } - $json = json_decode(file_get_contents($path), true); + $json = \json_decode(file_get_contents($path), true); $this->all[$json['name']['internal']] = $json; } } @@ -472,7 +472,7 @@ final class ModuleManager return false; } - if (!file_exists($this->modulePath . '/' . $module . '/Admin/Installer.php')) { + if (!\file_exists($this->modulePath . '/' . $module . '/Admin/Installer.php')) { // todo download; return false; } diff --git a/Module/PackageManager.php b/Module/PackageManager.php index 039149644..b336ec7b6 100644 --- a/Module/PackageManager.php +++ b/Module/PackageManager.php @@ -105,11 +105,11 @@ final class PackageManager */ public function load() : void { - if (!file_exists($this->extractPath)) { + if (!\file_exists($this->extractPath)) { throw new PathException($this->extractPath); } - $this->info = json_decode(file_get_contents($this->extractPath . '/info.json'), true); + $this->info = \json_decode(file_get_contents($this->extractPath . '/info.json'), true); } /** @@ -141,7 +141,7 @@ final class PackageManager continue; } - \sodium_crypto_generichash_update($state, file_get_contents($this->extractPath . '/package/' . $file)); + \sodium_crypto_generichash_update($state, \file_get_contents($this->extractPath . '/package/' . $file)); } return \sodium_crypto_generichash_final(); diff --git a/Router/Router.php b/Router/Router.php index f1afc3111..5e58ec9bb 100644 --- a/Router/Router.php +++ b/Router/Router.php @@ -137,6 +137,6 @@ final class Router */ private function match(string $route, int $routeVerb, string $uri, int $remoteVerb = RouteVerb::GET) : bool { - return (bool) preg_match('~^' . $route . '$~', $uri) && ($routeVerb === RouteVerb::ANY || $remoteVerb === RouteVerb::ANY || ($remoteVerb & $routeVerb) === $remoteVerb); + return (bool) \preg_match('~^' . $route . '$~', $uri) && ($routeVerb === RouteVerb::ANY || $remoteVerb === RouteVerb::ANY || ($remoteVerb & $routeVerb) === $remoteVerb); } } diff --git a/Security/PhpCode.php b/Security/PhpCode.php index 5b1fa21bf..716246bd9 100644 --- a/Security/PhpCode.php +++ b/Security/PhpCode.php @@ -76,7 +76,7 @@ final class PhpCode */ public static function normalizeSource(string $source) : string { - return str_replace(["\n", "\r\n", "\r", "\t"], ['', '', '', ' '], $source); + return \str_replace(["\n", "\r\n", "\r", "\t"], ['', '', '', ' '], $source); } /** @@ -90,7 +90,7 @@ final class PhpCode */ public static function hasUnicode(string $source) : bool { - return (bool) preg_match('/[^\x00-\x7f]/', $source); + return (bool) \preg_match('/[^\x00-\x7f]/', $source); } /** @@ -105,11 +105,11 @@ final class PhpCode public static function isDisabled(array $functions) : bool { $disabled = ini_get('disable_functions'); - $disabled = str_replace(' ', '', $disabled); - $disabled = explode(',', $disabled); + $disabled = \str_replace(' ', '', $disabled); + $disabled = \explode(',', $disabled); foreach ($functions as $function) { - if (!in_array($function, $disabled)) { + if (!\in_array($function, $disabled)) { return false; } } @@ -129,7 +129,7 @@ final class PhpCode public static function hasDeprecatedFunction(string $source) : bool { foreach (self::$deprecatedFunctions as $function) { - if (preg_match('/' . $function . '\s*\(/', $source) === 1) { + if (\preg_match('/' . $function . '\s*\(/', $source) === 1) { return true; } } diff --git a/Socket/Client/Client.php b/Socket/Client/Client.php index fbc22db50..69ba36cc5 100644 --- a/Socket/Client/Client.php +++ b/Socket/Client/Client.php @@ -98,7 +98,7 @@ class Client extends SocketAbstract $data = trim($data); if (!empty($data)) { - $data = explode(' ', $data); + $data = \explode(' ', $data); $this->commands->trigger($data[0], 0, $data); } } diff --git a/Socket/Server/Server.php b/Socket/Server/Server.php index 6fc999619..74bc4bfca 100644 --- a/Socket/Server/Server.php +++ b/Socket/Server/Server.php @@ -130,27 +130,27 @@ class Server extends SocketAbstract // todo: different handshake for normal tcp connection return true; - if (preg_match("/Sec-WebSocket-Version: (.*)\r\n/", $headers, $match)) { + if (\preg_match("/Sec-WebSocket-Version: (.*)\r\n/", $headers, $match)) { $version = $match[1]; } else { return false; } if ($version == 13) { - if (preg_match("/GET (.*) HTTP/", $headers, $match)) { + if (\preg_match("/GET (.*) HTTP/", $headers, $match)) { $root = $match[1]; } - if (preg_match("/Host: (.*)\r\n/", $headers, $match)) { + if (\preg_match("/Host: (.*)\r\n/", $headers, $match)) { $host = $match[1]; } - if (preg_match("/Origin: (.*)\r\n/", $headers, $match)) { + if (\preg_match("/Origin: (.*)\r\n/", $headers, $match)) { $origin = $match[1]; } $key = ''; - if (preg_match("/Sec-WebSocket-Key: (.*)\r\n/", $headers, $match)) { + if (\preg_match("/Sec-WebSocket-Key: (.*)\r\n/", $headers, $match)) { $key = $match[1]; } diff --git a/Stdlib/Base/Enum.php b/Stdlib/Base/Enum.php index 9276a8559..71e877623 100644 --- a/Stdlib/Base/Enum.php +++ b/Stdlib/Base/Enum.php @@ -42,7 +42,7 @@ abstract class Enum { $constants = self::getConstants(); - return in_array($value, $constants, true); + return \in_array($value, $constants, true); } /** diff --git a/Stdlib/Base/EnumArray.php b/Stdlib/Base/EnumArray.php index 65db79838..30f7c04af 100644 --- a/Stdlib/Base/EnumArray.php +++ b/Stdlib/Base/EnumArray.php @@ -73,7 +73,7 @@ abstract class EnumArray { $constants = self::getConstants(); - return in_array($value, $constants, true); + return \in_array($value, $constants, true); } /** diff --git a/Stdlib/Base/Iban.php b/Stdlib/Base/Iban.php index c48b0f767..44d68beb5 100644 --- a/Stdlib/Base/Iban.php +++ b/Stdlib/Base/Iban.php @@ -75,7 +75,7 @@ class Iban implements \Serializable */ public static function normalize(string $iban) : string { - return strtoupper(str_replace(' ', '', $iban)); + return strtoupper(\str_replace(' ', '', $iban)); } /** @@ -114,9 +114,9 @@ class Iban implements \Serializable private function getSequence(string $sequence) : string { $country = $this->getCountry(); - $layout = str_replace(' ', '', IbanEnum::getByName('C_' . $country)); + $layout = \str_replace(' ', '', IbanEnum::getByName('C_' . $country)); - $start = stripos($layout, $sequence); + $start = \stripos($layout, $sequence); $end = strrpos($layout, $sequence); if ($start === false) { diff --git a/Stdlib/Base/Location.php b/Stdlib/Base/Location.php index 8ea4b4a29..f30934767 100644 --- a/Stdlib/Base/Location.php +++ b/Stdlib/Base/Location.php @@ -297,7 +297,7 @@ class Location implements \JsonSerializable, \Serializable */ public function serialize() : string { - return json_encode($this->jsonSerialize()); + return \json_encode($this->jsonSerialize()); } /** diff --git a/Stdlib/Base/SmartDateTime.php b/Stdlib/Base/SmartDateTime.php index ccbebda5c..12acb3f2e 100644 --- a/Stdlib/Base/SmartDateTime.php +++ b/Stdlib/Base/SmartDateTime.php @@ -240,7 +240,7 @@ class SmartDateTime extends \DateTime * * @param int $weekStartsWith Day of the week start (0 = Sunday) * - * @return array + * @return \DateTime[] * * @since 1.0.0 */ diff --git a/Stdlib/Map/MultiMap.php b/Stdlib/Map/MultiMap.php index 3a68b58b3..470604544 100644 --- a/Stdlib/Map/MultiMap.php +++ b/Stdlib/Map/MultiMap.php @@ -130,7 +130,7 @@ class MultiMap implements \Countable /* garbage collect values */ foreach ($this->values as $valueKey => $value) { - if (!in_array($valueKey, $this->keys)) { + if (!\in_array($valueKey, $this->keys)) { unset($this->values[$valueKey]); } } diff --git a/Stdlib/Queue/PriorityQueue.php b/Stdlib/Queue/PriorityQueue.php index 6d95f6a8d..96029929f 100644 --- a/Stdlib/Queue/PriorityQueue.php +++ b/Stdlib/Queue/PriorityQueue.php @@ -184,7 +184,7 @@ class PriorityQueue implements \Countable, \Serializable */ public function serialize() : string { - return json_encode($this->queue); + return \json_encode($this->queue); } /** @@ -198,7 +198,7 @@ class PriorityQueue implements \Countable, \Serializable */ public function unserialize($data) { - $this->queue = json_decode($data); + $this->queue = \json_decode($data); $this->count = count($this->queue); } } diff --git a/System/File/FileUtils.php b/System/File/FileUtils.php index cf144848d..c61690791 100644 --- a/System/File/FileUtils.php +++ b/System/File/FileUtils.php @@ -58,23 +58,23 @@ final class FileUtils { $extension = strtolower($extension); - if (in_array($extension, self::CODE_EXTENSION)) { + if (\in_array($extension, self::CODE_EXTENSION)) { return ExtensionType::CODE; - } elseif (in_array($extension, self::TEXT_EXTENSION)) { + } elseif (\in_array($extension, self::TEXT_EXTENSION)) { return ExtensionType::TEXT; - } elseif (in_array($extension, self::PRESENTATION_EXTENSION)) { + } elseif (\in_array($extension, self::PRESENTATION_EXTENSION)) { return ExtensionType::PRESENTATION; - } elseif (in_array($extension, self::PDF_EXTENSION)) { + } elseif (\in_array($extension, self::PDF_EXTENSION)) { return ExtensionType::PDF; - } elseif (in_array($extension, self::ARCHIVE_EXTENSION)) { + } elseif (\in_array($extension, self::ARCHIVE_EXTENSION)) { return ExtensionType::ARCHIVE; - } elseif (in_array($extension, self::AUDIO_EXTENSION)) { + } elseif (\in_array($extension, self::AUDIO_EXTENSION)) { return ExtensionType::AUDIO; - } elseif (in_array($extension, self::VIDEO_EXTENSION)) { + } elseif (\in_array($extension, self::VIDEO_EXTENSION)) { return ExtensionType::VIDEO; - } elseif (in_array($extension, self::IMAGE_EXTENSION)) { + } elseif (\in_array($extension, self::IMAGE_EXTENSION)) { return ExtensionType::IMAGE; - } elseif (in_array($extension, self::SPREADSHEET_EXTENSION)) { + } elseif (\in_array($extension, self::SPREADSHEET_EXTENSION)) { return ExtensionType::SPREADSHEET; } @@ -92,11 +92,11 @@ final class FileUtils */ public static function absolute(string $origPath) : string { - if (!file_exists($origPath)) { + if (!\file_exists($origPath)) { $startsWithSlash = strpos($origPath, '/') === 0 ? '/' : ''; $path = []; - $parts = explode('/', $origPath); + $parts = \explode('/', $origPath); foreach ($parts as $part) { if (empty($part) || $part === '.') { diff --git a/System/File/Ftp/Directory.php b/System/File/Ftp/Directory.php index 593df739b..3407f244c 100644 --- a/System/File/Ftp/Directory.php +++ b/System/File/Ftp/Directory.php @@ -48,17 +48,17 @@ class Directory extends FileAbstract implements DirectoryInterface { $list = ftp_nlist($con, LocalFile::parent($path)); - return in_array(LocalFile::name($path), $list); + return \in_array(LocalFile::name($path), $list); } public static function ftpCreate($con, string $path, int $permission, bool $recursive) { - $parts = explode('/', $path); + $parts = \explode('/', $path); ftp_chdir($con, '/' . $parts[0]); foreach ($parts as $part) { if (self::ftpExists($con, $part)) { - ftp_mkdir($con, $part); + ftp_\mkdir($con, $part); ftp_chdir($con, $part); ftp_chmod($con, $permission, $part); } diff --git a/System/File/Ftp/File.php b/System/File/Ftp/File.php index 261d8c038..3acc14a7b 100644 --- a/System/File/Ftp/File.php +++ b/System/File/Ftp/File.php @@ -62,19 +62,19 @@ class File extends FileAbstract implements FileInterface public static function ftpConnect(Http $http) { - $con = ftp_connect($http->getBase() . $http->getPath(), $http->getPort()); + $con = \ftp_connect($http->getBase() . $http->getPath(), $http->getPort()); - ftp_login($con, $http->getUser(), $http->getPass()); - ftp_chdir($con, $http->getPath()); // todo: is this required ? + \ftp_login($con, $http->getUser(), $http->getPass()); + \ftp_chdir($con, $http->getPath()); // todo: is this required ? return $con; } public static function ftpExists($con, string $path) { - $list = ftp_nlist($con, LocalFile::dirpath($path)); + $list = \ftp_nlist($con, LocalFile::dirpath($path)); - return in_array(LocalFile::basename($path), $list); + return \in_array(LocalFile::basename($path), $list); } /** @@ -85,7 +85,7 @@ class File extends FileAbstract implements FileInterface $http = new Http($path); $con = self::ftpConnect($http); - if (ftp_pwd($con) !== $http->getPath()) { + if (\ftp_pwd($con) !== $http->getPath()) { return false; } @@ -97,23 +97,23 @@ class File extends FileAbstract implements FileInterface || (!$exists && ContentPutMode::hasFlag($mode, ContentPutMode::CREATE)) ) { if (ContentPutMode::hasFlag($mode, ContentPutMode::APPEND) && $exists) { - file_put_contents($path, file_get_contents($path) . $content, 0, stream_context_create(['ftp' => ['overwrite' => true]])); + \file_put_contents($path, \file_get_contents($path) . $content, 0, \stream_context_create(['ftp' => ['overwrite' => true]])); } elseif (ContentPutMode::hasFlag($mode, ContentPutMode::PREPEND) && $exists) { - file_put_contents($path, $content . file_get_contents($path), 0, stream_context_create(['ftp' => ['overwrite' => true]])); + \file_put_contents($path, $content . \file_get_contents($path), 0, \stream_context_create(['ftp' => ['overwrite' => true]])); } else { - if (!Directory::ftpExists($con, dirname($path))) { - Directory::ftpCreate($con, dirname($path), 0755, true); + if (!Directory::ftpExists($con, \dirname($path))) { + Directory::ftpCreate($con, \dirname($path), 0755, true); } - file_put_contents($path, $content, 0, stream_context_create(['ftp' => ['overwrite' => true]])); + \file_put_contents($path, $content, 0, \stream_context_create(['ftp' => ['overwrite' => true]])); } - ftp_close($con); + \ftp_close($con); return true; } - ftp_close($con); + \ftp_close($con); return false; } @@ -123,17 +123,17 @@ class File extends FileAbstract implements FileInterface */ public static function get(string $path) : string { - $temp = fopen('php://temp', 'r+'); + $temp = \fopen('php://temp', 'r+'); $http = new Http($path); $content = ''; $con = self::ftpConnect($http); - if (ftp_chdir($con, File::dirpath($path)) && ftp_fget($con, $temp, $path, FTP_BINARY, 0)) { - rewind($temp); - $content = stream_get_contents($temp); + if (\ftp_chdir($con, File::dirpath($path)) && \ftp_fget($con, $temp, $path, FTP_BINARY, 0)) { + \rewind($temp); + $content = \stream_get_contents($temp); } - fclose($temp); + \fclose($temp); return $content; } @@ -211,7 +211,7 @@ class File extends FileAbstract implements FileInterface $changed->setTimestamp(ftp_mdtm($con, $http->getPath())); - fclose($con); + \fclose($con); return $changed; } @@ -228,9 +228,9 @@ class File extends FileAbstract implements FileInterface throw new PathException($path); } - $size = ftp_size($con, $http->getPath()); + $size = \ftp_size($con, $http->getPath()); - fclose($con); + \fclose($con); return $size; } @@ -244,7 +244,7 @@ class File extends FileAbstract implements FileInterface $con = self::ftpConnect($http); $owner = self::parseFtpFileData($con, $path)['user'] ?? ''; - fclose($con); + \fclose($con); return (int) $owner; } @@ -258,7 +258,7 @@ class File extends FileAbstract implements FileInterface $con = self::ftpConnect($http); $permission = (int) self::parseFtpFileData($con, $path)['permission'] ?? 0; - fclose($con); + \fclose($con); return $permission; } @@ -267,10 +267,10 @@ class File extends FileAbstract implements FileInterface { $items = []; - if (is_array($files = ftp_rawlist($con, LocalFile::dirpath($path)))) { + if (\is_array($files = \ftp_rawlist($con, LocalFile::dirpath($path)))) { foreach ($files as $fileData) { - if (strpos($fileData, self::name($path)) !== false) { - $chunks = preg_split("/\s+/", $fileData); + if (\strpos($fileData, self::name($path)) !== false) { + $chunks = \preg_split("/\s+/", $fileData); $items['permission'] = $chunks[0]; $items['user'] = $chunks[2]; @@ -342,17 +342,17 @@ class File extends FileAbstract implements FileInterface } if ($overwrite || !self::exists($to)) { - if (!Directory::exists(dirname($to))) { - Directory::create(dirname($to), 0755, true); + if (!Directory::exists(\dirname($to))) { + Directory::create(\dirname($to), 0755, true); } - $rename = ftp_rename($con, $from, $to); - fclose($con); + $rename = \ftp_rename($con, $from, $to); + \fclose($con); return $rename; } - fclose($con); + \fclose($con); return false; } @@ -369,8 +369,8 @@ class File extends FileAbstract implements FileInterface return false; } - ftp_delete($con, $path); - fclose($con); + \ftp_delete($con, $path); + \fclose($con); return true; } diff --git a/System/File/Ftp/FtpStorage.php b/System/File/Ftp/FtpStorage.php index 6af890e31..428b9a132 100644 --- a/System/File/Ftp/FtpStorage.php +++ b/System/File/Ftp/FtpStorage.php @@ -48,7 +48,7 @@ class FtpStorage extends StorageAbstract protected static function getClassType(string $path) : string { - return is_dir($path) || (!is_file($path) && stripos($path, '.') === false) ? Directory::class : File::class; + return \is_dir($path) || (!is_file($path) && \stripos($path, '.') === false) ? Directory::class : File::class; } /** @@ -80,7 +80,7 @@ class FtpStorage extends StorageAbstract */ public static function create(string $path) : bool { - return stripos($path, '.') === false ? Directory::create($path, 0755, true) : File::create($path); + return \stripos($path, '.') === false ? Directory::create($path, 0755, true) : File::create($path); } /** diff --git a/System/File/Local/Directory.php b/System/File/Local/Directory.php index 4d8cbaa35..86e01c01f 100644 --- a/System/File/Local/Directory.php +++ b/System/File/Local/Directory.php @@ -57,7 +57,7 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public function __construct(string $path, string $filter = '*') { - $this->filter = ltrim($filter, '\\/'); + $this->filter = \ltrim($filter, '\\/'); parent::__construct($path); if (file_exists($this->path)) { @@ -71,18 +71,18 @@ final class Directory extends FileAbstract implements DirectoryInterface * @param string $path Path * @param string $filter Filter * - * @return array + * @return string[] * * @since 1.0.0 */ public static function list(string $path, string $filter = '*') : array { - if (!file_exists($path)) { + if (!\file_exists($path)) { throw new PathException($path); } $list = []; - $path = rtrim($path, '\\/'); + $path = \rtrim($path, '\\/'); $iterator = new \RecursiveIteratorIterator( new \RecursiveDirectoryIterator($path, \RecursiveDirectoryIterator::SKIP_DOTS), \RecursiveIteratorIterator::SELF_FIRST); @@ -92,7 +92,7 @@ final class Directory extends FileAbstract implements DirectoryInterface } foreach ($iterator as $item) { - $list[] = str_replace('\\', '/', $iterator->getSubPathname()); + $list[] = \str_replace('\\', '/', $iterator->getSubPathname()); } return $list; @@ -105,23 +105,23 @@ final class Directory extends FileAbstract implements DirectoryInterface * @param string $extension Extension * @param string $exclude Pattern to exclude * - * @return array + * @return string[] * * @since 1.0.0 */ public static function listByExtension(string $path, string $extension = '', string $exclude = '') : array { $list = []; - $path = rtrim($path, '\\/'); + $path = \rtrim($path, '\\/'); foreach ($iterator = new \RecursiveIteratorIterator( new \RecursiveDirectoryIterator($path, \RecursiveDirectoryIterator::SKIP_DOTS), \RecursiveIteratorIterator::SELF_FIRST) as $item ) { if ((empty($extension) || $item->getExtension() === $extension) - && (empty($exclude) || (!(bool) preg_match('/' . $exclude . '/', $iterator->getSubPathname()))) + && (empty($exclude) || (!(bool) \preg_match('/' . $exclude . '/', $iterator->getSubPathname()))) ) { - $list[] = str_replace('\\', '/', $iterator->getSubPathname()); + $list[] = \str_replace('\\', '/', $iterator->getSubPathname()); } } @@ -135,9 +135,9 @@ final class Directory extends FileAbstract implements DirectoryInterface { parent::index(); - foreach (glob($this->path . DIRECTORY_SEPARATOR . $this->filter) as $filename) { + foreach (\glob($this->path . DIRECTORY_SEPARATOR . $this->filter) as $filename) { if (!StringUtils::endsWith(trim($filename), '.')) { - $file = is_dir($filename) ? new self($filename) : new File($filename); + $file = \is_dir($filename) ? new self($filename) : new File($filename); $this->addNode($file); } @@ -161,12 +161,12 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public static function size(string $dir, bool $recursive = true) : int { - if (!file_exists($dir) || !is_readable($dir)) { + if (!\file_exists($dir) || !\is_readable($dir)) { throw new PathException($dir); } $countSize = 0; - $directories = scandir($dir); + $directories = \scandir($dir); foreach ($directories as $key => $filename) { if ($filename === ".." || $filename === ".") { @@ -174,10 +174,10 @@ final class Directory extends FileAbstract implements DirectoryInterface } $path = $dir . "/" . $filename; - if (is_dir($path) && $recursive) { + if (\is_dir($path) && $recursive) { $countSize += self::size($path, $recursive); - } elseif (is_file($path)) { - $countSize += filesize($path); + } elseif (\is_file($path)) { + $countSize += \filesize($path); } } @@ -189,22 +189,22 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public static function count(string $path, bool $recursive = true, array $ignore = []) : int { - if (!file_exists($path)) { + if (!\file_exists($path)) { throw new PathException($path); } $size = 0; - $files = scandir($path); + $files = \scandir($path); $ignore[] = '.'; $ignore[] = '..'; foreach ($files as $t) { - if (in_array($t, $ignore)) { + if (\in_array($t, $ignore)) { continue; } - if (is_dir(rtrim($path, '/') . '/' . $t)) { + if (\is_dir(\rtrim($path, '/') . '/' . $t)) { if ($recursive) { - $size += self::count(rtrim($path, '/') . '/' . $t, true, $ignore); + $size += self::count(\rtrim($path, '/') . '/' . $t, true, $ignore); } } else { $size++; @@ -219,21 +219,21 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public static function delete(string $path) : bool { - $files = scandir($path); + $files = \scandir($path); /* Removing . and .. */ unset($files[1]); unset($files[0]); foreach ($files as $file) { - if (is_dir($path . '/' . $file)) { + if (\is_dir($path . '/' . $file)) { self::delete($path . '/' . $file); } else { - unlink($path . '/' . $file); + \unlink($path . '/' . $file); } } - rmdir($path); + \rmdir($path); return true; } @@ -243,10 +243,10 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public static function parent(string $path) : string { - $path = explode('/', str_replace('\\', '/', $path)); - array_pop($path); + $path = \explode('/', \str_replace('\\', '/', $path)); + \array_pop($path); - return implode('/', $path); + return \implode('/', $path); } /** @@ -255,12 +255,12 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public static function created(string $path) : \DateTime { - if (!file_exists($path)) { + if (!\file_exists($path)) { throw new PathException($path); } $created = new \DateTime('now'); - $created->setTimestamp(filemtime($path)); + $created->setTimestamp(\filemtime($path)); return $created; } @@ -270,12 +270,12 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public static function changed(string $path) : \DateTime { - if (!file_exists($path)) { + if (!\file_exists($path)) { throw new PathException($path); } $changed = new \DateTime(); - $changed->setTimestamp(filectime($path)); + $changed->setTimestamp(\filectime($path)); return $changed; } @@ -285,11 +285,11 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public static function owner(string $path) : int { - if (!file_exists($path)) { + if (!\file_exists($path)) { throw new PathException($path); } - return fileowner($path); + return \fileowner($path); } /** @@ -297,11 +297,11 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public static function permission(string $path) : int { - if (!file_exists($path)) { + if (!\file_exists($path)) { throw new PathException($path); } - return fileperms($path); + return \fileperms($path); } /** @@ -313,9 +313,9 @@ final class Directory extends FileAbstract implements DirectoryInterface throw new PathException($from); } - if (!file_exists($to)) { + if (!\file_exists($to)) { self::create($to, 0755, true); - } elseif ($overwrite && file_exists($to)) { + } elseif ($overwrite && \file_exists($to)) { self::delete($to); } else { return false; @@ -326,9 +326,9 @@ final class Directory extends FileAbstract implements DirectoryInterface \RecursiveIteratorIterator::SELF_FIRST) as $item ) { if ($item->isDir()) { - mkdir($to . '/' . $iterator->getSubPathname()); + \mkdir($to . '/' . $iterator->getSubPathname()); } else { - copy($from . '/' . $iterator->getSubPathname(), $to . '/' . $iterator->getSubPathname()); + \copy($from . '/' . $iterator->getSubPathname(), $to . '/' . $iterator->getSubPathname()); } } @@ -344,9 +344,9 @@ final class Directory extends FileAbstract implements DirectoryInterface throw new PathException($from); } - if (!$overwrite && file_exists($to)) { + if (!$overwrite && \file_exists($to)) { return false; - } elseif ($overwrite && file_exists($to)) { + } elseif ($overwrite && \file_exists($to)) { self::delete($to); } @@ -354,7 +354,7 @@ final class Directory extends FileAbstract implements DirectoryInterface self::create(self::parent($to), 0755, true); } - rename($from, $to); + \rename($from, $to); return true; } @@ -364,7 +364,7 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public static function exists(string $path) : bool { - return file_exists($path); + return \file_exists($path); } /** @@ -372,7 +372,7 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public static function sanitize(string $path, string $replace = '') : string { - return preg_replace('[^\w\s\d\.\-_~,;:\[\]\(\]\/]', $replace, $path); + return \preg_replace('[^\w\s\d\.\-_~,;:\[\]\(\]\/]', $replace, $path); } /** @@ -398,12 +398,12 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public static function create(string $path, int $permission = 0755, bool $recursive = false) : bool { - if (!file_exists($path)) { - if (!$recursive && !file_exists(self::parent($path))) { + if (!\file_exists($path)) { + if (!$recursive && !\file_exists(self::parent($path))) { return false; } - mkdir($path, $permission, $recursive); + \mkdir($path, $permission, $recursive); return true; } @@ -435,7 +435,7 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public function rewind() { - reset($this->nodes); + \reset($this->nodes); } /** @@ -443,7 +443,7 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public function current() { - return current($this->nodes); + return \current($this->nodes); } /** @@ -451,7 +451,7 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public function key() { - return key($this->nodes); + return \key($this->nodes); } /** @@ -459,7 +459,7 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public function next() { - return next($this->nodes); + return \next($this->nodes); } /** @@ -467,7 +467,7 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public function valid() { - $key = key($this->nodes); + $key = \key($this->nodes); return ($key !== null && $key !== false); } @@ -507,7 +507,7 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public static function name(string $path) : string { - return basename($path); + return \basename($path); } /** @@ -515,7 +515,7 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public static function dirname(string $path) : string { - return basename($path); + return \basename($path); } /** @@ -531,7 +531,7 @@ final class Directory extends FileAbstract implements DirectoryInterface */ public static function basename(string $path) : string { - return basename($path); + return \basename($path); } /** diff --git a/System/File/Local/File.php b/System/File/Local/File.php index 7abd73c8c..d1965feea 100644 --- a/System/File/Local/File.php +++ b/System/File/Local/File.php @@ -44,7 +44,7 @@ final class File extends FileAbstract implements FileInterface parent::__construct($path); $this->count = 1; - if (file_exists($this->path)) { + if (\file_exists($this->path)) { $this->index(); } } @@ -56,7 +56,7 @@ final class File extends FileAbstract implements FileInterface { parent::index(); - $this->size = filesize($this->path); + $this->size = \filesize($this->path); } /** @@ -64,7 +64,7 @@ final class File extends FileAbstract implements FileInterface */ public static function put(string $path, string $content, int $mode = ContentPutMode::REPLACE | ContentPutMode::CREATE) : bool { - $exists = file_exists($path); + $exists = \file_exists($path); if ((ContentPutMode::hasFlag($mode, ContentPutMode::APPEND) && $exists) || (ContentPutMode::hasFlag($mode, ContentPutMode::PREPEND) && $exists) @@ -72,15 +72,15 @@ final class File extends FileAbstract implements FileInterface || (!$exists && ContentPutMode::hasFlag($mode, ContentPutMode::CREATE)) ) { if (ContentPutMode::hasFlag($mode, ContentPutMode::APPEND) && $exists) { - file_put_contents($path, file_get_contents($path) . $content); + \file_put_contents($path, \file_get_contents($path) . $content); } elseif (ContentPutMode::hasFlag($mode, ContentPutMode::PREPEND) && $exists) { - file_put_contents($path, $content . file_get_contents($path)); + \file_put_contents($path, $content . \file_get_contents($path)); } else { - if (!Directory::exists(dirname($path))) { - Directory::create(dirname($path), 0755, true); + if (!Directory::exists(\dirname($path))) { + Directory::create(\dirname($path), 0755, true); } - file_put_contents($path, $content); + \file_put_contents($path, $content); } return true; @@ -94,11 +94,11 @@ final class File extends FileAbstract implements FileInterface */ public static function get(string $path) : string { - if (!file_exists($path)) { + if (!\file_exists($path)) { throw new PathException($path); } - return file_get_contents($path); + return \file_get_contents($path); } /** @@ -138,7 +138,7 @@ final class File extends FileAbstract implements FileInterface */ public static function exists(string $path) : bool { - return file_exists($path); + return \file_exists($path); } /** @@ -146,7 +146,7 @@ final class File extends FileAbstract implements FileInterface */ public static function parent(string $path) : string { - return Directory::parent(dirname($path)); + return Directory::parent(\dirname($path)); } /** @@ -154,7 +154,7 @@ final class File extends FileAbstract implements FileInterface */ public static function sanitize(string $path, string $replace = '') : string { - return preg_replace('/[^\w\s\d\.\-_~,;\/\[\]\(\]]/', $replace, $path); + return \preg_replace('/[^\w\s\d\.\-_~,;\/\[\]\(\]]/', $replace, $path); } /** @@ -162,11 +162,11 @@ final class File extends FileAbstract implements FileInterface */ public static function created(string $path) : \DateTime { - if (!file_exists($path)) { + if (!\file_exists($path)) { throw new PathException($path); } - return self::createFileTime(filemtime($path)); + return self::createFileTime(\filemtime($path)); } /** @@ -174,11 +174,11 @@ final class File extends FileAbstract implements FileInterface */ public static function changed(string $path) : \DateTime { - if (!file_exists($path)) { + if (!\file_exists($path)) { throw new PathException($path); } - return self::createFileTime(filemtime($path)); + return self::createFileTime(\filemtime($path)); } /** @@ -203,7 +203,7 @@ final class File extends FileAbstract implements FileInterface */ public static function size(string $path, bool $recursive = true) : int { - if (!file_exists($path)) { + if (!\file_exists($path)) { throw new PathException($path); } @@ -215,11 +215,11 @@ final class File extends FileAbstract implements FileInterface */ public static function owner(string $path) : int { - if (!file_exists($path)) { + if (!\file_exists($path)) { throw new PathException($path); } - return fileowner($path); + return \fileowner($path); } /** @@ -227,11 +227,11 @@ final class File extends FileAbstract implements FileInterface */ public static function permission(string $path) : int { - if (!file_exists($path)) { + if (!\file_exists($path)) { throw new PathException($path); } - return fileperms($path); + return \fileperms($path); } /** @@ -245,7 +245,7 @@ final class File extends FileAbstract implements FileInterface */ public static function dirname(string $path) : string { - return basename(dirname($path)); + return basename(\dirname($path)); } /** @@ -271,12 +271,12 @@ final class File extends FileAbstract implements FileInterface throw new PathException($from); } - if ($overwrite || !file_exists($to)) { - if (!Directory::exists(dirname($to))) { - Directory::create(dirname($to), 0755, true); + if ($overwrite || !\file_exists($to)) { + if (!Directory::exists(\dirname($to))) { + Directory::create(\dirname($to), 0755, true); } - if ($overwrite && file_exists($to)) { + if ($overwrite && \file_exists($to)) { unlink($to); } @@ -307,7 +307,7 @@ final class File extends FileAbstract implements FileInterface */ public static function delete(string $path) : bool { - if (!file_exists($path)) { + if (!\file_exists($path)) { return false; } @@ -325,7 +325,7 @@ final class File extends FileAbstract implements FileInterface */ public function getDirName() : string { - return basename(dirname($this->path)); + return basename(\dirname($this->path)); } /** @@ -353,16 +353,16 @@ final class File extends FileAbstract implements FileInterface */ public static function create(string $path) : bool { - if (!file_exists($path)) { - if (!Directory::exists(dirname($path))) { - Directory::create(dirname($path), 0755, true); + if (!\file_exists($path)) { + if (!Directory::exists(\dirname($path))) { + Directory::create(\dirname($path), 0755, true); } - if (!is_writable(dirname($path))) { + if (!is_writable(\dirname($path))) { return false; } - touch($path); + \touch($path); return true; } @@ -375,7 +375,7 @@ final class File extends FileAbstract implements FileInterface */ public function getContent() : string { - return file_get_contents($this->path); + return \file_get_contents($this->path); } /** @@ -407,7 +407,7 @@ final class File extends FileAbstract implements FileInterface */ public function getName() : string { - return explode('.', $this->name)[0]; + return \explode('.', $this->name)[0]; } /** @@ -415,7 +415,7 @@ final class File extends FileAbstract implements FileInterface */ public function getExtension() : string { - $extension = explode('.', $this->name); + $extension = \explode('.', $this->name); return $extension[1] ?? ''; } @@ -465,7 +465,7 @@ final class File extends FileAbstract implements FileInterface */ public static function name(string $path) : string { - return explode('.', basename($path))[0]; + return \explode('.', \basename($path))[0]; } /** @@ -473,7 +473,7 @@ final class File extends FileAbstract implements FileInterface */ public static function basename(string $path) : string { - return basename($path); + return \basename($path); } /** @@ -481,7 +481,7 @@ final class File extends FileAbstract implements FileInterface */ public static function extension(string $path) : string { - $extension = explode('.', basename($path)); + $extension = \explode('.', \basename($path)); return $extension[1] ?? ''; } diff --git a/System/File/Local/LocalStorage.php b/System/File/Local/LocalStorage.php index 0a03b2c48..fc3860de9 100644 --- a/System/File/Local/LocalStorage.php +++ b/System/File/Local/LocalStorage.php @@ -64,7 +64,7 @@ class LocalStorage extends StorageAbstract */ protected static function getClassType(string $path) : string { - return is_dir($path) || (!is_file($path) && stripos($path, '.') === false) ? Directory::class : File::class; + return \is_dir($path) || (!is_file($path) && \stripos($path, '.') === false) ? Directory::class : File::class; } /** @@ -72,7 +72,7 @@ class LocalStorage extends StorageAbstract */ public static function put(string $path, string $content, int $mode = 0) : bool { - if (is_dir($path)) { + if (\is_dir($path)) { throw new PathException($path); } @@ -84,7 +84,7 @@ class LocalStorage extends StorageAbstract */ public static function get(string $path) : string { - if (is_dir($path)) { + if (\is_dir($path)) { throw new PathException($path); } @@ -96,7 +96,7 @@ class LocalStorage extends StorageAbstract */ public static function list(string $path, string $filter = '*') : array { - if (is_file($path)) { + if (\is_file($path)) { throw new PathException($path); } @@ -108,7 +108,7 @@ class LocalStorage extends StorageAbstract */ public static function create(string $path) : bool { - return stripos($path, '.') === false ? Directory::create($path, 0755, true) : File::create($path); + return \stripos($path, '.') === false ? Directory::create($path, 0755, true) : File::create($path); } /** @@ -116,7 +116,7 @@ class LocalStorage extends StorageAbstract */ public static function set(string $path, string $content) : bool { - if (is_dir($path)) { + if (\is_dir($path)) { throw new PathException($path); } @@ -128,7 +128,7 @@ class LocalStorage extends StorageAbstract */ public static function append(string $path, string $content) : bool { - if (is_dir($path)) { + if (\is_dir($path)) { throw new PathException($path); } @@ -140,7 +140,7 @@ class LocalStorage extends StorageAbstract */ public static function prepend(string $path, string $content) : bool { - if (is_dir($path)) { + if (\is_dir($path)) { throw new PathException($path); } @@ -152,7 +152,7 @@ class LocalStorage extends StorageAbstract */ public static function extension(string $path) : string { - if (is_dir($path)) { + if (\is_dir($path)) { throw new PathException($path); } diff --git a/System/SystemUtils.php b/System/SystemUtils.php index c0383fe92..ce40b5a34 100644 --- a/System/SystemUtils.php +++ b/System/SystemUtils.php @@ -58,7 +58,7 @@ final class SystemUtils while ($line = fgets($fh)) { $pieces = []; - if (preg_match('/^MemTotal:\s+(\d+)\skB$/', $line, $pieces)) { + if (\preg_match('/^MemTotal:\s+(\d+)\skB$/', $line, $pieces)) { $mem = $pieces[1] * 1024; break; } @@ -84,8 +84,8 @@ final class SystemUtils if (stristr(PHP_OS, 'LINUX')) { $free = shell_exec('free'); $free = (string) trim($free); - $freeArr = explode("\n", $free); - $mem = explode(" ", $freeArr[1]); + $freeArr = \explode("\n", $free); + $mem = \explode(" ", $freeArr[1]); $mem = array_values(array_filter($mem)); $memUsage = $mem[2] / $mem[1] * 100; } diff --git a/UnhandledHandler.php b/UnhandledHandler.php index 1511188b9..defda347f 100644 --- a/UnhandledHandler.php +++ b/UnhandledHandler.php @@ -28,7 +28,7 @@ final class UnhandledHandler /** * Exception handler. * - * @param mixed $e Exception + * @param \Throwable $e Exception * * @return void * diff --git a/Uri/UriFactory.php b/Uri/UriFactory.php index cdb06cbd4..ccfc01fab 100644 --- a/Uri/UriFactory.php +++ b/Uri/UriFactory.php @@ -157,7 +157,7 @@ final class UriFactory $success = false; foreach (self::$uri as $key => $value) { - if (((bool) preg_match('~^' . $pattern . '$~', $key))) { + if (((bool) \preg_match('~^' . $pattern . '$~', $key))) { unset(self::$uri[$key]); $success = true; } @@ -179,16 +179,16 @@ final class UriFactory */ private static function unique(string $url) : string { - $parts = explode('?', $url); + $parts = \explode('?', $url); if (count($parts) >= 2) { $full = $parts[1]; - $pars = explode('&', $full); + $pars = \explode('&', $full); $comps = []; $length = count($pars); for ($i = 0; $i < $length; ++$i) { - $spl = explode('=', $pars[$i]); + $spl = \explode('=', $pars[$i]); if (isset($spl[1])) { $comps[$spl[0]] = $spl[1]; @@ -200,7 +200,7 @@ final class UriFactory $pars[] = $key . '=' . $value; } - $url = $parts[0] . (empty($pars) ? '' : '?' . implode('&', $pars)); + $url = $parts[0] . (empty($pars) ? '' : '?' . \implode('&', $pars)); } return $url; @@ -227,15 +227,15 @@ final class UriFactory */ public static function build(string $uri, array $toMatch = []) : string { - $parsed = preg_replace_callback('(\{[\/#\?%@\.\$][a-zA-Z0-9\-]*\})', function ($match) use ($toMatch) { - $match = substr($match[0], 1, strlen($match[0]) - 2); + $parsed = \preg_replace_callback('(\{[\/#\?%@\.\$][a-zA-Z0-9\-]*\})', function ($match) use ($toMatch) { + $match = \substr($match[0], 1, \strlen($match[0]) - 2); return $toMatch[$match] ?? self::$uri[$match] ?? $match; }, $uri); // todo: maybe don't do this and adjust unique?! - if (strpos($parsed, '?')) { - str_replace('&', '?', $parsed); + if (\strpos($parsed, '?')) { + \str_replace('&', '?', $parsed); } return self::unique($parsed); diff --git a/Utils/ArrayUtils.php b/Utils/ArrayUtils.php index bf77a272a..02733d7e6 100644 --- a/Utils/ArrayUtils.php +++ b/Utils/ArrayUtils.php @@ -48,7 +48,7 @@ final class ArrayUtils */ public static function unsetArray(string $path, array $data, string $delim = '/') : array { - $nodes = explode($delim, trim($path, $delim)); + $nodes = \explode($delim, trim($path, $delim)); $prevEl = null; $el = &$data; @@ -86,7 +86,7 @@ final class ArrayUtils */ public static function setArray(string $path, array $data, $value, string $delim = '/', bool $overwrite = false) : array { - $pathParts = explode($delim, trim($path, $delim)); + $pathParts = \explode($delim, trim($path, $delim)); $current = &$data; foreach ($pathParts as $key) { @@ -121,7 +121,7 @@ final class ArrayUtils */ public static function getArray(string $path, array $data, string $delim = '/') { - $pathParts = explode($delim, trim($path, $delim)); + $pathParts = \explode($delim, trim($path, $delim)); $current = $data; foreach ($pathParts as $key) { @@ -167,7 +167,7 @@ final class ArrayUtils /** * Check if any of the needles are in the array * - * @param mixed $needles Needles for search + * @param array $needles Needles for search * @param array $haystack Haystack for search * * @return bool @@ -177,7 +177,7 @@ final class ArrayUtils public static function anyInArray(array $needles, array $haystack) : bool { foreach ($needles as $needle) { - if (in_array($needle, $haystack)) { + if (\in_array($needle, $haystack)) { return true; } } @@ -188,7 +188,7 @@ final class ArrayUtils /** * Check if all of the needles are in the array * - * @param mixed $needles Needles for search + * @param array $needles Needles for search * @param array $haystack Haystack for search * * @return bool @@ -198,7 +198,7 @@ final class ArrayUtils public static function allInArray(array $needles, array $haystack) : bool { foreach ($needles as $needle) { - if (!in_array($needle, $haystack)) { + if (!\in_array($needle, $haystack)) { return false; } } diff --git a/Utils/Barcode/C128Abstract.php b/Utils/Barcode/C128Abstract.php index 4ef6482ec..14d365967 100644 --- a/Utils/Barcode/C128Abstract.php +++ b/Utils/Barcode/C128Abstract.php @@ -370,7 +370,7 @@ abstract class C128Abstract * * @param string $codeString Code string to render * - * @return array + * @return array * * @since 1.0.0 */ diff --git a/Utils/Barcode/C25.php b/Utils/Barcode/C25.php index e7fd316ab..a5d62c39f 100644 --- a/Utils/Barcode/C25.php +++ b/Utils/Barcode/C25.php @@ -125,8 +125,8 @@ class C25 extends C128Abstract for ($posX = 1; $posX <= $length; $posX += 2) { if (isset($temp[$posX], $temp[($posX + 1)])) { - $temp1 = explode('-', $temp[$posX]); - $temp2 = explode('-', $temp[($posX + 1)]); + $temp1 = \explode('-', $temp[$posX]); + $temp2 = \explode('-', $temp[($posX + 1)]); $count = count($temp1); for ($posY = 0; $posY < $count; $posY++) { diff --git a/Utils/ColorUtils.php b/Utils/ColorUtils.php index ef9b1245d..6917b1c83 100644 --- a/Utils/ColorUtils.php +++ b/Utils/ColorUtils.php @@ -40,7 +40,7 @@ final class ColorUtils * * @param int $rgbInt Value to convert * - * @return array + * @return array * * @since 1.0.0 */ diff --git a/Utils/Compression/LZW.php b/Utils/Compression/LZW.php index 589d60a0f..3e8cee371 100644 --- a/Utils/Compression/LZW.php +++ b/Utils/Compression/LZW.php @@ -65,7 +65,7 @@ class LZW implements CompressionInterface */ public function decompress(string $compressed) : string { - $compressed = explode(',', $compressed); + $compressed = \explode(',', $compressed); $dictionary = []; $entry = ''; $dictSize = 256; diff --git a/Utils/Converter/Ip.php b/Utils/Converter/Ip.php index 0916690ee..a2e686b8b 100644 --- a/Utils/Converter/Ip.php +++ b/Utils/Converter/Ip.php @@ -47,7 +47,7 @@ class Ip */ public static function ip2Float(string $ip) : float { - $split = explode('.', $ip); + $split = \explode('.', $ip); return $split[0] * (256 ** 3) + $split[1] * (256 ** 2) + $split[2] * (256 ** 1) + $split[3]; } diff --git a/Utils/Encoding/Huffman/Dictionary.php b/Utils/Encoding/Huffman/Dictionary.php index 2cbd48dfb..45fdd5446 100644 --- a/Utils/Encoding/Huffman/Dictionary.php +++ b/Utils/Encoding/Huffman/Dictionary.php @@ -80,7 +80,7 @@ final class Dictionary $count = []; while (isset($source[0])) { $count[] = [substr_count($source, $source[0]), $source[0]]; - $source = str_replace($source[0], '', $source); + $source = \str_replace($source[0], '', $source); } sort($count); @@ -144,7 +144,7 @@ final class Dictionary throw new \InvalidArgumentException('Character already exists'); } - if (strlen(str_replace('0', '', str_replace('1', '', $value))) !== 0) { + if (strlen(\str_replace('0', '', \str_replace('1', '', $value))) !== 0) { throw new \InvalidArgumentException('Bad formatting.'); } diff --git a/Utils/Git/Repository.php b/Utils/Git/Repository.php index b86abee43..46117aad5 100644 --- a/Utils/Git/Repository.php +++ b/Utils/Git/Repository.php @@ -95,7 +95,7 @@ class Repository throw new PathException($path); } - if (file_exists($this->path . '/.git') && is_dir($this->path . '/.git')) { + if (file_exists($this->path . '/.git') && \is_dir($this->path . '/.git')) { $this->bare = false; } elseif (is_file($this->path . '/config')) { // Is this a bare repo? $parseIni = parse_ini_file($this->path . '/config'); @@ -171,7 +171,7 @@ class Repository private function run(string $cmd) : array { if (strtolower(substr(PHP_OS, 0, 3)) == 'win') { - $cmd = 'cd ' . escapeshellarg(dirname(Git::getBin())) + $cmd = 'cd ' . escapeshellarg(\dirname(Git::getBin())) . ' && ' . basename(Git::getBin()) . ' -C ' . escapeshellarg($this->path) . ' ' . $cmd; @@ -242,12 +242,12 @@ class Repository */ public function create(string $source = null) : void { - if (!is_dir($this->path) || file_exists($this->path . '/.git')) { + if (!is_dir($this->path) || \file_exists($this->path . '/.git')) { throw new \Exception('Already repository'); } if ($source !== null) { - stripos($source, '//') !== false ? $this->cloneRemote($source) : $this->cloneFrom($source); + \stripos($source, '//') !== false ? $this->cloneRemote($source) : $this->cloneFrom($source); return; } @@ -438,8 +438,8 @@ class Repository { if (empty($this->name)) { $path = $this->getDirectoryPath(); - $path = str_replace('\\', '/', $path); - $path = explode('/', $path); + $path = \str_replace('\\', '/', $path); + $path = \explode('/', $path); $this->name = $path[count($path) - ($this->bare ? 1 : 2)]; } @@ -605,7 +605,7 @@ class Repository */ public function setDescription(string $description) : void { - file_put_contents($this->getDirectoryPath(), $description); + \file_put_contents($this->getDirectoryPath(), $description); } /** @@ -617,7 +617,7 @@ class Repository */ public function getDescription() : string { - return file_get_contents($this->getDirectoryPath() . '/description'); + return \file_get_contents($this->getDirectoryPath() . '/description'); } /** @@ -657,7 +657,7 @@ class Repository continue; } - if (!file_exists($path = $this->getDirectoryPath() . ($this->bare ? '/' : '/../') . $line)) { + if (!\file_exists($path = $this->getDirectoryPath() . ($this->bare ? '/' : '/../') . $line)) { return 0; } @@ -702,7 +702,7 @@ class Repository $contributors = []; foreach ($lines as $line) { - preg_match('/^[0-9]*/', $line, $matches); + \preg_match('/^[0-9]*/', $line, $matches); $contributor = new Author(substr($line, strlen($matches[0]) + 1)); $contributor->setCommitCount($this->getCommitsCount($start, $end)[$contributor->getName()]); @@ -741,7 +741,7 @@ class Repository $commits = []; foreach ($lines as $line) { - preg_match('/^[0-9]*/', $line, $matches); + \preg_match('/^[0-9]*/', $line, $matches); $commits[substr($line, strlen($matches[0]) + 1)] = (int) $matches[0]; } @@ -779,7 +779,7 @@ class Repository ); foreach ($lines as $line) { - $nums = explode(' ', $line); + $nums = \explode(' ', $line); $addremove['added'] += $nums[0]; $addremove['removed'] += $nums[1]; @@ -836,7 +836,7 @@ class Repository $commits = []; for ($i = 0; $i < $count; ++$i) { - $match = preg_match('/[0-9ABCDEFabcdef]{40}/', $lines[$i], $matches); + $match = \preg_match('/[0-9ABCDEFabcdef]{40}/', $lines[$i], $matches); if ($match !== false && $match !== 0) { $commit = $this->getCommit($matches[0]); @@ -868,7 +868,7 @@ class Repository return new Commit(); } - preg_match('/[0-9ABCDEFabcdef]{40}/', $lines[0], $matches); + \preg_match('/[0-9ABCDEFabcdef]{40}/', $lines[0], $matches); if (!isset($matches[0]) || strlen($matches[0]) !== 40) { throw new \Exception('Invalid commit id'); @@ -879,8 +879,8 @@ class Repository } // todo: validate if array values are all initialized - $author = explode(':', $lines[1]); - $author = explode('<', trim($author[1])); + $author = \explode(':', $lines[1]); + $author = \explode('<', trim($author[1])); $date = substr($lines[2], 6); $commit = new Commit($matches[0]); @@ -918,7 +918,7 @@ class Repository return new Commit(); } - preg_match('/[0-9ABCDEFabcdef]{40}/', $lines[0], $matches); + \preg_match('/[0-9ABCDEFabcdef]{40}/', $lines[0], $matches); if (!isset($matches[0]) || strlen($matches[0]) !== 40) { throw new \Exception('Invalid commit id'); diff --git a/Utils/IO/Csv/CsvDatabaseMapper.php b/Utils/IO/Csv/CsvDatabaseMapper.php index d5005ec22..26489fe94 100644 --- a/Utils/IO/Csv/CsvDatabaseMapper.php +++ b/Utils/IO/Csv/CsvDatabaseMapper.php @@ -71,7 +71,7 @@ class CsvDatabaseMapper implements IODatabaseMapper } $query = new Builder($this->db); - $query->insert(...$header)->into(str_replace(' ', '', explode($source, '.'))); + $query->insert(...$header)->into(\str_replace(' ', '', explode($source, '.'))); while (feof($file)) { $c = 0; diff --git a/Utils/IO/Zip/Gz.php b/Utils/IO/Zip/Gz.php index c43168cd5..47e3ea97f 100644 --- a/Utils/IO/Zip/Gz.php +++ b/Utils/IO/Zip/Gz.php @@ -31,8 +31,8 @@ class Gz implements ArchiveInterface */ public static function pack($source, string $destination, bool $overwrite = true) : bool { - $destination = str_replace('\\', '/', realpath($destination)); - if (!$overwrite && file_exists($destination)) { + $destination = \str_replace('\\', '/', realpath($destination)); + if (!$overwrite && \file_exists($destination)) { return false; } @@ -55,7 +55,7 @@ class Gz implements ArchiveInterface */ public static function unpack(string $source, string $destination) : bool { - $destination = str_replace('\\', '/', realpath($destination)); + $destination = \str_replace('\\', '/', realpath($destination)); if (file_exists($destination)) { return false; } diff --git a/Utils/IO/Zip/Tar.php b/Utils/IO/Zip/Tar.php index 457701394..498494215 100644 --- a/Utils/IO/Zip/Tar.php +++ b/Utils/IO/Zip/Tar.php @@ -31,17 +31,17 @@ class Tar implements ArchiveInterface */ public static function pack($sources, string $destination, bool $overwrite = true) : bool { - $destination = str_replace('\\', '/', realpath($destination)); + $destination = \str_replace('\\', '/', realpath($destination)); - if (!$overwrite && file_exists($destination)) { + if (!$overwrite && \file_exists($destination)) { return false; } /** @var array $sources */ foreach ($sources as $source) { - $source = str_replace('\\', '/', realpath($source)); + $source = \str_replace('\\', '/', realpath($source)); - if (!file_exists($source)) { + if (!\file_exists($source)) { continue; } @@ -52,10 +52,10 @@ class Tar implements ArchiveInterface ); foreach ($files as $file) { - $file = str_replace('\\', '/', $file); + $file = \str_replace('\\', '/', $file); /* Ignore . and .. */ - if (in_array(mb_substr($file, mb_strrpos($file, '/') + 1), ['.', '..'])) { + if (\in_array(mb_substr($file, mb_strrpos($file, '/') + 1), ['.', '..'])) { continue; } diff --git a/Utils/IO/Zip/Zip.php b/Utils/IO/Zip/Zip.php index 26c85f9d7..0060cc868 100644 --- a/Utils/IO/Zip/Zip.php +++ b/Utils/IO/Zip/Zip.php @@ -34,9 +34,9 @@ class Zip implements ArchiveInterface */ public static function pack($sources, string $destination, bool $overwrite = true) : bool { - $destination = FileUtils::absolute(str_replace('\\', '/', $destination)); + $destination = FileUtils::absolute(\str_replace('\\', '/', $destination)); - if (!$overwrite && file_exists($destination)) { + if (!$overwrite && \file_exists($destination)) { return false; } @@ -47,9 +47,9 @@ class Zip implements ArchiveInterface /** @var array $sources */ foreach ($sources as $source => $relative) { - $source = str_replace('\\', '/', realpath($source)); + $source = \str_replace('\\', '/', realpath($source)); - if (!file_exists($source)) { + if (!\file_exists($source)) { continue; } @@ -57,16 +57,16 @@ class Zip implements ArchiveInterface $files = new \RecursiveIteratorIterator(new \RecursiveDirectoryIterator($source), \RecursiveIteratorIterator::SELF_FIRST); foreach ($files as $file) { - $file = str_replace('\\', '/', $file); + $file = \str_replace('\\', '/', $file); /* Ignore . and .. */ - if (in_array(mb_substr($file, mb_strrpos($file, '/') + 1), ['.', '..'])) { + if (\in_array(mb_substr($file, mb_strrpos($file, '/') + 1), ['.', '..'])) { continue; } $absolute = realpath($file); - $absolute = str_replace('\\', '/', $absolute); - $dir = str_replace($source . '/', '', $relative . '/' . $absolute); + $absolute = \str_replace('\\', '/', $absolute); + $dir = \str_replace($source . '/', '', $relative . '/' . $absolute); if (is_dir($absolute)) { $zip->addEmptyDir($dir . '/'); @@ -87,11 +87,11 @@ class Zip implements ArchiveInterface */ public static function unpack(string $source, string $destination) : bool { - if (!file_exists($source)) { + if (!\file_exists($source)) { return false; } - $destination = str_replace('\\', '/', $destination); + $destination = \str_replace('\\', '/', $destination); $destination = rtrim($destination, '/'); $zip = new \ZipArchive(); diff --git a/Utils/ImageUtils.php b/Utils/ImageUtils.php index d1e82b3c0..9cd030d7b 100644 --- a/Utils/ImageUtils.php +++ b/Utils/ImageUtils.php @@ -48,8 +48,8 @@ final class ImageUtils */ public static function decodeBase64Image(string $img) : string { - $img = str_replace('data:image/png;base64,', '', $img); - $img = str_replace(' ', '+', $img); + $img = \str_replace('data:image/png;base64,', '', $img); + $img = \str_replace(' ', '+', $img); return base64_decode($img); } diff --git a/Utils/JsonBuilder.php b/Utils/JsonBuilder.php index b1c0aabc9..f96d709bf 100644 --- a/Utils/JsonBuilder.php +++ b/Utils/JsonBuilder.php @@ -80,7 +80,7 @@ final class JsonBuilder implements \Serializable, \JsonSerializable */ public function serialize() : string { - return json_encode($this->json); + return \json_encode($this->json); } /** @@ -88,7 +88,7 @@ final class JsonBuilder implements \Serializable, \JsonSerializable */ public function unserialize($serialized) { - $this->json = json_decode($serialized, true); + $this->json = \json_decode($serialized, true); } /** diff --git a/Utils/Parser/LaTex/Expressions/Product.php b/Utils/Parser/LaTex/Expressions/Product.php deleted file mode 100644 index fd78aecb4..000000000 --- a/Utils/Parser/LaTex/Expressions/Product.php +++ /dev/null @@ -1,19 +0,0 @@ - 0 ? substr($line, $indent) : $line; + $text = $indent > 0 ? \substr($line, $indent) : $line; $lineArray = ['body' => $line, 'indent' => $indent, 'text' => $text]; if (isset($currentBlock['continuable'])) { @@ -288,7 +288,7 @@ class Markdown $currentBlock = $block; continue; - } elseif (in_array($currentBlock['type'], self::$completable)) { + } elseif (\in_array($currentBlock['type'], self::$completable)) { $currentBlock = self::{'block' . $currentBlock['type'] . 'Complete'}($currentBlock); } } @@ -314,7 +314,7 @@ class Markdown $block['identified'] = true; } - if (in_array($blockType, self::$continuable)) { + if (\in_array($blockType, self::$continuable)) { $block['continuable'] = true; } @@ -333,7 +333,7 @@ class Markdown } } - if (isset($currentBlock['continuable']) && in_array($currentBlock['type'], self::$completable)) { + if (isset($currentBlock['continuable']) && \in_array($currentBlock['type'], self::$completable)) { $currentBlock = self::{'block' . $currentBlock['type'] . 'Complete'}($currentBlock); } @@ -381,7 +381,7 @@ class Markdown 'handler' => 'element', 'text' => [ 'name' => 'code', - 'text' => substr($lineArray['body'], 4), + 'text' => \substr($lineArray['body'], 4), ], ], ]; @@ -410,7 +410,7 @@ class Markdown } $block['element']['text']['text'] .= "\n"; - $block['element']['text']['text'] .= substr($lineArray['body'], 4); + $block['element']['text']['text'] .= \substr($lineArray['body'], 4); return $block; } @@ -440,7 +440,7 @@ class Markdown */ protected static function blockFencedCode(array $lineArray) : ?array { - if (!preg_match('/^[' . $lineArray['text'][0] . ']{3,}[ ]*([^`]+)?[ ]*$/', $lineArray['text'], $matches)) { + if (!\preg_match('/^[' . $lineArray['text'][0] . ']{3,}[ ]*([^`]+)?[ ]*$/', $lineArray['text'], $matches)) { return null; } @@ -487,8 +487,8 @@ class Markdown unset($block['interrupted']); } - if (preg_match('/^' . $block['char'] . '{3,}[ ]*$/', $lineArray['text'])) { - $block['element']['text']['text'] = substr($block['element']['text']['text'], 1); + if (\preg_match('/^' . $block['char'] . '{3,}[ ]*$/', $lineArray['text'])) { + $block['element']['text']['text'] = \substr($block['element']['text']['text'], 1); $block['complete'] = true; return $block; @@ -540,7 +540,7 @@ class Markdown return [ 'element' => [ 'name' => 'h' . min(6, $level), - 'text' => trim($lineArray['text'], '# '), + 'text' => \trim($lineArray['text'], '# '), 'handler' => 'line', ], ]; @@ -559,7 +559,7 @@ class Markdown { list($name, $pattern) = $lineArray['text'][0] <= '-' ? ['ul', '[*+-]'] : ['ol', '[0-9]+[.]']; - if (!preg_match('/^(' . $pattern . '[ ]+)(.*)/', $lineArray['text'], $matches)) { + if (!\preg_match('/^(' . $pattern . '[ ]+)(.*)/', $lineArray['text'], $matches)) { return null; } @@ -605,7 +605,7 @@ class Markdown */ protected static function blockListContinue(array $lineArray, array $block) : ?array { - if ($block['indent'] === $lineArray['indent'] && preg_match('/^' . $block['pattern'] . '(?:[ ]+(.*)|$)/', $lineArray['text'], $matches)) { + if ($block['indent'] === $lineArray['indent'] && \preg_match('/^' . $block['pattern'] . '(?:[ ]+(.*)|$)/', $lineArray['text'], $matches)) { if (isset($block['interrupted'])) { $block['li']['text'][] = ''; @@ -632,14 +632,14 @@ class Markdown } if (!isset($block['interrupted'])) { - $block['li']['text'][] = preg_replace('/^[ ]{0,4}/', '', $lineArray['body']); + $block['li']['text'][] = \preg_replace('/^[ ]{0,4}/', '', $lineArray['body']); return $block; } if ($lineArray['indent'] > 0) { $block['li']['text'][] = ''; - $block['li']['text'][] = preg_replace('/^[ ]{0,4}/', '', $lineArray['body']); + $block['li']['text'][] = \preg_replace('/^[ ]{0,4}/', '', $lineArray['body']); unset($block['interrupted']); @@ -660,7 +660,7 @@ class Markdown */ protected static function blockQuote(array $lineArray) : ?array { - if (!preg_match('/^>[ ]?(.*)/', $lineArray['text'], $matches)) { + if (!\preg_match('/^>[ ]?(.*)/', $lineArray['text'], $matches)) { return null; } @@ -685,7 +685,7 @@ class Markdown */ protected static function blockQuoteContinue(array $lineArray, array $block) : ?array { - if ($lineArray['text'][0] === '>' && preg_match('/^>[ ]?(.*)/', $lineArray['text'], $matches)) { + if ($lineArray['text'][0] === '>' && \preg_match('/^>[ ]?(.*)/', $lineArray['text'], $matches)) { if (isset($block['interrupted'])) { $block['element']['text'][] = ''; @@ -717,7 +717,7 @@ class Markdown */ protected static function blockRule(array $lineArray) : ?array { - if (!preg_match('/^([' . $lineArray['text'][0] . '])([ ]*\1){2,}[ ]*$/', $lineArray['text'])) { + if (!\preg_match('/^([' . $lineArray['text'][0] . '])([ ]*\1){2,}[ ]*$/', $lineArray['text'])) { return null; } @@ -764,7 +764,7 @@ class Markdown */ protected static function blockReference(array $lineArray) : ?array { - if (!preg_match('/^\[(.+?)\]:[ ]*?(?:[ ]+["\'(](.+)["\')])?[ ]*$/', $lineArray['text'], $matches)) { + if (!\preg_match('/^\[(.+?)\]:[ ]*?(?:[ ]+["\'(](.+)["\')])?[ ]*$/', $lineArray['text'], $matches)) { return null; } @@ -773,7 +773,7 @@ class Markdown 'title' => $matches[3] ?? null, ]; - self::$definitionData['Reference'][strtolower($matches[1])] = $data; + self::$definitionData['Reference'][\strtolower($matches[1])] = $data; return ['hidden' => true]; } @@ -794,15 +794,15 @@ class Markdown return null; } - if (strpos($block['element']['text'], '|') !== false && chop($lineArray['text'], ' -:|') === '') { + if (\strpos($block['element']['text'], '|') !== false && chop($lineArray['text'], ' -:|') === '') { $alignments = []; $divider = $lineArray['text']; - $divider = trim($divider); - $divider = trim($divider, '|'); - $dividerCells = explode('|', $divider); + $divider = \trim($divider); + $divider = \trim($divider, '|'); + $dividerCells = \explode('|', $divider); foreach ($dividerCells as $dividerCell) { - $dividerCell = trim($dividerCell); + $dividerCell = \trim($dividerCell); if ($dividerCell === '') { continue; @@ -823,14 +823,14 @@ class Markdown $headerElements = []; $header = $block['element']['text']; - $header = trim($header); - $header = trim($header, '|'); - $headerCells = explode('|', $header); + $header = \trim($header); + $header = \trim($header, '|'); + $headerCells = \explode('|', $header); foreach ($headerCells as $index => $headerCell) { $headerElement = [ 'name' => 'th', - 'text' => trim($headerCell), + 'text' => \trim($headerCell), 'handler' => 'line', ]; @@ -891,11 +891,11 @@ class Markdown return null; } - if ($lineArray['text'][0] === '|' || strpos($lineArray['text'], '|')) { + if ($lineArray['text'][0] === '|' || \strpos($lineArray['text'], '|')) { $elements = []; $row = $lineArray['text']; - $row = trim($row); - $row = trim($row, '|'); + $row = \trim($row); + $row = \trim($row, '|'); preg_match_all('/(?:(\\\\[|])|[^|`]|`[^`]+`|`)+/', $row, $matches); @@ -903,7 +903,7 @@ class Markdown $element = [ 'name' => 'td', 'handler' => 'line', - 'text' => trim($cell), + 'text' => \trim($cell), ]; if (isset($block['alignments'][$index])) { @@ -958,9 +958,9 @@ class Markdown { $markup = ''; - while ($excerpt = strpbrk($text, self::$inlineMarkerList)) { + while ($excerpt = \strpbrk($text, self::$inlineMarkerList)) { $marker = $excerpt[0]; - $markerPosition = strpos($text, $marker); + $markerPosition = \strpos($text, $marker); $excerptArray = ['text' => $excerpt, 'context' => $text]; foreach (self::$inlineTypes[$marker] as $inlineType) { @@ -978,17 +978,17 @@ class Markdown $inline['position'] = $markerPosition; } - $unmarkedText = substr($text, 0, $inline['position']); + $unmarkedText = \substr($text, 0, $inline['position']); $markup .= self::unmarkedText($unmarkedText); $markup .= isset($inline['markup']) ? $inline['markup'] : self::element($inline['element']); - $text = substr($text, $inline['position'] + $inline['extent']); + $text = \substr($text, $inline['position'] + $inline['extent']); continue 2; } - $unmarkedText = substr($text, 0, $markerPosition + 1); + $unmarkedText = \substr($text, 0, $markerPosition + 1); $markup .= self::unmarkedText($unmarkedText); - $text = substr($text, $markerPosition + 1); + $text = \substr($text, $markerPosition + 1); } $markup .= self::unmarkedText($text); @@ -1009,15 +1009,15 @@ class Markdown { $marker = $excerpt['text'][0]; - if (!preg_match('/^(' . $marker . '+)[ ]*(.+?)[ ]*(? strlen($matches[0]), + 'extent' => \strlen($matches[0]), 'element' => [ 'name' => 'code', - 'text' => preg_replace("/[ ]*\n/", ' ', $matches[2]), + 'text' => \preg_replace("/[ ]*\n/", ' ', $matches[2]), ], ]; } @@ -1033,7 +1033,7 @@ class Markdown */ protected static function inlineEmailTag(array $excerpt) : ?array { - if (strpos($excerpt['text'], '>') === false || !preg_match('/^<((mailto:)?\S+?@\S+?)>/i', $excerpt['text'], $matches)) { + if (\strpos($excerpt['text'], '>') === false || !\preg_match('/^<((mailto:)?\S+?@\S+?)>/i', $excerpt['text'], $matches)) { return null; } @@ -1044,7 +1044,7 @@ class Markdown } return [ - 'extent' => strlen($matches[0]), + 'extent' => \strlen($matches[0]), 'element' => [ 'name' => 'a', 'text' => $matches[1], @@ -1072,18 +1072,18 @@ class Markdown $marker = $excerpt['text'][0]; - if ($excerpt['text'][1] === $marker && isset(self::$strongRegex[$marker]) && preg_match(self::$strongRegex[$marker], $excerpt['text'], $matches)) { + if ($excerpt['text'][1] === $marker && isset(self::$strongRegex[$marker]) && \preg_match(self::$strongRegex[$marker], $excerpt['text'], $matches)) { $emphasis = 'strong'; - } elseif ($excerpt['text'][1] === $marker && isset(self::$underlineRegex[$marker]) && preg_match(self::$underlineRegex[$marker], $excerpt['text'], $matches)) { + } elseif ($excerpt['text'][1] === $marker && isset(self::$underlineRegex[$marker]) && \preg_match(self::$underlineRegex[$marker], $excerpt['text'], $matches)) { $emphasis = 'u'; - } elseif (preg_match(self::$emRegex[$marker], $excerpt['text'], $matches)) { + } elseif (\preg_match(self::$emRegex[$marker], $excerpt['text'], $matches)) { $emphasis = 'em'; } else { return null; } return [ - 'extent' => strlen($matches[0]), + 'extent' => \strlen($matches[0]), 'element' => [ 'name' => $emphasis, 'handler' => 'line', @@ -1103,7 +1103,7 @@ class Markdown */ protected static function inlineEscapeSequence(array $excerpt) : ?array { - if (!isset($excerpt['text'][1]) || !in_array($excerpt['text'][1], self::$specialCharacters)) { + if (!isset($excerpt['text'][1]) || !\in_array($excerpt['text'][1], self::$specialCharacters)) { return null; } @@ -1128,7 +1128,7 @@ class Markdown return null; } - $excerpt['text'] = substr($excerpt['text'], 1); + $excerpt['text'] = \substr($excerpt['text'], 1); $link = self::inlineLink($excerpt); if ($link === null) { @@ -1177,30 +1177,30 @@ class Markdown $extent = 0; $remainder = $excerpt['text']; - if (!preg_match('/\[((?:[^][]++|(?R))*+)\]/', $remainder, $matches)) { + if (!\preg_match('/\[((?:[^][]++|(?R))*+)\]/', $remainder, $matches)) { return null; } $element['text'] = $matches[1]; - $extent += strlen($matches[0]); - $remainder = substr($remainder, $extent); + $extent += \strlen($matches[0]); + $remainder = \substr($remainder, $extent); - if (preg_match('/^[(]\s*+((?:[^ ()]++|[(][^ )]+[)])++)(?:[ ]+("[^"]*"|\'[^\']*\'))?\s*[)]/', $remainder, $matches)) { + if (\preg_match('/^[(]\s*+((?:[^ ()]++|[(][^ )]+[)])++)(?:[ ]+("[^"]*"|\'[^\']*\'))?\s*[)]/', $remainder, $matches)) { $element['attributes']['href'] = $matches[1]; if (isset($matches[2])) { - $element['attributes']['title'] = substr($matches[2], 1, - 1); + $element['attributes']['title'] = \substr($matches[2], 1, - 1); } - $extent += strlen($matches[0]); + $extent += \strlen($matches[0]); } else { - if (preg_match('/^\s*\[(.*?)\]/', $remainder, $matches)) { - $definition = strlen($matches[1]) ? $matches[1] : $element['text']; - $definition = strtolower($definition); + if (\preg_match('/^\s*\[(.*?)\]/', $remainder, $matches)) { + $definition = \strlen($matches[1]) ? $matches[1] : $element['text']; + $definition = \strtolower($definition); - $extent += strlen($matches[0]); + $extent += \strlen($matches[0]); } else { - $definition = strtolower($element['text']); + $definition = \strtolower($element['text']); } if (!isset(self::$definitionData['Reference'][$definition])) { @@ -1230,7 +1230,7 @@ class Markdown */ protected static function inlineSpecialCharacter(array $excerpt) : ?array { - if ($excerpt['text'][0] === '&' && !preg_match('/^&#?\w+;/', $excerpt['text'])) { + if ($excerpt['text'][0] === '&' && !\preg_match('/^&#?\w+;/', $excerpt['text'])) { return [ 'markup' => '&', 'extent' => 1, @@ -1262,12 +1262,12 @@ class Markdown return null; } - if ($excerpt['text'][1] !== '~' || !preg_match('/^~~(?=\S)(.+?)(?<=\S)~~/', $excerpt['text'], $matches)) { + if ($excerpt['text'][1] !== '~' || !\preg_match('/^~~(?=\S)(.+?)(?<=\S)~~/', $excerpt['text'], $matches)) { return null; } return [ - 'extent' => strlen($matches[0]), + 'extent' => \strlen($matches[0]), 'element' => [ 'name' => 'del', 'text' => $matches[1], @@ -1291,12 +1291,12 @@ class Markdown return null; } - if (!preg_match('/\bhttps?:[\/]{2}[^\s<]+\b\/*/ui', $excerpt['context'], $matches, PREG_OFFSET_CAPTURE)) { + if (!\preg_match('/\bhttps?:[\/]{2}[^\s<]+\b\/*/ui', $excerpt['context'], $matches, PREG_OFFSET_CAPTURE)) { return null; } return [ - 'extent' => strlen($matches[0][0]), + 'extent' => \strlen($matches[0][0]), 'position' => $matches[0][1], 'element' => [ 'name' => 'a', @@ -1319,12 +1319,12 @@ class Markdown */ protected static function inlineUrlTag(array $excerpt) : ?array { - if (strpos($excerpt['text'], '>') === false || !preg_match('/^<(\w+:\/{2}[^ >]+)>/i', $excerpt['text'], $matches)) { + if (\strpos($excerpt['text'], '>') === false || !\preg_match('/^<(\w+:\/{2}[^ >]+)>/i', $excerpt['text'], $matches)) { return null; } return [ - 'extent' => strlen($matches[0]), + 'extent' => \strlen($matches[0]), 'element' => [ 'name' => 'a', 'text' => $matches[1], @@ -1346,8 +1346,8 @@ class Markdown */ protected static function unmarkedText(string $text) : string { - $text = preg_replace('/(?:[ ][ ]+|[ ]*\\\\)\n/', "
\n", $text); - $text = str_replace(" \n", "\n", $text); + $text = \preg_replace('/(?:[ ][ ]+|[ ]*\\\\)\n/', "
\n", $text); + $text = \str_replace(" \n", "\n", $text); return $text; } @@ -1421,13 +1421,13 @@ class Markdown protected static function li(array $lines) : string { $markup = self::lines($lines); - $trimmedMarkup = trim($markup); + $trimmedMarkup = \trim($markup); - if (!in_array('', $lines) && substr($trimmedMarkup, 0, 3) === '

') { + if (!\in_array('', $lines) && \substr($trimmedMarkup, 0, 3) === '

') { $markup = $trimmedMarkup; - $markup = substr($markup, 3); - $position = strpos($markup, '

'); - $markup = substr_replace($markup, '', $position, 4); + $markup = \substr($markup, 3); + $position = \strpos($markup, '

'); + $markup = \substr_replace($markup, '', $position, 4); } return $markup; @@ -1455,7 +1455,7 @@ class Markdown if (!empty($element['attributes'])) { foreach ($element['attributes'] as $att => $val) { - if (!preg_match('/^[a-zA-Z0-9][a-zA-Z0-9-_]*+$/', $att)) { + if (!\preg_match('/^[a-zA-Z0-9][a-zA-Z0-9-_]*+$/', $att)) { unset($element['attributes'][$att]); } elseif (self::striAtStart($att, 'on')) { unset($element['attributes'][$att]); @@ -1484,7 +1484,7 @@ class Markdown } } - $element['attributes'][$attribute] = str_replace(':', '%3A', $element['attributes'][$attribute]); + $element['attributes'][$attribute] = \str_replace(':', '%3A', $element['attributes'][$attribute]); return $element; } @@ -1501,7 +1501,7 @@ class Markdown */ protected static function escape(string $text, bool $allowQuotes = false) : string { - return htmlspecialchars($text, $allowQuotes ? ENT_NOQUOTES : ENT_QUOTES, 'UTF-8'); + return \htmlspecialchars($text, $allowQuotes ? ENT_NOQUOTES : ENT_QUOTES, 'UTF-8'); } /** @@ -1516,12 +1516,12 @@ class Markdown */ protected static function striAtStart(string $string, string $needle) : bool { - $length = strlen($needle); + $length = \strlen($needle); - if ($length > strlen($string)) { + if ($length > \strlen($string)) { return false; } - return strtolower(substr($string, 0, $length)) === strtolower($needle); + return \strtolower(\substr($string, 0, $length)) === \strtolower($needle); } } diff --git a/Utils/Parser/Php/ArrayParser.php b/Utils/Parser/Php/ArrayParser.php index f09c877c3..ae98ed482 100644 --- a/Utils/Parser/Php/ArrayParser.php +++ b/Utils/Parser/Php/ArrayParser.php @@ -42,7 +42,7 @@ class ArrayParser foreach ($arr as $key => $val) { if (is_string($key)) { - $key = '\'' . str_replace('\'', '\\\'', $key) . '\''; + $key = '\'' . \str_replace('\'', '\\\'', $key) . '\''; } $stringify .= str_repeat(' ', $depth * 4) . $key . ' => ' . self::parseVariable($val, $depth + 1) . ',' . "\n"; @@ -66,7 +66,7 @@ class ArrayParser if (is_array($value)) { return ArrayParser::serializeArray($value, $depth); } elseif (is_string($value)) { - return '\'' . str_replace('\'', '\\\'', $value) . '\''; + return '\'' . \str_replace('\'', '\\\'', $value) . '\''; } elseif (is_scalar($value)) { return (string) $value; } elseif ($value === null) { diff --git a/Utils/RnG/Phone.php b/Utils/RnG/Phone.php index 1b696f784..c3ae1bba2 100644 --- a/Utils/RnG/Phone.php +++ b/Utils/RnG/Phone.php @@ -36,12 +36,13 @@ class Phone * * @since 1.0.0 */ - public static function generatePhone($isInt = true, $layout = ['struct' => '+$1 ($2) $3-$4', - 'size' => [null, - [3, 4], - [3, 5], - [3, 8],],], $countries = null) - { + public static function generatePhone( + $isInt = true, + $layout = [ + 'struct' => '+$1 ($2) $3-$4', + 'size' => [null, [3, 4], [3, 5], [3, 8],],], + $countries = null + ) { $numberString = $layout['struct']; if ($isInt) { @@ -49,13 +50,13 @@ class Phone $countries = ['de' => 49, 'us' => 1]; } - $numberString = str_replace('$1', $countries[array_keys($countries)[rand(0, count($countries))]], $numberString); + $numberString = \str_replace('$1', $countries[array_keys($countries)[rand(0, count($countries))]], $numberString); } $numberParts = substr_count($layout['struct'], '$'); for ($i = ($isInt ? 2 : 1); $i < $numberParts; ++$i) { - $numberString = str_replace( + $numberString = \str_replace( '$' . $i, StringUtils::generateString($layout['size'][$i - 1][0], $layout['size'][$i - 1][1], '0123456789'), $numberString ); diff --git a/Utils/RnG/Text.php b/Utils/RnG/Text.php index 16e96304d..706ea8667 100644 --- a/Utils/RnG/Text.php +++ b/Utils/RnG/Text.php @@ -196,7 +196,7 @@ class Text } } - $text = ltrim($text); + $text = \ltrim($text); if ($this->hasParagraphs) { $text = '

' . $text . '

'; diff --git a/Utils/StringUtils.php b/Utils/StringUtils.php index 8c5628be2..50c46f306 100644 --- a/Utils/StringUtils.php +++ b/Utils/StringUtils.php @@ -270,7 +270,7 @@ final class StringUtils if ($charlist === ' ') { return trim($string); } else { - $charlist = str_replace('/', '\/', preg_quote($charlist)); + $charlist = \str_replace('/', '\/', preg_quote($charlist)); return preg_replace('/(^[' . $charlist . ']+)|([ ' . $charlist . ']+$)/us', '', $string); } @@ -291,7 +291,7 @@ final class StringUtils if ($charlist === ' ') { return rtrim($string); } else { - $charlist = str_replace('/', '\/', preg_quote($charlist)); + $charlist = \str_replace('/', '\/', preg_quote($charlist)); return preg_replace('/([' . $charlist . ']+$)/us', '', $string); } @@ -310,9 +310,9 @@ final class StringUtils public static function mb_ltrim(string $string, string $charlist = ' ') : string { if ($charlist === ' ') { - return ltrim($string); + return \ltrim($string); } else { - $charlist = str_replace('/', '\/', preg_quote($charlist)); + $charlist = \str_replace('/', '\/', preg_quote($charlist)); return preg_replace('/(^[' . $charlist . ']+)/us', '', $string); } @@ -375,7 +375,7 @@ final class StringUtils * * @param string $input String to count chars. * - * @return array + * @return array * * @since 1.0.0 */ diff --git a/Utils/TaskSchedule/Cron.php b/Utils/TaskSchedule/Cron.php index 4ce9e3582..37171fee6 100644 --- a/Utils/TaskSchedule/Cron.php +++ b/Utils/TaskSchedule/Cron.php @@ -39,7 +39,7 @@ class Cron extends SchedulerAbstract */ private function run(string $cmd) : string { - $cmd = 'cd ' . escapeshellarg(dirname(self::$bin)) . ' && ' . basename(self::$bin) . ' ' . $cmd; + $cmd = 'cd ' . escapeshellarg(\dirname(self::$bin)) . ' && ' . basename(self::$bin) . ' ' . $cmd; $pipes = []; $desc = [ @@ -75,7 +75,7 @@ class Cron extends SchedulerAbstract */ private function normalize(string $raw) : string { - return str_replace("\r\n", "\n", $raw); + return \str_replace("\r\n", "\n", $raw); } /** @@ -83,7 +83,7 @@ class Cron extends SchedulerAbstract */ public function getAll() : array { - $lines = explode("\n", $this->normalize($this->run('-l'))); + $lines = \explode("\n", $this->normalize($this->run('-l'))); unset($lines[0]); $jobs = []; @@ -101,7 +101,7 @@ class Cron extends SchedulerAbstract */ public function getAllByName(string $name, bool $exact = true) : array { - $lines = explode("\n", $this->normalize($this->run('-l'))); + $lines = \explode("\n", $this->normalize($this->run('-l'))); unset($lines[0]); if ($exact) { @@ -118,7 +118,7 @@ class Cron extends SchedulerAbstract foreach ($lines as $line) { $csv = str_getcsv($line, ' '); - if ($line !== '' && strrpos($line, '#', -strlen($line)) === false && stripos($csv[5], $name) !== false) { + if ($line !== '' && strrpos($line, '#', -strlen($line)) === false && \stripos($csv[5], $name) !== false) { $jobs[] = CronJob::createWith($csv); } } diff --git a/Utils/TaskSchedule/Interval.php b/Utils/TaskSchedule/Interval.php index ef046d2d0..12864ba0c 100644 --- a/Utils/TaskSchedule/Interval.php +++ b/Utils/TaskSchedule/Interval.php @@ -116,7 +116,7 @@ class Interval implements \Serializable */ public function unserialize($serialized) { - $elements = explode(' ', trim($serialized)); + $elements = \explode(' ', trim($serialized)); $this->minute = $this->parseMinute($elements[0]); $this->hour = $this->parseHour($elements[1]); diff --git a/Utils/TaskSchedule/TaskScheduler.php b/Utils/TaskSchedule/TaskScheduler.php index 7b70eac91..6d76c6ba3 100644 --- a/Utils/TaskSchedule/TaskScheduler.php +++ b/Utils/TaskSchedule/TaskScheduler.php @@ -38,7 +38,7 @@ class TaskScheduler extends SchedulerAbstract */ private function run(string $cmd) : string { - $cmd = 'cd ' . escapeshellarg(dirname(self::$bin)) . ' && ' . basename(self::$bin) . ' ' . $cmd; + $cmd = 'cd ' . escapeshellarg(\dirname(self::$bin)) . ' && ' . basename(self::$bin) . ' ' . $cmd; $pipes = []; $desc = [ @@ -74,7 +74,7 @@ class TaskScheduler extends SchedulerAbstract */ private function normalize(string $raw) : string { - return str_replace("\r\n", "\n", $raw); + return \str_replace("\r\n", "\n", $raw); } /** @@ -82,7 +82,7 @@ class TaskScheduler extends SchedulerAbstract */ public function getAll() : array { - $lines = explode("\n", $this->normalize($this->run('/query /v /fo CSV'))); + $lines = \explode("\n", $this->normalize($this->run('/query /v /fo CSV'))); unset($lines[0]); $jobs = []; @@ -99,7 +99,7 @@ class TaskScheduler extends SchedulerAbstract public function getAllByName(string $name, bool $exact = true) : array { if ($exact) { - $lines = explode("\n", $this->normalize($this->run('/query /v /fo CSV /tn ' . escapeshellarg($name)))); + $lines = \explode("\n", $this->normalize($this->run('/query /v /fo CSV /tn ' . escapeshellarg($name)))); unset($lines[0]); $jobs = []; @@ -107,7 +107,7 @@ class TaskScheduler extends SchedulerAbstract $jobs[] = Schedule::createWith(str_getcsv($line)); } } else { - $lines = explode("\n", $this->normalize($this->run('/query /v /fo CSV'))); + $lines = \explode("\n", $this->normalize($this->run('/query /v /fo CSV'))); unset($lines[0]); $jobs = []; diff --git a/Validation/Finance/BIC.php b/Validation/Finance/BIC.php index 6160e0b4d..b61139b65 100644 --- a/Validation/Finance/BIC.php +++ b/Validation/Finance/BIC.php @@ -32,6 +32,6 @@ final class BIC extends ValidatorAbstract */ public static function isValid($value, array $constraints = null) : bool { - return (bool) preg_match('/^[a-z]{6}[0-9a-z]{2}([0-9a-z]{3})?\z/i', $value); + return (bool) \preg_match('/^[a-z]{6}[0-9a-z]{2}([0-9a-z]{3})?\z/i', $value); } } diff --git a/Validation/Finance/Iban.php b/Validation/Finance/Iban.php index d4e3ba549..00884dda2 100644 --- a/Validation/Finance/Iban.php +++ b/Validation/Finance/Iban.php @@ -31,7 +31,7 @@ final class Iban extends ValidatorAbstract */ public static function isValid($value, array $constraints = null) : bool { - $value = str_replace(' ', '', strtolower($value)); + $value = \str_replace(' ', '', strtolower($value)); $enumName = 'C_' . strtoupper(substr($value, 0, 2)); if (!IbanEnum::isValidName($enumName)) { @@ -40,7 +40,7 @@ final class Iban extends ValidatorAbstract return false; } - $layout = str_replace(' ', '', IbanEnum::getByName($enumName)); + $layout = \str_replace(' ', '', IbanEnum::getByName($enumName)); if (strlen($value) !== strlen($layout)) { self::$error = IbanErrorType::INVALID_LENGTH; diff --git a/Validation/Validator.php b/Validation/Validator.php index bebc2e2f3..090156223 100644 --- a/Validation/Validator.php +++ b/Validation/Validator.php @@ -136,7 +136,7 @@ final class Validator extends ValidatorAbstract */ public static function matches(string $var, string $pattern) : bool { - return (preg_match($pattern, $var) === 1 ? true : false); + return (\preg_match($pattern, $var) === 1 ? true : false); } /** diff --git a/Views/ViewAbstract.php b/Views/ViewAbstract.php index 398c7fce5..8861a24ab 100644 --- a/Views/ViewAbstract.php +++ b/Views/ViewAbstract.php @@ -203,7 +203,7 @@ abstract class ViewAbstract implements \Serializable public function serialize() : string { if (empty($this->template)) { - return json_encode($this->toArray()); + return \json_encode($this->toArray()); } return $this->render(); @@ -245,7 +245,7 @@ abstract class ViewAbstract implements \Serializable $ob = ''; $path = __DIR__ . '/../..' . $this->template . '.tpl.php'; - if (!file_exists($path)) { + if (!\file_exists($path)) { throw new PathException($path); } @@ -256,7 +256,7 @@ abstract class ViewAbstract implements \Serializable $ob = ob_get_clean(); if (is_array($includeData)) { - return json_encode($includeData); + return \json_encode($includeData); } } catch (\Throwable $e) { $ob = ''; diff --git a/tests/Account/AccountTest.php b/tests/Account/AccountTest.php index 464f2e33a..5e6b16cc5 100644 --- a/tests/Account/AccountTest.php +++ b/tests/Account/AccountTest.php @@ -98,7 +98,7 @@ class AccountTest extends \PHPUnit\Framework\TestCase $array = $account->toArray(); self::assertTrue(is_array($array)); self::assertGreaterThan(0, count($array)); - self::assertEquals(json_encode($array), $account->__toString()); + self::assertEquals(\json_encode($array), $account->__toString()); self::assertEquals($array, $account->jsonSerialize()); } diff --git a/tests/Account/GroupTest.php b/tests/Account/GroupTest.php index da556fe50..e2b163c75 100644 --- a/tests/Account/GroupTest.php +++ b/tests/Account/GroupTest.php @@ -55,7 +55,7 @@ class GroupTest extends \PHPUnit\Framework\TestCase $array = $group->toArray(); self::assertTrue(is_array($array)); self::assertGreaterThan(0, count($array)); - self::assertEquals(json_encode($array), $group->__toString()); + self::assertEquals(\json_encode($array), $group->__toString()); self::assertEquals($array, $group->jsonSerialize()); } diff --git a/tests/Autoloader.php b/tests/Autoloader.php index 932dc5218..14d7d1998 100644 --- a/tests/Autoloader.php +++ b/tests/Autoloader.php @@ -42,10 +42,10 @@ class Autoloader */ public static function defaultAutoloader(string $class) : void { - $class = ltrim($class, '\\'); - $class = str_replace(['_', '\\'], '/', $class); + $class = \ltrim($class, '\\'); + $class = \str_replace(['_', '\\'], '/', $class); - if (!file_exists($path = __DIR__ . '/../../' . $class . '.php')) { + if (!\file_exists($path = __DIR__ . '/../../' . $class . '.php')) { return; } @@ -66,9 +66,9 @@ class Autoloader */ public static function exists(string $class) : bool { - $class = ltrim($class, '\\'); - $class = str_replace(['_', '\\'], '/', $class); + $class = \ltrim($class, '\\'); + $class = \str_replace(['_', '\\'], '/', $class); - return file_exists(__DIR__ . '/../../' . $class . '.php'); + return \file_exists(__DIR__ . '/../../' . $class . '.php'); } } diff --git a/tests/DataStorage/Database/TestModel/BaseModelMapper.php b/tests/DataStorage/Database/TestModel/BaseModelMapper.php index 2eccc4fb8..8b7a423c6 100644 --- a/tests/DataStorage/Database/TestModel/BaseModelMapper.php +++ b/tests/DataStorage/Database/TestModel/BaseModelMapper.php @@ -24,7 +24,7 @@ class BaseModelMapper extends DataMapperAbstract /** * Columns. * - * @var array + * @var array> * @since 1.0.0 */ protected static $columns = [ diff --git a/tests/DataStorage/Database/TestModel/BelongsToModelMapper.php b/tests/DataStorage/Database/TestModel/BelongsToModelMapper.php index 716cea1ad..b4c3f80e0 100644 --- a/tests/DataStorage/Database/TestModel/BelongsToModelMapper.php +++ b/tests/DataStorage/Database/TestModel/BelongsToModelMapper.php @@ -24,7 +24,7 @@ class BelongsToModelMapper extends DataMapperAbstract /** * Columns. * - * @var array + * @var array> * @since 1.0.0 */ protected static $columns = [ diff --git a/tests/DataStorage/Database/TestModel/ManyToManyDirectModelMapper.php b/tests/DataStorage/Database/TestModel/ManyToManyDirectModelMapper.php index 897cdd7ea..1b53fe5ad 100644 --- a/tests/DataStorage/Database/TestModel/ManyToManyDirectModelMapper.php +++ b/tests/DataStorage/Database/TestModel/ManyToManyDirectModelMapper.php @@ -24,7 +24,7 @@ class ManyToManyDirectModelMapper extends DataMapperAbstract /** * Columns. * - * @var array + * @var array> * @since 1.0.0 */ protected static $columns = [ diff --git a/tests/DataStorage/Database/TestModel/ManyToManyRelModelMapper.php b/tests/DataStorage/Database/TestModel/ManyToManyRelModelMapper.php index f8b8bdfd3..799c8b71a 100644 --- a/tests/DataStorage/Database/TestModel/ManyToManyRelModelMapper.php +++ b/tests/DataStorage/Database/TestModel/ManyToManyRelModelMapper.php @@ -24,7 +24,7 @@ class ManyToManyRelModelMapper extends DataMapperAbstract /** * Columns. * - * @var array + * @var array> * @since 1.0.0 */ protected static $columns = [ diff --git a/tests/DataStorage/Database/TestModel/OwnsOneModelMapper.php b/tests/DataStorage/Database/TestModel/OwnsOneModelMapper.php index ab137f620..136120e02 100644 --- a/tests/DataStorage/Database/TestModel/OwnsOneModelMapper.php +++ b/tests/DataStorage/Database/TestModel/OwnsOneModelMapper.php @@ -24,7 +24,7 @@ class OwnsOneModelMapper extends DataMapperAbstract /** * Columns. * - * @var array + * @var array> * @since 1.0.0 */ protected static $columns = [ diff --git a/tests/Localization/Defaults/CityMapperTest.php b/tests/Localization/Defaults/CityMapperTest.php new file mode 100644 index 000000000..376386a12 --- /dev/null +++ b/tests/Localization/Defaults/CityMapperTest.php @@ -0,0 +1,23 @@ +getName()); + self::assertEquals('', $obj->getCountryCode()); + self::assertEquals('', $obj->getState()); + self::assertEquals(0, $obj->getPostal()); + self::assertEquals(0.0, $obj->getLat()); + self::assertEquals(0.0, $obj->getLong()); + } +} diff --git a/tests/Localization/Defaults/CountryMapperTest.php b/tests/Localization/Defaults/CountryMapperTest.php new file mode 100644 index 000000000..629f35676 --- /dev/null +++ b/tests/Localization/Defaults/CountryMapperTest.php @@ -0,0 +1,23 @@ +getName()); + self::assertEquals('', $obj->getCode2()); + self::assertEquals('', $obj->getCode3()); + self::assertEquals(0, $obj->getNumeric()); + self::assertEquals('', $obj->getSubdevision()); + } +} diff --git a/tests/Localization/Defaults/CurrencyMapperTest.php b/tests/Localization/Defaults/CurrencyMapperTest.php new file mode 100644 index 000000000..e80f7f9a9 --- /dev/null +++ b/tests/Localization/Defaults/CurrencyMapperTest.php @@ -0,0 +1,23 @@ +getName()); + self::assertEquals(0, $obj->getNumber()); + self::assertEquals(0, $obj->getDecimals()); + self::assertEquals('', $obj->getCountries()); + } +} diff --git a/tests/Localization/Defaults/IbanMapperTest.php b/tests/Localization/Defaults/IbanMapperTest.php new file mode 100644 index 000000000..080f03bf4 --- /dev/null +++ b/tests/Localization/Defaults/IbanMapperTest.php @@ -0,0 +1,23 @@ +getCountry()); + self::assertEquals('', $obj->getChars()); + self::assertEquals('', $obj->getBban()); + self::assertEquals('', $obj->getFields()); + } +} diff --git a/tests/Localization/Defaults/LanguageMapperTest.php b/tests/Localization/Defaults/LanguageMapperTest.php new file mode 100644 index 000000000..c9a9c0f67 --- /dev/null +++ b/tests/Localization/Defaults/LanguageMapperTest.php @@ -0,0 +1,23 @@ +getName()); + self::assertEquals('', $obj->getNative()); + self::assertEquals('', $obj->getCode2()); + self::assertEquals('', $obj->getCode3()); + } +} diff --git a/tests/Math/Geometry/Shape/D2/TriangleTest.php b/tests/Math/Geometry/Shape/D2/TriangleTest.php index 0be4b4cf0..520e1bd42 100644 --- a/tests/Math/Geometry/Shape/D2/TriangleTest.php +++ b/tests/Math/Geometry/Shape/D2/TriangleTest.php @@ -22,5 +22,6 @@ class TriangleTest extends \PHPUnit\Framework\TestCase self::assertEquals(3, Triangle::getSurface(2, 3), '', 0.001); self::assertEquals(9, Triangle::getPerimeter(2, 3, 4), '', 0.001); self::assertEquals(3, Triangle::getHeight(3, 2), '', 0.001); + self::assertEquals(5, Triangle::getHypot(4, 3), '', 0.001); } } diff --git a/tests/Math/Geometry/Shape/D3/SphereTest.php b/tests/Math/Geometry/Shape/D3/SphereTest.php index 40dcc846e..0b4df8858 100644 --- a/tests/Math/Geometry/Shape/D3/SphereTest.php +++ b/tests/Math/Geometry/Shape/D3/SphereTest.php @@ -22,6 +22,8 @@ class SphereTest extends \PHPUnit\Framework\TestCase $sphere = new Sphere(3); self::assertEquals(113.1, $sphere->getVolume(), '', 0.1); self::assertEquals(113.1, $sphere->getSurface(), '', 0.1); + + self::assertEquals(422740, Sphere::distance2PointsOnSphere(32.9697, -96.80322, 29.46786, -98.53506), '', 50); } public function testGetBy() diff --git a/tests/Math/Optimization/AssignmentProblemTest.php b/tests/Math/Optimization/AssignmentProblemTest.php deleted file mode 100644 index 34e89c7df..000000000 --- a/tests/Math/Optimization/AssignmentProblemTest.php +++ /dev/null @@ -1,24 +0,0 @@ -getName()); - self::assertEquals((float) 0, $obj->getLatitude()); - self::assertEquals((float) 0, $obj->getLongitude()); - self::assertTrue($obj->equals(new City())); - self::assertEquals(0, $obj->getDistanceTo(new City())); - } - - public function testGetSet() - { - $obj = new City(10, 20, 'A'); - self::assertEquals('A', $obj->getName()); - self::assertEquals((float) 10, $obj->getLatitude()); - self::assertEquals((float) 20, $obj->getLongitude()); - self::assertTrue(abs(2476171 - $obj->getDistanceTo(new City())) < 1); - self::assertFalse($obj->equals(new City())); - } -} diff --git a/tests/Math/Optimization/TSP/GATest.php b/tests/Math/Optimization/TSP/GATest.php deleted file mode 100644 index b673a791e..000000000 --- a/tests/Math/Optimization/TSP/GATest.php +++ /dev/null @@ -1,33 +0,0 @@ -evolvePopulation($basePopulation); - - } -} diff --git a/tests/Math/Optimization/TSP/PopulationTest.php b/tests/Math/Optimization/TSP/PopulationTest.php deleted file mode 100644 index 80bb4e78d..000000000 --- a/tests/Math/Optimization/TSP/PopulationTest.php +++ /dev/null @@ -1,24 +0,0 @@ -getCity(1)); - self::assertEquals(0.0, $obj->getFitness()); - self::assertEquals(0.0, $obj->getDistance()); - self::assertFalse($obj->hasCity(new City())); - self::assertEquals(0, $obj->count()); - } -} diff --git a/tests/Math/Optimization/TransportationProblemTest.php b/tests/Math/Optimization/TransportationProblemTest.php deleted file mode 100644 index 711dd7658..000000000 --- a/tests/Math/Optimization/TransportationProblemTest.php +++ /dev/null @@ -1,24 +0,0 @@ -setMethod(RequestMethod::POST); self::assertTrue($request->setData('pdata', 'abc')); - self::assertEquals('abc', json_decode(REST::request($request), true)['form']['pdata']); + self::assertEquals('abc', \json_decode(REST::request($request), true)['form']['pdata']); } public function testPut() @@ -45,7 +45,7 @@ class RestTest extends \PHPUnit\Framework\TestCase $request = new Request(new Http('http://httpbin.org/put')); $request->setMethod(RequestMethod::PUT); self::assertTrue($request->setData('pdata', 'abc')); - self::assertEquals('abc', json_decode(REST::request($request), true)['form']['pdata']); + self::assertEquals('abc', \json_decode(REST::request($request), true)['form']['pdata']); } public function testDelete() @@ -53,7 +53,7 @@ class RestTest extends \PHPUnit\Framework\TestCase $request = new Request(new Http('http://httpbin.org/delete')); $request->setMethod(RequestMethod::DELETE); self::assertTrue($request->setData('ddata', 'abc')); - self::assertEquals('abc', json_decode(REST::request($request), true)['form']['ddata']); + self::assertEquals('abc', \json_decode(REST::request($request), true)['form']['ddata']); } public function testGet() @@ -61,6 +61,6 @@ class RestTest extends \PHPUnit\Framework\TestCase $request = new Request(new Http('http://httpbin.org/get')); $request->setMethod(RequestMethod::GET); self::assertTrue($request->setData('gdata', 'abc')); - self::assertEquals('abc', json_decode(REST::request($request), true)['args']['gdata']); + self::assertEquals('abc', \json_decode(REST::request($request), true)['args']['gdata']); } } diff --git a/tests/Module/InfoManagerTest.php b/tests/Module/InfoManagerTest.php index 39c35cf77..6ac7d988c 100644 --- a/tests/Module/InfoManagerTest.php +++ b/tests/Module/InfoManagerTest.php @@ -24,7 +24,7 @@ class InfoManagerTest extends \PHPUnit\Framework\TestCase $info = new InfoManager(__DIR__ . '/info-test.json'); $info->load(); - $jarray = json_decode(file_get_contents(__DIR__ . '/info-test.json'), true); + $jarray = \json_decode(file_get_contents(__DIR__ . '/info-test.json'), true); self::assertEquals($jarray, $info->get()); self::assertEquals($jarray['name']['internal'], $info->getInternalName()); diff --git a/tests/Security/PhpCodeTest.php b/tests/Security/PhpCodeTest.php index 2a9116244..583198aeb 100644 --- a/tests/Security/PhpCodeTest.php +++ b/tests/Security/PhpCodeTest.php @@ -24,7 +24,7 @@ class RouteVerbTest extends \PHPUnit\Framework\TestCase self::assertTrue( PhpCode::hasUnicode( PhpCode::normalizeSource( - file_get_contents(__DIR__ . '/Sample/hasUnicode.php') + \file_get_contents(__DIR__ . '/Sample/hasUnicode.php') ) ) ); @@ -32,7 +32,7 @@ class RouteVerbTest extends \PHPUnit\Framework\TestCase self::assertFalse( PhpCode::hasUnicode( PhpCode::normalizeSource( - file_get_contents(__DIR__ . '/Sample/noUnicode.php') + \file_get_contents(__DIR__ . '/Sample/noUnicode.php') ) ) ); @@ -49,7 +49,7 @@ class RouteVerbTest extends \PHPUnit\Framework\TestCase self::assertTrue( PhpCode::hasDeprecatedFunction( PhpCode::normalizeSource( - file_get_contents(__DIR__ . '/Sample/hasDeprecated.php') + \file_get_contents(__DIR__ . '/Sample/hasDeprecated.php') ) ) ); @@ -57,7 +57,7 @@ class RouteVerbTest extends \PHPUnit\Framework\TestCase self::assertFalse( PhpCode::hasDeprecatedFunction( PhpCode::normalizeSource( - file_get_contents(__DIR__ . '/Sample/noDeprecated.php') + \file_get_contents(__DIR__ . '/Sample/noDeprecated.php') ) ) ); diff --git a/tests/System/File/Ftp/DirectoryTest.php b/tests/System/File/Ftp/DirectoryTest.php index 769a7c5bf..43411d9cb 100644 --- a/tests/System/File/Ftp/DirectoryTest.php +++ b/tests/System/File/Ftp/DirectoryTest.php @@ -38,7 +38,7 @@ class DirectoryTest extends \PHPUnit\Framework\TestCase self::assertEquals('test', Directory::name($dirPath)); self::assertEquals('test', Directory::basename($dirPath)); self::assertEquals('test', Directory::dirname($dirPath)); - self::assertEquals(str_replace('\\', '/', realpath($dirPath . '/../')), Directory::parent($dirPath)); + self::assertEquals(\str_replace('\\', '/', realpath($dirPath . '/../')), Directory::parent($dirPath)); self::assertEquals($dirPath, Directory::dirpath($dirPath)); $now = new \DateTime('now'); diff --git a/tests/System/File/Ftp/FileTest.php b/tests/System/File/Ftp/FileTest.php index 872ee27d2..bc5ba193b 100644 --- a/tests/System/File/Ftp/FileTest.php +++ b/tests/System/File/Ftp/FileTest.php @@ -44,7 +44,7 @@ class FileTest extends \PHPUnit\Framework\TestCase self::assertTrue(File::prepend($testFile, 'test5')); self::assertEquals('test5test3test4', File::get($testFile)); - self::assertEquals(str_replace('\\', '/', realpath(dirname($testFile) . '/../')), File::parent($testFile)); + self::assertEquals(\str_replace('\\', '/', realpath(\dirname($testFile) . '/../')), File::parent($testFile)); self::assertEquals('txt', File::extension($testFile)); self::assertEquals('test', File::name($testFile)); self::assertEquals('test.txt', File::basename($testFile)); diff --git a/tests/System/File/Ftp/FtpStorageTest.php b/tests/System/File/Ftp/FtpStorageTest.php index aea4d6ba4..511cacefe 100644 --- a/tests/System/File/Ftp/FtpStorageTest.php +++ b/tests/System/File/Ftp/FtpStorageTest.php @@ -44,7 +44,7 @@ class FtpStorageTest extends \PHPUnit\Framework\TestCase self::assertTrue(FtpStorage::prepend($testFile, 'test5')); self::assertEquals('test5test3test4', FtpStorage::get($testFile)); - self::assertEquals(str_replace('\\', '/', realpath(dirname($testFile) . '/../')), FtpStorage::parent($testFile)); + self::assertEquals(\str_replace('\\', '/', realpath(\dirname($testFile) . '/../')), FtpStorage::parent($testFile)); self::assertEquals('txt', FtpStorage::extension($testFile)); self::assertEquals('test', FtpStorage::name($testFile)); self::assertEquals('test.txt', FtpStorage::basename($testFile)); @@ -103,7 +103,7 @@ class FtpStorageTest extends \PHPUnit\Framework\TestCase self::assertEquals('test', FtpStorage::name($dirPath)); self::assertEquals('test', FtpStorage::basename($dirPath)); self::assertEquals('test', FtpStorage::dirname($dirPath)); - self::assertEquals(str_replace('\\', '/', realpath($dirPath . '/../')), FtpStorage::parent($dirPath)); + self::assertEquals(\str_replace('\\', '/', realpath($dirPath . '/../')), FtpStorage::parent($dirPath)); self::assertEquals($dirPath, FtpStorage::dirpath($dirPath)); $now = new \DateTime('now'); diff --git a/tests/System/File/Local/DirectoryTest.php b/tests/System/File/Local/DirectoryTest.php index 59ca84f90..9728b1210 100644 --- a/tests/System/File/Local/DirectoryTest.php +++ b/tests/System/File/Local/DirectoryTest.php @@ -31,7 +31,7 @@ class DirectoryTest extends \PHPUnit\Framework\TestCase self::assertEquals('test', Directory::name($dirPath)); self::assertEquals('test', Directory::basename($dirPath)); self::assertEquals('test', Directory::dirname($dirPath)); - self::assertEquals(str_replace('\\', '/', realpath($dirPath . '/../')), Directory::parent($dirPath)); + self::assertEquals(\str_replace('\\', '/', realpath($dirPath . '/../')), Directory::parent($dirPath)); self::assertEquals($dirPath, Directory::dirpath($dirPath)); $now = new \DateTime('now'); diff --git a/tests/System/File/Local/FileTest.php b/tests/System/File/Local/FileTest.php index 0abb34982..a834ed91d 100644 --- a/tests/System/File/Local/FileTest.php +++ b/tests/System/File/Local/FileTest.php @@ -37,7 +37,7 @@ class FileTest extends \PHPUnit\Framework\TestCase self::assertTrue(File::prepend($testFile, 'test5')); self::assertEquals('test5test3test4', File::get($testFile)); - self::assertEquals(str_replace('\\', '/', realpath(dirname($testFile) . '/../')), File::parent($testFile)); + self::assertEquals(\str_replace('\\', '/', realpath(\dirname($testFile) . '/../')), File::parent($testFile)); self::assertEquals('txt', File::extension($testFile)); self::assertEquals('test', File::name($testFile)); self::assertEquals('test.txt', File::basename($testFile)); diff --git a/tests/System/File/Local/LocalStorageTest.php b/tests/System/File/Local/LocalStorageTest.php index e0854366f..37b4a37ca 100644 --- a/tests/System/File/Local/LocalStorageTest.php +++ b/tests/System/File/Local/LocalStorageTest.php @@ -37,7 +37,7 @@ class LocalStorageTest extends \PHPUnit\Framework\TestCase self::assertTrue(LocalStorage::prepend($testFile, 'test5')); self::assertEquals('test5test3test4', LocalStorage::get($testFile)); - self::assertEquals(str_replace('\\', '/', realpath(dirname($testFile) . '/../')), LocalStorage::parent($testFile)); + self::assertEquals(\str_replace('\\', '/', realpath(\dirname($testFile) . '/../')), LocalStorage::parent($testFile)); self::assertEquals('txt', LocalStorage::extension($testFile)); self::assertEquals('test', LocalStorage::name($testFile)); self::assertEquals('test.txt', LocalStorage::basename($testFile)); @@ -92,7 +92,7 @@ class LocalStorageTest extends \PHPUnit\Framework\TestCase self::assertEquals('test', LocalStorage::name($dirPath)); self::assertEquals('test', LocalStorage::basename($dirPath)); self::assertEquals('test', LocalStorage::dirname($dirPath)); - self::assertEquals(str_replace('\\', '/', realpath($dirPath . '/../')), LocalStorage::parent($dirPath)); + self::assertEquals(\str_replace('\\', '/', realpath($dirPath . '/../')), LocalStorage::parent($dirPath)); self::assertEquals($dirPath, LocalStorage::dirpath($dirPath)); $now = new \DateTime('now'); diff --git a/tests/Utils/Git/RepositoryTest.php b/tests/Utils/Git/RepositoryTest.php index 35b878de7..fe9f2e9a4 100644 --- a/tests/Utils/Git/RepositoryTest.php +++ b/tests/Utils/Git/RepositoryTest.php @@ -21,7 +21,7 @@ class RepositoryTest extends \PHPUnit\Framework\TestCase { $repo = new Repository(realpath(__DIR__ . '/../../../')); self::assertTrue('phpOMS' === $repo->getName() || 'build' === $repo->getName()); - self::assertEquals(str_replace('\\', '/', realpath(__DIR__ . '/../../../.git')), str_replace('\\', '/', $repo->getDirectoryPath())); + self::assertEquals(\str_replace('\\', '/', realpath(__DIR__ . '/../../../.git')), \str_replace('\\', '/', $repo->getDirectoryPath())); self::assertEquals(realpath(__DIR__ . '/../../../'), $repo->getPath()); } } diff --git a/tests/Utils/IO/Zip/ZipTest.php b/tests/Utils/IO/Zip/ZipTest.php index 045ce337f..90e2b4a87 100644 --- a/tests/Utils/IO/Zip/ZipTest.php +++ b/tests/Utils/IO/Zip/ZipTest.php @@ -39,11 +39,11 @@ class ZipTest extends \PHPUnit\Framework\TestCase false )); - $a = file_get_contents(__DIR__ . '/test a.txt'); - $b = file_get_contents(__DIR__ . '/test b.md'); - $c = file_get_contents(__DIR__ . '/test/test c.txt'); - $d = file_get_contents(__DIR__ . '/test/test d.txt'); - $e = file_get_contents(__DIR__ . '/test/sub/test e.txt'); + $a = \file_get_contents(__DIR__ . '/test a.txt'); + $b = \file_get_contents(__DIR__ . '/test b.md'); + $c = \file_get_contents(__DIR__ . '/test/test c.txt'); + $d = \file_get_contents(__DIR__ . '/test/test d.txt'); + $e = \file_get_contents(__DIR__ . '/test/sub/test e.txt'); unlink(__DIR__ . '/test a.txt'); unlink(__DIR__ . '/test b.md'); @@ -71,11 +71,11 @@ class ZipTest extends \PHPUnit\Framework\TestCase self::assertTrue(file_exists(__DIR__ . '/test/sub')); self::assertTrue(file_exists(__DIR__ . '/test')); - self::assertEquals($a, file_get_contents(__DIR__ . '/test a.txt')); - self::assertEquals($b, file_get_contents(__DIR__ . '/test b.md')); - self::assertEquals($c, file_get_contents(__DIR__ . '/test/test c.txt')); - self::assertEquals($d, file_get_contents(__DIR__ . '/test/test d.txt')); - self::assertEquals($e, file_get_contents(__DIR__ . '/test/sub/test e.txt')); + self::assertEquals($a, \file_get_contents(__DIR__ . '/test a.txt')); + self::assertEquals($b, \file_get_contents(__DIR__ . '/test b.md')); + self::assertEquals($c, \file_get_contents(__DIR__ . '/test/test c.txt')); + self::assertEquals($d, \file_get_contents(__DIR__ . '/test/test d.txt')); + self::assertEquals($e, \file_get_contents(__DIR__ . '/test/sub/test e.txt')); unlink(__DIR__ . '/test.zip'); self::assertFalse(file_exists(__DIR__ . '/test.zip')); diff --git a/tests/Utils/ImageUtilsTest.php b/tests/Utils/ImageUtilsTest.php index 9eaf0bfa8..6df0cb339 100644 --- a/tests/Utils/ImageUtilsTest.php +++ b/tests/Utils/ImageUtilsTest.php @@ -22,7 +22,7 @@ class ImageUtilsTest extends \PHPUnit\Framework\TestCase public function testImage() { self::assertEquals( - file_get_contents(__DIR__ . '/logo.png'), + \file_get_contents(__DIR__ . '/logo.png'), ImageUtils::decodeBase64Image( '' ) diff --git a/tests/Utils/JsonBuilderTest.php b/tests/Utils/JsonBuilderTest.php index 423c5031f..21cfed82b 100644 --- a/tests/Utils/JsonBuilderTest.php +++ b/tests/Utils/JsonBuilderTest.php @@ -39,7 +39,7 @@ class JsonBuilderTest extends \PHPUnit\Framework\TestCase $arr = $builder->getJson(); self::assertEquals($arr, $builder->jsonSerialize()); - self::assertEquals(json_encode($arr), $builder->serialize()); + self::assertEquals(\json_encode($arr), $builder->serialize()); $builder->unserialize($builder->serialize()); self::assertEquals($arr, $builder->getJson()); diff --git a/tests/Utils/Parser/LaTex/Expressions/ProductTest.php b/tests/Utils/Parser/LaTex/Expressions/ProductTest.php deleted file mode 100644 index ab083ca16..000000000 --- a/tests/Utils/Parser/LaTex/Expressions/ProductTest.php +++ /dev/null @@ -1,24 +0,0 @@ -