mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-06-15 08:10:17 +02:00
Add disjoint syntax object type
* libguile/Makefile.am (libguile_@GUILE_EFFECTIVE_VERSION@_la_SOURCES): (DOT_X_FILES, DOT_DOC_FILES, noinst_HEADERS): Add syntax.c and syntax.h. * libguile/evalext.c (scm_self_evaluating_p): * libguile/goops.c (class_syntax, scm_class_of, scm_goops_early_init): * libguile/init.c (scm_init_guile): * libguile/print.c (iprin1): * libguile/tags.h (scm_tc7_syntax): * module/oop/goops.scm (<syntax>): * module/system/base/types.scm (%tc7-syntax, cell->object): * module/system/vm/disassembler.scm (code-annotation): Wire up the new data type. * libguile/syntax.c: * libguile/syntax.h: New files. * module/ice-9/boot-9.scm: Move new definitions to (system syntax internal). * module/system/syntax.scm (print-syntax): New helper. * module/system/vm/assembler.scm (statically-allocatable?) (intern-constant, link-data): Arrange to be able to write syntax objects into images. * module/language/cps/types.scm (&syntax): New type. Remove &hash-table; it was never detected, an internal binding, and we need the bit to avoid going into bignum territory.
This commit is contained in:
parent
6ba3f35f26
commit
64c5cc58fc
15 changed files with 221 additions and 8 deletions
|
@ -46,6 +46,7 @@
|
|||
#include "libguile/ports-internal.h"
|
||||
#include "libguile/strings.h"
|
||||
#include "libguile/strports.h"
|
||||
#include "libguile/syntax.h"
|
||||
#include "libguile/vectors.h"
|
||||
#include "libguile/numbers.h"
|
||||
#include "libguile/vm.h"
|
||||
|
@ -716,6 +717,9 @@ iprin1 (SCM exp, SCM port, scm_print_state *pstate)
|
|||
scm_puts ("#:", port);
|
||||
scm_iprin1 (scm_keyword_to_symbol (exp), port, pstate);
|
||||
break;
|
||||
case scm_tc7_syntax:
|
||||
scm_i_syntax_print (exp, port, pstate);
|
||||
break;
|
||||
case scm_tc7_atomic_box:
|
||||
scm_i_atomic_box_print (exp, port, pstate);
|
||||
break;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue