From b13a70c08778104b0d2e3cc8e4cca67de56851b3 Mon Sep 17 00:00:00 2001
From: zYne <zYne@625475ce-881a-0410-a577-b389adb331d8>
Date: Wed, 18 Jul 2007 19:18:30 +0000
Subject: [PATCH]

---
 lib/Doctrine/AuditLog.php             | 10 +++---
 lib/Doctrine/AuditLog/Listener.php    |  9 ++++-
 lib/Doctrine/Template/Versionable.php | 51 +++++++++++++++++++++++++++
 3 files changed, 64 insertions(+), 6 deletions(-)
 create mode 100644 lib/Doctrine/Template/Versionable.php

diff --git a/lib/Doctrine/AuditLog.php b/lib/Doctrine/AuditLog.php
index 3f574baf5..5044327a9 100644
--- a/lib/Doctrine/AuditLog.php
+++ b/lib/Doctrine/AuditLog.php
@@ -43,10 +43,6 @@ class Doctrine_AuditLog
     public function __construct($options)
     {
         $this->_options = array_merge($this->_options, $options);
-        
-        $this->_options['className'] = str_replace('%CLASS%', 
-                                                   $this->_options['table']->getComponentName(),
-                                                   $this->_options['className']);
     }
     /**
      * __get
@@ -133,7 +129,11 @@ class Doctrine_AuditLog
         return $q->execute($values, Doctrine_HYDRATE::HYDRATE_ARRAY);
     }
     public function buildDefinition(Doctrine_Table $table)
-    {
+    {              
+        $this->_options['className'] = str_replace('%CLASS%', 
+                                                   $this->_options['table']->getComponentName(),
+                                                   $this->_options['className']);
+
         $name = $table->getComponentName();
 
         $className = $name . 'Version';
diff --git a/lib/Doctrine/AuditLog/Listener.php b/lib/Doctrine/AuditLog/Listener.php
index ff3ed9a01..0405393ab 100644
--- a/lib/Doctrine/AuditLog/Listener.php
+++ b/lib/Doctrine/AuditLog/Listener.php
@@ -52,6 +52,7 @@ class Doctrine_AuditLog_Listener extends Doctrine_Record_Listener
 
         $version = new $class();
         $version->merge($record->toArray());
+        $version->save();
 
     	$versionColumn = $this->_auditLog->getOption('versionColumn');
     	$version = $record->get($versionColumn);
@@ -60,8 +61,14 @@ class Doctrine_AuditLog_Listener extends Doctrine_Record_Listener
     }
     public function preUpdate(Doctrine_Event $event)
     {
+    	$class = $this->_auditLog->getOption('className');
+        $record  = $event->getInvoker();
+        
+        $version = new $class();
+        $version->merge($record->toArray());
+        $version->save();        
+
     	$versionColumn = $this->_auditLog->getOption('versionColumn');
-    	$record  = $event->getInvoker();
 
     	$version = $record->get($versionColumn);
 
diff --git a/lib/Doctrine/Template/Versionable.php b/lib/Doctrine/Template/Versionable.php
new file mode 100644
index 000000000..8a94582be
--- /dev/null
+++ b/lib/Doctrine/Template/Versionable.php
@@ -0,0 +1,51 @@
+<?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.phpdoctrine.com>.
+ */
+/**
+ * Doctrine_Template_Versionable
+ *
+ * @package     Doctrine
+ * @license     http://www.opensource.org/licenses/lgpl-license.php LGPL
+ * @category    Object Relational Mapping
+ * @link        www.phpdoctrine.com
+ * @since       1.0
+ * @version     $Revision$
+ * @author      Konsta Vesterinen <kvesteri@cc.hut.fi>
+ */
+class Doctrine_Template_Versionable extends Doctrine_Template
+{
+    protected $_auditLog;
+
+    public function __construct(array $options)
+    {
+        $this->_auditLog = new Doctrine_AuditLog($options);
+    }
+    public function setUp()
+    {
+    	$this->_auditLog->setOption('table', $this->_table);
+        $this->_auditLog->buildDefinition($this->_table);
+
+        $this->addListener(new Doctrine_AuditLog_Listener($this->_auditLog));
+    }
+    public function getAuditLog()
+    {
+        return $this->_auditLog;
+    }
+}