1
Fork 0
mirror of https://git.savannah.gnu.org/git/guile.git synced 2025-05-06 15:40:29 +02:00

Add (system finalizers)

This will replace an internal interface in (system foreign-objects).

* module/system/finalizers.scm: New file.
* am/bootstrap.am (SOURCES): Add new file.
* libguile/foreign-object.h:
* libguile/foreign-object.c (invoke_finalizer):
(sys_add_finalizer_x):
(scm_init_foreign_object):
(scm_register_foreign_object): Remove.
* libguile/init.c (scm_i_init_guile): Register finalizers instead of
foreign-object.
* module/system/foreign-object.scm (allocate-instance): Use finalizers
module.
* libguile/finalizers.c (invoke_finalizer):
(scm_sys_add_finalizer): New helper.
This commit is contained in:
Andy Wingo 2025-05-02 15:26:37 +02:00
parent 604a8e8540
commit 75c7f79abc
9 changed files with 98 additions and 49 deletions

View file

@ -0,0 +1,34 @@
;;; Copyright (C) 2025 Free Software Foundation, Inc.
;;;
;;; This library is free software: you can redistribute it and/or modify
;;; it under the terms of the GNU Lesser General Public License as
;;; published by the Free Software Foundation, either version 3 of the
;;; License, or (at your option) any later version.
;;;
;;; This library is distributed in the hope that it will be useful, but
;;; WITHOUT ANY WARRANTY; without even the implied warranty of
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
;;; Lesser General Public License for more details.
;;;
;;; You should have received a copy of the GNU Lesser General Public
;;; License along with this program. If not, see
;;; <http://www.gnu.org/licenses/>.
(define-module (system finalizers)
#:export (add-finalizer!
%guardian-finalizer-priority
%default-finalizer-priority))
(eval-when (expand load eval)
(load-extension (string-append "libguile-" (effective-version))
"scm_init_finalizers_module"))
(define %guardian-finalizer-priority 1)
(define %default-finalizer-priority 0)
(define* (add-finalizer! obj proc
#:optional (priority %default-finalizer-priority))
"Add a finalizer @var{proc} to object @var{obj}, with priority
@var{priority}. Return the finalizer object."
(%add-finalizer! obj proc priority))

View file

@ -1,6 +1,6 @@
;;; Wrapping foreign objects in Scheme
;;; Copyright (C) 2014, 2015, 2024 Free Software Foundation, Inc.
;;; Copyright (C) 2014, 2015, 2024, 2025 Free Software Foundation, Inc.
;;;
;;; This library is free software; you can redistribute it and/or
;;; modify it under the terms of the GNU Lesser General Public
@ -24,13 +24,10 @@
(define-module (system foreign-object)
#:use-module (oop goops)
#:use-module (system finalizers)
#:export (make-foreign-object-type
define-foreign-object-type))
(eval-when (eval load expand)
(load-extension (string-append "libguile-" (effective-version))
"scm_init_foreign_object"))
(define-class <foreign-class> (<class>))
(define-class <foreign-class-with-finalizer> (<foreign-class>)
@ -42,7 +39,7 @@
(let ((instance (next-method))
(finalizer (finalizer class)))
(when finalizer
(%add-finalizer! instance finalizer))
(add-finalizer! instance finalizer))
instance))
(define* (make-foreign-object-type name slots #:key finalizer