12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- <?php
- /*
- * $Id$
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
- * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
- * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
- * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
- * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
- * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- *
- * This software consists of voluntary contributions made by many individuals
- * and is licensed under the LGPL. For more information, see
- * <http://www.doctrine-project.org>.
- */
- namespace Doctrine\ORM\Tools\Export;
- use Doctrine\ORM\Tools\Export\ExportException,
- Doctrine\ORM\EntityManager;
- /**
- * Class used for converting your mapping information between the
- * supported formats: yaml, xml, and php/annotation.
- *
- * @license http://www.opensource.org/licenses/lgpl-license.php LGPL
- * @link www.doctrine-project.org
- * @since 2.0
- * @version $Revision$
- * @author Jonathan Wage <jonwage@gmail.com>
- */
- class ClassMetadataExporter
- {
- private static $_exporterDrivers = array(
- 'xml' => 'Doctrine\ORM\Tools\Export\Driver\XmlExporter',
- 'yaml' => 'Doctrine\ORM\Tools\Export\Driver\YamlExporter',
- 'yml' => 'Doctrine\ORM\Tools\Export\Driver\YamlExporter',
- 'php' => 'Doctrine\ORM\Tools\Export\Driver\PhpExporter',
- 'annotation' => 'Doctrine\ORM\Tools\Export\Driver\AnnotationExporter'
- );
- /**
- * Register a new exporter driver class under a specified name
- *
- * @param string $name
- * @param string $class
- */
- public static function registerExportDriver($name, $class)
- {
- self::$_exporterDrivers[$name] = $class;
- }
- /**
- * Get a exporter driver instance
- *
- * @param string $type The type to get (yml, xml, etc.)
- * @param string $source The directory where the exporter will export to
- * @return AbstractExporter $exporter
- */
- public function getExporter($type, $dest = null)
- {
- if ( ! isset(self::$_exporterDrivers[$type])) {
- throw ExportException::invalidExporterDriverType($type);
- }
- $class = self::$_exporterDrivers[$type];
- return new $class($dest);
- }
- }
|