| Current Path : /var/www/magento.test.indacotrentino.com/www/vendor/laminas/laminas-db/src/Sql/Ddl/Index/ |
| Current File : /var/www/magento.test.indacotrentino.com/www/vendor/laminas/laminas-db/src/Sql/Ddl/Index/Index.php |
<?php
namespace Laminas\Db\Sql\Ddl\Index;
use function array_merge;
use function count;
use function implode;
use function str_replace;
class Index extends AbstractIndex
{
/** @var string */
protected $specification = 'INDEX %s(...)';
/** @var array */
protected $lengths;
/**
* @param string|array|null $columns
* @param null|string $name
* @param array $lengths
*/
public function __construct($columns, $name = null, array $lengths = [])
{
$this->setColumns($columns);
$this->name = null === $name ? null : (string) $name;
$this->lengths = $lengths;
}
/**
* @return array of array|string should return an array in the format:
*
* array (
* // a sprintf formatted string
* string $specification,
*
* // the values for the above sprintf formatted string
* array $values,
*
* // an array of equal length of the $values array, with either TYPE_IDENTIFIER or TYPE_VALUE for each value
* array $types,
* )
*/
public function getExpressionData()
{
$colCount = count($this->columns);
$values = [];
$values[] = $this->name ?: '';
$newSpecTypes = [self::TYPE_IDENTIFIER];
$newSpecParts = [];
for ($i = 0; $i < $colCount; $i++) {
$specPart = '%s';
if (isset($this->lengths[$i])) {
$specPart .= "({$this->lengths[$i]})";
}
$newSpecParts[] = $specPart;
$newSpecTypes[] = self::TYPE_IDENTIFIER;
}
$newSpec = str_replace('...', implode(', ', $newSpecParts), $this->specification);
return [
[
$newSpec,
array_merge($values, $this->columns),
$newSpecTypes,
],
];
}
}