From e0eafb56d76884a6c1f1610b3904f4e2dfa5e7c4 Mon Sep 17 00:00:00 2001
From: zYne <zYne@625475ce-881a-0410-a577-b389adb331d8>
Date: Mon, 21 May 2007 20:06:18 +0000
Subject: [PATCH]

---
 lib/Doctrine/Table.php | 49 ++++++++++++++++++++++--------------------
 1 file changed, 26 insertions(+), 23 deletions(-)

diff --git a/lib/Doctrine/Table.php b/lib/Doctrine/Table.php
index f58950fc8..f18c481a2 100644
--- a/lib/Doctrine/Table.php
+++ b/lib/Doctrine/Table.php
@@ -166,6 +166,10 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable
      * @var Doctrine_Tree $tree             tree object associated with this table
      */
     protected $tree;
+    /**
+     * @var Doctrine_Relation_Parser $_parser   relation parser object
+     */
+    protected $_parser;
     /**
      * the constructor
      * @throws Doctrine_Connection_Exception    if there are no opened connections
@@ -179,9 +183,10 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable
         $this->setParent($this->conn);
 
         $this->options['name'] = $name;
+        $this->_parser = new Doctrine_Relation_Parser($this);
 
         if ( ! class_exists($name) || empty($name)) {
-            throw new Doctrine_Exception("Couldn't find class $name");
+            throw new Doctrine_Exception("Couldn't find class " . $name);
         }
         $record = new $name($this);
 
@@ -192,8 +197,9 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable
         // get parent classes
 
         do {
-            if ($class == "Doctrine_Record")
-                break;
+            if ($class == "Doctrine_Record") {
+                break;                        
+            }
 
             $name  = $class;
             $names[] = $name;
@@ -207,9 +213,10 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable
             $record->setTableDefinition();
 
             // set the table definition for the given tree implementation
-            if($this->isTree())
+            if ($this->isTree()) {
                 $this->getTree()->setTableDefinition();
-
+            }
+            
             $this->columnCount = count($this->columns);
 
             if (isset($this->columns)) {
@@ -284,19 +291,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable
                             $this->identifier = $pk;
                         }
                     }
-                };
-                /**
-                            if ( ! isset($definition['values'])) {
-                                throw new Doctrine_Table_Exception('No values set for enum column ' . $name);
-                            }
-
-                            if ( ! is_array($definition['values'])) {
-                                throw new Doctrine_Table_Exception('Enum column values should be specified as an array.');
-                            }
-
-                 */
-
-
+                }
             }
         } else {
             throw new Doctrine_Table_Exception("Class '$name' has no table definition.");
@@ -313,9 +308,6 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable
         array_pop($names);
         $this->options['parents']   = $names;
 
-        $this->query     = 'SELECT ' . implode(', ', array_keys($this->columns)) . ' FROM ' . $this->getTableName();
-
-
         $this->repository = new Doctrine_Table_Repository($this);
     }
     /**
@@ -412,7 +404,17 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable
             throw $e;
         }
     }
-    /** 
+    /**
+     * getRelationParser
+     * return the relation parser associated with this table
+     *
+     * @return Doctrine_Relation_Parser     relation parser object
+     */
+    public function getRelationParser()
+    {
+        return $this->_parser;
+    }
+    /**
      * __get
      * an alias for getOption
      *
@@ -1048,7 +1050,8 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable
                 $id = array_values($id);
             }
 
-            $query  = $this->query . ' WHERE ' . implode(' = ? AND ', $this->primaryKeys) . ' = ?';
+            $query  = 'SELECT ' . implode(', ', array_keys($this->columns)) . ' FROM ' . $this->getTableName() 
+                    . ' WHERE ' . implode(' = ? AND ', $this->primaryKeys) . ' = ?';
             $query  = $this->applyInheritance($query);
 
             $params = array_merge($id, array_values($this->options['inheritanceMap']));