From 82a1626e82729740ab0ef8bbb711369f6f12a897 Mon Sep 17 00:00:00 2001 From: Asmir Mustafic Date: Fri, 18 Nov 2011 10:57:27 +0100 Subject: [PATCH 1/3] Better generation of exported xml (valid with xsd) --- .../ORM/Tools/Export/Driver/XmlExporter.php | 25 ++++++++++++++++--- 1 file changed, 21 insertions(+), 4 deletions(-) diff --git a/lib/Doctrine/ORM/Tools/Export/Driver/XmlExporter.php b/lib/Doctrine/ORM/Tools/Export/Driver/XmlExporter.php index 01309475b..8ec4d5cd5 100644 --- a/lib/Doctrine/ORM/Tools/Export/Driver/XmlExporter.php +++ b/lib/Doctrine/ORM/Tools/Export/Driver/XmlExporter.php @@ -95,7 +95,10 @@ class XmlExporter extends AbstractExporter } } - $root->addChild('change-tracking-policy', $this->_getChangeTrackingPolicyString($metadata->changeTrackingPolicy)); + $trackingPolicy = $this->_getChangeTrackingPolicyString($metadata->changeTrackingPolicy); + if ( $trackingPolicy != 'DEFERRED_IMPLICIT') { + $root->addChild('change-tracking-policy', $trackingPolicy); + } if (isset($metadata->table['indexes'])) { $indexesXml = $root->addChild('indexes'); @@ -183,7 +186,17 @@ class XmlExporter extends AbstractExporter } } } - + $orderMap = array( + ClassMetadataInfo::ONE_TO_ONE, + ClassMetadataInfo::ONE_TO_MANY, + ClassMetadataInfo::MANY_TO_ONE, + ClassMetadataInfo::MANY_TO_MANY, + ); + uasort($metadata->associationMappings, function($m1, $m2)use(&$orderMap){ + $a1 = array_search($m1['type'],$orderMap); + $a2 = array_search($m2['type'],$orderMap); + return strcmp($a1, $a2); + }); foreach ($metadata->associationMappings as $name => $associationMapping) { if ($associationMapping['type'] == ClassMetadataInfo::ONE_TO_ONE) { $associationMappingXml = $root->addChild('one-to-one'); @@ -204,7 +217,11 @@ class XmlExporter extends AbstractExporter if (isset($associationMapping['inversedBy'])) { $associationMappingXml->addAttribute('inversed-by', $associationMapping['inversedBy']); } - if (isset($associationMapping['orphanRemoval'])) { + if (isset($associationMapping['indexBy'])) { + $associationMappingXml->addAttribute('index-by', $associationMapping['indexBy']); + } + if (isset($associationMapping['orphanRemoval']) && $associationMapping['orphanRemoval']!==false) { + // false is the xml default $associationMappingXml->addAttribute('orphan-removal', $associationMapping['orphanRemoval']); } if (isset($associationMapping['joinTable']) && $associationMapping['joinTable']) { @@ -287,7 +304,7 @@ class XmlExporter extends AbstractExporter } } - if (isset($metadata->lifecycleCallbacks)) { + if (isset($metadata->lifecycleCallbacks) && count($metadata->lifecycleCallbacks)>0) { $lifecycleCallbacksXml = $root->addChild('lifecycle-callbacks'); foreach ($metadata->lifecycleCallbacks as $name => $methods) { foreach ($methods as $method) { From 24432bd0abf1da96b9c2214efdec81ce2911563d Mon Sep 17 00:00:00 2001 From: Asmir Mustafic Date: Fri, 18 Nov 2011 11:00:20 +0100 Subject: [PATCH 2/3] tabs --- lib/Doctrine/ORM/Tools/Export/Driver/XmlExporter.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/Doctrine/ORM/Tools/Export/Driver/XmlExporter.php b/lib/Doctrine/ORM/Tools/Export/Driver/XmlExporter.php index 8ec4d5cd5..3e936a487 100644 --- a/lib/Doctrine/ORM/Tools/Export/Driver/XmlExporter.php +++ b/lib/Doctrine/ORM/Tools/Export/Driver/XmlExporter.php @@ -217,7 +217,7 @@ class XmlExporter extends AbstractExporter if (isset($associationMapping['inversedBy'])) { $associationMappingXml->addAttribute('inversed-by', $associationMapping['inversedBy']); } - if (isset($associationMapping['indexBy'])) { + if (isset($associationMapping['indexBy'])) { $associationMappingXml->addAttribute('index-by', $associationMapping['indexBy']); } if (isset($associationMapping['orphanRemoval']) && $associationMapping['orphanRemoval']!==false) { @@ -331,4 +331,4 @@ class XmlExporter extends AbstractExporter $result = $dom->saveXML(); return $result; } -} \ No newline at end of file +} From 289c186de5d6bc6cbf36f960c4f4f78f1d6fd773 Mon Sep 17 00:00:00 2001 From: Asmir Mustafic Date: Fri, 16 Dec 2011 16:16:52 +0100 Subject: [PATCH 3/3] orphanRemoval default is false --- lib/Doctrine/ORM/Tools/Export/Driver/XmlExporter.php | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/lib/Doctrine/ORM/Tools/Export/Driver/XmlExporter.php b/lib/Doctrine/ORM/Tools/Export/Driver/XmlExporter.php index 3e936a487..1ca5fb403 100644 --- a/lib/Doctrine/ORM/Tools/Export/Driver/XmlExporter.php +++ b/lib/Doctrine/ORM/Tools/Export/Driver/XmlExporter.php @@ -221,8 +221,7 @@ class XmlExporter extends AbstractExporter $associationMappingXml->addAttribute('index-by', $associationMapping['indexBy']); } if (isset($associationMapping['orphanRemoval']) && $associationMapping['orphanRemoval']!==false) { - // false is the xml default - $associationMappingXml->addAttribute('orphan-removal', $associationMapping['orphanRemoval']); + $associationMappingXml->addAttribute('orphan-removal', 'true'); } if (isset($associationMapping['joinTable']) && $associationMapping['joinTable']) { $joinTableXml = $associationMappingXml->addChild('join-table');