<?php /* * $Id: Yml.php 1838 2007-06-26 00:58:21Z nicobn $ * * 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.phpdoctrine.com>. */ /** * class Doctrine_Import_Schema_Yml * * Different methods to import a YML schema. The logic behind using two different * methods is simple. Some people will like the idea of producing Doctrine_Record * objects directly, which is totally fine. But in fast and growing application, * table definitions tend to be a little bit more volatile. importArr() can be used * to output a table definition in a PHP file. This file can then be stored * independantly from the object itself. * * @package Doctrine * @category Object Relational Mapping * @link www.phpdoctrine.com * @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @version $Revision: 1838 $ * @author Nicolas BĂ©rard-Nault <nicobn@gmail.com> * @author Jonathan H. Wage <jonwage@gmail.com> */ class Doctrine_Import_Schema_Yml extends Doctrine_Import_Schema { /** * parse * * @param string $schema * @return void */ public function parse($schema) { if (!is_readable($schema)) { throw new Doctrine_Import_Exception('Could not read schema file '. $schema); } return array(); } /** * parseSchema * * A method to parse a Yml Schema and translate it into a property array. * The function returns that property array. * * @param string $schema Path to the file containing the XML schema * @return array */ public function parseSchema($schema) { $array = $this->parse($schema); $tables = array(); // Not working yet /* // Go through all tables... foreach ($array['table'] as $table) { // Go through all columns... foreach ($table['declaration']['field'] as $field) { $colDesc = array( 'name' => (string) $field['name'], 'type' => (string) $field['type'], 'ptype' => (string) $field['type'], 'length' => (int) $field['length'], 'fixed' => (int) $field['fixed'], 'unsigned' => (bool) $field['unsigned'], 'primary' => (bool) (isset($field['primary']) && $field['primary']), 'default' => (string) $field['default'], 'notnull' => (bool) (isset($field['notnull']) && $field['notnull']), 'autoinc' => (bool) (isset($field['autoincrement']) && $field['autoincrement']), ); $columns[(string) $field['name']] = $colDesc; } $tables[(string) $table['name']] = $columns; } */ return $tables; } }