1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
|
<?php
declare(strict_types=1);
namespace Doctrine\ORM\Mapping;
use function preg_replace;
use function str_contains;
use function strrpos;
use function strtolower;
use function strtoupper;
use function substr;
use const CASE_LOWER;
use const CASE_UPPER;
/**
* Naming strategy implementing the underscore naming convention.
* Converts 'MyEntity' to 'my_entity' or 'MY_ENTITY'.
*
* @link www.doctrine-project.org
*/
class UnderscoreNamingStrategy implements NamingStrategy
{
/**
* Underscore naming strategy construct.
*
* @param int $case CASE_LOWER | CASE_UPPER
*/
public function __construct(private int $case = CASE_LOWER)
{
}
/** @return int CASE_LOWER | CASE_UPPER */
public function getCase(): int
{
return $this->case;
}
/**
* Sets string case CASE_LOWER | CASE_UPPER.
* Alphabetic characters converted to lowercase or uppercase.
*/
public function setCase(int $case): void
{
$this->case = $case;
}
public function classToTableName(string $className): string
{
if (str_contains($className, '\\')) {
$className = substr($className, strrpos($className, '\\') + 1);
}
return $this->underscore($className);
}
public function propertyToColumnName(string $propertyName, string $className): string
{
return $this->underscore($propertyName);
}
public function embeddedFieldToColumnName(
string $propertyName,
string $embeddedColumnName,
string $className,
string $embeddedClassName,
): string {
return $this->underscore($propertyName) . '_' . $embeddedColumnName;
}
public function referenceColumnName(): string
{
return $this->case === CASE_UPPER ? 'ID' : 'id';
}
public function joinColumnName(string $propertyName, string $className): string
{
return $this->underscore($propertyName) . '_' . $this->referenceColumnName();
}
public function joinTableName(
string $sourceEntity,
string $targetEntity,
string $propertyName,
): string {
return $this->classToTableName($sourceEntity) . '_' . $this->classToTableName($targetEntity);
}
public function joinKeyColumnName(
string $entityName,
string|null $referencedColumnName,
): string {
return $this->classToTableName($entityName) . '_' .
($referencedColumnName ?: $this->referenceColumnName());
}
private function underscore(string $string): string
{
$string = preg_replace('/(?<=[a-z0-9])([A-Z])/', '_$1', $string);
if ($this->case === CASE_UPPER) {
return strtoupper($string);
}
return strtolower($string);
}
}
|