|
Apache/2.4.41 (Ubuntu) Linux vmi616275.contaboserver.net 5.4.0-84-generic #94-Ubuntu SMP Thu Aug 26 20:27:37 UTC 2021 x86_64 uid=33(www-data) gid=33(www-data) groups=33(www-data) server ip : 62.171.164.128 | your ip : 127.0.0.1 safemode OFF > / home / dev2.destoffenstraat.com / vendor / magento / framework / DB / Select / |
Filename | /home/dev2.destoffenstraat.com/vendor/magento/framework/DB/Select/SelectRenderer.php |
Size | 1.85 kb |
Permission | rw-r--r-- |
Owner | root : root |
Create time | 17-Aug-2025 10:26 |
Last modified | 07-Jan-2021 21:08 |
Last accessed | 22-Aug-2025 16:17 |
Actions | edit | rename | delete | download (gzip) |
View | text | code | image |
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
namespace Magento\Framework\DB\Select;
use Magento\Framework\DB\Select;
/**
* Phrase renderer interface
*/
class SelectRenderer implements RendererInterface
{
private const MANDATORY_SELECT_PARTS = [
Select::COLUMNS => true,
Select::FROM => true
];
/**
* @var RendererInterface[]
*/
protected $renderers;
/**
* @param RendererInterface[] $renderers
*/
public function __construct(
array $renderers
) {
$this->renderers = $this->sort($renderers);
}
/**
* Sort renderers
*
* @param array $renders
* @return array
*/
protected function sort($renders)
{
$length = count($renders);
if ($length <= 1) {
return $renders;
} else {
$pivot = array_shift($renders);
$left = $right = [];
foreach ($renders as $render) {
if ($render['sort'] < $pivot['sort']) {
$left[] = $render;
} else {
$right[] = $render;
}
}
return array_merge(
$this->sort($left),
[$pivot],
$this->sort($right)
);
}
}
/**
* Render SELECT statement
*
* @param Select $select
* @param string $sql
* @return string
*/
public function render(Select $select, $sql = '')
{
$sql = Select::SQL_SELECT;
foreach ($this->renderers as $renderer) {
$part = $renderer['part'];
if (isset(self::MANDATORY_SELECT_PARTS[$part]) || $select->getPart($part)) {
$sql = $renderer['renderer']->render($select, $sql);
}
}
return $sql;
}
}
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
namespace Magento\Framework\DB\Select;
use Magento\Framework\DB\Select;
/**
* Phrase renderer interface
*/
class SelectRenderer implements RendererInterface
{
private const MANDATORY_SELECT_PARTS = [
Select::COLUMNS => true,
Select::FROM => true
];
/**
* @var RendererInterface[]
*/
protected $renderers;
/**
* @param RendererInterface[] $renderers
*/
public function __construct(
array $renderers
) {
$this->renderers = $this->sort($renderers);
}
/**
* Sort renderers
*
* @param array $renders
* @return array
*/
protected function sort($renders)
{
$length = count($renders);
if ($length <= 1) {
return $renders;
} else {
$pivot = array_shift($renders);
$left = $right = [];
foreach ($renders as $render) {
if ($render['sort'] < $pivot['sort']) {
$left[] = $render;
} else {
$right[] = $render;
}
}
return array_merge(
$this->sort($left),
[$pivot],
$this->sort($right)
);
}
}
/**
* Render SELECT statement
*
* @param Select $select
* @param string $sql
* @return string
*/
public function render(Select $select, $sql = '')
{
$sql = Select::SQL_SELECT;
foreach ($this->renderers as $renderer) {
$part = $renderer['part'];
if (isset(self::MANDATORY_SELECT_PARTS[$part]) || $select->getPart($part)) {
$sql = $renderer['renderer']->render($select, $sql);
}
}
return $sql;
}
}