comparison src/ChangeLog @ 5560:58b38d5b32d0

Implement print-circle, allowing recursive and circular structures to be read. src/ChangeLog addition: 2011-09-04 Aidan Kehoe <kehoea@parhasard.net> * alloc.c: * alloc.c (ALLOC_FROB_BLOCK_LISP_OBJECT_1): * alloc.c (ALLOC_FROB_BLOCK_LISP_OBJECT): * alloc.c (cons_print_preprocess): * alloc.c (vector_print_preprocess): * alloc.c (vector_nsubst_structures_descend): * alloc.c (Fmake_symbol): * alloc.c (UNMARK_symbol): * alloc.c (sweep_symbols): * alloc.c (reinit_alloc_objects_early): * alloc.c (reinit_alloc_early): * bytecode.c: * bytecode.c (compiled_function_print_preprocess): * bytecode.c (compiled_function_nsubst_structures_descend): * bytecode.c (set_compiled_function_arglist): * bytecode.c (set_compiled_function_interactive): * bytecode.c (bytecode_objects_create): * chartab.c: * chartab.c (print_preprocess_mapper): * chartab.c (nsubst_structures_mapper): * chartab.c (char_table_nsubst_structures_descend): * chartab.c (chartab_objects_create): * elhash.c: * elhash.c (nsubst_structures_map_hash_table): * elhash.c (hash_table_nsubst_structures_descend): * elhash.c (print_preprocess_mapper): * elhash.c (hash_table_print_preprocess): * elhash.c (inchash_eq): * elhash.c (hash_table_objects_create): * elhash.c (syms_of_elhash): * elhash.h: * emacs.c (main_1): * fns.c: * fns.c (check_eq_nokey): * fns.c (Fnsubst): * fns.c (syms_of_fns): * lisp.h: * lisp.h (struct Lisp_Symbol): * lisp.h (IN_OBARRAY): * lisp.h (struct): * lisp.h (PRINT_PREPROCESS): * lread.c (read1): * lrecord.h: * lrecord.h (struct lrecord_implementation): * lrecord.h (DEFINE_DUMPABLE_MODULE_LISP_OBJECT): * print.c: * print.c (PRINT_CIRCLE_LIMIT): * print.c (print_continuous_numbering_changed): * print.c (print_prepare): * print.c (print_finish): * print.c (Fprin1_to_string): * print.c (print_cons): * print.c (print_preprocess_inchash_eq): * print.c (print_preprocess): * print.c (print_sort_get_numbers): * print.c (print_sort_compare_ordinals): * print.c (print_gensym_or_circle): * print.c (nsubst_structures_descend): * print.c (nsubst_structures): * print.c (print_internal): * print.c (print_symbol): * print.c (vars_of_print): * rangetab.c: * rangetab.c (range_table_print_preprocess): * rangetab.c (range_table_nsubst_structures_descend): * rangetab.c (rangetab_objects_create): * rangetab.c (syms_of_rangetab): * symbols.c: * symbols.c (symbol_print_preprocess): * symbols.c (Fintern): * symbols.c (Funintern): * symbols.c (reinit_symbol_objects_early): * symbols.c (init_symbols_once_early): * symsinit.h: Implement print-circle, printing circular structures in a readable fashion, and treating them appropriately on read. This is by means of two new object methods, print_preprocess (detecting circularities), and nsubst_structures_descend (replacing placeholders with the read objects). Expose the substitution to Lisp via #'nsubst and its new :descend-structures keyword. Store information as to whether symbols are interned in obarray or not in their header, making checking for keywords and uninterned symbols (and thus printing) cheaper. Default print_gensym to t, as Common Lisp does, and as a more-than-decade old comment suggests. lisp/ChangeLog addition: 2011-09-04 Aidan Kehoe <kehoea@parhasard.net> * bytecomp.el (byte-compile-output-file-form): * bytecomp.el (byte-compile-output-docform): Bind print-circle, print-continuous-numbering in these functions, now those variables are available. * lisp.el (forward-sexp): * lisp.el (backward-sexp): Recognise leading #N= as being part of an expression. tests/ChangeLog addition: 2011-09-04 Aidan Kehoe <kehoea@parhasard.net> * automated/lisp-reader-tests.el: * automated/lisp-tests.el (literal-with-uninterned): * automated/symbol-tests.el (foo): Test print-circle, for printing (mutually-)recursive and circular structures. Bind print-continuous-numbering where appropriate.
author Aidan Kehoe <kehoea@parhasard.net>
date Sun, 04 Sep 2011 19:51:35 +0100
parents f3ab0c29c246
children 309e5631e4c8
comparison
equal deleted inserted replaced
5559:f3ab0c29c246 5560:58b38d5b32d0
1 2011-09-04 Aidan Kehoe <kehoea@parhasard.net>
2
3 * alloc.c:
4 * alloc.c (ALLOC_FROB_BLOCK_LISP_OBJECT_1):
5 * alloc.c (ALLOC_FROB_BLOCK_LISP_OBJECT):
6 * alloc.c (cons_print_preprocess):
7 * alloc.c (vector_print_preprocess):
8 * alloc.c (vector_nsubst_structures_descend):
9 * alloc.c (Fmake_symbol):
10 * alloc.c (UNMARK_symbol):
11 * alloc.c (sweep_symbols):
12 * alloc.c (reinit_alloc_objects_early):
13 * alloc.c (reinit_alloc_early):
14 * bytecode.c:
15 * bytecode.c (compiled_function_print_preprocess):
16 * bytecode.c (compiled_function_nsubst_structures_descend):
17 * bytecode.c (set_compiled_function_arglist):
18 * bytecode.c (set_compiled_function_interactive):
19 * bytecode.c (bytecode_objects_create):
20 * chartab.c:
21 * chartab.c (print_preprocess_mapper):
22 * chartab.c (nsubst_structures_mapper):
23 * chartab.c (char_table_nsubst_structures_descend):
24 * chartab.c (chartab_objects_create):
25 * elhash.c:
26 * elhash.c (nsubst_structures_map_hash_table):
27 * elhash.c (hash_table_nsubst_structures_descend):
28 * elhash.c (print_preprocess_mapper):
29 * elhash.c (hash_table_print_preprocess):
30 * elhash.c (inchash_eq):
31 * elhash.c (hash_table_objects_create):
32 * elhash.c (syms_of_elhash):
33 * elhash.h:
34 * emacs.c (main_1):
35 * fns.c:
36 * fns.c (check_eq_nokey):
37 * fns.c (Fnsubst):
38 * fns.c (syms_of_fns):
39 * lisp.h:
40 * lisp.h (struct Lisp_Symbol):
41 * lisp.h (IN_OBARRAY):
42 * lisp.h (struct):
43 * lisp.h (PRINT_PREPROCESS):
44 * lread.c (read1):
45 * lrecord.h:
46 * lrecord.h (struct lrecord_implementation):
47 * lrecord.h (DEFINE_DUMPABLE_MODULE_LISP_OBJECT):
48 * print.c:
49 * print.c (PRINT_CIRCLE_LIMIT):
50 * print.c (print_continuous_numbering_changed):
51 * print.c (print_prepare):
52 * print.c (print_finish):
53 * print.c (Fprin1_to_string):
54 * print.c (print_cons):
55 * print.c (print_preprocess_inchash_eq):
56 * print.c (print_preprocess):
57 * print.c (print_sort_get_numbers):
58 * print.c (print_sort_compare_ordinals):
59 * print.c (print_gensym_or_circle):
60 * print.c (nsubst_structures_descend):
61 * print.c (nsubst_structures):
62 * print.c (print_internal):
63 * print.c (print_symbol):
64 * print.c (vars_of_print):
65 * rangetab.c:
66 * rangetab.c (range_table_print_preprocess):
67 * rangetab.c (range_table_nsubst_structures_descend):
68 * rangetab.c (rangetab_objects_create):
69 * rangetab.c (syms_of_rangetab):
70 * symbols.c:
71 * symbols.c (symbol_print_preprocess):
72 * symbols.c (Fintern):
73 * symbols.c (Funintern):
74 * symbols.c (reinit_symbol_objects_early):
75 * symbols.c (init_symbols_once_early):
76 * symsinit.h:
77 Implement print-circle, printing circular structures in a readable
78 fashion, and treating them appropriately on read. This is by means
79 of two new object methods, print_preprocess (detecting
80 circularities), and nsubst_structures_descend (replacing
81 placeholders with the read objects).
82 Expose the substitution to Lisp via #'nsubst and its new
83 :descend-structures keyword.
84 Store information as to whether symbols are interned in obarray or
85 not in their header, making checking for keywords and uninterned
86 symbols (and thus printing) cheaper.
87 Default print_gensym to t, as Common Lisp does, and as a
88 more-than-decade old comment suggests.
89
1 2011-08-28 Aidan Kehoe <kehoea@parhasard.net> 90 2011-08-28 Aidan Kehoe <kehoea@parhasard.net>
2 91
3 * event-Xt.c (x_to_emacs_keysym): 92 * event-Xt.c (x_to_emacs_keysym):
4 Take a new pointer argument, X_KEYSYM_OUT, where we store the X11 93 Take a new pointer argument, X_KEYSYM_OUT, where we store the X11
5 keysym that we actually used. 94 keysym that we actually used.