M1n1 Shira0ka File Manager

Current Path : /home/bullgymbny/app2/vendor/doctrine/dbal/src/Platforms/MySQL/
Upload File :
Current File : /home/bullgymbny/app2/vendor/doctrine/dbal/src/Platforms/MySQL/Comparator.php

<?php

namespace Doctrine\DBAL\Platforms\MySQL;

use Doctrine\DBAL\Platforms\AbstractMySQLPlatform;
use Doctrine\DBAL\Schema\Comparator as BaseComparator;
use Doctrine\DBAL\Schema\Table;

use function array_diff_assoc;
use function array_intersect_key;

/**
 * Compares schemas in the context of MySQL platform.
 *
 * In MySQL, unless specified explicitly, the column's character set and collation are inherited from its containing
 * table. So during comparison, an omitted value and the value that matches the default value of table in the
 * desired schema must be considered equal.
 */
class Comparator extends BaseComparator
{
    /**
     * @internal The comparator can be only instantiated by a schema manager.
     */
    public function __construct(AbstractMySQLPlatform $platform)
    {
        parent::__construct($platform);
    }

    /**
     * {@inheritDoc}
     */
    public function diffTable(Table $fromTable, Table $toTable)
    {
        return parent::diffTable(
            $this->normalizeColumns($fromTable),
            $this->normalizeColumns($toTable)
        );
    }

    private function normalizeColumns(Table $table): Table
    {
        $defaults = array_intersect_key($table->getOptions(), [
            'charset'   => null,
            'collation' => null,
        ]);

        if ($defaults === []) {
            return $table;
        }

        $table = clone $table;

        foreach ($table->getColumns() as $column) {
            $options = $column->getPlatformOptions();
            $diff    = array_diff_assoc($options, $defaults);

            if ($diff === $options) {
                continue;
            }

            $column->setPlatformOptions($diff);
        }

        return $table;
    }
}

GO Party By You