vendor/doctrine/orm/lib/Doctrine/ORM/Query/Expr/OrderBy.php line 31

Open in your IDE?
  1. <?php
  2. /*
  3.  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  4.  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  5.  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  6.  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  7.  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  8.  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  9.  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  10.  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  11.  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  12.  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  13.  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  14.  *
  15.  * This software consists of voluntary contributions made by many individuals
  16.  * and is licensed under the MIT license. For more information, see
  17.  * <http://www.doctrine-project.org>.
  18.  */
  19. namespace Doctrine\ORM\Query\Expr;
  20. /**
  21.  * Expression class for building DQL Order By parts.
  22.  *
  23.  * @link    www.doctrine-project.org
  24.  * @since   2.0
  25.  * @author  Guilherme Blanco <guilhermeblanco@hotmail.com>
  26.  * @author  Jonathan Wage <jonwage@gmail.com>
  27.  * @author  Roman Borschel <roman@code-factory.org>
  28.  */
  29. class OrderBy
  30. {
  31.     /**
  32.      * @var string
  33.      */
  34.     protected $preSeparator '';
  35.     /**
  36.      * @var string
  37.      */
  38.     protected $separator ', ';
  39.     /**
  40.      * @var string
  41.      */
  42.     protected $postSeparator '';
  43.     /**
  44.      * @var array
  45.      */
  46.     protected $allowedClasses = [];
  47.     /**
  48.      * @var array
  49.      */
  50.     protected $parts = [];
  51.     /**
  52.      * @param string|null $sort
  53.      * @param string|null $order
  54.      */
  55.     public function __construct($sort null$order null)
  56.     {
  57.         if ($sort) {
  58.             $this->add($sort$order);
  59.         }
  60.     }
  61.     /**
  62.      * @param string      $sort
  63.      * @param string|null $order
  64.      *
  65.      * @return void
  66.      */
  67.     public function add($sort$order null)
  68.     {
  69.         $order = ! $order 'ASC' $order;
  70.         $this->parts[] = $sort ' '$order;
  71.     }
  72.     /**
  73.      * @return integer
  74.      */
  75.     public function count()
  76.     {
  77.         return count($this->parts);
  78.     }
  79.     /**
  80.      * @return array
  81.      */
  82.     public function getParts()
  83.     {
  84.         return $this->parts;
  85.     }
  86.     /**
  87.      * @return string
  88.      */
  89.     public function __toString()
  90.     {
  91.         return $this->preSeparator implode($this->separator$this->parts) . $this->postSeparator;
  92.     }
  93. }