1
Fork 0
mirror of https://git.savannah.gnu.org/git/guile.git synced 2025-06-04 11:10:27 +02:00
guile/libguile/deprecated.c
Andy Wingo c63f9101f8 Reimplement weak vectors in Scheme using ephemerons
* module/ice-9/weak-vector.scm: New implementation, same interface.

* doc/ref/api-memory.texi (Weak vectors): Default weak vector value was
documented as empty list when it was actually unspecified, but #f is
most useful, so we change documentation and code to match.

* libguile/Makefile.am (libguile_@GUILE_EFFECTIVE_VERSION@_la_SOURCES):
(DOT_X_FILES):
(DOT_DOC_FILES):
(noinst_HEADERS):
(modinclude_HEADERS):
* libguile.h:
* libguile/deprecated.c:
* libguile/deprecated.h:
* libguile/init.c:
* libguile/weak-vector.c:
* libguile/weak-vector.h: Remove C weak vector implementation, replaced
with deprecation stubs that call out to Scheme.

* libguile/weak-set.c:
* libguile/weak-table.c:
* libguile/weak-list.h: Remove unused internal header.

* libguile/eq.c:
* libguile/evalext.c:
* libguile/goops.c:
* libguile/hash.c:
* libguile/scm.h:
* module/system/base/types.scm:
* module/system/base/types/internal.scm:
* module/system/vm/assembler.scm: Remove wvect tc7.
2025-05-05 16:29:24 +02:00

180 lines
4.2 KiB
C
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/* Copyright 2003-2004,2006,2008-2018,2020,2021,2022,2025
Free Software Foundation, Inc.
This file is part of Guile.
Guile 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.
Guile 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 Guile. If not, see
<https://www.gnu.org/licenses/>. */
#ifdef HAVE_CONFIG_H
# include <config.h>
#endif
#define SCM_BUILDING_DEPRECATED_CODE
#include "deprecation.h"
#include "eval.h"
#include "gsubr.h"
#include "modules.h"
#include "numbers.h"
#include "threads.h"
#include "variable.h"
#include "deprecated.h"
#if (SCM_ENABLE_DEPRECATED == 1)
/* Deprecated functions go here. */
static SCM make_guardian_var;
static void
init_make_guardian_var (void)
{
make_guardian_var = scm_c_public_lookup ("ice-9 guardians", "make-guardian");
}
SCM
scm_make_guardian (void)
{
static scm_i_pthread_once_t once = SCM_I_PTHREAD_ONCE_INIT;
scm_i_pthread_once (&once, init_make_guardian_var);
scm_c_issue_deprecation_warning
("The scm_make_guardian C interface is deprecated. Invoke the Scheme "
"make-guardian procedure from (ice-9 guardians) instead.");
return scm_call_0 (scm_variable_ref (make_guardian_var));
}
static SCM make_weak_vector_var;
static SCM weak_vector_var;
static SCM weak_vector_p_var;
static SCM weak_vector_length_var;
static SCM weak_vector_ref_var;
static SCM weak_vector_set_x_var;
static void
init_weak_vector_vars (void)
{
make_weak_vector_var =
scm_c_public_lookup ("ice-9 weak-vector", "make-weak-vector");
weak_vector_var =
scm_c_public_lookup ("ice-9 weak-vector", "weak-vector");
weak_vector_p_var =
scm_c_public_lookup ("ice-9 weak-vector", "weak-vector?");
weak_vector_length_var =
scm_c_public_lookup ("ice-9 weak-vector", "weak-vector-length");
weak_vector_ref_var =
scm_c_public_lookup ("ice-9 weak-vector", "weak-vector-ref");
weak_vector_set_x_var =
scm_c_public_lookup ("ice-9 weak-vector", "weak-vector-set!");
}
static void
init_weak_vectors (void)
{
static scm_i_pthread_once_t once = SCM_I_PTHREAD_ONCE_INIT;
scm_c_issue_deprecation_warning
("The weak vector C interface is deprecated. Invoke the Scheme "
"procedures from (ice-9 weak-vector) instead.");
scm_i_pthread_once (&once, init_weak_vector_vars);
}
SCM
scm_make_weak_vector (SCM len, SCM fill)
{
init_weak_vectors ();
return scm_call_2 (scm_variable_ref (make_weak_vector_var), len,
SCM_UNBNDP (fill) ? SCM_BOOL_F : fill);
}
SCM
scm_weak_vector (SCM l)
{
init_weak_vectors ();
return scm_call_1 (scm_variable_ref (weak_vector_var), l);
}
SCM
scm_weak_vector_p (SCM x)
{
init_weak_vectors ();
return scm_call_1 (scm_variable_ref (weak_vector_p_var), x);
}
SCM
scm_weak_vector_length (SCM v)
{
init_weak_vectors ();
return scm_call_1 (scm_variable_ref (weak_vector_length_var), v);
}
SCM
scm_weak_vector_ref (SCM v, SCM k)
{
init_weak_vectors ();
return scm_call_2 (scm_variable_ref (weak_vector_ref_var), v, k);
}
SCM
scm_weak_vector_set_x (SCM v, SCM k, SCM x)
{
init_weak_vectors ();
scm_call_3 (scm_variable_ref (weak_vector_set_x_var), v, k, x);
return SCM_UNSPECIFIED;
}
SCM
scm_c_make_weak_vector (size_t len, SCM fill)
{
return scm_make_weak_vector (scm_from_size_t (len), fill);
}
int
scm_is_weak_vector (SCM obj)
{
return scm_is_true (scm_weak_vector_p (obj));
}
size_t
scm_c_weak_vector_length (SCM vec)
{
return scm_to_size_t (scm_weak_vector_length (vec));
}
SCM
scm_c_weak_vector_ref (SCM v, size_t k)
{
return scm_weak_vector_ref (v, scm_from_size_t (k));
}
void
scm_c_weak_vector_set_x (SCM v, size_t k, SCM x)
{
scm_weak_vector_set_x (v, scm_from_size_t (k), x);
}
void
scm_i_init_deprecated ()
{
#include "deprecated.x"
}
#endif /* SCM_ENABLE_DEPRECATED == 1 */