4 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
5 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
6 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
7 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
8 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
9 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
10 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
11 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
12 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
13 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
14 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
16 * This software consists of voluntary contributions made by many individuals
17 * and is licensed under the MIT license. For more information, see
18 * <http://www.doctrine-project.org>.
21 namespace Doctrine\ORM\Mapping;
24 * The default NamingStrategy
27 * @link www.doctrine-project.org
29 * @author Fabio B. Silva <fabio.bat.silva@gmail.com>
31 class DefaultNamingStrategy implements NamingStrategy
36 public function classToTableName($className)
38 if (strpos($className, '\\') !== false) {
39 return substr($className, strrpos($className, '\\') + 1);
48 public function propertyToColumnName($propertyName)
56 public function referenceColumnName()
64 public function joinColumnName($propertyName)
66 return $propertyName . '_' . $this->referenceColumnName();
72 public function joinTableName($sourceEntity, $targetEntity, $propertyName = null)
74 return strtolower($this->classToTableName($sourceEntity) . '_' .
75 $this->classToTableName($targetEntity));
81 public function joinKeyColumnName($entityName, $referencedColumnName = null)
83 return strtolower($this->classToTableName($entityName) . '_' .
84 ($referencedColumnName ?: $this->referenceColumnName()));