From 312e7b7bc74744955800e6de7e21c660ddbecd27 Mon Sep 17 00:00:00 2001 From: Michael Knappe Date: Wed, 25 Jan 2023 15:32:18 +0100 Subject: [PATCH 1/2] Removed redundant type cast --- src/Propel/Generator/Builder/Om/ObjectBuilder.php | 2 +- src/Propel/Generator/Command/TestPrepareCommand.php | 2 +- src/Propel/Generator/Manager/AbstractManager.php | 2 +- src/Propel/Generator/Manager/ReverseManager.php | 4 ++-- src/Propel/Generator/Manager/SqlManager.php | 2 +- src/Propel/Generator/Model/Column.php | 12 ++++++------ src/Propel/Generator/Model/ForeignKey.php | 2 +- src/Propel/Generator/Model/Index.php | 2 +- src/Propel/Generator/Model/Table.php | 8 ++++---- src/Propel/Runtime/ActiveQuery/Criteria.php | 6 +++--- .../Runtime/ActiveQuery/Criterion/BasicCriterion.php | 2 +- .../ActiveQuery/Criterion/CustomCriterion.php | 2 +- .../Runtime/ActiveQuery/Criterion/LikeCriterion.php | 2 +- .../ActiveQuery/Criterion/LikeModelCriterion.php | 2 +- src/Propel/Runtime/Adapter/Pdo/MysqlAdapter.php | 3 --- src/Propel/Runtime/Collection/Collection.php | 2 +- src/Propel/Runtime/Collection/OnDemandIterator.php | 2 +- .../Connection/ConnectionManagerPrimaryReplica.php | 2 +- src/Propel/Runtime/Connection/ConnectionWrapper.php | 2 +- src/Propel/Runtime/Map/ColumnMap.php | 6 +++--- src/Propel/Runtime/Map/TableMap.php | 2 +- 21 files changed, 33 insertions(+), 36 deletions(-) diff --git a/src/Propel/Generator/Builder/Om/ObjectBuilder.php b/src/Propel/Generator/Builder/Om/ObjectBuilder.php index 6914982a52..ec0fe53657 100644 --- a/src/Propel/Generator/Builder/Om/ObjectBuilder.php +++ b/src/Propel/Generator/Builder/Om/ObjectBuilder.php @@ -200,7 +200,7 @@ protected function getDefaultValueString(Column $column): string } $defaultValue = (string)array_search($val, $valueSet); } elseif ($column->isSetType()) { - $defaultValue = (string)SetColumnConverter::convertToInt($val, $column->getValueSet()); + $defaultValue = SetColumnConverter::convertToInt($val, $column->getValueSet()); } elseif ($column->isPhpPrimitiveType()) { settype($val, $column->getPhpType()); $defaultValue = var_export($val, true); diff --git a/src/Propel/Generator/Command/TestPrepareCommand.php b/src/Propel/Generator/Command/TestPrepareCommand.php index fd9454da93..28b2e56c64 100644 --- a/src/Propel/Generator/Command/TestPrepareCommand.php +++ b/src/Propel/Generator/Command/TestPrepareCommand.php @@ -151,7 +151,7 @@ protected function buildFixtures(string $fixturesDir, array $connections, InputI $command->run($in, $output); } - if (0 < count((array)$this->getSchemas('.'))) { + if (0 < count($this->getSchemas('.'))) { $in = new ArrayInput([ 'command' => 'model:build', '--schema-dir' => '.', diff --git a/src/Propel/Generator/Manager/AbstractManager.php b/src/Propel/Generator/Manager/AbstractManager.php index 8f9a21f13a..3eaf51c082 100644 --- a/src/Propel/Generator/Manager/AbstractManager.php +++ b/src/Propel/Generator/Manager/AbstractManager.php @@ -235,7 +235,7 @@ public function getDatabase(string $name): ?Database */ public function setValidate(bool $validate): void { - $this->validate = (bool)$validate; + $this->validate = $validate; } /** diff --git a/src/Propel/Generator/Manager/ReverseManager.php b/src/Propel/Generator/Manager/ReverseManager.php index 27b51ff689..e67da557be 100644 --- a/src/Propel/Generator/Manager/ReverseManager.php +++ b/src/Propel/Generator/Manager/ReverseManager.php @@ -150,7 +150,7 @@ public function setDatabaseName(string $databaseName): void */ public function setSamePhpName(bool $samePhpName): void { - $this->samePhpName = (bool)$samePhpName; + $this->samePhpName = $samePhpName; } /** @@ -162,7 +162,7 @@ public function setSamePhpName(bool $samePhpName): void */ public function setAddVendorInfo(bool $addVendorInfo): void { - $this->addVendorInfo = (bool)$addVendorInfo; + $this->addVendorInfo = $addVendorInfo; } /** diff --git a/src/Propel/Generator/Manager/SqlManager.php b/src/Propel/Generator/Manager/SqlManager.php index 0d2c5e651d..4828ea6072 100644 --- a/src/Propel/Generator/Manager/SqlManager.php +++ b/src/Propel/Generator/Manager/SqlManager.php @@ -80,7 +80,7 @@ public function isOverwriteSqlMap(): bool */ public function setOverwriteSqlMap(bool $overwriteSqlMap): void { - $this->overwriteSqlMap = (bool)$overwriteSqlMap; + $this->overwriteSqlMap = $overwriteSqlMap; } /** diff --git a/src/Propel/Generator/Model/Column.php b/src/Propel/Generator/Model/Column.php index 72d2385ca2..72a6d6e79f 100644 --- a/src/Propel/Generator/Model/Column.php +++ b/src/Propel/Generator/Model/Column.php @@ -928,7 +928,7 @@ public function getNotNullString(): string */ public function setPrimaryString(bool $isPrimaryString): void { - $this->isPrimaryString = (bool)$isPrimaryString; + $this->isPrimaryString = $isPrimaryString; } /** @@ -973,7 +973,7 @@ public function isPrimaryKey(): bool */ public function setNodeKey(bool $isNodeKey): void { - $this->isNodeKey = (bool)$isNodeKey; + $this->isNodeKey = $isNodeKey; } /** @@ -995,7 +995,7 @@ public function isNodeKey(): bool */ public function setNodeKeySep(string $sep): void { - $this->nodeKeySep = (string)$sep; + $this->nodeKeySep = $sep; } /** @@ -1017,7 +1017,7 @@ public function getNodeKeySep(): string */ public function setNestedSetLeftKey(bool $isNestedSetLeftKey): void { - $this->isNestedSetLeftKey = (bool)$isNestedSetLeftKey; + $this->isNestedSetLeftKey = $isNestedSetLeftKey; } /** @@ -1039,7 +1039,7 @@ public function isNestedSetLeftKey(): bool */ public function setNestedSetRightKey(bool $isNestedSetRightKey): void { - $this->isNestedSetRightKey = (bool)$isNestedSetRightKey; + $this->isNestedSetRightKey = $isNestedSetRightKey; } /** @@ -1061,7 +1061,7 @@ public function isNestedSetRightKey(): bool */ public function setTreeScopeKey(bool $isTreeScopeKey): void { - $this->isTreeScopeKey = (bool)$isTreeScopeKey; + $this->isTreeScopeKey = $isTreeScopeKey; } /** diff --git a/src/Propel/Generator/Model/ForeignKey.php b/src/Propel/Generator/Model/ForeignKey.php index ea7c8cba73..ac7c5c25c6 100644 --- a/src/Propel/Generator/Model/ForeignKey.php +++ b/src/Propel/Generator/Model/ForeignKey.php @@ -1025,7 +1025,7 @@ public function isLocalPrimaryKey(): bool */ public function setSkipSql(bool $skip): void { - $this->skipSql = (bool)$skip; + $this->skipSql = $skip; } /** diff --git a/src/Propel/Generator/Model/Index.php b/src/Propel/Generator/Model/Index.php index ed7226e04b..1a749c5afe 100644 --- a/src/Propel/Generator/Model/Index.php +++ b/src/Propel/Generator/Model/Index.php @@ -190,7 +190,7 @@ public function addColumn($data): void { if ($data instanceof Column) { $column = $data; - $this->columns[] = (string)$column->getName(); + $this->columns[] = $column->getName(); if ($column->getSize()) { $this->columnsSize[$column->getName()] = (int)$column->getSize(); } diff --git a/src/Propel/Generator/Model/Table.php b/src/Propel/Generator/Model/Table.php index 32c26ef3cf..568832ec5d 100644 --- a/src/Propel/Generator/Model/Table.php +++ b/src/Propel/Generator/Model/Table.php @@ -205,7 +205,7 @@ public function setupObject(): void // retrieves the method for converting from specified name to a PHP name. $this->phpNamingMethod = $this->getAttribute('phpNamingMethod', $this->database->getDefaultPhpNamingMethod()); - $this->phpName = $this->getAttribute('phpName', $this->buildPhpName((string)$this->getStdSeparatedName())); + $this->phpName = $this->getAttribute('phpName', $this->buildPhpName($this->getStdSeparatedName())); if ($this->database->getTablePrefix()) { $this->commonName = $this->database->getTablePrefix() . $this->commonName; @@ -944,7 +944,7 @@ public function getOtherRequiredPrimaryKeys(array $primaryKeys): array */ public function setContainsForeignPK(bool $containsForeignPK): void { - $this->containsForeignPK = (bool)$containsForeignPK; + $this->containsForeignPK = $containsForeignPK; } /** @@ -1248,7 +1248,7 @@ public function setDescription(string $description): void public function getPhpName(): string { if ($this->phpName === null) { - $this->phpName = $this->buildPhpName((string)$this->getStdSeparatedName()); + $this->phpName = $this->buildPhpName($this->getStdSeparatedName()); } return $this->phpName; @@ -1416,7 +1416,7 @@ public function isSkipSql(): bool */ public function setSkipSql(bool $skip): void { - $this->skipSql = (bool)$skip; + $this->skipSql = $skip; } /** diff --git a/src/Propel/Runtime/ActiveQuery/Criteria.php b/src/Propel/Runtime/ActiveQuery/Criteria.php index 485e2d8292..1145c2c01a 100644 --- a/src/Propel/Runtime/ActiveQuery/Criteria.php +++ b/src/Propel/Runtime/ActiveQuery/Criteria.php @@ -652,7 +652,7 @@ public function hasWhereClause(): bool */ public function setUseTransaction(bool $v) { - $this->useTransaction = (bool)$v; + $this->useTransaction = $v; return $this; } @@ -1444,7 +1444,7 @@ public function withoutLock() */ public function setIgnoreCase(bool $b) { - $this->ignoreCase = (bool)$b; + $this->ignoreCase = $b; return $this; } @@ -1474,7 +1474,7 @@ public function isIgnoreCase(): bool */ public function setSingleRecord(bool $b) { - $this->singleRecord = (bool)$b; + $this->singleRecord = $b; return $this; } diff --git a/src/Propel/Runtime/ActiveQuery/Criterion/BasicCriterion.php b/src/Propel/Runtime/ActiveQuery/Criterion/BasicCriterion.php index a541bf726a..a04ba047ad 100644 --- a/src/Propel/Runtime/ActiveQuery/Criterion/BasicCriterion.php +++ b/src/Propel/Runtime/ActiveQuery/Criterion/BasicCriterion.php @@ -44,7 +44,7 @@ public function __construct(Criteria $outer, $column, $value, ?string $compariso */ public function setIgnoreCase(bool $b) { - $this->ignoreStringCase = (bool)$b; + $this->ignoreStringCase = $b; return $this; } diff --git a/src/Propel/Runtime/ActiveQuery/Criterion/CustomCriterion.php b/src/Propel/Runtime/ActiveQuery/Criterion/CustomCriterion.php index 896ce81b84..5e8122697c 100644 --- a/src/Propel/Runtime/ActiveQuery/Criterion/CustomCriterion.php +++ b/src/Propel/Runtime/ActiveQuery/Criterion/CustomCriterion.php @@ -38,7 +38,7 @@ public function __construct(Criteria $outer, string $value) protected function appendPsForUniqueClauseTo(string &$sb, array &$params): void { if ($this->value !== '') { - $sb .= (string)$this->value; + $sb .= $this->value; } } } diff --git a/src/Propel/Runtime/ActiveQuery/Criterion/LikeCriterion.php b/src/Propel/Runtime/ActiveQuery/Criterion/LikeCriterion.php index a91b8d4f5c..4cfcb1c8ec 100644 --- a/src/Propel/Runtime/ActiveQuery/Criterion/LikeCriterion.php +++ b/src/Propel/Runtime/ActiveQuery/Criterion/LikeCriterion.php @@ -44,7 +44,7 @@ public function __construct(Criteria $outer, $column, $value, string $comparison */ public function setIgnoreCase(bool $b) { - $this->ignoreStringCase = (bool)$b; + $this->ignoreStringCase = $b; return $this; } diff --git a/src/Propel/Runtime/ActiveQuery/Criterion/LikeModelCriterion.php b/src/Propel/Runtime/ActiveQuery/Criterion/LikeModelCriterion.php index 8bb92fb111..795e594c47 100644 --- a/src/Propel/Runtime/ActiveQuery/Criterion/LikeModelCriterion.php +++ b/src/Propel/Runtime/ActiveQuery/Criterion/LikeModelCriterion.php @@ -31,7 +31,7 @@ class LikeModelCriterion extends BasicModelCriterion */ public function setIgnoreCase(bool $b) { - $this->ignoreStringCase = (bool)$b; + $this->ignoreStringCase = $b; return $this; } diff --git a/src/Propel/Runtime/Adapter/Pdo/MysqlAdapter.php b/src/Propel/Runtime/Adapter/Pdo/MysqlAdapter.php index d62bbe62cd..11f8f0cf32 100644 --- a/src/Propel/Runtime/Adapter/Pdo/MysqlAdapter.php +++ b/src/Propel/Runtime/Adapter/Pdo/MysqlAdapter.php @@ -128,9 +128,6 @@ public function quoteIdentifierTable(string $table): string */ public function applyLimit(string &$sql, int $offset, int $limit, ?Criteria $criteria = null): void { - $offset = (int)$offset; - $limit = (int)$limit; - if ($limit >= 0) { $sql .= ' LIMIT ' . ($offset > 0 ? $offset . ', ' : '') . $limit; } elseif ($offset > 0) { diff --git a/src/Propel/Runtime/Collection/Collection.php b/src/Propel/Runtime/Collection/Collection.php index ed2262f2f7..50b5a2d62f 100644 --- a/src/Propel/Runtime/Collection/Collection.php +++ b/src/Propel/Runtime/Collection/Collection.php @@ -648,7 +648,7 @@ public function __call(string $name, $params) */ public function __toString(): string { - return (string)$this->exportTo($this->getTableMapClass()::DEFAULT_STRING_FORMAT, false); + return $this->exportTo($this->getTableMapClass()::DEFAULT_STRING_FORMAT, false); } /** diff --git a/src/Propel/Runtime/Collection/OnDemandIterator.php b/src/Propel/Runtime/Collection/OnDemandIterator.php index 83bb54632d..c24c5807a2 100644 --- a/src/Propel/Runtime/Collection/OnDemandIterator.php +++ b/src/Propel/Runtime/Collection/OnDemandIterator.php @@ -166,6 +166,6 @@ public function rewind(): void */ public function valid(): bool { - return (bool)$this->isValid; + return $this->isValid; } } diff --git a/src/Propel/Runtime/Connection/ConnectionManagerPrimaryReplica.php b/src/Propel/Runtime/Connection/ConnectionManagerPrimaryReplica.php index f81a50591d..c5b6e22681 100644 --- a/src/Propel/Runtime/Connection/ConnectionManagerPrimaryReplica.php +++ b/src/Propel/Runtime/Connection/ConnectionManagerPrimaryReplica.php @@ -90,7 +90,7 @@ public function isForcePrimaryConnection(): bool */ public function setForcePrimaryConnection(bool $isForceMasterConnection): void { - $this->isForcePrimaryConnection = (bool)$isForceMasterConnection; + $this->isForcePrimaryConnection = $isForceMasterConnection; } /** diff --git a/src/Propel/Runtime/Connection/ConnectionWrapper.php b/src/Propel/Runtime/Connection/ConnectionWrapper.php index 144cc4b1c9..55a7276a5a 100644 --- a/src/Propel/Runtime/Connection/ConnectionWrapper.php +++ b/src/Propel/Runtime/Connection/ConnectionWrapper.php @@ -326,7 +326,7 @@ public function forceRollBack(): bool */ public function inTransaction(): bool { - return (bool)$this->connection->inTransaction(); + return $this->connection->inTransaction(); } /** diff --git a/src/Propel/Runtime/Map/ColumnMap.php b/src/Propel/Runtime/Map/ColumnMap.php index e36e1a4744..d684482895 100644 --- a/src/Propel/Runtime/Map/ColumnMap.php +++ b/src/Propel/Runtime/Map/ColumnMap.php @@ -335,7 +335,7 @@ public function getSize(): int */ public function setPrimaryKey(bool $pk): void { - $this->pk = (bool)$pk; + $this->pk = $pk; } /** @@ -357,7 +357,7 @@ public function isPrimaryKey(): bool */ public function setNotNull(bool $nn): void { - $this->notNull = (bool)$nn; + $this->notNull = $nn; } /** @@ -592,7 +592,7 @@ public static function normalizeName(string $name): string */ public function setPrimaryString(bool $pkString): void { - $this->isPkString = (bool)$pkString; + $this->isPkString = $pkString; } /** diff --git a/src/Propel/Runtime/Map/TableMap.php b/src/Propel/Runtime/Map/TableMap.php index ce10ddf1c5..07185760eb 100644 --- a/src/Propel/Runtime/Map/TableMap.php +++ b/src/Propel/Runtime/Map/TableMap.php @@ -401,7 +401,7 @@ public function getPackage(): ?string */ public function setUseIdGenerator(bool $bit): void { - $this->useIdGenerator = (bool)$bit; + $this->useIdGenerator = $bit; } /** From 03ff801c04ea85e143edaa1c4b890293e2cdbb25 Mon Sep 17 00:00:00 2001 From: mringler Date: Sun, 23 Apr 2023 13:12:56 +0200 Subject: [PATCH 2/2] avoid name collision in cross ref relations --- .../Builder/Om/AbstractOMBuilder.php | 53 +++++---- src/Propel/Generator/Model/Table.php | 14 +++ tests/Propel/Tests/Issues/Issue941Test.php | 104 ++++++++++++++++++ tests/Propel/Tests/Issues/Issue989Test.php | 1 + 4 files changed, 150 insertions(+), 22 deletions(-) create mode 100644 tests/Propel/Tests/Issues/Issue941Test.php diff --git a/src/Propel/Generator/Builder/Om/AbstractOMBuilder.php b/src/Propel/Generator/Builder/Om/AbstractOMBuilder.php index ee87b51381..441a8ec94f 100644 --- a/src/Propel/Generator/Builder/Om/AbstractOMBuilder.php +++ b/src/Propel/Generator/Builder/Om/AbstractOMBuilder.php @@ -686,34 +686,43 @@ public function getFKPhpNameAffix(ForeignKey $fk, bool $plural = false): string * @return string */ protected function getCrossFKsPhpNameAffix(CrossForeignKeys $crossFKs, bool $plural = true): string + { + $baseName = $this->buildCombineCrossFKsPhpNameAffix($crossFKs, false); + + $existingTable = $this->getDatabase()->getTableByPhpName($baseName); + $isNameCollision = $existingTable && $this->getTable()->isConnectedWithTable($existingTable); + + return ($plural || $isNameCollision) ? $this->buildCombineCrossFKsPhpNameAffix($crossFKs, $plural, $isNameCollision) : $baseName; + } + + /** + * @param \Propel\Generator\Model\CrossForeignKeys $crossFKs + * @param bool $plural + * @param bool $withPrefix + * + * @return string + */ + protected function buildCombineCrossFKsPhpNameAffix(CrossForeignKeys $crossFKs, bool $plural = true, bool $withPrefix = false): string { $names = []; + if ($withPrefix) { + $names[] = 'Cross'; + } + $fks = $crossFKs->getCrossForeignKeys(); + $lastCrossFk = array_pop($fks); + $unclassifiedPrimaryKeys = $crossFKs->getUnclassifiedPrimaryKeys(); + $lastIsPlural = $plural && !$unclassifiedPrimaryKeys; - if ($plural) { - if ($crossFKs->getUnclassifiedPrimaryKeys()) { - //we have a non fk as pk as well, so we need to make pluralisation on our own and can't - //rely on getFKPhpNameAffix's pluralisation - foreach ($crossFKs->getCrossForeignKeys() as $fk) { - $names[] = $this->getFKPhpNameAffix($fk, false); - } - } else { - //we have only fks, so give us names with plural and return those - $lastIdx = count($crossFKs->getCrossForeignKeys()) - 1; - foreach ($crossFKs->getCrossForeignKeys() as $idx => $fk) { - $needPlural = $idx === $lastIdx; //only last fk should be plural - $names[] = $this->getFKPhpNameAffix($fk, $needPlural); - } + foreach ($fks as $fk) { + $names[] = $this->getFKPhpNameAffix($fk, false); + } + $names[] = $this->getFKPhpNameAffix($lastCrossFk, $lastIsPlural); - return implode('', $names); - } - } else { - // no plural, so $plural=false - foreach ($crossFKs->getCrossForeignKeys() as $fk) { - $names[] = $this->getFKPhpNameAffix($fk, false); - } + if (!$unclassifiedPrimaryKeys) { + return implode('', $names); } - foreach ($crossFKs->getUnclassifiedPrimaryKeys() as $pk) { + foreach ($unclassifiedPrimaryKeys as $pk) { $names[] = $pk->getPhpName(); } diff --git a/src/Propel/Generator/Model/Table.php b/src/Propel/Generator/Model/Table.php index 568832ec5d..2376ca0ab3 100644 --- a/src/Propel/Generator/Model/Table.php +++ b/src/Propel/Generator/Model/Table.php @@ -2288,4 +2288,18 @@ public function getAdditionalModelClassImports(): ?array return null; } + + /** + * Check if there is a FK rellation between the current table and the given + * table in either direction. + * + * @param \Propel\Generator\Model\Table $table + * + * @return bool + */ + public function isConnectedWithTable(Table $table): bool + { + return $this->getForeignKeysReferencingTable($table->getName()) || + $table->getForeignKeysReferencingTable($this->getName()); + } } diff --git a/tests/Propel/Tests/Issues/Issue941Test.php b/tests/Propel/Tests/Issues/Issue941Test.php new file mode 100644 index 0000000000..b581d76a77 --- /dev/null +++ b/tests/Propel/Tests/Issues/Issue941Test.php @@ -0,0 +1,104 @@ + + + +
+ + + +
+ + + + + + + + + + + + + + + + + +
+ + + +
+ + + '; + QuickBuilder::buildSchema($schema); + } + } + + /** + * @return void + */ + public function testIssue941() + { + $nature = new Nature(); + $nature->save(); + + $category = new Category(); + $category->save(); + + // RechercheNature + $rechercheNature = new RechercheNature(); + $rechercheNature->setNatureId($nature->getId()); + $rechercheNature->setCategoryId($category->getId()); + + // Collection + $collection = new ObjectCollection(); + $collection->setModel('\RechercheNature'); + $collection->setData([$rechercheNature]); + + // Recherche + $recherche = new Recherche(); + $recherche->setRechercheNatures($collection); + + $countBeforeSave = $recherche->countRechercheNatures(); + + $recherche->save(); + + $countAfterSave = $recherche->countRechercheNatures(); + + $this->assertEquals($countBeforeSave, $countAfterSave); + } +} diff --git a/tests/Propel/Tests/Issues/Issue989Test.php b/tests/Propel/Tests/Issues/Issue989Test.php index d21f839a33..28237c2816 100644 --- a/tests/Propel/Tests/Issues/Issue989Test.php +++ b/tests/Propel/Tests/Issues/Issue989Test.php @@ -38,6 +38,7 @@ protected function setUp(): void +