mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-06-06 20:20:20 +02:00
* module/ice-9/source-properties.scm: New file, providing the source-properties API, as well as a replacement for `read' that always attaches source properties, regardless of the 'positions option on the port. * am/bootstrap.am (SOURCES): Add the new file. * libguile/srcprop.c: * libguile/srcprop.h: Remove. * libguile/Makefile.am (libguile_@GUILE_EFFECTIVE_VERSION@_la_SOURCES): (DOT_X_FILES): (DOT_DOC_FILES): (modinclude_HEADERS): * libguile.h: Remove srcprop.h. * libguile/deprecated.c: * libguile/deprecated.h: Add deprecation shims for srcprop.h interface. * libguile/backtrace.c: * libguile/debug.c: * libguile/eval.c: * libguile/init.c: * libguile/memoize.c: * libguile/promises.c: * libguile/read.c: * libguile/syntax.c: Remove needless srcprop.h includes. * module/ice-9/boot-9.scm: Reorder some definitions so that deprecated modules can use the (system syntax internal) module. * module/ice-9/deprecated.scm: Add shims for Scheme source-properties interface. * module/ice-9/read.scm (read): Never attach source properties. Users that want source can use read-syntax. * module/language/cps.scm: * module/language/cps/spec.scm: * module/language/ecmascript/compile-tree-il.scm: * module/language/elisp/compile-tree-il.scm: * module/language/elisp/lexer.scm: * module/language/elisp/parser.scm: * module/language/tree-il.scm: * module/language/tree-il/spec.scm: * module/language/wisp.scm: * module/system/base/lalr.scm: * test-suite/tests/elisp-reader.test: * test-suite/tests/reader.test: * test-suite/tests/srcprop.test: * test-suite/tests/srfi-105.test: * test-suite/tests/srfi-119.test: Use the (ice-9 source-properties) module to get access to source properties.
316 lines
7.7 KiB
C
316 lines
7.7 KiB
C
/* 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 "symbols.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);
|
||
}
|
||
|
||
|
||
|
||
|
||
static SCM object_properties_var;
|
||
static SCM set_object_properties_var;
|
||
static SCM object_property_var;
|
||
static SCM set_object_property_var;
|
||
|
||
static void
|
||
init_object_properties_vars (void)
|
||
{
|
||
object_properties_var =
|
||
scm_c_public_lookup ("ice-9 object-properties", "object-properties");
|
||
set_object_properties_var =
|
||
scm_c_public_lookup ("ice-9 object-properties", "set-object-properties!");
|
||
object_property_var =
|
||
scm_c_public_lookup ("ice-9 object-properties", "object-property");
|
||
set_object_property_var =
|
||
scm_c_public_lookup ("ice-9 object-properties", "set-object-property!");
|
||
}
|
||
|
||
static void
|
||
init_object_properties (void)
|
||
{
|
||
static scm_i_pthread_once_t once = SCM_I_PTHREAD_ONCE_INIT;
|
||
scm_c_issue_deprecation_warning
|
||
("The object properties C interface is deprecated. Invoke the Scheme "
|
||
"procedures from (ice-9 object-properties) instead.");
|
||
scm_i_pthread_once (&once, init_object_properties_vars);
|
||
}
|
||
|
||
SCM
|
||
scm_object_properties (SCM obj)
|
||
{
|
||
init_object_properties ();
|
||
return scm_call_1 (scm_variable_ref (object_properties_var), obj);
|
||
}
|
||
|
||
|
||
SCM
|
||
scm_set_object_properties_x (SCM obj, SCM alist)
|
||
{
|
||
init_object_properties ();
|
||
return scm_call_2 (scm_variable_ref (set_object_properties_var), obj, alist);
|
||
}
|
||
|
||
SCM
|
||
scm_object_property (SCM obj, SCM key)
|
||
{
|
||
init_object_properties ();
|
||
return scm_call_2 (scm_variable_ref (object_property_var), obj, key);
|
||
}
|
||
|
||
SCM
|
||
scm_set_object_property_x (SCM obj, SCM key, SCM value)
|
||
{
|
||
init_object_properties ();
|
||
return scm_call_3 (scm_variable_ref (set_object_property_var), obj, key, value);
|
||
}
|
||
|
||
|
||
|
||
|
||
SCM_GLOBAL_SYMBOL (scm_sym_filename, "filename");
|
||
SCM_GLOBAL_SYMBOL (scm_sym_line, "line");
|
||
SCM_GLOBAL_SYMBOL (scm_sym_column, "column");
|
||
|
||
static SCM source_properties_var;
|
||
static SCM set_source_properties_var;
|
||
static SCM source_property_var;
|
||
static SCM set_source_property_var;
|
||
static SCM cons_source_var;
|
||
|
||
static void
|
||
init_source_properties_vars (void)
|
||
{
|
||
source_properties_var =
|
||
scm_c_public_lookup ("ice-9 source-properties", "source-properties");
|
||
set_source_properties_var =
|
||
scm_c_public_lookup ("ice-9 source-properties", "set-source-properties!");
|
||
source_property_var =
|
||
scm_c_public_lookup ("ice-9 source-properties", "source-property");
|
||
set_source_property_var =
|
||
scm_c_public_lookup ("ice-9 source-properties", "set-source-property!");
|
||
cons_source_var =
|
||
scm_c_public_lookup ("ice-9 source-properties", "cons-source");
|
||
}
|
||
|
||
static void
|
||
init_source_properties (void)
|
||
{
|
||
static scm_i_pthread_once_t once = SCM_I_PTHREAD_ONCE_INIT;
|
||
scm_c_issue_deprecation_warning
|
||
("The source properties C interface is deprecated. Invoke the Scheme "
|
||
"procedures from (ice-9 source-properties) instead.");
|
||
scm_i_pthread_once (&once, init_source_properties_vars);
|
||
}
|
||
|
||
SCM
|
||
scm_source_properties (SCM obj)
|
||
{
|
||
init_source_properties ();
|
||
return scm_call_1 (scm_variable_ref (source_properties_var), obj);
|
||
}
|
||
|
||
|
||
SCM
|
||
scm_set_source_properties_x (SCM obj, SCM alist)
|
||
{
|
||
init_source_properties ();
|
||
return scm_call_2 (scm_variable_ref (set_source_properties_var), obj, alist);
|
||
}
|
||
|
||
SCM
|
||
scm_source_property (SCM obj, SCM key)
|
||
{
|
||
init_source_properties ();
|
||
return scm_call_2 (scm_variable_ref (source_property_var), obj, key);
|
||
}
|
||
|
||
SCM
|
||
scm_set_source_property_x (SCM obj, SCM key, SCM value)
|
||
{
|
||
init_source_properties ();
|
||
return scm_call_3 (scm_variable_ref (set_source_property_var), obj, key, value);
|
||
}
|
||
|
||
SCM
|
||
scm_cons_source (SCM orig, SCM x, SCM y)
|
||
{
|
||
init_source_properties ();
|
||
return scm_call_3 (scm_variable_ref (cons_source_var), orig, x, y);
|
||
}
|
||
|
||
|
||
|
||
|
||
void
|
||
scm_i_init_deprecated ()
|
||
{
|
||
#include "deprecated.x"
|
||
}
|
||
|
||
#endif /* SCM_ENABLE_DEPRECATED == 1 */
|