Custom Query (1030 matches)
Results (730 - 732 of 1030)
| Ticket | Resolution | Summary | Owner | Reporter |
|---|---|---|---|---|
| #1350 | fixed | Firefox doesn't like lists.clozure.com | ||
| Description |
Trying to open https://lists.clozure.com/pipermail/openmcl-devel/2008-February/003755.html , I get: "The owner of lists.clozure.com has configured their website improperly. To protect your information from being stolen, Firefox has not connected to this website." |
|||
| #896 | fixed | Finalizer ordering | ||
| Description |
As per discussion on #ccl: Finalizer ordering is currently arbitrary or backwards where it seems it should not be. (Note the definition of FINALIZE is essentially lifted from TRIVIAL-GARBAGE.) ;; This is a demonstration of finalization order in CCL. When I run this,
;; I get the following output:
;;
;; Finalize FOO 1
;; Finalize FOO 2
;; I would like #S(FOO) 2
;; Finalize BAR 2
;;
;; This unfortunately means that if the FOO finalizer does something destructive
;; and permanent (like freeing a foreign value), BAR's finalizer can cause a
;; crash.
(defstruct (foo (:constructor %make-foo)))
(defstruct (bar (:constructor %make-bar)))
(defun finalize (object function)
(ccl:terminate-when-unreachable object
(lambda (obj)
(declare (ignore obj))
(funcall function)))
object)
(defun make-foo (id)
(let* ((foo (%make-foo)))
(finalize foo (lambda () (format t "~&Finalize FOO ~A~%" id)))))
(defun make-bar (id)
(let* ((foo (make-foo id))
(bar (%make-bar)))
(finalize bar
(lambda ()
(format t "~&I would like ~A ~A~%" foo id)
(format t "~&Finalize BAR ~A~%" id)))))
(make-foo 1)
(make-bar 2)
(gc)
One would expect that FOO 2 would not be finalized until after BAR 2, because FOO 2 is referenced by BAR 2's finalizer lambda. I surmise that this is because the only reference to a finalizer is via its object, and therefore, anything the finalizer references becomes eligible for collection as soon as the object itself does. A simple workaround is to simply strongly reference the lambda, and then make it dereference itself: (defvar *strong-finalizers* (make-hash-table))
(defstruct (foo (:constructor %make-foo)))
(defstruct (bar (:constructor %make-bar)))
(defun finalize (object function)
(setf (gethash function *strong-finalizers*) t)
(ccl:terminate-when-unreachable object
(lambda (obj)
(declare (ignore obj))
(funcall function)
(remhash function *strong-finalizers*)))
object)
(defun make-foo (id)
(let* ((foo (%make-foo)))
(finalize foo (lambda () (format t "~&Finalize FOO ~A~%" id)))))
(defun make-bar (id)
(let* ((foo (make-foo id))
(bar (%make-bar)))
(finalize bar
(lambda ()
(format t "~&I would like ~A ~A~%" foo id)
(format t "~&Finalize BAR ~A~%" id)))))
(make-bar 2)
(gc)
(make-foo 1)
(gc)
(gc)
(gc)
In this case, the finalizer for FOO 2 is not called until the next cycle (though it appears to take some allocation and a cycle or two to make it notice). |
|||
| #1374 | worksforme | Feature request: Export unix signals | ||
| Description |
Since the numerical value of a signal depends on the version of the posix standard and is thus different on different operating systems (e.g. SIGCONT is 19 on macOS but 18 on Linux (it might even be more complicated than that)), it's nice to be able to query the lisp compiler/interpreter for the number behind a name. Allegro CL, CMU CL, ECL, and SBCL each provide such a mechanism (through constants or functions). It would be nice if so did Clozure CL. |
|||
