diff options
Diffstat (limited to 'vendor/doctrine/dbal/src/SQL/Builder/CreateSchemaObjectsSQLBuilder.php')
-rw-r--r-- | vendor/doctrine/dbal/src/SQL/Builder/CreateSchemaObjectsSQLBuilder.php | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/vendor/doctrine/dbal/src/SQL/Builder/CreateSchemaObjectsSQLBuilder.php b/vendor/doctrine/dbal/src/SQL/Builder/CreateSchemaObjectsSQLBuilder.php new file mode 100644 index 0000000..5f6a77a --- /dev/null +++ b/vendor/doctrine/dbal/src/SQL/Builder/CreateSchemaObjectsSQLBuilder.php | |||
@@ -0,0 +1,73 @@ | |||
1 | <?php | ||
2 | |||
3 | declare(strict_types=1); | ||
4 | |||
5 | namespace Doctrine\DBAL\SQL\Builder; | ||
6 | |||
7 | use Doctrine\DBAL\Platforms\AbstractPlatform; | ||
8 | use Doctrine\DBAL\Schema\Schema; | ||
9 | use Doctrine\DBAL\Schema\Sequence; | ||
10 | use Doctrine\DBAL\Schema\Table; | ||
11 | |||
12 | use function array_merge; | ||
13 | |||
14 | final class CreateSchemaObjectsSQLBuilder | ||
15 | { | ||
16 | public function __construct(private readonly AbstractPlatform $platform) | ||
17 | { | ||
18 | } | ||
19 | |||
20 | /** @return list<string> */ | ||
21 | public function buildSQL(Schema $schema): array | ||
22 | { | ||
23 | return array_merge( | ||
24 | $this->buildNamespaceStatements($schema->getNamespaces()), | ||
25 | $this->buildSequenceStatements($schema->getSequences()), | ||
26 | $this->buildTableStatements($schema->getTables()), | ||
27 | ); | ||
28 | } | ||
29 | |||
30 | /** | ||
31 | * @param list<string> $namespaces | ||
32 | * | ||
33 | * @return list<string> | ||
34 | */ | ||
35 | private function buildNamespaceStatements(array $namespaces): array | ||
36 | { | ||
37 | $statements = []; | ||
38 | |||
39 | if ($this->platform->supportsSchemas()) { | ||
40 | foreach ($namespaces as $namespace) { | ||
41 | $statements[] = $this->platform->getCreateSchemaSQL($namespace); | ||
42 | } | ||
43 | } | ||
44 | |||
45 | return $statements; | ||
46 | } | ||
47 | |||
48 | /** | ||
49 | * @param list<Table> $tables | ||
50 | * | ||
51 | * @return list<string> | ||
52 | */ | ||
53 | private function buildTableStatements(array $tables): array | ||
54 | { | ||
55 | return $this->platform->getCreateTablesSQL($tables); | ||
56 | } | ||
57 | |||
58 | /** | ||
59 | * @param list<Sequence> $sequences | ||
60 | * | ||
61 | * @return list<string> | ||
62 | */ | ||
63 | private function buildSequenceStatements(array $sequences): array | ||
64 | { | ||
65 | $statements = []; | ||
66 | |||
67 | foreach ($sequences as $sequence) { | ||
68 | $statements[] = $this->platform->getCreateSequenceSQL($sequence); | ||
69 | } | ||
70 | |||
71 | return $statements; | ||
72 | } | ||
73 | } | ||