<?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;
    }
}