From ab566f2c276d5b73296cd5c1f3ff4b01a98ebfdd Mon Sep 17 00:00:00 2001 Message-Id: From: Mark Wooding Date: Wed, 23 Aug 2000 21:36:44 +0000 Subject: [PATCH] Fixed a design flaw in quark-from-object Organization: Straylight/Edgeware From: espen --- glib/glib.lisp | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/glib/glib.lisp b/glib/glib.lisp index edbbd16..1d4e200 100644 --- a/glib/glib.lisp +++ b/glib/glib.lisp @@ -15,7 +15,7 @@ ;; License along with this library; if not, write to the Free Software ;; Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA -;; $Id: glib.lisp,v 1.4 2000-08-23 14:27:41 espen Exp $ +;; $Id: glib.lisp,v 1.5 2000-08-23 21:36:44 espen Exp $ (in-package "GLIB") @@ -54,7 +54,11 @@ (defun quark-from-object (object &key (test #'eq)) (or (assoc-ref object (gethash hash-code *quark-from-object*) :test test) (let ((quark (%quark-get-reserved))) - (push (cons object quark) (gethash hash-code *quark-from-object*)) + (setf + (gethash hash-code *quark-from-object*) + (append + (gethash hash-code *quark-from-object*) + (list (cons object quark)))) (setf (gethash quark *quark-to-object*) object) quark)))) -- [mdw]