X-Git-Url: http://git.kpe.io/?p=clsql.git;a=blobdiff_plain;f=db-oracle%2Fforeign-resources.lisp;h=3344cb4bd12009f0ab62d9f817b76821263acab8;hp=919a21156e4f8f478b5cf2455f5ea2d6476eceae;hb=d2d49ab13c98bc7a1819a0fd3968268a5567bdc3;hpb=5c67b804b62d2970685ebd8d28c88446457be975 diff --git a/db-oracle/foreign-resources.lisp b/db-oracle/foreign-resources.lisp index 919a211..3344cb4 100644 --- a/db-oracle/foreign-resources.lisp +++ b/db-oracle/foreign-resources.lisp @@ -2,8 +2,6 @@ ;;;; ************************************************************************* ;;;; FILE IDENTIFICATION ;;;; -;;;; $Id$ -;;;; ;;;; This file is part of CLSQL. ;;;; ;;;; CLSQL users are granted the rights to distribute and use this software @@ -17,36 +15,36 @@ (defstruct (foreign-resource) (type (error "Missing TYPE.") - :read-only t) + :read-only t) (sizeof (error "Missing SIZEOF.") - :read-only t) + :read-only t) (buffer (error "Missing BUFFER.") - :read-only t) + :read-only t) (in-use nil :type boolean)) (defun %get-resource (type sizeof) (let ((resources (gethash type *foreign-resource-hash*))) (car (member-if - #'(lambda (res) - (and (= (foreign-resource-sizeof res) sizeof) - (not (foreign-resource-in-use res)))) - resources)))) + #'(lambda (res) + (and (= (foreign-resource-sizeof res) sizeof) + (not (foreign-resource-in-use res)))) + resources)))) (defun %insert-foreign-resource (type res) (let ((resource (gethash type *foreign-resource-hash*))) (setf (gethash type *foreign-resource-hash*) - (cons res (gethash type *foreign-resource-hash*))))) + (cons res resource)))) (defmacro acquire-foreign-resource (type &optional size) `(let ((res (%get-resource ,type ,size))) (unless res (setf res (make-foreign-resource - :type ,type :sizeof ,size - :buffer (uffi:allocate-foreign-object ,type ,size))) + :type ,type :sizeof ,size + :buffer (uffi:allocate-foreign-object ,type ,size))) (%insert-foreign-resource ',type res)) (claim-foreign-resource res))) - + (defun free-foreign-resource (ares) (setf (foreign-resource-in-use ares) nil) ares)