$droppedForeignKeys * @param array $addedColumns * @param array $changedColumns * @param array $droppedColumns * @param array $addedIndexes * @param array $modifiedIndexes * @param array $droppedIndexes * @param array $renamedIndexes * @param array $addedForeignKeys * @param array $modifiedForeignKeys */ public function __construct( private readonly Table $oldTable, private readonly array $addedColumns = [], private readonly array $changedColumns = [], private readonly array $droppedColumns = [], private array $addedIndexes = [], private readonly array $modifiedIndexes = [], private array $droppedIndexes = [], private readonly array $renamedIndexes = [], private readonly array $addedForeignKeys = [], private readonly array $modifiedForeignKeys = [], private readonly array $droppedForeignKeys = [], ) { if (count($this->modifiedIndexes) !== 0) { Deprecation::trigger( 'doctrine/dbal', 'https://github.com/doctrine/dbal/pull/6831', 'Passing a non-empty $modifiedIndexes value to %s() is deprecated. Instead, pass dropped' . ' indexes via $droppedIndexes and added indexes via $addedIndexes.', __METHOD__, ); } foreach ($droppedForeignKeys as $droppedForeignKey) { if ($droppedForeignKey->getName() === '') { Deprecation::trigger( 'doctrine/dbal', 'https://github.com/doctrine/dbal/pull/7143', 'Dropping a foreign key constraints without specifying its name is deprecated.', ); break; } } if (count($modifiedForeignKeys) === 0) { return; } Deprecation::trigger( 'doctrine/dbal', 'https://github.com/doctrine/dbal/pull/6827', 'Passing a non-empty $modifiedForeignKeys value to %s() is deprecated. Instead, pass dropped' . ' constraints via $droppedForeignKeys and added constraints via $addedForeignKeys.', __METHOD__, ); } public function getOldTable(): Table { return $this->oldTable; } /** @return array */ public function getAddedColumns(): array { return $this->addedColumns; } /** @return array */ public function getChangedColumns(): array { return $this->changedColumns; } /** * @deprecated Use {@see getChangedColumns()} instead. * * @return list */ public function getModifiedColumns(): array { Deprecation::triggerIfCalledFromOutside( 'doctrine/dbal', 'https://github.com/doctrine/dbal/pull/6280', '%s is deprecated, use `getChangedColumns()` instead.', __METHOD__, ); return array_values(array_filter( $this->getChangedColumns(), static fn (ColumnDiff $diff): bool => $diff->countChangedProperties() > ($diff->hasNameChanged() ? 1 : 0), )); } /** * @deprecated Use {@see getChangedColumns()} instead. * * @return array */ public function getRenamedColumns(): array { Deprecation::triggerIfCalledFromOutside( 'doctrine/dbal', 'https://github.com/doctrine/dbal/pull/6280', '%s is deprecated, you should use `getChangedColumns()` instead.', __METHOD__, ); $renamed = []; foreach ($this->getChangedColumns() as $diff) { if (! $diff->hasNameChanged()) { continue; } $oldColumnName = $diff->getOldColumn()->getName(); $renamed[$oldColumnName] = $diff->getNewColumn(); } return $renamed; } /** @return array */ public function getDroppedColumns(): array { return $this->droppedColumns; } /** @return array */ public function getAddedIndexes(): array { return $this->addedIndexes; } /** * @internal This method exists only for compatibility with the current implementation of schema managers * that modify the diff while processing it. */ public function unsetAddedIndex(Index $index): void { $this->addedIndexes = array_filter( $this->addedIndexes, static function (Index $addedIndex) use ($index): bool { return $addedIndex !== $index; }, ); } /** * @deprecated Use {@see getAddedIndexes()} and {@see getDroppedIndexes()} instead. * * @return array */ public function getModifiedIndexes(): array { Deprecation::triggerIfCalledFromOutside( 'doctrine/dbal', 'https://github.com/doctrine/dbal/pull/6831', '%s() is deprecated, use getAddedIndexes() and getDroppedIndexes() instead.', __METHOD__, ); return $this->modifiedIndexes; } /** @return array */ public function getDroppedIndexes(): array { return $this->droppedIndexes; } /** * @internal This method exists only for compatibility with the current implementation of schema managers * that modify the diff while processing it. */ public function unsetDroppedIndex(Index $index): void { $this->droppedIndexes = array_filter( $this->droppedIndexes, static function (Index $droppedIndex) use ($index): bool { return $droppedIndex !== $index; }, ); } /** @return array */ public function getRenamedIndexes(): array { return $this->renamedIndexes; } /** @return array */ public function getAddedForeignKeys(): array { return $this->addedForeignKeys; } /** * @deprecated Use {@see getAddedForeignKeys()} and {@see getDroppedForeignKeys()} instead. * * @return array */ public function getModifiedForeignKeys(): array { Deprecation::triggerIfCalledFromOutside( 'doctrine/dbal', 'https://github.com/doctrine/dbal/pull/6827', '%s() is deprecated, use getDroppedForeignKeys() and getAddedForeignKeys() instead.', __METHOD__, ); return $this->modifiedForeignKeys; } /** * @deprecated Use {@see getDroppedForeignKeyConstraintNames()}. * * @return array */ public function getDroppedForeignKeys(): array { return $this->droppedForeignKeys; } /** @return array */ public function getDroppedForeignKeyConstraintNames(): array { $names = []; foreach ($this->droppedForeignKeys as $constraint) { $name = $constraint->getObjectName(); if ($name === null) { throw InvalidState::tableDiffContainsUnnamedDroppedForeignKeyConstraints(); } $names[] = $name; } return $names; } /** * Returns whether the diff is empty (contains no changes). */ public function isEmpty(): bool { return count($this->addedColumns) === 0 && count($this->changedColumns) === 0 && count($this->droppedColumns) === 0 && count($this->addedIndexes) === 0 && count($this->modifiedIndexes) === 0 && count($this->droppedIndexes) === 0 && count($this->renamedIndexes) === 0 && count($this->addedForeignKeys) === 0 && count($this->modifiedForeignKeys) === 0 && count($this->droppedForeignKeys) === 0; } }