X-Git-Url: https://git.distorted.org.uk/~mdw/clg/blobdiff_plain/a75fc933fb4fccfc8ea1c1c5349bc5d77d74f4f8..9535cfbda4702d3c28e2257a03a90dc11d8cdeb6:/gffi/proxy.lisp diff --git a/gffi/proxy.lisp b/gffi/proxy.lisp index b3802b7..c54c423 100644 --- a/gffi/proxy.lisp +++ b/gffi/proxy.lisp @@ -20,7 +20,7 @@ ;; TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE ;; SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -;; $Id: proxy.lisp,v 1.6 2007/01/12 10:26:44 espen Exp $ +;; $Id: proxy.lisp,v 1.8 2007/05/10 20:23:28 espen Exp $ (in-package "GFFI") @@ -87,7 +87,7 @@ (defvar *foreign-instance-locations* (make-hash-table #+clisp :weak #+sbcl :weakness :key)) -;; TODO: add a ref-counted-proxy subclass + (eval-when (:compile-toplevel :load-toplevel :execute) (defclass proxy (virtual-slots-object) (#?-(or (sbcl>= 0 9 17) (featurep :clisp))(%location :special t :type pointer)) @@ -167,6 +167,7 @@ ;; :FINALZIE given to MAKE-PROXY-INSTANCE or non NIL if the proxy was ;; created with MAKE-INSTANCE (defmethod invalidate-instance ((instance proxy) &optional finalize-p) + #+clisp(declare (ignore finalize-p)) (remove-cached-instance (foreign-location instance)) #+(or sbcl cmu) (progn