X-Git-Url: http://git.kpe.io/?p=clsql.git;a=blobdiff_plain;f=sql%2Ftransactions.cl;h=c95e8c307501fd368049b48623af48401658b242;hp=7717162d604cbf833b427dd50903dfbb2a5ac782;hb=998937376fa6f9ce29bd3c7954fb0ebca91c37d7;hpb=e930501699cd43183e458fdc1bbfd45dd4094344 diff --git a/sql/transactions.cl b/sql/transactions.cl index 7717162..c95e8c3 100644 --- a/sql/transactions.cl +++ b/sql/transactions.cl @@ -7,7 +7,7 @@ ;;;; Programmers: Marc Battyani ;;;; Date Started: Apr 2002 ;;;; -;;;; $Id: transactions.cl,v 1.3 2002/05/10 08:05:48 marc.battyani Exp $ +;;;; $Id: transactions.cl,v 1.7 2002/09/17 17:16:43 kevin Exp $ ;;;; ;;;; This file, part of CLSQL, is Copyright (c) 2002 by Kevin M. Rosenberg ;;;; @@ -27,7 +27,7 @@ (status :initform nil :accessor status))) ;can be nil :rolled-back or :commited (defmethod database-start-transaction ((database closed-database)) - (signal-closed-database-error database)) + (error 'clsql-closed-database-error database)) (defmethod database-start-transaction (database) (unless (transaction database) @@ -40,7 +40,7 @@ (execute-command "BEGIN" :database database)))) (defmethod database-end-transaction ((database closed-database)) - (signal-closed-database-error database)) + (error 'clsql-closed-database-error database)) (defmethod database-end-transaction (database) (if (> (transaction-level database) 0) @@ -52,7 +52,7 @@ (map nil #'funcall (commit-hooks transaction))) (unwind-protect ;status is not :commited (execute-command "ROLLBACK" :database database) - (map nil #'funcall (rollback-hooks database)))))) + (map nil #'funcall (rollback-hooks transaction)))))) (warn "Continue without commit." 'clsql-simple-error :format-control "Cannot commit transaction against ~A because there is no transaction in progress." @@ -66,9 +66,9 @@ (when (and (transaction database)(not (status (transaction database)))) (setf (status (transaction database)) :commited))) -(defun add-transaction-commit-hook (database abort-hook) +(defun add-transaction-commit-hook (database commit-hook) (when (transaction database) - (push abort-hook (abort-hooks (transaction database))))) + (push commit-hook (commit-hooks (transaction database))))) (defun add-transaction-rollback-hook (database rollback-hook) (when (transaction database) @@ -79,7 +79,7 @@ `(let ((,db ,database)) (unwind-protect (progn - (start-transaction ,db) + (database-start-transaction ,db) ,@body (commit-transaction ,db)) (database-end-transaction ,db)))))