From 230c7c5684966f1ea9b9e1329c3b1115f38861fc Mon Sep 17 00:00:00 2001 From: Sergei Morozov Date: Fri, 2 Sep 2022 23:59:34 -0700 Subject: [PATCH] Deprecate and mark internal APIs related to schema comparison --- UPGRADE.md | 16 +++++++++++++--- psalm.xml.dist | 9 +++++++++ src/Schema/ColumnDiff.php | 12 ++++++++++-- src/Schema/Comparator.php | 19 ++++++++++++++++++- 4 files changed, 50 insertions(+), 6 deletions(-) diff --git a/UPGRADE.md b/UPGRADE.md index ce66c78498c..6e7020f9778 100644 --- a/UPGRADE.md +++ b/UPGRADE.md @@ -13,10 +13,20 @@ awareness about deprecated code. Relying on the default precision and scale of decimal columns provided by the DBAL is deprecated. When declaring decimal columns, specify the precision and scale explicitly. -## Marked `ColumnDiff::hasChanged()` as internal. +## Marked `Comparator` methods as internal. -The `ColumnDiff::hasChanged()` method has been marked as internal. Use one of the following `ColumnDiff` methods -in order to check if a given column property has changed: +The following `Comparator` methods have been marked as internal: + +- `columnsEqual()`, +- `diffForeignKey()`, +- `diffIndex()`. + +The `diffColumn()` method has been deprecated. Use `diffTable()` instead. + +## Deprecated `ColumnDiff::$changedProperties` and `::hasChanged()`. + +The `ColumnDiff::$changedProperties` property and the `hasChanged()` method have been deprecated. Use one of the +following `ColumnDiff` methods in order to check if a given column property has changed: - `hasTypeChanged()`, - `hasLengthChanged()`, diff --git a/psalm.xml.dist b/psalm.xml.dist index 87469cf3ba7..83bc98322f5 100644 --- a/psalm.xml.dist +++ b/psalm.xml.dist @@ -418,6 +418,11 @@ TODO: remove in 4.0.0 --> + + + @@ -451,6 +456,10 @@ TODO: remove in 4.0.0 --> + + diff --git a/src/Schema/ColumnDiff.php b/src/Schema/ColumnDiff.php index ae86f211edf..b7c07ee115b 100644 --- a/src/Schema/ColumnDiff.php +++ b/src/Schema/ColumnDiff.php @@ -21,7 +21,13 @@ class ColumnDiff /** @var Column */ public $column; - /** @var string[] */ + /** + * @deprecated Use {@see hasTypeChanged()}, {@see hasLengthChanged()}, {@see hasPrecisionChanged()}, + * {@see hasScaleChanged()}, {@see hasUnsignedChanged()}, {@see hasFixedChanged()}, {@see hasNotNullChanged()}, + * {@see hasDefaultChanged()}, {@see hasAutoIncrementChanged()} or {@see hasCommentChanged()} instead. + * + * @var string[] + */ public $changedProperties = []; /** @var Column|null */ @@ -105,7 +111,9 @@ public function hasCommentChanged(): bool } /** - * @internal + * @deprecated Use {@see hasTypeChanged()}, {@see hasLengthChanged()}, {@see hasPrecisionChanged()}, + * {@see hasScaleChanged()}, {@see hasUnsignedChanged()}, {@see hasFixedChanged()}, {@see hasNotNullChanged()}, + * {@see hasDefaultChanged()}, {@see hasAutoIncrementChanged()} or {@see hasCommentChanged()} instead. * * @param string $propertyName * diff --git a/src/Schema/Comparator.php b/src/Schema/Comparator.php index 189dbb1a4f1..bccf4dc6f34 100644 --- a/src/Schema/Comparator.php +++ b/src/Schema/Comparator.php @@ -467,7 +467,11 @@ private function detectIndexRenamings(TableDiff $tableDifferences): void } } - /** @return bool */ + /** + * @internal The method should be only used from within the {@see Comparator} class hierarchy. + * + * @return bool + */ public function diffForeignKey(ForeignKeyConstraint $key1, ForeignKeyConstraint $key2) { if ( @@ -498,6 +502,8 @@ public function diffForeignKey(ForeignKeyConstraint $key1, ForeignKeyConstraint /** * Compares the definitions of the given columns * + * @internal The method should be only used from within the {@see Comparator} class hierarchy. + * * @throws Exception */ public function columnsEqual(Column $column1, Column $column2): bool @@ -515,10 +521,19 @@ public function columnsEqual(Column $column1, Column $column2): bool * If there are differences this method returns the changed properties as a * string array, otherwise an empty array gets returned. * + * @deprecated Use {@see diffTable()} instead. + * * @return string[] */ public function diffColumn(Column $column1, Column $column2) { + Deprecation::triggerIfCalledFromOutside( + 'doctrine/dbal', + 'https://github.com/doctrine/dbal/pull/5650', + '%s is deprecated. Use diffTable() instead.', + __METHOD__, + ); + $properties1 = $column1->toArray(); $properties2 = $column2->toArray(); @@ -609,6 +624,8 @@ public function diffColumn(Column $column1, Column $column2) * Compares $index1 with $index2 and returns $index2 if there are any * differences or false in case there are no differences. * + * @internal The method should be only used from within the {@see Comparator} class hierarchy. + * * @return bool */ public function diffIndex(Index $index1, Index $index2)