mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-06-12 23:00:22 +02:00
use the new finalizer helpers
* libguile/foreign.c (scm_set_pointer_finalizer_x) * libguile/ports.c (finalize_port) * libguile/smob.c (scm_i_new_smob, scm_i_new_double_smob) * libguile/struct.c (scm_i_alloc_struct) * libguile/numbers.c (make_bignum): Use the new API.
This commit is contained in:
parent
7b327550e2
commit
75ba64d679
5 changed files with 12 additions and 60 deletions
|
@ -160,16 +160,8 @@ scm_from_pointer (void *ptr, scm_t_pointer_finalizer finalizer)
|
||||||
ret = scm_cell (scm_tc7_pointer, (scm_t_bits) ptr);
|
ret = scm_cell (scm_tc7_pointer, (scm_t_bits) ptr);
|
||||||
|
|
||||||
if (finalizer)
|
if (finalizer)
|
||||||
{
|
scm_i_set_finalizer (SCM2PTR (ret), pointer_finalizer_trampoline,
|
||||||
/* Register a finalizer for the newly created instance. */
|
finalizer);
|
||||||
GC_finalization_proc prev_finalizer;
|
|
||||||
GC_PTR prev_finalizer_data;
|
|
||||||
GC_REGISTER_FINALIZER_NO_ORDER (SCM2PTR (ret),
|
|
||||||
pointer_finalizer_trampoline,
|
|
||||||
finalizer,
|
|
||||||
&prev_finalizer,
|
|
||||||
&prev_finalizer_data);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -319,20 +311,11 @@ SCM_DEFINE (scm_set_pointer_finalizer_x, "set-pointer-finalizer!", 2, 0, 0,
|
||||||
"Scheme. If you need a Scheme finalizer, use guardians.")
|
"Scheme. If you need a Scheme finalizer, use guardians.")
|
||||||
#define FUNC_NAME s_scm_set_pointer_finalizer_x
|
#define FUNC_NAME s_scm_set_pointer_finalizer_x
|
||||||
{
|
{
|
||||||
void *c_finalizer;
|
|
||||||
GC_finalization_proc prev_finalizer;
|
|
||||||
GC_PTR prev_finalizer_data;
|
|
||||||
|
|
||||||
SCM_VALIDATE_POINTER (1, pointer);
|
SCM_VALIDATE_POINTER (1, pointer);
|
||||||
SCM_VALIDATE_POINTER (2, finalizer);
|
SCM_VALIDATE_POINTER (2, finalizer);
|
||||||
|
|
||||||
c_finalizer = SCM_POINTER_VALUE (finalizer);
|
scm_i_add_finalizer (SCM2PTR (pointer), pointer_finalizer_trampoline,
|
||||||
|
SCM_POINTER_VALUE (finalizer));
|
||||||
GC_REGISTER_FINALIZER_NO_ORDER (SCM2PTR (pointer),
|
|
||||||
pointer_finalizer_trampoline,
|
|
||||||
c_finalizer,
|
|
||||||
&prev_finalizer,
|
|
||||||
&prev_finalizer_data);
|
|
||||||
|
|
||||||
return SCM_UNSPECIFIED;
|
return SCM_UNSPECIFIED;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002,2003,2004,2005, 2006, 2007, 2008, 2009, 2010, 2011 Free Software Foundation, Inc.
|
/* Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002,2003,2004,2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012 Free Software Foundation, Inc.
|
||||||
*
|
*
|
||||||
* Portions Copyright 1990, 1991, 1992, 1993 by AT&T Bell Laboratories
|
* Portions Copyright 1990, 1991, 1992, 1993 by AT&T Bell Laboratories
|
||||||
* and Bellcore. See scm_divide.
|
* and Bellcore. See scm_divide.
|
||||||
|
@ -217,17 +217,13 @@ static inline SCM
|
||||||
make_bignum (void)
|
make_bignum (void)
|
||||||
{
|
{
|
||||||
scm_t_bits *p;
|
scm_t_bits *p;
|
||||||
GC_finalization_proc prev_finalizer;
|
|
||||||
GC_PTR prev_finalizer_data;
|
|
||||||
|
|
||||||
/* Allocate one word for the type tag and enough room for an `mpz_t'. */
|
/* Allocate one word for the type tag and enough room for an `mpz_t'. */
|
||||||
p = scm_gc_malloc_pointerless (sizeof (scm_t_bits) + sizeof (mpz_t),
|
p = scm_gc_malloc_pointerless (sizeof (scm_t_bits) + sizeof (mpz_t),
|
||||||
"bignum");
|
"bignum");
|
||||||
p[0] = scm_tc16_big;
|
p[0] = scm_tc16_big;
|
||||||
|
|
||||||
GC_REGISTER_FINALIZER_NO_ORDER (p, finalize_bignum, NULL,
|
scm_i_set_finalizer (p, finalize_bignum, NULL);
|
||||||
&prev_finalizer,
|
|
||||||
&prev_finalizer_data);
|
|
||||||
|
|
||||||
return SCM_PACK (p);
|
return SCM_PACK (p);
|
||||||
}
|
}
|
||||||
|
|
|
@ -546,14 +546,9 @@ static void finalize_port (GC_PTR, GC_PTR);
|
||||||
static SCM_C_INLINE_KEYWORD void
|
static SCM_C_INLINE_KEYWORD void
|
||||||
register_finalizer_for_port (SCM port)
|
register_finalizer_for_port (SCM port)
|
||||||
{
|
{
|
||||||
GC_finalization_proc prev_finalizer;
|
|
||||||
GC_PTR prev_finalization_data;
|
|
||||||
|
|
||||||
/* Register a finalizer for PORT so that its iconv CDs get freed and
|
/* Register a finalizer for PORT so that its iconv CDs get freed and
|
||||||
optionally its type's `free' function gets called. */
|
optionally its type's `free' function gets called. */
|
||||||
GC_REGISTER_FINALIZER_NO_ORDER (SCM2PTR (port), finalize_port, 0,
|
scm_i_set_finalizer (SCM2PTR (port), finalize_port, NULL);
|
||||||
&prev_finalizer,
|
|
||||||
&prev_finalization_data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Finalize the object (a port) pointed to by PTR. */
|
/* Finalize the object (a port) pointed to by PTR. */
|
||||||
|
|
|
@ -602,14 +602,7 @@ scm_i_new_smob (scm_t_bits tc, scm_t_bits data)
|
||||||
SCM_SET_CELL_WORD_0 (ret, tc);
|
SCM_SET_CELL_WORD_0 (ret, tc);
|
||||||
|
|
||||||
if (scm_smobs[smobnum].free)
|
if (scm_smobs[smobnum].free)
|
||||||
{
|
scm_i_set_finalizer (SCM2PTR (ret), finalize_smob, NULL);
|
||||||
GC_finalization_proc prev_finalizer;
|
|
||||||
GC_PTR prev_finalizer_data;
|
|
||||||
|
|
||||||
GC_REGISTER_FINALIZER_NO_ORDER (SCM2PTR (ret),
|
|
||||||
finalize_smob, NULL,
|
|
||||||
&prev_finalizer, &prev_finalizer_data);
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -636,14 +629,7 @@ scm_i_new_double_smob (scm_t_bits tc, scm_t_bits data1,
|
||||||
SCM_SET_CELL_WORD_0 (ret, tc);
|
SCM_SET_CELL_WORD_0 (ret, tc);
|
||||||
|
|
||||||
if (scm_smobs[smobnum].free)
|
if (scm_smobs[smobnum].free)
|
||||||
{
|
scm_i_set_finalizer (SCM2PTR (ret), finalize_smob, NULL);
|
||||||
GC_finalization_proc prev_finalizer;
|
|
||||||
GC_PTR prev_finalizer_data;
|
|
||||||
|
|
||||||
GC_REGISTER_FINALIZER_NO_ORDER (SCM2PTR (ret),
|
|
||||||
finalize_smob, NULL,
|
|
||||||
&prev_finalizer, &prev_finalizer_data);
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* Copyright (C) 1996,1997,1998,1999,2000,2001, 2003, 2004, 2006, 2007, 2008, 2009, 2010, 2011 Free Software Foundation, Inc.
|
/* Copyright (C) 1996,1997,1998,1999,2000,2001, 2003, 2004, 2006, 2007, 2008, 2009, 2010, 2011, 2012 Free Software Foundation, Inc.
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or
|
* This library is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU Lesser General Public License
|
* modify it under the terms of the GNU Lesser General Public License
|
||||||
|
@ -443,16 +443,8 @@ scm_i_alloc_struct (scm_t_bits *vtable_data, int n_words)
|
||||||
|
|
||||||
/* vtable_data can be null when making a vtable vtable */
|
/* vtable_data can be null when making a vtable vtable */
|
||||||
if (vtable_data && vtable_data[scm_vtable_index_instance_finalize])
|
if (vtable_data && vtable_data[scm_vtable_index_instance_finalize])
|
||||||
{
|
/* Register a finalizer for the newly created instance. */
|
||||||
/* Register a finalizer for the newly created instance. */
|
scm_i_set_finalizer (SCM2PTR (ret), struct_finalizer_trampoline, NULL);
|
||||||
GC_finalization_proc prev_finalizer;
|
|
||||||
GC_PTR prev_finalizer_data;
|
|
||||||
GC_REGISTER_FINALIZER_NO_ORDER (SCM2PTR (ret),
|
|
||||||
struct_finalizer_trampoline,
|
|
||||||
NULL,
|
|
||||||
&prev_finalizer,
|
|
||||||
&prev_finalizer_data);
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue