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('/^\[(.+?)\]:[ ]*(\S+?)>?(?:[ ]+["\'(](.+)["\')])?[ ]*$/', $lineArray['text'], $matches)) {
+ if (!\preg_match('/^\[(.+?)\]:[ ]*(\S+?)>?(?:[ ]+["\'(](.+)["\')])?[ ]*$/', $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 @@
-