![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/mautic.corals.io/vendor/doctrine/orm/src/Query/Expr/ |
<?php declare(strict_types=1); namespace Doctrine\ORM\Query\Expr; use function count; use function implode; /** * Expression class for building DQL Order By parts. * * @link www.doctrine-project.org */ class OrderBy { /** @var string */ protected $preSeparator = ''; /** @var string */ protected $separator = ', '; /** @var string */ protected $postSeparator = ''; /** @var string[] */ protected $allowedClasses = []; /** @psalm-var list<string> */ protected $parts = []; /** * @param string|null $sort * @param string|null $order */ public function __construct($sort = null, $order = null) { if ($sort) { $this->add($sort, $order); } } /** * @param string $sort * @param string|null $order * * @return void */ public function add($sort, $order = null) { $order = ! $order ? 'ASC' : $order; $this->parts[] = $sort . ' ' . $order; } /** * @return int * @psalm-return 0|positive-int */ public function count() { return count($this->parts); } /** @psalm-return list<string> */ public function getParts() { return $this->parts; } /** @return string */ public function __toString() { return $this->preSeparator . implode($this->separator, $this->parts) . $this->postSeparator; } }