Mercurial > emacs
annotate src/print.c @ 83416:4513d8dcdfd5
Reimplement and extend support for terminal-local environment variables.
* lisp/termdev.el: New file. Move terminal parameter-related functions
here from frame.el.
(terminal-getenv, with-terminal-environment): Reimplement and extend.
(terminal-setenv, terminal-setenv-internal): New functions.
* lisp/frame.el (make-frame-on-tty, framep-on-display, suspend-frame):
Extend doc string, update parameter names.
(terminal-id, terminal-parameter-alist, terminal-parameters)
(terminal-parameter-p, terminal-parameter, set-terminal-parameter)
(terminal-handle-delete-frame, terminal-getenv, terminal-getenv)
(with-terminal-environment): Move to termdev.el.
* lisp/loadup.el: Load termdev as well.
* lisp/Makefile.in (lisp, shortlisp): Add termdev.elc.
* lisp/makefile.MPW (shortlisp): Ditto.
* lisp/ebuff-menu.el (electric-buffer-menu-mode-map): Bind C-z to
`suspend-frame', not `suspend-emacs'.
* lisp/echistory.el (electric-history-map): Ditto.
* lisp/ebrowse.el (ebrowse-electric-list-mode-map): Ditto.
* lisp/ebrowse.el (ebrowse-electric-position-mode-map): Ditto.
* lisp/startup.el (normal-splash-screen): Use `save-buffers-kill-display'
instead of `save-buffers-kill-emacs'.
* lisp/x-win.el (x-initialize-window-system): Add 'global-ok option to
`terminal-getenv'.
* src/term.c (suspend-tty): Update doc string.
git-archimport-id: lorentey@elte.hu--2004/emacs--multi-tty--0--patch-456
| author | Karoly Lorentey <lorentey@elte.hu> |
|---|---|
| date | Thu, 22 Dec 2005 21:02:45 +0000 |
| parents | 14a4eb789b45 |
| children | 50fd371bed05 |
| rev | line source |
|---|---|
| 329 | 1 /* Lisp object printing and output streams. |
|
64770
a0d1312ede66
Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
64084
diff
changeset
|
2 Copyright (C) 1985, 1986, 1988, 1993, 1994, 1995, 1997, |
|
a0d1312ede66
Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
64084
diff
changeset
|
3 1998, 1999, 2000, 2001, 2002, 2003, 2004, |
|
a0d1312ede66
Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
64084
diff
changeset
|
4 2005 Free Software Foundation, Inc. |
| 329 | 5 |
| 6 This file is part of GNU Emacs. | |
| 7 | |
| 8 GNU Emacs is free software; you can redistribute it and/or modify | |
| 9 it under the terms of the GNU General Public License as published by | |
| 621 | 10 the Free Software Foundation; either version 2, or (at your option) |
| 329 | 11 any later version. |
| 12 | |
| 13 GNU Emacs is distributed in the hope that it will be useful, | |
| 14 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 16 GNU General Public License for more details. | |
| 17 | |
| 18 You should have received a copy of the GNU General Public License | |
| 19 along with GNU Emacs; see the file COPYING. If not, write to | |
| 64084 | 20 the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
| 21 Boston, MA 02110-1301, USA. */ | |
| 329 | 22 |
| 23 | |
|
4696
1fc792473491
Include <config.h> instead of "config.h".
Roland McGrath <roland@gnu.org>
parents:
4224
diff
changeset
|
24 #include <config.h> |
| 329 | 25 #include <stdio.h> |
| 26 #include "lisp.h" | |
| 27 #include "buffer.h" | |
| 17040 | 28 #include "charset.h" |
|
31102
6a0caa788013
Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents:
30461
diff
changeset
|
29 #include "keyboard.h" |
| 766 | 30 #include "frame.h" |
| 329 | 31 #include "window.h" |
| 32 #include "process.h" | |
| 33 #include "dispextern.h" | |
| 34 #include "termchar.h" | |
| 1967 | 35 #include "intervals.h" |
| 36 | |
| 329 | 37 Lisp_Object Vstandard_output, Qstandard_output; |
| 38 | |
|
24049
a45f10911408
(Qtemp_buffer_setup_hook): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
23931
diff
changeset
|
39 Lisp_Object Qtemp_buffer_setup_hook; |
|
a45f10911408
(Qtemp_buffer_setup_hook): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
23931
diff
changeset
|
40 |
|
15908
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
41 /* These are used to print like we read. */ |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
42 extern Lisp_Object Qbackquote, Qcomma, Qcomma_at, Qcomma_dot, Qfunction; |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
43 |
| 329 | 44 Lisp_Object Vfloat_output_format, Qfloat_output_format; |
| 20121 | 45 |
| 46 /* Work around a problem that happens because math.h on hpux 7 | |
| 47 defines two static variables--which, in Emacs, are not really static, | |
| 48 because `static' is defined as nothing. The problem is that they are | |
| 49 defined both here and in lread.c. | |
| 50 These macros prevent the name conflict. */ | |
| 51 #if defined (HPUX) && !defined (HPUX8) | |
| 52 #define _MAXLDBL print_maxldbl | |
| 53 #define _NMAXLDBL print_nmaxldbl | |
| 54 #endif | |
| 55 | |
| 56 #include <math.h> | |
| 57 | |
| 58 #if STDC_HEADERS | |
| 59 #include <float.h> | |
| 60 #endif | |
| 61 | |
| 62 /* Default to values appropriate for IEEE floating point. */ | |
| 63 #ifndef FLT_RADIX | |
| 64 #define FLT_RADIX 2 | |
| 65 #endif | |
| 66 #ifndef DBL_MANT_DIG | |
| 67 #define DBL_MANT_DIG 53 | |
| 68 #endif | |
| 69 #ifndef DBL_DIG | |
| 70 #define DBL_DIG 15 | |
| 71 #endif | |
|
20200
b69f8ea35fef
(DBL_MIN): Use workaround if DBL_MIN_REPLACEMENT is defined.
Paul Eggert <eggert@twinsun.com>
parents:
20121
diff
changeset
|
72 #ifndef DBL_MIN |
|
b69f8ea35fef
(DBL_MIN): Use workaround if DBL_MIN_REPLACEMENT is defined.
Paul Eggert <eggert@twinsun.com>
parents:
20121
diff
changeset
|
73 #define DBL_MIN 2.2250738585072014e-308 |
|
b69f8ea35fef
(DBL_MIN): Use workaround if DBL_MIN_REPLACEMENT is defined.
Paul Eggert <eggert@twinsun.com>
parents:
20121
diff
changeset
|
74 #endif |
|
b69f8ea35fef
(DBL_MIN): Use workaround if DBL_MIN_REPLACEMENT is defined.
Paul Eggert <eggert@twinsun.com>
parents:
20121
diff
changeset
|
75 |
|
b69f8ea35fef
(DBL_MIN): Use workaround if DBL_MIN_REPLACEMENT is defined.
Paul Eggert <eggert@twinsun.com>
parents:
20121
diff
changeset
|
76 #ifdef DBL_MIN_REPLACEMENT |
|
b69f8ea35fef
(DBL_MIN): Use workaround if DBL_MIN_REPLACEMENT is defined.
Paul Eggert <eggert@twinsun.com>
parents:
20121
diff
changeset
|
77 #undef DBL_MIN |
|
b69f8ea35fef
(DBL_MIN): Use workaround if DBL_MIN_REPLACEMENT is defined.
Paul Eggert <eggert@twinsun.com>
parents:
20121
diff
changeset
|
78 #define DBL_MIN DBL_MIN_REPLACEMENT |
|
b69f8ea35fef
(DBL_MIN): Use workaround if DBL_MIN_REPLACEMENT is defined.
Paul Eggert <eggert@twinsun.com>
parents:
20121
diff
changeset
|
79 #endif |
| 20121 | 80 |
| 81 /* Define DOUBLE_DIGITS_BOUND, an upper bound on the number of decimal digits | |
| 82 needed to express a float without losing information. | |
| 83 The general-case formula is valid for the usual case, IEEE floating point, | |
| 84 but many compilers can't optimize the formula to an integer constant, | |
| 85 so make a special case for it. */ | |
| 86 #if FLT_RADIX == 2 && DBL_MANT_DIG == 53 | |
| 87 #define DOUBLE_DIGITS_BOUND 17 /* IEEE floating point */ | |
| 88 #else | |
| 89 #define DOUBLE_DIGITS_BOUND ((int) ceil (log10 (pow (FLT_RADIX, DBL_MANT_DIG)))) | |
| 90 #endif | |
| 91 | |
| 329 | 92 /* Avoid actual stack overflow in print. */ |
| 93 int print_depth; | |
| 94 | |
|
47864
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
95 /* Nonzero if inside outputting backquote in old style. */ |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
96 int old_backquote_output; |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
97 |
|
379
34ec8957c6c0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
373
diff
changeset
|
98 /* Detect most circularities to print finite output. */ |
|
34ec8957c6c0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
373
diff
changeset
|
99 #define PRINT_CIRCLE 200 |
|
34ec8957c6c0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
373
diff
changeset
|
100 Lisp_Object being_printed[PRINT_CIRCLE]; |
|
34ec8957c6c0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
373
diff
changeset
|
101 |
|
15801
b0bd5de2ce82
When printing into a buffer, generate all the text
Richard M. Stallman <rms@gnu.org>
parents:
15707
diff
changeset
|
102 /* When printing into a buffer, first we put the text in this |
|
b0bd5de2ce82
When printing into a buffer, generate all the text
Richard M. Stallman <rms@gnu.org>
parents:
15707
diff
changeset
|
103 block, then insert it all at once. */ |
|
b0bd5de2ce82
When printing into a buffer, generate all the text
Richard M. Stallman <rms@gnu.org>
parents:
15707
diff
changeset
|
104 char *print_buffer; |
|
b0bd5de2ce82
When printing into a buffer, generate all the text
Richard M. Stallman <rms@gnu.org>
parents:
15707
diff
changeset
|
105 |
|
b0bd5de2ce82
When printing into a buffer, generate all the text
Richard M. Stallman <rms@gnu.org>
parents:
15707
diff
changeset
|
106 /* Size allocated in print_buffer. */ |
|
b0bd5de2ce82
When printing into a buffer, generate all the text
Richard M. Stallman <rms@gnu.org>
parents:
15707
diff
changeset
|
107 int print_buffer_size; |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
108 /* Chars stored in print_buffer. */ |
|
15801
b0bd5de2ce82
When printing into a buffer, generate all the text
Richard M. Stallman <rms@gnu.org>
parents:
15707
diff
changeset
|
109 int print_buffer_pos; |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
110 /* Bytes stored in print_buffer. */ |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
111 int print_buffer_pos_byte; |
|
15801
b0bd5de2ce82
When printing into a buffer, generate all the text
Richard M. Stallman <rms@gnu.org>
parents:
15707
diff
changeset
|
112 |
| 329 | 113 /* Maximum length of list to print in full; noninteger means |
| 114 effectively infinity */ | |
| 115 | |
| 116 Lisp_Object Vprint_length; | |
| 117 | |
| 118 /* Maximum depth of list to print in full; noninteger means | |
| 119 effectively infinity. */ | |
| 120 | |
| 121 Lisp_Object Vprint_level; | |
| 122 | |
| 123 /* Nonzero means print newlines in strings as \n. */ | |
| 124 | |
| 125 int print_escape_newlines; | |
| 126 | |
|
22240
4e4c377f3310
(print_escape_nonascii): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22231
diff
changeset
|
127 /* Nonzero means to print single-byte non-ascii characters in strings as |
|
4e4c377f3310
(print_escape_nonascii): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22231
diff
changeset
|
128 octal escapes. */ |
|
4e4c377f3310
(print_escape_nonascii): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22231
diff
changeset
|
129 |
|
4e4c377f3310
(print_escape_nonascii): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22231
diff
changeset
|
130 int print_escape_nonascii; |
|
4e4c377f3310
(print_escape_nonascii): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22231
diff
changeset
|
131 |
|
22933
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
132 /* Nonzero means to print multibyte characters in strings as hex escapes. */ |
|
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
133 |
|
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
134 int print_escape_multibyte; |
|
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
135 |
|
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
136 Lisp_Object Qprint_escape_newlines; |
|
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
137 Lisp_Object Qprint_escape_multibyte, Qprint_escape_nonascii; |
|
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
138 |
|
15908
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
139 /* Nonzero means print (quote foo) forms as 'foo, etc. */ |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
140 |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
141 int print_quoted; |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
142 |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
143 /* Non-nil means print #: before uninterned symbols. */ |
|
16140
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
144 |
|
18961
e537071624ee
(Vprint_gensym_alist): Renamed from printed_gensyms.
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
145 Lisp_Object Vprint_gensym; |
|
16140
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
146 |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
147 /* Non-nil means print recursive structures using #n= and #n# syntax. */ |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
148 |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
149 Lisp_Object Vprint_circle; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
150 |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
151 /* Non-nil means keep continuous number for #n= and #n# syntax |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
152 between several print functions. */ |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
153 |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
154 Lisp_Object Vprint_continuous_numbering; |
|
16140
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
155 |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
156 /* Vprint_number_table is a vector like [OBJ1 STAT1 OBJ2 STAT2 ...], |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
157 where OBJn are objects going to be printed, and STATn are their status, |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
158 which may be different meanings during process. See the comments of |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
159 the functions print and print_preprocess for details. |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
160 print_number_index keeps the last position the next object should be added, |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
161 twice of which is the actual vector position in Vprint_number_table. */ |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
162 int print_number_index; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
163 Lisp_Object Vprint_number_table; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
164 |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
165 /* PRINT_NUMBER_OBJECT returns the I'th object in Vprint_number_table TABLE. |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
166 PRINT_NUMBER_STATUS returns the status of the I'th object in TABLE. |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
167 See the comment of the variable Vprint_number_table. */ |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
168 #define PRINT_NUMBER_OBJECT(table,i) XVECTOR ((table))->contents[(i) * 2] |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
169 #define PRINT_NUMBER_STATUS(table,i) XVECTOR ((table))->contents[(i) * 2 + 1] |
|
15908
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
170 |
|
10418
fdad41459fd6
(printchar, strout): Call message_dolog.
Karl Heuer <kwzh@gnu.org>
parents:
10301
diff
changeset
|
171 /* Nonzero means print newline to stdout before next minibuffer message. |
| 329 | 172 Defined in xdisp.c */ |
| 173 | |
| 174 extern int noninteractive_need_newline; | |
|
10418
fdad41459fd6
(printchar, strout): Call message_dolog.
Karl Heuer <kwzh@gnu.org>
parents:
10301
diff
changeset
|
175 |
|
19001
2190c39dc640
(strout, printchar): Handle minibuffer_auto_raise.
Richard M. Stallman <rms@gnu.org>
parents:
18961
diff
changeset
|
176 extern int minibuffer_auto_raise; |
|
2190c39dc640
(strout, printchar): Handle minibuffer_auto_raise.
Richard M. Stallman <rms@gnu.org>
parents:
18961
diff
changeset
|
177 |
| 329 | 178 #ifdef MAX_PRINT_CHARS |
| 179 static int print_chars; | |
| 180 static int max_print; | |
| 181 #endif /* MAX_PRINT_CHARS */ | |
| 1967 | 182 |
| 183 void print_interval (); | |
| 329 | 184 |
| 185 | |
|
3591
507f64624555
Apply typo patches from Paul Eggert.
Jim Blandy <jimb@redhat.com>
parents:
3377
diff
changeset
|
186 /* Low level output routines for characters and strings */ |
| 329 | 187 |
| 188 /* Lisp functions to do output using a stream | |
|
16140
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
189 must have the stream in a variable called printcharfun |
|
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
190 and must start with PRINTPREPARE, end with PRINTFINISH, |
|
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
191 and use PRINTDECLARE to declare common variables. |
|
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
192 Use PRINTCHAR to output one character, |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47864
diff
changeset
|
193 or call strout to output a block of characters. */ |
| 329 | 194 |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
195 #define PRINTDECLARE \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
196 struct buffer *old = current_buffer; \ |
|
34798
9794feac3a9d
(print_unwind): Return nil.
Gerd Moellmann <gerd@gnu.org>
parents:
31102
diff
changeset
|
197 int old_point = -1, start_point = -1; \ |
|
9794feac3a9d
(print_unwind): Return nil.
Gerd Moellmann <gerd@gnu.org>
parents:
31102
diff
changeset
|
198 int old_point_byte = -1, start_point_byte = -1; \ |
|
46293
1fb8f75062c6
Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents:
45995
diff
changeset
|
199 int specpdl_count = SPECPDL_INDEX (); \ |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
200 int free_print_buffer = 0; \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
201 int multibyte = !NILP (current_buffer->enable_multibyte_characters); \ |
|
16140
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
202 Lisp_Object original |
|
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
203 |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
204 #define PRINTPREPARE \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
205 original = printcharfun; \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
206 if (NILP (printcharfun)) printcharfun = Qt; \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
207 if (BUFFERP (printcharfun)) \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
208 { \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
209 if (XBUFFER (printcharfun) != current_buffer) \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
210 Fset_buffer (printcharfun); \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
211 printcharfun = Qnil; \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
212 } \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
213 if (MARKERP (printcharfun)) \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
214 { \ |
|
61407
88c04d73f43d
(PRINTPREPARE): Check if the marker PRINTCHARFUN is within the
Lute Kamstra <lute@gnu.org>
parents:
58094
diff
changeset
|
215 EMACS_INT marker_pos; \ |
|
88c04d73f43d
(PRINTPREPARE): Check if the marker PRINTCHARFUN is within the
Lute Kamstra <lute@gnu.org>
parents:
58094
diff
changeset
|
216 if (!(XMARKER (printcharfun)->buffer)) \ |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
217 error ("Marker does not point anywhere"); \ |
|
61407
88c04d73f43d
(PRINTPREPARE): Check if the marker PRINTCHARFUN is within the
Lute Kamstra <lute@gnu.org>
parents:
58094
diff
changeset
|
218 if (XMARKER (printcharfun)->buffer != current_buffer) \ |
|
88c04d73f43d
(PRINTPREPARE): Check if the marker PRINTCHARFUN is within the
Lute Kamstra <lute@gnu.org>
parents:
58094
diff
changeset
|
219 set_buffer_internal (XMARKER (printcharfun)->buffer); \ |
|
88c04d73f43d
(PRINTPREPARE): Check if the marker PRINTCHARFUN is within the
Lute Kamstra <lute@gnu.org>
parents:
58094
diff
changeset
|
220 marker_pos = marker_position (printcharfun); \ |
|
88c04d73f43d
(PRINTPREPARE): Check if the marker PRINTCHARFUN is within the
Lute Kamstra <lute@gnu.org>
parents:
58094
diff
changeset
|
221 if (marker_pos < BEGV || marker_pos > ZV) \ |
|
88c04d73f43d
(PRINTPREPARE): Check if the marker PRINTCHARFUN is within the
Lute Kamstra <lute@gnu.org>
parents:
58094
diff
changeset
|
222 error ("Marker is outside the accessible part of the buffer"); \ |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
223 old_point = PT; \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
224 old_point_byte = PT_BYTE; \ |
|
61407
88c04d73f43d
(PRINTPREPARE): Check if the marker PRINTCHARFUN is within the
Lute Kamstra <lute@gnu.org>
parents:
58094
diff
changeset
|
225 SET_PT_BOTH (marker_pos, \ |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
226 marker_byte_position (printcharfun)); \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
227 start_point = PT; \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
228 start_point_byte = PT_BYTE; \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
229 printcharfun = Qnil; \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
230 } \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
231 if (NILP (printcharfun)) \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
232 { \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
233 Lisp_Object string; \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
234 if (NILP (current_buffer->enable_multibyte_characters) \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
235 && ! print_escape_multibyte) \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
236 specbind (Qprint_escape_multibyte, Qt); \ |
|
42460
21eaf0f81c5d
(print_object): Test print_escape_nonascii only for unibyte strings.
Richard M. Stallman <rms@gnu.org>
parents:
42423
diff
changeset
|
237 if (! NILP (current_buffer->enable_multibyte_characters) \ |
|
21eaf0f81c5d
(print_object): Test print_escape_nonascii only for unibyte strings.
Richard M. Stallman <rms@gnu.org>
parents:
42423
diff
changeset
|
238 && ! print_escape_nonascii) \ |
|
21eaf0f81c5d
(print_object): Test print_escape_nonascii only for unibyte strings.
Richard M. Stallman <rms@gnu.org>
parents:
42423
diff
changeset
|
239 specbind (Qprint_escape_nonascii, Qt); \ |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
240 if (print_buffer != 0) \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
241 { \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
242 string = make_string_from_bytes (print_buffer, \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
243 print_buffer_pos, \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
244 print_buffer_pos_byte); \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
245 record_unwind_protect (print_unwind, string); \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
246 } \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
247 else \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
248 { \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
249 print_buffer_size = 1000; \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
250 print_buffer = (char *) xmalloc (print_buffer_size); \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
251 free_print_buffer = 1; \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
252 } \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
253 print_buffer_pos = 0; \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
254 print_buffer_pos_byte = 0; \ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
255 } \ |
|
26460
ea7e77758acd
(PRINTPREPARE): Don't call setup_echo_area_for_printing
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
256 if (EQ (printcharfun, Qt) && ! noninteractive) \ |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
257 setup_echo_area_for_printing (multibyte); |
| 329 | 258 |
|
22605
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
259 #define PRINTFINISH \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
260 if (NILP (printcharfun)) \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
261 { \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
262 if (print_buffer_pos != print_buffer_pos_byte \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
263 && NILP (current_buffer->enable_multibyte_characters)) \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
264 { \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
265 unsigned char *temp \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
266 = (unsigned char *) alloca (print_buffer_pos + 1); \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
267 copy_text (print_buffer, temp, print_buffer_pos_byte, \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
268 1, 0); \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
269 insert_1_both (temp, print_buffer_pos, \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
270 print_buffer_pos, 0, 1, 0); \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
271 } \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
272 else \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
273 insert_1_both (print_buffer, print_buffer_pos, \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
274 print_buffer_pos_byte, 0, 1, 0); \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
275 } \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
276 if (free_print_buffer) \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
277 { \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
278 xfree (print_buffer); \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
279 print_buffer = 0; \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
280 } \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
281 unbind_to (specpdl_count, Qnil); \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
282 if (MARKERP (original)) \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
283 set_marker_both (original, Qnil, PT, PT_BYTE); \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
284 if (old_point >= 0) \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
285 SET_PT_BOTH (old_point + (old_point >= start_point \ |
|
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
286 ? PT - start_point : 0), \ |
|
20549
ba676f083e7c
(PRINTDECLARE): Declare old_point_byte and start_point_byte.
Richard M. Stallman <rms@gnu.org>
parents:
20377
diff
changeset
|
287 old_point_byte + (old_point_byte >= start_point_byte \ |
|
ba676f083e7c
(PRINTDECLARE): Declare old_point_byte and start_point_byte.
Richard M. Stallman <rms@gnu.org>
parents:
20377
diff
changeset
|
288 ? PT_BYTE - start_point_byte : 0)); \ |
|
22605
c3ffffc994d1
(PRINTFINISH): Convert text to unibyte before
Richard M. Stallman <rms@gnu.org>
parents:
22544
diff
changeset
|
289 if (old != current_buffer) \ |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
290 set_buffer_internal (old); |
| 329 | 291 |
| 292 #define PRINTCHAR(ch) printchar (ch, printcharfun) | |
| 293 | |
|
16512
59835b743b93
(PRINTDECLARE): Declare specpdl_count and free_print_buffer.
Richard M. Stallman <rms@gnu.org>
parents:
16496
diff
changeset
|
294 /* This is used to restore the saved contents of print_buffer |
|
59835b743b93
(PRINTDECLARE): Declare specpdl_count and free_print_buffer.
Richard M. Stallman <rms@gnu.org>
parents:
16496
diff
changeset
|
295 when there is a recursive call to print. */ |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
296 |
|
16512
59835b743b93
(PRINTDECLARE): Declare specpdl_count and free_print_buffer.
Richard M. Stallman <rms@gnu.org>
parents:
16496
diff
changeset
|
297 static Lisp_Object |
|
59835b743b93
(PRINTDECLARE): Declare specpdl_count and free_print_buffer.
Richard M. Stallman <rms@gnu.org>
parents:
16496
diff
changeset
|
298 print_unwind (saved_text) |
|
59835b743b93
(PRINTDECLARE): Declare specpdl_count and free_print_buffer.
Richard M. Stallman <rms@gnu.org>
parents:
16496
diff
changeset
|
299 Lisp_Object saved_text; |
|
59835b743b93
(PRINTDECLARE): Declare specpdl_count and free_print_buffer.
Richard M. Stallman <rms@gnu.org>
parents:
16496
diff
changeset
|
300 { |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
301 bcopy (SDATA (saved_text), print_buffer, SCHARS (saved_text)); |
|
34798
9794feac3a9d
(print_unwind): Return nil.
Gerd Moellmann <gerd@gnu.org>
parents:
31102
diff
changeset
|
302 return Qnil; |
|
16512
59835b743b93
(PRINTDECLARE): Declare specpdl_count and free_print_buffer.
Richard M. Stallman <rms@gnu.org>
parents:
16496
diff
changeset
|
303 } |
|
59835b743b93
(PRINTDECLARE): Declare specpdl_count and free_print_buffer.
Richard M. Stallman <rms@gnu.org>
parents:
16496
diff
changeset
|
304 |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
305 |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
306 /* Print character CH using method FUN. FUN nil means print to |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
307 print_buffer. FUN t means print to echo area or stdout if |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
308 non-interactive. If FUN is neither nil nor t, call FUN with CH as |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
309 argument. */ |
| 329 | 310 |
| 311 static void | |
| 312 printchar (ch, fun) | |
| 17040 | 313 unsigned int ch; |
| 329 | 314 Lisp_Object fun; |
| 315 { | |
| 316 #ifdef MAX_PRINT_CHARS | |
| 317 if (max_print) | |
| 318 print_chars++; | |
| 319 #endif /* MAX_PRINT_CHARS */ | |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
320 |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
321 if (!NILP (fun) && !EQ (fun, Qt)) |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
322 call1 (fun, make_number (ch)); |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
323 else |
| 329 | 324 { |
|
26867
b633c8e0fee1
(printchar): Adjusted for the change of CHAR_STRING.
Kenichi Handa <handa@m17n.org>
parents:
26460
diff
changeset
|
325 unsigned char str[MAX_MULTIBYTE_LENGTH]; |
|
b633c8e0fee1
(printchar): Adjusted for the change of CHAR_STRING.
Kenichi Handa <handa@m17n.org>
parents:
26460
diff
changeset
|
326 int len = CHAR_STRING (ch, str); |
|
b633c8e0fee1
(printchar): Adjusted for the change of CHAR_STRING.
Kenichi Handa <handa@m17n.org>
parents:
26460
diff
changeset
|
327 |
|
16496
a4e5a8ee32cc
(printchar, strout): Do QUIT for echo area output.
Richard M. Stallman <rms@gnu.org>
parents:
16140
diff
changeset
|
328 QUIT; |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47864
diff
changeset
|
329 |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
330 if (NILP (fun)) |
| 329 | 331 { |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
332 if (print_buffer_pos_byte + len >= print_buffer_size) |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
333 print_buffer = (char *) xrealloc (print_buffer, |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
334 print_buffer_size *= 2); |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
335 bcopy (str, print_buffer + print_buffer_pos_byte, len); |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
336 print_buffer_pos += 1; |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
337 print_buffer_pos_byte += len; |
| 329 | 338 } |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
339 else if (noninteractive) |
|
23931
5fea9ce6601a
(printchar): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
23898
diff
changeset
|
340 { |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
341 fwrite (str, 1, len, stdout); |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
342 noninteractive_need_newline = 1; |
|
23931
5fea9ce6601a
(printchar): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
23898
diff
changeset
|
343 } |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
344 else |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
345 { |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
346 int multibyte_p |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
347 = !NILP (current_buffer->enable_multibyte_characters); |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47864
diff
changeset
|
348 |
|
29642
5b727419f3aa
(printchar, strout): Don't check message_buf_print
Gerd Moellmann <gerd@gnu.org>
parents:
29016
diff
changeset
|
349 setup_echo_area_for_printing (multibyte_p); |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
350 insert_char (ch); |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
351 message_dolog (str, len, 0, multibyte_p); |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
352 } |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
353 } |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
354 } |
|
20888
98172ad9f511
(printchar): When outputting to echo area,
Richard M. Stallman <rms@gnu.org>
parents:
20862
diff
changeset
|
355 |
|
23931
5fea9ce6601a
(printchar): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents:
23898
diff
changeset
|
356 |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
357 /* Output SIZE characters, SIZE_BYTE bytes from string PTR using |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
358 method PRINTCHARFUN. If SIZE < 0, use the string length of PTR for |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
359 both SIZE and SIZE_BYTE. PRINTCHARFUN nil means output to |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
360 print_buffer. PRINTCHARFUN t means output to the echo area or to |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
361 stdout if non-interactive. If neither nil nor t, call Lisp |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
362 function PRINTCHARFUN for each character printed. MULTIBYTE |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
363 non-zero means PTR contains multibyte characters. */ |
| 329 | 364 |
| 365 static void | |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
366 strout (ptr, size, size_byte, printcharfun, multibyte) |
| 329 | 367 char *ptr; |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
368 int size, size_byte; |
| 329 | 369 Lisp_Object printcharfun; |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
370 int multibyte; |
| 329 | 371 { |
| 17040 | 372 if (size < 0) |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
373 size_byte = size = strlen (ptr); |
| 17040 | 374 |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
375 if (NILP (printcharfun)) |
| 329 | 376 { |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
377 if (print_buffer_pos_byte + size_byte > print_buffer_size) |
|
15801
b0bd5de2ce82
When printing into a buffer, generate all the text
Richard M. Stallman <rms@gnu.org>
parents:
15707
diff
changeset
|
378 { |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
379 print_buffer_size = print_buffer_size * 2 + size_byte; |
|
15801
b0bd5de2ce82
When printing into a buffer, generate all the text
Richard M. Stallman <rms@gnu.org>
parents:
15707
diff
changeset
|
380 print_buffer = (char *) xrealloc (print_buffer, |
|
b0bd5de2ce82
When printing into a buffer, generate all the text
Richard M. Stallman <rms@gnu.org>
parents:
15707
diff
changeset
|
381 print_buffer_size); |
|
b0bd5de2ce82
When printing into a buffer, generate all the text
Richard M. Stallman <rms@gnu.org>
parents:
15707
diff
changeset
|
382 } |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
383 bcopy (ptr, print_buffer + print_buffer_pos_byte, size_byte); |
|
15801
b0bd5de2ce82
When printing into a buffer, generate all the text
Richard M. Stallman <rms@gnu.org>
parents:
15707
diff
changeset
|
384 print_buffer_pos += size; |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
385 print_buffer_pos_byte += size_byte; |
|
15801
b0bd5de2ce82
When printing into a buffer, generate all the text
Richard M. Stallman <rms@gnu.org>
parents:
15707
diff
changeset
|
386 |
| 329 | 387 #ifdef MAX_PRINT_CHARS |
| 388 if (max_print) | |
|
15801
b0bd5de2ce82
When printing into a buffer, generate all the text
Richard M. Stallman <rms@gnu.org>
parents:
15707
diff
changeset
|
389 print_chars += size; |
| 329 | 390 #endif /* MAX_PRINT_CHARS */ |
| 391 } | |
|
26298
759384838eae
(strout): Consider `noninteractive' and use stdout
Richard M. Stallman <rms@gnu.org>
parents:
26088
diff
changeset
|
392 else if (noninteractive && EQ (printcharfun, Qt)) |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
393 { |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
394 fwrite (ptr, 1, size_byte, stdout); |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
395 noninteractive_need_newline = 1; |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
396 } |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
397 else if (EQ (printcharfun, Qt)) |
| 329 | 398 { |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
399 /* Output to echo area. We're trying to avoid a little overhead |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
400 here, that's the reason we don't call printchar to do the |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
401 job. */ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
402 int i; |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
403 int multibyte_p |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
404 = !NILP (current_buffer->enable_multibyte_characters); |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47864
diff
changeset
|
405 |
|
29642
5b727419f3aa
(printchar, strout): Don't check message_buf_print
Gerd Moellmann <gerd@gnu.org>
parents:
29016
diff
changeset
|
406 setup_echo_area_for_printing (multibyte_p); |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
407 message_dolog (ptr, size_byte, 0, multibyte_p); |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47864
diff
changeset
|
408 |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
409 if (size == size_byte) |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
410 { |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
411 for (i = 0; i < size; ++i) |
|
38622
9412466adbca
(strout): Treat the characters at *ptr as unsigned char.
Eli Zaretskii <eliz@gnu.org>
parents:
37638
diff
changeset
|
412 insert_char ((unsigned char )*ptr++); |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
413 } |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
414 else |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
415 { |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
416 int len; |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
417 for (i = 0; i < size_byte; i += len) |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
418 { |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
419 int ch = STRING_CHAR_AND_LENGTH (ptr + i, size_byte - i, len); |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
420 insert_char (ch); |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
421 } |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
422 } |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47864
diff
changeset
|
423 |
| 329 | 424 #ifdef MAX_PRINT_CHARS |
| 425 if (max_print) | |
| 17040 | 426 print_chars += size; |
| 329 | 427 #endif /* MAX_PRINT_CHARS */ |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
428 } |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
429 else |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
430 { |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
431 /* PRINTCHARFUN is a Lisp function. */ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
432 int i = 0; |
| 329 | 433 |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
434 if (size == size_byte) |
| 329 | 435 { |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
436 while (i < size_byte) |
|
19001
2190c39dc640
(strout, printchar): Handle minibuffer_auto_raise.
Richard M. Stallman <rms@gnu.org>
parents:
18961
diff
changeset
|
437 { |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
438 int ch = ptr[i++]; |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
439 PRINTCHAR (ch); |
|
19001
2190c39dc640
(strout, printchar): Handle minibuffer_auto_raise.
Richard M. Stallman <rms@gnu.org>
parents:
18961
diff
changeset
|
440 } |
| 329 | 441 } |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
442 else |
| 17040 | 443 { |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
444 while (i < size_byte) |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
445 { |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
446 /* Here, we must convert each multi-byte form to the |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
447 corresponding character code before handing it to |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
448 PRINTCHAR. */ |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
449 int len; |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
450 int ch = STRING_CHAR_AND_LENGTH (ptr + i, size_byte - i, len); |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
451 PRINTCHAR (ch); |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
452 i += len; |
|
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
453 } |
| 17040 | 454 } |
| 329 | 455 } |
| 456 } | |
| 457 | |
| 458 /* Print the contents of a string STRING using PRINTCHARFUN. | |
|
13147
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
459 It isn't safe to use strout in many cases, |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
460 because printing one char can relocate. */ |
| 329 | 461 |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
462 static void |
| 329 | 463 print_string (string, printcharfun) |
| 464 Lisp_Object string; | |
| 465 Lisp_Object printcharfun; | |
| 466 { | |
|
15801
b0bd5de2ce82
When printing into a buffer, generate all the text
Richard M. Stallman <rms@gnu.org>
parents:
15707
diff
changeset
|
467 if (EQ (printcharfun, Qt) || NILP (printcharfun)) |
|
22544
f2d3eeec754e
(print_string): Properly compute number of chars
Karl Heuer <kwzh@gnu.org>
parents:
22528
diff
changeset
|
468 { |
|
f2d3eeec754e
(print_string): Properly compute number of chars
Karl Heuer <kwzh@gnu.org>
parents:
22528
diff
changeset
|
469 int chars; |
|
f2d3eeec754e
(print_string): Properly compute number of chars
Karl Heuer <kwzh@gnu.org>
parents:
22528
diff
changeset
|
470 |
|
f2d3eeec754e
(print_string): Properly compute number of chars
Karl Heuer <kwzh@gnu.org>
parents:
22528
diff
changeset
|
471 if (STRING_MULTIBYTE (string)) |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
472 chars = SCHARS (string); |
|
22544
f2d3eeec754e
(print_string): Properly compute number of chars
Karl Heuer <kwzh@gnu.org>
parents:
22528
diff
changeset
|
473 else if (EQ (printcharfun, Qt) |
|
f2d3eeec754e
(print_string): Properly compute number of chars
Karl Heuer <kwzh@gnu.org>
parents:
22528
diff
changeset
|
474 ? ! NILP (buffer_defaults.enable_multibyte_characters) |
|
f2d3eeec754e
(print_string): Properly compute number of chars
Karl Heuer <kwzh@gnu.org>
parents:
22528
diff
changeset
|
475 : ! NILP (current_buffer->enable_multibyte_characters)) |
|
35948
0c203af33b2d
(print_string): If we are going to print a unibyte
Kenichi Handa <handa@m17n.org>
parents:
35866
diff
changeset
|
476 { |
|
0c203af33b2d
(print_string): If we are going to print a unibyte
Kenichi Handa <handa@m17n.org>
parents:
35866
diff
changeset
|
477 /* If unibyte string STRING contains 8-bit codes, we must |
|
0c203af33b2d
(print_string): If we are going to print a unibyte
Kenichi Handa <handa@m17n.org>
parents:
35866
diff
changeset
|
478 convert STRING to a multibyte string containing the same |
|
0c203af33b2d
(print_string): If we are going to print a unibyte
Kenichi Handa <handa@m17n.org>
parents:
35866
diff
changeset
|
479 character codes. */ |
|
0c203af33b2d
(print_string): If we are going to print a unibyte
Kenichi Handa <handa@m17n.org>
parents:
35866
diff
changeset
|
480 Lisp_Object newstr; |
|
0c203af33b2d
(print_string): If we are going to print a unibyte
Kenichi Handa <handa@m17n.org>
parents:
35866
diff
changeset
|
481 int bytes; |
|
0c203af33b2d
(print_string): If we are going to print a unibyte
Kenichi Handa <handa@m17n.org>
parents:
35866
diff
changeset
|
482 |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
483 chars = SBYTES (string); |
|
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
484 bytes = parse_str_to_multibyte (SDATA (string), chars); |
|
35948
0c203af33b2d
(print_string): If we are going to print a unibyte
Kenichi Handa <handa@m17n.org>
parents:
35866
diff
changeset
|
485 if (chars < bytes) |
|
0c203af33b2d
(print_string): If we are going to print a unibyte
Kenichi Handa <handa@m17n.org>
parents:
35866
diff
changeset
|
486 { |
|
0c203af33b2d
(print_string): If we are going to print a unibyte
Kenichi Handa <handa@m17n.org>
parents:
35866
diff
changeset
|
487 newstr = make_uninit_multibyte_string (chars, bytes); |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
488 bcopy (SDATA (string), SDATA (newstr), chars); |
|
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
489 str_to_multibyte (SDATA (newstr), bytes, chars); |
|
35948
0c203af33b2d
(print_string): If we are going to print a unibyte
Kenichi Handa <handa@m17n.org>
parents:
35866
diff
changeset
|
490 string = newstr; |
|
0c203af33b2d
(print_string): If we are going to print a unibyte
Kenichi Handa <handa@m17n.org>
parents:
35866
diff
changeset
|
491 } |
|
0c203af33b2d
(print_string): If we are going to print a unibyte
Kenichi Handa <handa@m17n.org>
parents:
35866
diff
changeset
|
492 } |
|
22544
f2d3eeec754e
(print_string): Properly compute number of chars
Karl Heuer <kwzh@gnu.org>
parents:
22528
diff
changeset
|
493 else |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
494 chars = SBYTES (string); |
|
22544
f2d3eeec754e
(print_string): Properly compute number of chars
Karl Heuer <kwzh@gnu.org>
parents:
22528
diff
changeset
|
495 |
|
f2d3eeec754e
(print_string): Properly compute number of chars
Karl Heuer <kwzh@gnu.org>
parents:
22528
diff
changeset
|
496 /* strout is safe for output to a frame (echo area) or to print_buffer. */ |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
497 strout (SDATA (string), |
|
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
498 chars, SBYTES (string), |
|
22544
f2d3eeec754e
(print_string): Properly compute number of chars
Karl Heuer <kwzh@gnu.org>
parents:
22528
diff
changeset
|
499 printcharfun, STRING_MULTIBYTE (string)); |
|
f2d3eeec754e
(print_string): Properly compute number of chars
Karl Heuer <kwzh@gnu.org>
parents:
22528
diff
changeset
|
500 } |
| 329 | 501 else |
| 502 { | |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
503 /* Otherwise, string may be relocated by printing one char. |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
504 So re-fetch the string address for each character. */ |
| 329 | 505 int i; |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
506 int size = SCHARS (string); |
|
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
507 int size_byte = SBYTES (string); |
| 329 | 508 struct gcpro gcpro1; |
| 509 GCPRO1 (string); | |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
510 if (size == size_byte) |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
511 for (i = 0; i < size; i++) |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
512 PRINTCHAR (SREF (string, i)); |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
513 else |
|
52164
809050824a8f
(print_string): Fix printing of multibyte string with
Andreas Schwab <schwab@suse.de>
parents:
52020
diff
changeset
|
514 for (i = 0; i < size_byte; ) |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
515 { |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
516 /* Here, we must convert each multi-byte form to the |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
517 corresponding character code before handing it to PRINTCHAR. */ |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
518 int len; |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
519 int ch = STRING_CHAR_AND_LENGTH (SDATA (string) + i, |
|
25502
4a69654961a6
(print_string): Use the macro STRING_CHAR_AND_LENGTH.
Kenichi Handa <handa@m17n.org>
parents:
25355
diff
changeset
|
520 size_byte - i, len); |
|
23632
8c829259606f
(print_string): Check validity of a character.
Kenichi Handa <handa@m17n.org>
parents:
23236
diff
changeset
|
521 if (!CHAR_VALID_P (ch, 0)) |
|
8c829259606f
(print_string): Check validity of a character.
Kenichi Handa <handa@m17n.org>
parents:
23236
diff
changeset
|
522 { |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
523 ch = SREF (string, i); |
|
23632
8c829259606f
(print_string): Check validity of a character.
Kenichi Handa <handa@m17n.org>
parents:
23236
diff
changeset
|
524 len = 1; |
|
8c829259606f
(print_string): Check validity of a character.
Kenichi Handa <handa@m17n.org>
parents:
23236
diff
changeset
|
525 } |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
526 PRINTCHAR (ch); |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
527 i += len; |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
528 } |
| 329 | 529 UNGCPRO; |
| 530 } | |
| 531 } | |
| 532 | |
| 533 DEFUN ("write-char", Fwrite_char, Swrite_char, 1, 2, 0, | |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
534 doc: /* Output character CHARACTER to stream PRINTCHARFUN. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
535 PRINTCHARFUN defaults to the value of `standard-output' (which see). */) |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
536 (character, printcharfun) |
|
14084
8765a56417ac
(Fwrite_char, Fprin1, Fprin1_to_string, Fprinc, Fprint): Harmonize
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
537 Lisp_Object character, printcharfun; |
| 329 | 538 { |
|
16140
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
539 PRINTDECLARE; |
| 329 | 540 |
| 520 | 541 if (NILP (printcharfun)) |
| 329 | 542 printcharfun = Vstandard_output; |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40472
diff
changeset
|
543 CHECK_NUMBER (character); |
| 329 | 544 PRINTPREPARE; |
|
14084
8765a56417ac
(Fwrite_char, Fprin1, Fprin1_to_string, Fprinc, Fprint): Harmonize
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
545 PRINTCHAR (XINT (character)); |
| 329 | 546 PRINTFINISH; |
|
14084
8765a56417ac
(Fwrite_char, Fprin1, Fprin1_to_string, Fprinc, Fprint): Harmonize
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
547 return character; |
| 329 | 548 } |
| 549 | |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
550 /* Used from outside of print.c to print a block of SIZE |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
551 single-byte chars at DATA on the default output stream. |
| 329 | 552 Do not use this on the contents of a Lisp string. */ |
| 553 | |
|
20303
13efdf0fe96e
(printchar): Declare `work' as unsigned char.
Andreas Schwab <schwab@suse.de>
parents:
20200
diff
changeset
|
554 void |
| 329 | 555 write_string (data, size) |
| 556 char *data; | |
| 557 int size; | |
| 558 { | |
|
16140
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
559 PRINTDECLARE; |
| 329 | 560 Lisp_Object printcharfun; |
| 561 | |
| 562 printcharfun = Vstandard_output; | |
| 563 | |
| 564 PRINTPREPARE; | |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
565 strout (data, size, size, printcharfun, 0); |
| 329 | 566 PRINTFINISH; |
| 567 } | |
| 568 | |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
569 /* Used from outside of print.c to print a block of SIZE |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
570 single-byte chars at DATA on a specified stream PRINTCHARFUN. |
| 329 | 571 Do not use this on the contents of a Lisp string. */ |
| 572 | |
|
20303
13efdf0fe96e
(printchar): Declare `work' as unsigned char.
Andreas Schwab <schwab@suse.de>
parents:
20200
diff
changeset
|
573 void |
| 329 | 574 write_string_1 (data, size, printcharfun) |
| 575 char *data; | |
| 576 int size; | |
| 577 Lisp_Object printcharfun; | |
| 578 { | |
|
16140
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
579 PRINTDECLARE; |
| 329 | 580 |
| 581 PRINTPREPARE; | |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
582 strout (data, size, size, printcharfun, 0); |
| 329 | 583 PRINTFINISH; |
| 584 } | |
| 585 | |
| 586 | |
| 587 void | |
| 588 temp_output_buffer_setup (bufname) | |
|
46553
61742ffed0bb
(temp_output_buffer_setup):
Ken Raeburn <raeburn@raeburn.org>
parents:
46370
diff
changeset
|
589 const char *bufname; |
| 329 | 590 { |
|
46293
1fb8f75062c6
Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents:
45995
diff
changeset
|
591 int count = SPECPDL_INDEX (); |
| 329 | 592 register struct buffer *old = current_buffer; |
| 593 register Lisp_Object buf; | |
| 594 | |
|
24049
a45f10911408
(Qtemp_buffer_setup_hook): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
23931
diff
changeset
|
595 record_unwind_protect (set_buffer_if_live, Fcurrent_buffer ()); |
|
a45f10911408
(Qtemp_buffer_setup_hook): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
23931
diff
changeset
|
596 |
| 329 | 597 Fset_buffer (Fget_buffer_create (build_string (bufname))); |
| 598 | |
|
45995
c3e620e7c70b
(temp_output_buffer_setup): Kill all local variables.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
45409
diff
changeset
|
599 Fkill_all_local_variables (); |
|
52017
cfe412cda900
(temp_output_buffer_setup): Use delete_all_overlays.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51835
diff
changeset
|
600 delete_all_overlays (current_buffer); |
|
11114
c8ab5c627f74
(temp_output_buffer_setup): (Re)set the default
Richard M. Stallman <rms@gnu.org>
parents:
11010
diff
changeset
|
601 current_buffer->directory = old->directory; |
| 329 | 602 current_buffer->read_only = Qnil; |
|
21484
e4f63bf20c03
(temp_output_buffer_setup): Clear out overlays,
Karl Heuer <kwzh@gnu.org>
parents:
21480
diff
changeset
|
603 current_buffer->filename = Qnil; |
|
e4f63bf20c03
(temp_output_buffer_setup): Clear out overlays,
Karl Heuer <kwzh@gnu.org>
parents:
21480
diff
changeset
|
604 current_buffer->undo_list = Qt; |
|
52020
87dced6b77d2
(temp_output_buffer_setup): Typo.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52017
diff
changeset
|
605 eassert (current_buffer->overlays_before == NULL); |
|
87dced6b77d2
(temp_output_buffer_setup): Typo.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52017
diff
changeset
|
606 eassert (current_buffer->overlays_after == NULL); |
|
21484
e4f63bf20c03
(temp_output_buffer_setup): Clear out overlays,
Karl Heuer <kwzh@gnu.org>
parents:
21480
diff
changeset
|
607 current_buffer->enable_multibyte_characters |
|
e4f63bf20c03
(temp_output_buffer_setup): Clear out overlays,
Karl Heuer <kwzh@gnu.org>
parents:
21480
diff
changeset
|
608 = buffer_defaults.enable_multibyte_characters; |
|
55493
a318c79b8463
(temp_output_buffer_setup): Bind inhibit-read-only and
Kenichi Handa <handa@m17n.org>
parents:
55162
diff
changeset
|
609 specbind (Qinhibit_read_only, Qt); |
|
a318c79b8463
(temp_output_buffer_setup): Bind inhibit-read-only and
Kenichi Handa <handa@m17n.org>
parents:
55162
diff
changeset
|
610 specbind (Qinhibit_modification_hooks, Qt); |
| 329 | 611 Ferase_buffer (); |
|
24049
a45f10911408
(Qtemp_buffer_setup_hook): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
23931
diff
changeset
|
612 XSETBUFFER (buf, current_buffer); |
| 329 | 613 |
|
41525
e484ddbc92e1
(temp_output_buffer_setup): Use Frun_hooks, not Vrun_hooks.
Richard M. Stallman <rms@gnu.org>
parents:
41081
diff
changeset
|
614 Frun_hooks (1, &Qtemp_buffer_setup_hook); |
|
24049
a45f10911408
(Qtemp_buffer_setup_hook): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
23931
diff
changeset
|
615 |
|
a45f10911408
(Qtemp_buffer_setup_hook): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
23931
diff
changeset
|
616 unbind_to (count, Qnil); |
|
a45f10911408
(Qtemp_buffer_setup_hook): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
23931
diff
changeset
|
617 |
| 329 | 618 specbind (Qstandard_output, buf); |
| 619 } | |
| 620 | |
| 621 Lisp_Object | |
| 622 internal_with_output_to_temp_buffer (bufname, function, args) | |
|
46553
61742ffed0bb
(temp_output_buffer_setup):
Ken Raeburn <raeburn@raeburn.org>
parents:
46370
diff
changeset
|
623 const char *bufname; |
| 21514 | 624 Lisp_Object (*function) P_ ((Lisp_Object)); |
| 329 | 625 Lisp_Object args; |
| 626 { | |
|
46293
1fb8f75062c6
Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents:
45995
diff
changeset
|
627 int count = SPECPDL_INDEX (); |
| 329 | 628 Lisp_Object buf, val; |
|
8315
8921d0012bd5
(internal_with_output_to_temp_buffer): gcpro things.
Richard M. Stallman <rms@gnu.org>
parents:
7185
diff
changeset
|
629 struct gcpro gcpro1; |
| 329 | 630 |
|
8315
8921d0012bd5
(internal_with_output_to_temp_buffer): gcpro things.
Richard M. Stallman <rms@gnu.org>
parents:
7185
diff
changeset
|
631 GCPRO1 (args); |
| 329 | 632 record_unwind_protect (Fset_buffer, Fcurrent_buffer ()); |
| 633 temp_output_buffer_setup (bufname); | |
| 634 buf = Vstandard_output; | |
|
8315
8921d0012bd5
(internal_with_output_to_temp_buffer): gcpro things.
Richard M. Stallman <rms@gnu.org>
parents:
7185
diff
changeset
|
635 UNGCPRO; |
| 329 | 636 |
| 637 val = (*function) (args); | |
| 638 | |
|
8315
8921d0012bd5
(internal_with_output_to_temp_buffer): gcpro things.
Richard M. Stallman <rms@gnu.org>
parents:
7185
diff
changeset
|
639 GCPRO1 (val); |
| 329 | 640 temp_output_buffer_show (buf); |
|
8315
8921d0012bd5
(internal_with_output_to_temp_buffer): gcpro things.
Richard M. Stallman <rms@gnu.org>
parents:
7185
diff
changeset
|
641 UNGCPRO; |
| 329 | 642 |
| 643 return unbind_to (count, val); | |
| 644 } | |
| 645 | |
|
40143
3c480f0b4146
(Fwith_output_to_temp_buffer): Add usage: string to doc string.
Miles Bader <miles@gnu.org>
parents:
40123
diff
changeset
|
646 DEFUN ("with-output-to-temp-buffer", |
|
3c480f0b4146
(Fwith_output_to_temp_buffer): Add usage: string to doc string.
Miles Bader <miles@gnu.org>
parents:
40123
diff
changeset
|
647 Fwith_output_to_temp_buffer, Swith_output_to_temp_buffer, |
| 329 | 648 1, UNEVALLED, 0, |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
649 doc: /* Bind `standard-output' to buffer BUFNAME, eval BODY, then show that buffer. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
650 The buffer is cleared out initially, and marked as unmodified when done. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
651 All output done by BODY is inserted in that buffer by default. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
652 The buffer is displayed in another window, but not selected. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
653 The value of the last form in BODY is returned. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
654 If BODY does not finish normally, the buffer BUFNAME is not displayed. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
655 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
656 The hook `temp-buffer-setup-hook' is run before BODY, |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
657 with the buffer BUFNAME temporarily current. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
658 The hook `temp-buffer-show-hook' is run after the buffer is displayed, |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
659 with the buffer temporarily current, and the window that was used |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
660 to display it temporarily selected. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
661 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
662 If variable `temp-buffer-show-function' is non-nil, call it at the end |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
663 to get the buffer displayed instead of just displaying the non-selected |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47864
diff
changeset
|
664 buffer and calling the hook. It gets one argument, the buffer to display. |
|
40143
3c480f0b4146
(Fwith_output_to_temp_buffer): Add usage: string to doc string.
Miles Bader <miles@gnu.org>
parents:
40123
diff
changeset
|
665 |
|
56182
745575295194
(Fwith_output_to_temp_buffer): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents:
56069
diff
changeset
|
666 usage: (with-output-to-temp-buffer BUFNAME BODY ...) */) |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
667 (args) |
| 329 | 668 Lisp_Object args; |
| 669 { | |
| 670 struct gcpro gcpro1; | |
| 671 Lisp_Object name; | |
|
46293
1fb8f75062c6
Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents:
45995
diff
changeset
|
672 int count = SPECPDL_INDEX (); |
| 329 | 673 Lisp_Object buf, val; |
| 674 | |
| 675 GCPRO1(args); | |
| 676 name = Feval (Fcar (args)); | |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40472
diff
changeset
|
677 CHECK_STRING (name); |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
678 temp_output_buffer_setup (SDATA (name)); |
| 329 | 679 buf = Vstandard_output; |
|
39856
3fb9aba0cbd4
(Fwith_output_to_temp_buffer): Align with
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
39582
diff
changeset
|
680 UNGCPRO; |
| 329 | 681 |
|
39856
3fb9aba0cbd4
(Fwith_output_to_temp_buffer): Align with
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
39582
diff
changeset
|
682 val = Fprogn (XCDR (args)); |
| 329 | 683 |
|
39856
3fb9aba0cbd4
(Fwith_output_to_temp_buffer): Align with
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
39582
diff
changeset
|
684 GCPRO1 (val); |
| 329 | 685 temp_output_buffer_show (buf); |
|
39856
3fb9aba0cbd4
(Fwith_output_to_temp_buffer): Align with
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
39582
diff
changeset
|
686 UNGCPRO; |
| 329 | 687 |
| 688 return unbind_to (count, val); | |
| 689 } | |
|
25355
e25e953cfc58
Remove conditional compilation on `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
25011
diff
changeset
|
690 |
| 329 | 691 |
| 692 static void print (); | |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
693 static void print_preprocess (); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
694 static void print_preprocess_string (); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
695 static void print_object (); |
| 329 | 696 |
| 697 DEFUN ("terpri", Fterpri, Sterpri, 0, 1, 0, | |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
698 doc: /* Output a newline to stream PRINTCHARFUN. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
699 If PRINTCHARFUN is omitted or nil, the value of `standard-output' is used. */) |
| 329 | 700 (printcharfun) |
| 701 Lisp_Object printcharfun; | |
| 702 { | |
|
16140
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
703 PRINTDECLARE; |
| 329 | 704 |
| 520 | 705 if (NILP (printcharfun)) |
| 329 | 706 printcharfun = Vstandard_output; |
| 707 PRINTPREPARE; | |
| 708 PRINTCHAR ('\n'); | |
| 709 PRINTFINISH; | |
| 710 return Qt; | |
| 711 } | |
| 712 | |
| 713 DEFUN ("prin1", Fprin1, Sprin1, 1, 2, 0, | |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
714 doc: /* Output the printed representation of OBJECT, any Lisp object. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
715 Quoting characters are printed when needed to make output that `read' |
| 41056 | 716 can handle, whenever this is possible. For complex objects, the behavior |
| 41081 | 717 is controlled by `print-level' and `print-length', which see. |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
718 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
719 OBJECT is any of the Lisp data types: a number, a string, a symbol, |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
720 a list, a buffer, a window, a frame, etc. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
721 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
722 A printed representation of an object is text which describes that object. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
723 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
724 Optional argument PRINTCHARFUN is the output stream, which can be one |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
725 of these: |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
726 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
727 - a buffer, in which case output is inserted into that buffer at point; |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
728 - a marker, in which case output is inserted at marker's position; |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
729 - a function, in which case that function is called once for each |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
730 character of OBJECT's printed representation; |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
731 - a symbol, in which case that symbol's function definition is called; or |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
732 - t, in which case the output is displayed in the echo area. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
733 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
734 If PRINTCHARFUN is omitted, the value of `standard-output' (which see) |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
735 is used instead. */) |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
736 (object, printcharfun) |
|
14084
8765a56417ac
(Fwrite_char, Fprin1, Fprin1_to_string, Fprinc, Fprint): Harmonize
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
737 Lisp_Object object, printcharfun; |
| 329 | 738 { |
|
16140
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
739 PRINTDECLARE; |
| 329 | 740 |
| 741 #ifdef MAX_PRINT_CHARS | |
| 742 max_print = 0; | |
| 743 #endif /* MAX_PRINT_CHARS */ | |
| 520 | 744 if (NILP (printcharfun)) |
| 329 | 745 printcharfun = Vstandard_output; |
| 746 PRINTPREPARE; | |
|
14084
8765a56417ac
(Fwrite_char, Fprin1, Fprin1_to_string, Fprinc, Fprint): Harmonize
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
747 print (object, printcharfun, 1); |
| 329 | 748 PRINTFINISH; |
|
14084
8765a56417ac
(Fwrite_char, Fprin1, Fprin1_to_string, Fprinc, Fprint): Harmonize
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
749 return object; |
| 329 | 750 } |
| 751 | |
| 752 /* a buffer which is used to hold output being built by prin1-to-string */ | |
| 753 Lisp_Object Vprin1_to_string_buffer; | |
| 754 | |
| 755 DEFUN ("prin1-to-string", Fprin1_to_string, Sprin1_to_string, 1, 2, 0, | |
|
41030
8144c97ba576
(Fprin1_to_string): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
40656
diff
changeset
|
756 doc: /* Return a string containing the printed representation of OBJECT. |
|
8144c97ba576
(Fprin1_to_string): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
40656
diff
changeset
|
757 OBJECT can be any Lisp object. This function outputs quoting characters |
| 42481 | 758 when necessary to make output that `read' can handle, whenever possible, |
|
41030
8144c97ba576
(Fprin1_to_string): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
40656
diff
changeset
|
759 unless the optional second argument NOESCAPE is non-nil. |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
760 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
761 OBJECT is any of the Lisp data types: a number, a string, a symbol, |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
762 a list, a buffer, a window, a frame, etc. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
763 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
764 A printed representation of an object is text which describes that object. */) |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
765 (object, noescape) |
|
14084
8765a56417ac
(Fwrite_char, Fprin1, Fprin1_to_string, Fprinc, Fprint): Harmonize
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
766 Lisp_Object object, noescape; |
| 329 | 767 { |
|
16140
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
768 Lisp_Object printcharfun; |
|
50920
997593980303
(Fprin1_to_string): Instead of gcpro, set abort_on_gc.
Richard M. Stallman <rms@gnu.org>
parents:
50080
diff
changeset
|
769 /* struct gcpro gcpro1, gcpro2; */ |
|
997593980303
(Fprin1_to_string): Instead of gcpro, set abort_on_gc.
Richard M. Stallman <rms@gnu.org>
parents:
50080
diff
changeset
|
770 Lisp_Object save_deactivate_mark; |
|
997593980303
(Fprin1_to_string): Instead of gcpro, set abort_on_gc.
Richard M. Stallman <rms@gnu.org>
parents:
50080
diff
changeset
|
771 int count = specpdl_ptr - specpdl; |
|
52538
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
772 struct buffer *previous; |
|
50920
997593980303
(Fprin1_to_string): Instead of gcpro, set abort_on_gc.
Richard M. Stallman <rms@gnu.org>
parents:
50080
diff
changeset
|
773 |
|
997593980303
(Fprin1_to_string): Instead of gcpro, set abort_on_gc.
Richard M. Stallman <rms@gnu.org>
parents:
50080
diff
changeset
|
774 specbind (Qinhibit_modification_hooks, Qt); |
|
15270
22867e90511f
(Fprin1_to_string): Preserve Vdeactivate_mark.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
775 |
|
52538
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
776 { |
|
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
777 PRINTDECLARE; |
| 329 | 778 |
|
52538
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
779 /* Save and restore this--we are altering a buffer |
|
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
780 but we don't want to deactivate the mark just for that. |
|
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
781 No need for specbind, since errors deactivate the mark. */ |
|
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
782 save_deactivate_mark = Vdeactivate_mark; |
|
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
783 /* GCPRO2 (object, save_deactivate_mark); */ |
|
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
784 abort_on_gc++; |
|
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
785 |
|
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
786 printcharfun = Vprin1_to_string_buffer; |
|
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
787 PRINTPREPARE; |
|
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
788 print (object, printcharfun, NILP (noescape)); |
|
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
789 /* Make Vprin1_to_string_buffer be the default buffer after PRINTFINSH */ |
|
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
790 PRINTFINISH; |
|
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
791 } |
|
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
792 |
|
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
793 previous = current_buffer; |
| 329 | 794 set_buffer_internal (XBUFFER (Vprin1_to_string_buffer)); |
|
14084
8765a56417ac
(Fwrite_char, Fprin1, Fprin1_to_string, Fprinc, Fprint): Harmonize
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
795 object = Fbuffer_string (); |
|
50080
5ff2f3145fd1
(Fprin1_to_string): Return unibyte string if possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49600
diff
changeset
|
796 if (SBYTES (object) == SCHARS (object)) |
|
5ff2f3145fd1
(Fprin1_to_string): Return unibyte string if possible.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
49600
diff
changeset
|
797 STRING_SET_UNIBYTE (object); |
| 329 | 798 |
|
55651
dcb7d888bb38
(print_object): Increase buf size.
Kim F. Storm <storm@cua.dk>
parents:
55498
diff
changeset
|
799 /* Note that this won't make prepare_to_modify_buffer call |
|
52538
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
800 ask-user-about-supersession-threat because this buffer |
|
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
801 does not visit a file. */ |
| 329 | 802 Ferase_buffer (); |
|
52538
ecd666ee0ea1
(Fprin1_to_string): Move the PRINTPREPARE later,
Richard M. Stallman <rms@gnu.org>
parents:
52401
diff
changeset
|
803 set_buffer_internal (previous); |
|
15270
22867e90511f
(Fprin1_to_string): Preserve Vdeactivate_mark.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
804 |
|
50920
997593980303
(Fprin1_to_string): Instead of gcpro, set abort_on_gc.
Richard M. Stallman <rms@gnu.org>
parents:
50080
diff
changeset
|
805 Vdeactivate_mark = save_deactivate_mark; |
|
997593980303
(Fprin1_to_string): Instead of gcpro, set abort_on_gc.
Richard M. Stallman <rms@gnu.org>
parents:
50080
diff
changeset
|
806 /* UNGCPRO; */ |
| 329 | 807 |
|
50920
997593980303
(Fprin1_to_string): Instead of gcpro, set abort_on_gc.
Richard M. Stallman <rms@gnu.org>
parents:
50080
diff
changeset
|
808 abort_on_gc--; |
|
997593980303
(Fprin1_to_string): Instead of gcpro, set abort_on_gc.
Richard M. Stallman <rms@gnu.org>
parents:
50080
diff
changeset
|
809 return unbind_to (count, object); |
| 329 | 810 } |
| 811 | |
| 812 DEFUN ("princ", Fprinc, Sprinc, 1, 2, 0, | |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
813 doc: /* Output the printed representation of OBJECT, any Lisp object. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
814 No quoting characters are used; no delimiters are printed around |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
815 the contents of strings. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
816 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
817 OBJECT is any of the Lisp data types: a number, a string, a symbol, |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
818 a list, a buffer, a window, a frame, etc. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
819 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
820 A printed representation of an object is text which describes that object. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
821 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
822 Optional argument PRINTCHARFUN is the output stream, which can be one |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
823 of these: |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
824 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
825 - a buffer, in which case output is inserted into that buffer at point; |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
826 - a marker, in which case output is inserted at marker's position; |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
827 - a function, in which case that function is called once for each |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
828 character of OBJECT's printed representation; |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
829 - a symbol, in which case that symbol's function definition is called; or |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
830 - t, in which case the output is displayed in the echo area. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
831 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
832 If PRINTCHARFUN is omitted, the value of `standard-output' (which see) |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
833 is used instead. */) |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
834 (object, printcharfun) |
|
14084
8765a56417ac
(Fwrite_char, Fprin1, Fprin1_to_string, Fprinc, Fprint): Harmonize
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
835 Lisp_Object object, printcharfun; |
| 329 | 836 { |
|
16140
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
837 PRINTDECLARE; |
| 329 | 838 |
| 520 | 839 if (NILP (printcharfun)) |
| 329 | 840 printcharfun = Vstandard_output; |
| 841 PRINTPREPARE; | |
|
14084
8765a56417ac
(Fwrite_char, Fprin1, Fprin1_to_string, Fprinc, Fprint): Harmonize
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
842 print (object, printcharfun, 0); |
| 329 | 843 PRINTFINISH; |
|
14084
8765a56417ac
(Fwrite_char, Fprin1, Fprin1_to_string, Fprinc, Fprint): Harmonize
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
844 return object; |
| 329 | 845 } |
| 846 | |
| 847 DEFUN ("print", Fprint, Sprint, 1, 2, 0, | |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
848 doc: /* Output the printed representation of OBJECT, with newlines around it. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
849 Quoting characters are printed when needed to make output that `read' |
| 41056 | 850 can handle, whenever this is possible. For complex objects, the behavior |
| 41081 | 851 is controlled by `print-level' and `print-length', which see. |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
852 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
853 OBJECT is any of the Lisp data types: a number, a string, a symbol, |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
854 a list, a buffer, a window, a frame, etc. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
855 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
856 A printed representation of an object is text which describes that object. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
857 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
858 Optional argument PRINTCHARFUN is the output stream, which can be one |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
859 of these: |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
860 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
861 - a buffer, in which case output is inserted into that buffer at point; |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
862 - a marker, in which case output is inserted at marker's position; |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
863 - a function, in which case that function is called once for each |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
864 character of OBJECT's printed representation; |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
865 - a symbol, in which case that symbol's function definition is called; or |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
866 - t, in which case the output is displayed in the echo area. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
867 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
868 If PRINTCHARFUN is omitted, the value of `standard-output' (which see) |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
869 is used instead. */) |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
870 (object, printcharfun) |
|
14084
8765a56417ac
(Fwrite_char, Fprin1, Fprin1_to_string, Fprinc, Fprint): Harmonize
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
871 Lisp_Object object, printcharfun; |
| 329 | 872 { |
|
16140
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
873 PRINTDECLARE; |
| 329 | 874 struct gcpro gcpro1; |
| 875 | |
| 876 #ifdef MAX_PRINT_CHARS | |
| 877 print_chars = 0; | |
| 878 max_print = MAX_PRINT_CHARS; | |
| 879 #endif /* MAX_PRINT_CHARS */ | |
| 520 | 880 if (NILP (printcharfun)) |
| 329 | 881 printcharfun = Vstandard_output; |
|
14084
8765a56417ac
(Fwrite_char, Fprin1, Fprin1_to_string, Fprinc, Fprint): Harmonize
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
882 GCPRO1 (object); |
| 329 | 883 PRINTPREPARE; |
| 884 PRINTCHAR ('\n'); | |
|
14084
8765a56417ac
(Fwrite_char, Fprin1, Fprin1_to_string, Fprinc, Fprint): Harmonize
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
885 print (object, printcharfun, 1); |
| 329 | 886 PRINTCHAR ('\n'); |
| 887 PRINTFINISH; | |
| 888 #ifdef MAX_PRINT_CHARS | |
| 889 max_print = 0; | |
| 890 print_chars = 0; | |
| 891 #endif /* MAX_PRINT_CHARS */ | |
| 892 UNGCPRO; | |
|
14084
8765a56417ac
(Fwrite_char, Fprin1, Fprin1_to_string, Fprinc, Fprint): Harmonize
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
893 return object; |
| 329 | 894 } |
| 895 | |
| 896 /* The subroutine object for external-debugging-output is kept here | |
| 897 for the convenience of the debugger. */ | |
| 898 Lisp_Object Qexternal_debugging_output; | |
| 899 | |
| 621 | 900 DEFUN ("external-debugging-output", Fexternal_debugging_output, Sexternal_debugging_output, 1, 1, 0, |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
901 doc: /* Write CHARACTER to stderr. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
902 You can call print while debugging emacs, and pass it this function |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
903 to make it write to the debugging output. */) |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
904 (character) |
| 621 | 905 Lisp_Object character; |
| 329 | 906 { |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40472
diff
changeset
|
907 CHECK_NUMBER (character); |
| 329 | 908 putc (XINT (character), stderr); |
|
19882
b6aaf1f70676
(Fexternal_debugging_output): On Windows output to debugger.
Richard M. Stallman <rms@gnu.org>
parents:
19001
diff
changeset
|
909 |
|
b6aaf1f70676
(Fexternal_debugging_output): On Windows output to debugger.
Richard M. Stallman <rms@gnu.org>
parents:
19001
diff
changeset
|
910 #ifdef WINDOWSNT |
|
b6aaf1f70676
(Fexternal_debugging_output): On Windows output to debugger.
Richard M. Stallman <rms@gnu.org>
parents:
19001
diff
changeset
|
911 /* Send the output to a debugger (nothing happens if there isn't one). */ |
|
b6aaf1f70676
(Fexternal_debugging_output): On Windows output to debugger.
Richard M. Stallman <rms@gnu.org>
parents:
19001
diff
changeset
|
912 { |
|
b6aaf1f70676
(Fexternal_debugging_output): On Windows output to debugger.
Richard M. Stallman <rms@gnu.org>
parents:
19001
diff
changeset
|
913 char buf[2] = {(char) XINT (character), '\0'}; |
|
b6aaf1f70676
(Fexternal_debugging_output): On Windows output to debugger.
Richard M. Stallman <rms@gnu.org>
parents:
19001
diff
changeset
|
914 OutputDebugString (buf); |
|
b6aaf1f70676
(Fexternal_debugging_output): On Windows output to debugger.
Richard M. Stallman <rms@gnu.org>
parents:
19001
diff
changeset
|
915 } |
|
b6aaf1f70676
(Fexternal_debugging_output): On Windows output to debugger.
Richard M. Stallman <rms@gnu.org>
parents:
19001
diff
changeset
|
916 #endif |
|
b6aaf1f70676
(Fexternal_debugging_output): On Windows output to debugger.
Richard M. Stallman <rms@gnu.org>
parents:
19001
diff
changeset
|
917 |
| 329 | 918 return character; |
| 919 } | |
|
6533
49f896769be4
(debug_print): New function.
Richard M. Stallman <rms@gnu.org>
parents:
5852
diff
changeset
|
920 |
|
53158
1025f21ef0c9
(Fredirect_debugging_output) [!GNU_LINUX]: Do not
Kim F. Storm <storm@cua.dk>
parents:
53141
diff
changeset
|
921 |
|
1025f21ef0c9
(Fredirect_debugging_output) [!GNU_LINUX]: Do not
Kim F. Storm <storm@cua.dk>
parents:
53141
diff
changeset
|
922 #if defined(GNU_LINUX) |
|
1025f21ef0c9
(Fredirect_debugging_output) [!GNU_LINUX]: Do not
Kim F. Storm <storm@cua.dk>
parents:
53141
diff
changeset
|
923 |
|
1025f21ef0c9
(Fredirect_debugging_output) [!GNU_LINUX]: Do not
Kim F. Storm <storm@cua.dk>
parents:
53141
diff
changeset
|
924 /* This functionality is not vitally important in general, so we rely on |
|
1025f21ef0c9
(Fredirect_debugging_output) [!GNU_LINUX]: Do not
Kim F. Storm <storm@cua.dk>
parents:
53141
diff
changeset
|
925 non-portable ability to use stderr as lvalue. */ |
|
1025f21ef0c9
(Fredirect_debugging_output) [!GNU_LINUX]: Do not
Kim F. Storm <storm@cua.dk>
parents:
53141
diff
changeset
|
926 |
|
1025f21ef0c9
(Fredirect_debugging_output) [!GNU_LINUX]: Do not
Kim F. Storm <storm@cua.dk>
parents:
53141
diff
changeset
|
927 #define WITH_REDIRECT_DEBUGGING_OUTPUT 1 |
|
1025f21ef0c9
(Fredirect_debugging_output) [!GNU_LINUX]: Do not
Kim F. Storm <storm@cua.dk>
parents:
53141
diff
changeset
|
928 |
|
53141
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
929 FILE *initial_stderr_stream = NULL; |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
930 |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
931 DEFUN ("redirect-debugging-output", Fredirect_debugging_output, Sredirect_debugging_output, |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
932 1, 2, |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
933 "FDebug output file: \nP", |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
934 doc: /* Redirect debugging output (stderr stream) to file FILE. |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
935 If FILE is nil, reset target to the initial stderr stream. |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
936 Optional arg APPEND non-nil (interactively, with prefix arg) means |
|
55651
dcb7d888bb38
(print_object): Increase buf size.
Kim F. Storm <storm@cua.dk>
parents:
55498
diff
changeset
|
937 append to existing target file. */) |
|
53141
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
938 (file, append) |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
939 Lisp_Object file, append; |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
940 { |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
941 if (initial_stderr_stream != NULL) |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
942 fclose(stderr); |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
943 stderr = initial_stderr_stream; |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
944 initial_stderr_stream = NULL; |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
945 |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
946 if (STRINGP (file)) |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
947 { |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
948 file = Fexpand_file_name (file, Qnil); |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
949 initial_stderr_stream = stderr; |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
950 stderr = fopen(SDATA (file), NILP (append) ? "w" : "a"); |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
951 if (stderr == NULL) |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
952 { |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
953 stderr = initial_stderr_stream; |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
954 initial_stderr_stream = NULL; |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
955 report_file_error ("Cannot open debugging output stream", |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
956 Fcons (file, Qnil)); |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
957 } |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
958 } |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
959 return Qnil; |
|
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
960 } |
|
53158
1025f21ef0c9
(Fredirect_debugging_output) [!GNU_LINUX]: Do not
Kim F. Storm <storm@cua.dk>
parents:
53141
diff
changeset
|
961 #endif /* GNU_LINUX */ |
|
1025f21ef0c9
(Fredirect_debugging_output) [!GNU_LINUX]: Do not
Kim F. Storm <storm@cua.dk>
parents:
53141
diff
changeset
|
962 |
|
53141
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
963 |
|
6533
49f896769be4
(debug_print): New function.
Richard M. Stallman <rms@gnu.org>
parents:
5852
diff
changeset
|
964 /* This is the interface for debugging printing. */ |
|
49f896769be4
(debug_print): New function.
Richard M. Stallman <rms@gnu.org>
parents:
5852
diff
changeset
|
965 |
|
49f896769be4
(debug_print): New function.
Richard M. Stallman <rms@gnu.org>
parents:
5852
diff
changeset
|
966 void |
|
49f896769be4
(debug_print): New function.
Richard M. Stallman <rms@gnu.org>
parents:
5852
diff
changeset
|
967 debug_print (arg) |
|
49f896769be4
(debug_print): New function.
Richard M. Stallman <rms@gnu.org>
parents:
5852
diff
changeset
|
968 Lisp_Object arg; |
|
49f896769be4
(debug_print): New function.
Richard M. Stallman <rms@gnu.org>
parents:
5852
diff
changeset
|
969 { |
|
49f896769be4
(debug_print): New function.
Richard M. Stallman <rms@gnu.org>
parents:
5852
diff
changeset
|
970 Fprin1 (arg, Qexternal_debugging_output); |
|
13456
b66f0626addb
(debug_print): Explicitly print a CR.
Richard M. Stallman <rms@gnu.org>
parents:
13405
diff
changeset
|
971 fprintf (stderr, "\r\n"); |
|
6533
49f896769be4
(debug_print): New function.
Richard M. Stallman <rms@gnu.org>
parents:
5852
diff
changeset
|
972 } |
|
66779
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
973 |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
974 void |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
975 safe_debug_print (arg) |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
976 Lisp_Object arg; |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
977 { |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
978 int valid = valid_lisp_object_p (arg); |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
979 |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
980 if (valid > 0) |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
981 debug_print (arg); |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
982 else |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
983 fprintf (stderr, "#<%s_LISP_OBJECT 0x%08lx>\r\n", |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
984 !valid ? "INVALID" : "SOME", |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
985 #ifdef NO_UNION_TYPE |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
986 (unsigned long) arg |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
987 #else |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
988 (unsigned long) arg.i |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
989 #endif |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
990 ); |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
991 } |
|
06e83e43c727
(safe_debug_print): New function to be called from gdb
Kim F. Storm <storm@cua.dk>
parents:
65485
diff
changeset
|
992 |
| 329 | 993 |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
994 DEFUN ("error-message-string", Ferror_message_string, Serror_message_string, |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
995 1, 1, 0, |
|
53460
6f8ae3624b9e
(Ferror_message_string): Add hyperlink to the definition of `signal'
Luc Teirlinck <teirllm@auburn.edu>
parents:
53158
diff
changeset
|
996 doc: /* Convert an error value (ERROR-SYMBOL . DATA) to an error message. |
|
6f8ae3624b9e
(Ferror_message_string): Add hyperlink to the definition of `signal'
Luc Teirlinck <teirllm@auburn.edu>
parents:
53158
diff
changeset
|
997 See Info anchor `(elisp)Definition of signal' for some details on how this |
|
6f8ae3624b9e
(Ferror_message_string): Add hyperlink to the definition of `signal'
Luc Teirlinck <teirllm@auburn.edu>
parents:
53158
diff
changeset
|
998 error message is constructed. */) |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
999 (obj) |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1000 Lisp_Object obj; |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1001 { |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1002 struct buffer *old = current_buffer; |
|
25726
9bfb1496cdd8
(PRINTFULLP): Removed because it is no longer used and
Gerd Moellmann <gerd@gnu.org>
parents:
25717
diff
changeset
|
1003 Lisp_Object value; |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1004 struct gcpro gcpro1; |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1005 |
|
18342
913d2cc5a6aa
(Ferror_message_string): Optimize (error STRING) case.
Richard M. Stallman <rms@gnu.org>
parents:
17509
diff
changeset
|
1006 /* If OBJ is (error STRING), just return STRING. |
|
913d2cc5a6aa
(Ferror_message_string): Optimize (error STRING) case.
Richard M. Stallman <rms@gnu.org>
parents:
17509
diff
changeset
|
1007 That is not only faster, it also avoids the need to allocate |
|
913d2cc5a6aa
(Ferror_message_string): Optimize (error STRING) case.
Richard M. Stallman <rms@gnu.org>
parents:
17509
diff
changeset
|
1008 space here when the error is due to memory full. */ |
|
25717
3c6ad00e51a8
Use XCAR, XCDR, and XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25694
diff
changeset
|
1009 if (CONSP (obj) && EQ (XCAR (obj), Qerror) |
|
3c6ad00e51a8
Use XCAR, XCDR, and XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25694
diff
changeset
|
1010 && CONSP (XCDR (obj)) |
|
3c6ad00e51a8
Use XCAR, XCDR, and XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25694
diff
changeset
|
1011 && STRINGP (XCAR (XCDR (obj))) |
|
3c6ad00e51a8
Use XCAR, XCDR, and XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25694
diff
changeset
|
1012 && NILP (XCDR (XCDR (obj)))) |
|
3c6ad00e51a8
Use XCAR, XCDR, and XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25694
diff
changeset
|
1013 return XCAR (XCDR (obj)); |
|
18342
913d2cc5a6aa
(Ferror_message_string): Optimize (error STRING) case.
Richard M. Stallman <rms@gnu.org>
parents:
17509
diff
changeset
|
1014 |
|
46574
2f83f3473b40
(print_error_message): New args CONTEXT and CALLER. Calls changed.
Richard M. Stallman <rms@gnu.org>
parents:
46553
diff
changeset
|
1015 print_error_message (obj, Vprin1_to_string_buffer, 0, Qnil); |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1016 |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1017 set_buffer_internal (XBUFFER (Vprin1_to_string_buffer)); |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1018 value = Fbuffer_string (); |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1019 |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1020 GCPRO1 (value); |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1021 Ferase_buffer (); |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1022 set_buffer_internal (old); |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1023 UNGCPRO; |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1024 |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1025 return value; |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1026 } |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1027 |
|
28732
e5694cf2ac01
(print_error_message): Print data of `end-of-file'
Gerd Moellmann <gerd@gnu.org>
parents:
28507
diff
changeset
|
1028 /* Print an error message for the error DATA onto Lisp output stream |
|
e5694cf2ac01
(print_error_message): Print data of `end-of-file'
Gerd Moellmann <gerd@gnu.org>
parents:
28507
diff
changeset
|
1029 STREAM (suitable for the print functions). */ |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1030 |
|
20303
13efdf0fe96e
(printchar): Declare `work' as unsigned char.
Andreas Schwab <schwab@suse.de>
parents:
20200
diff
changeset
|
1031 void |
|
46574
2f83f3473b40
(print_error_message): New args CONTEXT and CALLER. Calls changed.
Richard M. Stallman <rms@gnu.org>
parents:
46553
diff
changeset
|
1032 print_error_message (data, stream, context, caller) |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1033 Lisp_Object data, stream; |
|
46574
2f83f3473b40
(print_error_message): New args CONTEXT and CALLER. Calls changed.
Richard M. Stallman <rms@gnu.org>
parents:
46553
diff
changeset
|
1034 char *context; |
|
2f83f3473b40
(print_error_message): New args CONTEXT and CALLER. Calls changed.
Richard M. Stallman <rms@gnu.org>
parents:
46553
diff
changeset
|
1035 Lisp_Object caller; |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1036 { |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1037 Lisp_Object errname, errmsg, file_error, tail; |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1038 struct gcpro gcpro1; |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1039 int i; |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1040 |
|
46574
2f83f3473b40
(print_error_message): New args CONTEXT and CALLER. Calls changed.
Richard M. Stallman <rms@gnu.org>
parents:
46553
diff
changeset
|
1041 if (context != 0) |
|
2f83f3473b40
(print_error_message): New args CONTEXT and CALLER. Calls changed.
Richard M. Stallman <rms@gnu.org>
parents:
46553
diff
changeset
|
1042 write_string_1 (context, -1, stream); |
|
2f83f3473b40
(print_error_message): New args CONTEXT and CALLER. Calls changed.
Richard M. Stallman <rms@gnu.org>
parents:
46553
diff
changeset
|
1043 |
|
2f83f3473b40
(print_error_message): New args CONTEXT and CALLER. Calls changed.
Richard M. Stallman <rms@gnu.org>
parents:
46553
diff
changeset
|
1044 /* If we know from where the error was signaled, show it in |
|
2f83f3473b40
(print_error_message): New args CONTEXT and CALLER. Calls changed.
Richard M. Stallman <rms@gnu.org>
parents:
46553
diff
changeset
|
1045 *Messages*. */ |
|
2f83f3473b40
(print_error_message): New args CONTEXT and CALLER. Calls changed.
Richard M. Stallman <rms@gnu.org>
parents:
46553
diff
changeset
|
1046 if (!NILP (caller) && SYMBOLP (caller)) |
|
2f83f3473b40
(print_error_message): New args CONTEXT and CALLER. Calls changed.
Richard M. Stallman <rms@gnu.org>
parents:
46553
diff
changeset
|
1047 { |
|
65465
5780d53d7894
(print_error_message): Pass copy of caller name to message_dolog.
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
1048 Lisp_Object cname = SYMBOL_NAME (caller); |
|
5780d53d7894
(print_error_message): Pass copy of caller name to message_dolog.
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
1049 char *name = alloca (SBYTES (cname)); |
|
5780d53d7894
(print_error_message): Pass copy of caller name to message_dolog.
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
1050 bcopy (SDATA (cname), name, SBYTES (cname)); |
|
65485
6dd5312b60a7
(print_error_message): Fix last change.
Kim F. Storm <storm@cua.dk>
parents:
65465
diff
changeset
|
1051 message_dolog (name, SBYTES (cname), 0, 0); |
|
46574
2f83f3473b40
(print_error_message): New args CONTEXT and CALLER. Calls changed.
Richard M. Stallman <rms@gnu.org>
parents:
46553
diff
changeset
|
1052 message_dolog (": ", 2, 0, 0); |
|
2f83f3473b40
(print_error_message): New args CONTEXT and CALLER. Calls changed.
Richard M. Stallman <rms@gnu.org>
parents:
46553
diff
changeset
|
1053 } |
|
2f83f3473b40
(print_error_message): New args CONTEXT and CALLER. Calls changed.
Richard M. Stallman <rms@gnu.org>
parents:
46553
diff
changeset
|
1054 |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1055 errname = Fcar (data); |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1056 |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1057 if (EQ (errname, Qerror)) |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1058 { |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1059 data = Fcdr (data); |
|
28732
e5694cf2ac01
(print_error_message): Print data of `end-of-file'
Gerd Moellmann <gerd@gnu.org>
parents:
28507
diff
changeset
|
1060 if (!CONSP (data)) |
|
e5694cf2ac01
(print_error_message): Print data of `end-of-file'
Gerd Moellmann <gerd@gnu.org>
parents:
28507
diff
changeset
|
1061 data = Qnil; |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1062 errmsg = Fcar (data); |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1063 file_error = Qnil; |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1064 } |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1065 else |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1066 { |
|
28732
e5694cf2ac01
(print_error_message): Print data of `end-of-file'
Gerd Moellmann <gerd@gnu.org>
parents:
28507
diff
changeset
|
1067 Lisp_Object error_conditions; |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1068 errmsg = Fget (errname, Qerror_message); |
|
28732
e5694cf2ac01
(print_error_message): Print data of `end-of-file'
Gerd Moellmann <gerd@gnu.org>
parents:
28507
diff
changeset
|
1069 error_conditions = Fget (errname, Qerror_conditions); |
|
e5694cf2ac01
(print_error_message): Print data of `end-of-file'
Gerd Moellmann <gerd@gnu.org>
parents:
28507
diff
changeset
|
1070 file_error = Fmemq (Qfile_error, error_conditions); |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1071 } |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1072 |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1073 /* Print an error message including the data items. */ |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1074 |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1075 tail = Fcdr_safe (data); |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1076 GCPRO1 (tail); |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1077 |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1078 /* For file-error, make error message by concatenating |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1079 all the data items. They are all strings. */ |
|
24368
d4edd0f4edfa
(print_error_message): Don't crash if (cdr data) is not a list.
Richard M. Stallman <rms@gnu.org>
parents:
24049
diff
changeset
|
1080 if (!NILP (file_error) && CONSP (tail)) |
|
25717
3c6ad00e51a8
Use XCAR, XCDR, and XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25694
diff
changeset
|
1081 errmsg = XCAR (tail), tail = XCDR (tail); |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1082 |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1083 if (STRINGP (errmsg)) |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1084 Fprinc (errmsg, stream); |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1085 else |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1086 write_string_1 ("peculiar error", -1, stream); |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1087 |
|
28732
e5694cf2ac01
(print_error_message): Print data of `end-of-file'
Gerd Moellmann <gerd@gnu.org>
parents:
28507
diff
changeset
|
1088 for (i = 0; CONSP (tail); tail = XCDR (tail), i++) |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1089 { |
|
28732
e5694cf2ac01
(print_error_message): Print data of `end-of-file'
Gerd Moellmann <gerd@gnu.org>
parents:
28507
diff
changeset
|
1090 Lisp_Object obj; |
|
e5694cf2ac01
(print_error_message): Print data of `end-of-file'
Gerd Moellmann <gerd@gnu.org>
parents:
28507
diff
changeset
|
1091 |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1092 write_string_1 (i ? ", " : ": ", 2, stream); |
|
28732
e5694cf2ac01
(print_error_message): Print data of `end-of-file'
Gerd Moellmann <gerd@gnu.org>
parents:
28507
diff
changeset
|
1093 obj = XCAR (tail); |
|
e5694cf2ac01
(print_error_message): Print data of `end-of-file'
Gerd Moellmann <gerd@gnu.org>
parents:
28507
diff
changeset
|
1094 if (!NILP (file_error) || EQ (errname, Qend_of_file)) |
|
e5694cf2ac01
(print_error_message): Print data of `end-of-file'
Gerd Moellmann <gerd@gnu.org>
parents:
28507
diff
changeset
|
1095 Fprinc (obj, stream); |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1096 else |
|
28732
e5694cf2ac01
(print_error_message): Print data of `end-of-file'
Gerd Moellmann <gerd@gnu.org>
parents:
28507
diff
changeset
|
1097 Fprin1 (obj, stream); |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1098 } |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47864
diff
changeset
|
1099 |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1100 UNGCPRO; |
|
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1101 } |
|
28732
e5694cf2ac01
(print_error_message): Print data of `end-of-file'
Gerd Moellmann <gerd@gnu.org>
parents:
28507
diff
changeset
|
1102 |
|
e5694cf2ac01
(print_error_message): Print data of `end-of-file'
Gerd Moellmann <gerd@gnu.org>
parents:
28507
diff
changeset
|
1103 |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
1104 |
| 329 | 1105 /* |
|
1759
3c615a9dcd64
(float_to_string): Add `.0' at end if needed.
Richard M. Stallman <rms@gnu.org>
parents:
1521
diff
changeset
|
1106 * The buffer should be at least as large as the max string size of the |
| 14036 | 1107 * largest float, printed in the biggest notation. This is undoubtedly |
| 329 | 1108 * 20d float_output_format, with the negative of the C-constant "HUGE" |
| 1109 * from <math.h>. | |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47864
diff
changeset
|
1110 * |
| 329 | 1111 * On the vax the worst case is -1e38 in 20d format which takes 61 bytes. |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47864
diff
changeset
|
1112 * |
| 329 | 1113 * I assume that IEEE-754 format numbers can take 329 bytes for the worst |
| 1114 * case of -1e307 in 20d float_output_format. What is one to do (short of | |
| 1115 * re-writing _doprnt to be more sane)? | |
| 1116 * -wsr | |
| 1117 */ | |
|
1759
3c615a9dcd64
(float_to_string): Add `.0' at end if needed.
Richard M. Stallman <rms@gnu.org>
parents:
1521
diff
changeset
|
1118 |
|
3c615a9dcd64
(float_to_string): Add `.0' at end if needed.
Richard M. Stallman <rms@gnu.org>
parents:
1521
diff
changeset
|
1119 void |
|
3c615a9dcd64
(float_to_string): Add `.0' at end if needed.
Richard M. Stallman <rms@gnu.org>
parents:
1521
diff
changeset
|
1120 float_to_string (buf, data) |
|
1991
0f88f314fc34
* print.c (float_to_string): Define buf to be an unsigned char, to
Jim Blandy <jimb@redhat.com>
parents:
1967
diff
changeset
|
1121 unsigned char *buf; |
| 329 | 1122 double data; |
| 1123 { | |
|
4140
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1124 unsigned char *cp; |
|
4224
6cb1cfba6500
(float_to_string): Don't use uninitialized pointer `cp'.
Richard M. Stallman <rms@gnu.org>
parents:
4140
diff
changeset
|
1125 int width; |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47864
diff
changeset
|
1126 |
|
20816
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1127 /* Check for plus infinity in a way that won't lose |
|
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1128 if there is no plus infinity. */ |
|
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1129 if (data == data / 2 && data > 1.0) |
|
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1130 { |
|
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1131 strcpy (buf, "1.0e+INF"); |
|
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1132 return; |
|
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1133 } |
|
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1134 /* Likewise for minus infinity. */ |
|
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1135 if (data == data / 2 && data < -1.0) |
|
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1136 { |
|
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1137 strcpy (buf, "-1.0e+INF"); |
|
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1138 return; |
|
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1139 } |
|
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1140 /* Check for NaN in a way that won't fail if there are no NaNs. */ |
|
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1141 if (! (data * 0.0 >= 0.0)) |
|
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1142 { |
|
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26069
diff
changeset
|
1143 /* Prepend "-" if the NaN's sign bit is negative. |
|
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26069
diff
changeset
|
1144 The sign bit of a double is the bit that is 1 in -0.0. */ |
|
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26069
diff
changeset
|
1145 int i; |
|
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26069
diff
changeset
|
1146 union { double d; char c[sizeof (double)]; } u_data, u_minus_zero; |
|
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26069
diff
changeset
|
1147 u_data.d = data; |
|
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26069
diff
changeset
|
1148 u_minus_zero.d = - 0.0; |
|
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26069
diff
changeset
|
1149 for (i = 0; i < sizeof (double); i++) |
|
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26069
diff
changeset
|
1150 if (u_data.c[i] & u_minus_zero.c[i]) |
|
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26069
diff
changeset
|
1151 { |
|
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26069
diff
changeset
|
1152 *buf++ = '-'; |
|
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26069
diff
changeset
|
1153 break; |
|
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26069
diff
changeset
|
1154 } |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47864
diff
changeset
|
1155 |
|
20816
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1156 strcpy (buf, "0.0e+NaN"); |
|
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1157 return; |
|
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1158 } |
|
6397d7a97277
(float_to_string): Handle infinities and NaN specially.
Richard M. Stallman <rms@gnu.org>
parents:
20706
diff
changeset
|
1159 |
| 520 | 1160 if (NILP (Vfloat_output_format) |
|
9117
f69e6cf74874
(PRINTPREPARE, PRINTFINISH, float_to_string, print): Use type test macros.
Karl Heuer <kwzh@gnu.org>
parents:
8854
diff
changeset
|
1161 || !STRINGP (Vfloat_output_format)) |
| 329 | 1162 lose: |
|
4224
6cb1cfba6500
(float_to_string): Don't use uninitialized pointer `cp'.
Richard M. Stallman <rms@gnu.org>
parents:
4140
diff
changeset
|
1163 { |
| 20121 | 1164 /* Generate the fewest number of digits that represent the |
| 1165 floating point value without losing information. | |
| 1166 The following method is simple but a bit slow. | |
| 1167 For ideas about speeding things up, please see: | |
| 1168 | |
| 1169 Guy L Steele Jr & Jon L White, How to print floating-point numbers | |
| 1170 accurately. SIGPLAN notices 25, 6 (June 1990), 112-126. | |
| 1171 | |
| 1172 Robert G Burger & R Kent Dybvig, Printing floating point numbers | |
| 1173 quickly and accurately, SIGPLAN notices 31, 5 (May 1996), 108-116. */ | |
| 1174 | |
| 1175 width = fabs (data) < DBL_MIN ? 1 : DBL_DIG; | |
| 1176 do | |
| 1177 sprintf (buf, "%.*g", width, data); | |
| 1178 while (width++ < DOUBLE_DIGITS_BOUND && atof (buf) != data); | |
|
4224
6cb1cfba6500
(float_to_string): Don't use uninitialized pointer `cp'.
Richard M. Stallman <rms@gnu.org>
parents:
4140
diff
changeset
|
1179 } |
| 329 | 1180 else /* oink oink */ |
| 1181 { | |
| 1182 /* Check that the spec we have is fully valid. | |
| 1183 This means not only valid for printf, | |
| 1184 but meant for floats, and reasonable. */ | |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
1185 cp = SDATA (Vfloat_output_format); |
| 329 | 1186 |
| 1187 if (cp[0] != '%') | |
| 1188 goto lose; | |
| 1189 if (cp[1] != '.') | |
| 1190 goto lose; | |
| 1191 | |
| 1192 cp += 2; | |
|
4140
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1193 |
|
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1194 /* Check the width specification. */ |
|
4224
6cb1cfba6500
(float_to_string): Don't use uninitialized pointer `cp'.
Richard M. Stallman <rms@gnu.org>
parents:
4140
diff
changeset
|
1195 width = -1; |
|
4140
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1196 if ('0' <= *cp && *cp <= '9') |
|
11798
7646040d7383
(float_to_string): Fix type mismatch and simplify.
Karl Heuer <kwzh@gnu.org>
parents:
11697
diff
changeset
|
1197 { |
|
7646040d7383
(float_to_string): Fix type mismatch and simplify.
Karl Heuer <kwzh@gnu.org>
parents:
11697
diff
changeset
|
1198 width = 0; |
|
7646040d7383
(float_to_string): Fix type mismatch and simplify.
Karl Heuer <kwzh@gnu.org>
parents:
11697
diff
changeset
|
1199 do |
|
7646040d7383
(float_to_string): Fix type mismatch and simplify.
Karl Heuer <kwzh@gnu.org>
parents:
11697
diff
changeset
|
1200 width = (width * 10) + (*cp++ - '0'); |
|
7646040d7383
(float_to_string): Fix type mismatch and simplify.
Karl Heuer <kwzh@gnu.org>
parents:
11697
diff
changeset
|
1201 while (*cp >= '0' && *cp <= '9'); |
|
7646040d7383
(float_to_string): Fix type mismatch and simplify.
Karl Heuer <kwzh@gnu.org>
parents:
11697
diff
changeset
|
1202 |
|
7646040d7383
(float_to_string): Fix type mismatch and simplify.
Karl Heuer <kwzh@gnu.org>
parents:
11697
diff
changeset
|
1203 /* A precision of zero is valid only for %f. */ |
|
7646040d7383
(float_to_string): Fix type mismatch and simplify.
Karl Heuer <kwzh@gnu.org>
parents:
11697
diff
changeset
|
1204 if (width > DBL_DIG |
|
7646040d7383
(float_to_string): Fix type mismatch and simplify.
Karl Heuer <kwzh@gnu.org>
parents:
11697
diff
changeset
|
1205 || (width == 0 && *cp != 'f')) |
|
7646040d7383
(float_to_string): Fix type mismatch and simplify.
Karl Heuer <kwzh@gnu.org>
parents:
11697
diff
changeset
|
1206 goto lose; |
|
7646040d7383
(float_to_string): Fix type mismatch and simplify.
Karl Heuer <kwzh@gnu.org>
parents:
11697
diff
changeset
|
1207 } |
| 329 | 1208 |
| 1209 if (*cp != 'e' && *cp != 'f' && *cp != 'g') | |
| 1210 goto lose; | |
| 1211 | |
| 1212 if (cp[1] != 0) | |
| 1213 goto lose; | |
| 1214 | |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
1215 sprintf (buf, SDATA (Vfloat_output_format), data); |
| 329 | 1216 } |
|
1759
3c615a9dcd64
(float_to_string): Add `.0' at end if needed.
Richard M. Stallman <rms@gnu.org>
parents:
1521
diff
changeset
|
1217 |
|
4140
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1218 /* Make sure there is a decimal point with digit after, or an |
|
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1219 exponent, so that the value is readable as a float. But don't do |
|
4224
6cb1cfba6500
(float_to_string): Don't use uninitialized pointer `cp'.
Richard M. Stallman <rms@gnu.org>
parents:
4140
diff
changeset
|
1220 this with "%.0f"; it's valid for that not to produce a decimal |
|
6cb1cfba6500
(float_to_string): Don't use uninitialized pointer `cp'.
Richard M. Stallman <rms@gnu.org>
parents:
4140
diff
changeset
|
1221 point. Note that width can be 0 only for %.0f. */ |
|
6cb1cfba6500
(float_to_string): Don't use uninitialized pointer `cp'.
Richard M. Stallman <rms@gnu.org>
parents:
4140
diff
changeset
|
1222 if (width != 0) |
|
1764
94ff5d9ef48a
(float_to_string): Add final 0 if text ends with decimal pt.
Richard M. Stallman <rms@gnu.org>
parents:
1759
diff
changeset
|
1223 { |
|
4140
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1224 for (cp = buf; *cp; cp++) |
|
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1225 if ((*cp < '0' || *cp > '9') && *cp != '-') |
|
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1226 break; |
|
1764
94ff5d9ef48a
(float_to_string): Add final 0 if text ends with decimal pt.
Richard M. Stallman <rms@gnu.org>
parents:
1759
diff
changeset
|
1227 |
|
4140
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1228 if (*cp == '.' && cp[1] == 0) |
|
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1229 { |
|
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1230 cp[1] = '0'; |
|
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1231 cp[2] = 0; |
|
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1232 } |
|
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1233 |
|
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1234 if (*cp == 0) |
|
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1235 { |
|
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1236 *cp++ = '.'; |
|
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1237 *cp++ = '0'; |
|
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1238 *cp++ = 0; |
|
2738089e8383
* print.c (float_to_string): Distinguish between a precision of
Jim Blandy <jimb@redhat.com>
parents:
4003
diff
changeset
|
1239 } |
|
1759
3c615a9dcd64
(float_to_string): Add `.0' at end if needed.
Richard M. Stallman <rms@gnu.org>
parents:
1521
diff
changeset
|
1240 } |
| 329 | 1241 } |
|
27727
9400865ec7cf
Remove `LISP_FLOAT_TYPE' and `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
26867
diff
changeset
|
1242 |
| 329 | 1243 |
| 1244 static void | |
| 1245 print (obj, printcharfun, escapeflag) | |
| 1246 Lisp_Object obj; | |
| 1247 register Lisp_Object printcharfun; | |
| 1248 int escapeflag; | |
| 1249 { | |
|
47864
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1250 old_backquote_output = 0; |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1251 |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1252 /* Reset print_number_index and Vprint_number_table only when |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1253 the variable Vprint_continuous_numbering is nil. Otherwise, |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1254 the values of these variables will be kept between several |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1255 print functions. */ |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1256 if (NILP (Vprint_continuous_numbering)) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1257 { |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1258 print_number_index = 0; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1259 Vprint_number_table = Qnil; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1260 } |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1261 |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1262 /* Construct Vprint_number_table for print-gensym and print-circle. */ |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1263 if (!NILP (Vprint_gensym) || !NILP (Vprint_circle)) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1264 { |
|
25957
1751b057e4b0
(print): When removing objects from Vprint_number_table,
Richard M. Stallman <rms@gnu.org>
parents:
25726
diff
changeset
|
1265 int i, start, index; |
|
1751b057e4b0
(print): When removing objects from Vprint_number_table,
Richard M. Stallman <rms@gnu.org>
parents:
25726
diff
changeset
|
1266 start = index = print_number_index; |
|
47526
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
1267 /* Construct Vprint_number_table. |
|
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
1268 This increments print_number_index for the objects added. */ |
|
55683
3e6ff504a4ea
(print): Reset print_depth before to call print_object.
David Ponce <david@dponce.com>
parents:
55651
diff
changeset
|
1269 print_depth = 0; |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1270 print_preprocess (obj); |
|
47526
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
1271 |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1272 /* Remove unnecessary objects, which appear only once in OBJ; |
|
47526
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
1273 that is, whose status is Qnil. Compactify the necessary objects. */ |
|
25957
1751b057e4b0
(print): When removing objects from Vprint_number_table,
Richard M. Stallman <rms@gnu.org>
parents:
25726
diff
changeset
|
1274 for (i = start; i < print_number_index; i++) |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1275 if (!NILP (PRINT_NUMBER_STATUS (Vprint_number_table, i))) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1276 { |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1277 PRINT_NUMBER_OBJECT (Vprint_number_table, index) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1278 = PRINT_NUMBER_OBJECT (Vprint_number_table, i); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1279 index++; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1280 } |
|
47526
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
1281 |
|
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
1282 /* Clear out objects outside the active part of the table. */ |
|
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
1283 for (i = index; i < print_number_index; i++) |
|
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
1284 PRINT_NUMBER_OBJECT (Vprint_number_table, i) = Qnil; |
|
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
1285 |
|
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
1286 /* Reset the status field for the next print step. Now this |
|
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
1287 field means whether the object has already been printed. */ |
|
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
1288 for (i = start; i < print_number_index; i++) |
|
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
1289 PRINT_NUMBER_STATUS (Vprint_number_table, i) = Qnil; |
|
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
1290 |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1291 print_number_index = index; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1292 } |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1293 |
|
55683
3e6ff504a4ea
(print): Reset print_depth before to call print_object.
David Ponce <david@dponce.com>
parents:
55651
diff
changeset
|
1294 print_depth = 0; |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1295 print_object (obj, printcharfun, escapeflag); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1296 } |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1297 |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1298 /* Construct Vprint_number_table according to the structure of OBJ. |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1299 OBJ itself and all its elements will be added to Vprint_number_table |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1300 recursively if it is a list, vector, compiled function, char-table, |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1301 string (its text properties will be traced), or a symbol that has |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1302 no obarray (this is for the print-gensym feature). |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1303 The status fields of Vprint_number_table mean whether each object appears |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1304 more than once in OBJ: Qnil at the first time, and Qt after that . */ |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1305 static void |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1306 print_preprocess (obj) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1307 Lisp_Object obj; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1308 { |
|
53704
47b66024b855
(print_preprocess): Declare size as EMACS_INT to not lose bits.
Andreas Schwab <schwab@suse.de>
parents:
53537
diff
changeset
|
1309 int i; |
|
47b66024b855
(print_preprocess): Declare size as EMACS_INT to not lose bits.
Andreas Schwab <schwab@suse.de>
parents:
53537
diff
changeset
|
1310 EMACS_INT size; |
|
55498
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1311 int loop_count = 0; |
|
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1312 Lisp_Object halftail; |
|
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1313 |
|
56455
66c2afb52fc1
(print_preprocess): Test for print_depth at limit
Richard M. Stallman <rms@gnu.org>
parents:
56182
diff
changeset
|
1314 /* Give up if we go so deep that print_object will get an error. */ |
|
66c2afb52fc1
(print_preprocess): Test for print_depth at limit
Richard M. Stallman <rms@gnu.org>
parents:
56182
diff
changeset
|
1315 /* See similar code in print_object. */ |
|
67638
5c55209169fc
2005-12-17 Chong Yidong <cyd@stupidchicken.com>
Chong Yidong <cyd@stupidchicken.com>
parents:
67637
diff
changeset
|
1316 if (print_depth >= PRINT_CIRCLE) |
|
5c55209169fc
2005-12-17 Chong Yidong <cyd@stupidchicken.com>
Chong Yidong <cyd@stupidchicken.com>
parents:
67637
diff
changeset
|
1317 error ("Apparently circular structure being printed"); |
|
56455
66c2afb52fc1
(print_preprocess): Test for print_depth at limit
Richard M. Stallman <rms@gnu.org>
parents:
56182
diff
changeset
|
1318 |
|
55498
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1319 /* Avoid infinite recursion for circular nested structure |
|
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1320 in the case where Vprint_circle is nil. */ |
|
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1321 if (NILP (Vprint_circle)) |
|
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1322 { |
|
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1323 for (i = 0; i < print_depth; i++) |
|
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1324 if (EQ (obj, being_printed[i])) |
|
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1325 return; |
|
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1326 being_printed[print_depth] = obj; |
|
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1327 } |
|
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1328 |
|
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1329 print_depth++; |
|
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1330 halftail = obj; |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1331 |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1332 loop: |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1333 if (STRINGP (obj) || CONSP (obj) || VECTORP (obj) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1334 || COMPILEDP (obj) || CHAR_TABLE_P (obj) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1335 || (! NILP (Vprint_gensym) |
|
39582
3416667c2093
(print_preprocess, print_object): Test internedness of
Gerd Moellmann <gerd@gnu.org>
parents:
38622
diff
changeset
|
1336 && SYMBOLP (obj) |
|
3416667c2093
(print_preprocess, print_object): Test internedness of
Gerd Moellmann <gerd@gnu.org>
parents:
38622
diff
changeset
|
1337 && !SYMBOL_INTERNED_P (obj))) |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1338 { |
|
26069
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1339 /* In case print-circle is nil and print-gensym is t, |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1340 add OBJ to Vprint_number_table only when OBJ is a symbol. */ |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1341 if (! NILP (Vprint_circle) || SYMBOLP (obj)) |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1342 { |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1343 for (i = 0; i < print_number_index; i++) |
|
28507
b6f06a755c7d
make_number/XINT/XUINT conversions; EQ/== fixes; ==Qnil -> NILP
Ken Raeburn <raeburn@raeburn.org>
parents:
28351
diff
changeset
|
1344 if (EQ (PRINT_NUMBER_OBJECT (Vprint_number_table, i), obj)) |
|
26069
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1345 { |
|
83416
4513d8dcdfd5
Reimplement and extend support for terminal-local environment variables.
Karoly Lorentey <lorentey@elte.hu>
parents:
83414
diff
changeset
|
1346 /* OBJ appears more than once. Let's remember that. */ |
|
26069
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1347 PRINT_NUMBER_STATUS (Vprint_number_table, i) = Qt; |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1348 return; |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1349 } |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1350 |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1351 /* OBJ is not yet recorded. Let's add to the table. */ |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1352 if (print_number_index == 0) |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1353 { |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1354 /* Initialize the table. */ |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1355 Vprint_number_table = Fmake_vector (make_number (40), Qnil); |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1356 } |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1357 else if (XVECTOR (Vprint_number_table)->size == print_number_index * 2) |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1358 { |
|
26069
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1359 /* Reallocate the table. */ |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1360 int i = print_number_index * 4; |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1361 Lisp_Object old_table = Vprint_number_table; |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1362 Vprint_number_table = Fmake_vector (make_number (i), Qnil); |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1363 for (i = 0; i < print_number_index; i++) |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1364 { |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1365 PRINT_NUMBER_OBJECT (Vprint_number_table, i) |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1366 = PRINT_NUMBER_OBJECT (old_table, i); |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1367 PRINT_NUMBER_STATUS (Vprint_number_table, i) |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1368 = PRINT_NUMBER_STATUS (old_table, i); |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1369 } |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1370 } |
|
26069
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1371 PRINT_NUMBER_OBJECT (Vprint_number_table, print_number_index) = obj; |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1372 /* If Vprint_continuous_numbering is non-nil and OBJ is a gensym, |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1373 always print the gensym with a number. This is a special for |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1374 the lisp function byte-compile-output-docform. */ |
|
39582
3416667c2093
(print_preprocess, print_object): Test internedness of
Gerd Moellmann <gerd@gnu.org>
parents:
38622
diff
changeset
|
1375 if (!NILP (Vprint_continuous_numbering) |
|
3416667c2093
(print_preprocess, print_object): Test internedness of
Gerd Moellmann <gerd@gnu.org>
parents:
38622
diff
changeset
|
1376 && SYMBOLP (obj) |
|
3416667c2093
(print_preprocess, print_object): Test internedness of
Gerd Moellmann <gerd@gnu.org>
parents:
38622
diff
changeset
|
1377 && !SYMBOL_INTERNED_P (obj)) |
|
26069
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1378 PRINT_NUMBER_STATUS (Vprint_number_table, print_number_index) = Qt; |
|
6bf93a8f0e73
(print_preprocess): In case print-circle is nil,
Kenichi Handa <handa@m17n.org>
parents:
25957
diff
changeset
|
1379 print_number_index++; |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1380 } |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1381 |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1382 switch (XGCTYPE (obj)) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1383 { |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1384 case Lisp_String: |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1385 /* A string may have text properties, which can be circular. */ |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
1386 traverse_intervals_noorder (STRING_INTERVALS (obj), |
|
39856
3fb9aba0cbd4
(Fwith_output_to_temp_buffer): Align with
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
39582
diff
changeset
|
1387 print_preprocess_string, Qnil); |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1388 break; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1389 |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1390 case Lisp_Cons: |
|
55498
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1391 /* Use HALFTAIL and LOOP_COUNT to detect circular lists, |
|
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1392 just as in print_object. */ |
|
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1393 if (loop_count && EQ (obj, halftail)) |
|
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1394 break; |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1395 print_preprocess (XCAR (obj)); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1396 obj = XCDR (obj); |
|
55498
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1397 loop_count++; |
|
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1398 if (!(loop_count & 1)) |
|
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1399 halftail = XCDR (halftail); |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1400 goto loop; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1401 |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1402 case Lisp_Vectorlike: |
|
53537
c8f34cd38fd0
(print_preprocess) <case Lisp_Vectorlike>: Only mask
Andreas Schwab <schwab@suse.de>
parents:
53460
diff
changeset
|
1403 size = XVECTOR (obj)->size; |
|
c8f34cd38fd0
(print_preprocess) <case Lisp_Vectorlike>: Only mask
Andreas Schwab <schwab@suse.de>
parents:
53460
diff
changeset
|
1404 if (size & PSEUDOVECTOR_FLAG) |
|
c8f34cd38fd0
(print_preprocess) <case Lisp_Vectorlike>: Only mask
Andreas Schwab <schwab@suse.de>
parents:
53460
diff
changeset
|
1405 size &= PSEUDOVECTOR_SIZE_MASK; |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1406 for (i = 0; i < size; i++) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1407 print_preprocess (XVECTOR (obj)->contents[i]); |
|
34798
9794feac3a9d
(print_unwind): Return nil.
Gerd Moellmann <gerd@gnu.org>
parents:
31102
diff
changeset
|
1408 break; |
|
9794feac3a9d
(print_unwind): Return nil.
Gerd Moellmann <gerd@gnu.org>
parents:
31102
diff
changeset
|
1409 |
|
9794feac3a9d
(print_unwind): Return nil.
Gerd Moellmann <gerd@gnu.org>
parents:
31102
diff
changeset
|
1410 default: |
|
9794feac3a9d
(print_unwind): Return nil.
Gerd Moellmann <gerd@gnu.org>
parents:
31102
diff
changeset
|
1411 break; |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1412 } |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1413 } |
|
55498
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1414 print_depth--; |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1415 } |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1416 |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1417 static void |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1418 print_preprocess_string (interval, arg) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1419 INTERVAL interval; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1420 Lisp_Object arg; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1421 { |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1422 print_preprocess (interval->plist); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1423 } |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1424 |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1425 static void |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1426 print_object (obj, printcharfun, escapeflag) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1427 Lisp_Object obj; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1428 register Lisp_Object printcharfun; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1429 int escapeflag; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1430 { |
|
55651
dcb7d888bb38
(print_object): Increase buf size.
Kim F. Storm <storm@cua.dk>
parents:
55498
diff
changeset
|
1431 char buf[40]; |
| 329 | 1432 |
| 1433 QUIT; | |
| 1434 | |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1435 /* Detect circularities and truncate them. */ |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1436 if (STRINGP (obj) || CONSP (obj) || VECTORP (obj) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1437 || COMPILEDP (obj) || CHAR_TABLE_P (obj) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1438 || (! NILP (Vprint_gensym) |
|
39582
3416667c2093
(print_preprocess, print_object): Test internedness of
Gerd Moellmann <gerd@gnu.org>
parents:
38622
diff
changeset
|
1439 && SYMBOLP (obj) |
|
3416667c2093
(print_preprocess, print_object): Test internedness of
Gerd Moellmann <gerd@gnu.org>
parents:
38622
diff
changeset
|
1440 && !SYMBOL_INTERNED_P (obj))) |
|
379
34ec8957c6c0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
373
diff
changeset
|
1441 { |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1442 if (NILP (Vprint_circle) && NILP (Vprint_gensym)) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1443 { |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1444 /* Simple but incomplete way. */ |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1445 int i; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1446 for (i = 0; i < print_depth; i++) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1447 if (EQ (obj, being_printed[i])) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1448 { |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1449 sprintf (buf, "#%d", i); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1450 strout (buf, -1, -1, printcharfun, 0); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1451 return; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1452 } |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1453 being_printed[print_depth] = obj; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1454 } |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1455 else |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1456 { |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1457 /* With the print-circle feature. */ |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1458 int i; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1459 for (i = 0; i < print_number_index; i++) |
|
28507
b6f06a755c7d
make_number/XINT/XUINT conversions; EQ/== fixes; ==Qnil -> NILP
Ken Raeburn <raeburn@raeburn.org>
parents:
28351
diff
changeset
|
1460 if (EQ (PRINT_NUMBER_OBJECT (Vprint_number_table, i), obj)) |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1461 { |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1462 if (NILP (PRINT_NUMBER_STATUS (Vprint_number_table, i))) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1463 { |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1464 /* Add a prefix #n= if OBJ has not yet been printed; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1465 that is, its status field is nil. */ |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1466 sprintf (buf, "#%d=", i + 1); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1467 strout (buf, -1, -1, printcharfun, 0); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1468 /* OBJ is going to be printed. Set the status to t. */ |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1469 PRINT_NUMBER_STATUS (Vprint_number_table, i) = Qt; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1470 break; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1471 } |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1472 else |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1473 { |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1474 /* Just print #n# if OBJ has already been printed. */ |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1475 sprintf (buf, "#%d#", i + 1); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1476 strout (buf, -1, -1, printcharfun, 0); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1477 return; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1478 } |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1479 } |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1480 } |
|
379
34ec8957c6c0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
373
diff
changeset
|
1481 } |
|
34ec8957c6c0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
373
diff
changeset
|
1482 |
| 329 | 1483 print_depth++; |
| 1484 | |
|
55498
2b06def87ce0
(print_preprocess): Use being_printed, loop_count and
Richard M. Stallman <rms@gnu.org>
parents:
55493
diff
changeset
|
1485 /* See similar code in print_preprocess. */ |
|
379
34ec8957c6c0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
373
diff
changeset
|
1486 if (print_depth > PRINT_CIRCLE) |
| 329 | 1487 error ("Apparently circular structure being printed"); |
| 1488 #ifdef MAX_PRINT_CHARS | |
| 1489 if (max_print && print_chars > max_print) | |
| 1490 { | |
| 1491 PRINTCHAR ('\n'); | |
| 1492 print_chars = 0; | |
| 1493 } | |
| 1494 #endif /* MAX_PRINT_CHARS */ | |
| 1495 | |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1496 switch (XGCTYPE (obj)) |
| 329 | 1497 { |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1498 case Lisp_Int: |
|
11697
2de5b0c89802
(print): Make the printing understand EMACS_INTs
Richard M. Stallman <rms@gnu.org>
parents:
11341
diff
changeset
|
1499 if (sizeof (int) == sizeof (EMACS_INT)) |
|
2de5b0c89802
(print): Make the printing understand EMACS_INTs
Richard M. Stallman <rms@gnu.org>
parents:
11341
diff
changeset
|
1500 sprintf (buf, "%d", XINT (obj)); |
|
2de5b0c89802
(print): Make the printing understand EMACS_INTs
Richard M. Stallman <rms@gnu.org>
parents:
11341
diff
changeset
|
1501 else if (sizeof (long) == sizeof (EMACS_INT)) |
|
25726
9bfb1496cdd8
(PRINTFULLP): Removed because it is no longer used and
Gerd Moellmann <gerd@gnu.org>
parents:
25717
diff
changeset
|
1502 sprintf (buf, "%ld", (long) XINT (obj)); |
|
11697
2de5b0c89802
(print): Make the printing understand EMACS_INTs
Richard M. Stallman <rms@gnu.org>
parents:
11341
diff
changeset
|
1503 else |
|
2de5b0c89802
(print): Make the printing understand EMACS_INTs
Richard M. Stallman <rms@gnu.org>
parents:
11341
diff
changeset
|
1504 abort (); |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1505 strout (buf, -1, -1, printcharfun, 0); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1506 break; |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1507 |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1508 case Lisp_Float: |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1509 { |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1510 char pigbuf[350]; /* see comments in float_to_string */ |
| 329 | 1511 |
|
25717
3c6ad00e51a8
Use XCAR, XCDR, and XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25694
diff
changeset
|
1512 float_to_string (pigbuf, XFLOAT_DATA (obj)); |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1513 strout (pigbuf, -1, -1, printcharfun, 0); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1514 } |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1515 break; |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1516 |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1517 case Lisp_String: |
| 329 | 1518 if (!escapeflag) |
| 1519 print_string (obj, printcharfun); | |
| 1520 else | |
| 1521 { | |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1522 register int i, i_byte; |
| 329 | 1523 struct gcpro gcpro1; |
|
22183
3eedfddbbadd
(print_string): Don't ignore garbage bytes following a
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
1524 unsigned char *str; |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1525 int size_byte; |
|
21373
e53943cd93b2
(print) <Lisp_String>: Follow a hex escape with `\ ' if nec.
Richard M. Stallman <rms@gnu.org>
parents:
21250
diff
changeset
|
1526 /* 1 means we must ensure that the next character we output |
|
e53943cd93b2
(print) <Lisp_String>: Follow a hex escape with `\ ' if nec.
Richard M. Stallman <rms@gnu.org>
parents:
21250
diff
changeset
|
1527 cannot be taken as part of a hex character escape. */ |
|
e53943cd93b2
(print) <Lisp_String>: Follow a hex escape with `\ ' if nec.
Richard M. Stallman <rms@gnu.org>
parents:
21250
diff
changeset
|
1528 int need_nonhex = 0; |
|
42423
fe55eaa5dfb3
(print_object): In multibyte string, use hex escapes.
Richard M. Stallman <rms@gnu.org>
parents:
41525
diff
changeset
|
1529 int multibyte = STRING_MULTIBYTE (obj); |
| 329 | 1530 |
| 1967 | 1531 GCPRO1 (obj); |
| 1532 | |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
1533 if (!NULL_INTERVAL_P (STRING_INTERVALS (obj))) |
| 1967 | 1534 { |
| 1535 PRINTCHAR ('#'); | |
| 1536 PRINTCHAR ('('); | |
| 1537 } | |
| 329 | 1538 |
| 1539 PRINTCHAR ('\"'); | |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
1540 str = SDATA (obj); |
|
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
1541 size_byte = SBYTES (obj); |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1542 |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1543 for (i = 0, i_byte = 0; i_byte < size_byte;) |
| 329 | 1544 { |
|
20549
ba676f083e7c
(PRINTDECLARE): Declare old_point_byte and start_point_byte.
Richard M. Stallman <rms@gnu.org>
parents:
20377
diff
changeset
|
1545 /* Here, we must convert each multi-byte form to the |
|
ba676f083e7c
(PRINTDECLARE): Declare old_point_byte and start_point_byte.
Richard M. Stallman <rms@gnu.org>
parents:
20377
diff
changeset
|
1546 corresponding character code before handing it to PRINTCHAR. */ |
|
ba676f083e7c
(PRINTDECLARE): Declare old_point_byte and start_point_byte.
Richard M. Stallman <rms@gnu.org>
parents:
20377
diff
changeset
|
1547 int len; |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1548 int c; |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1549 |
|
42423
fe55eaa5dfb3
(print_object): In multibyte string, use hex escapes.
Richard M. Stallman <rms@gnu.org>
parents:
41525
diff
changeset
|
1550 if (multibyte) |
|
22183
3eedfddbbadd
(print_string): Don't ignore garbage bytes following a
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
1551 { |
|
25502
4a69654961a6
(print_string): Use the macro STRING_CHAR_AND_LENGTH.
Kenichi Handa <handa@m17n.org>
parents:
25355
diff
changeset
|
1552 c = STRING_CHAR_AND_LENGTH (str + i_byte, |
|
4a69654961a6
(print_string): Use the macro STRING_CHAR_AND_LENGTH.
Kenichi Handa <handa@m17n.org>
parents:
25355
diff
changeset
|
1553 size_byte - i_byte, len); |
|
23632
8c829259606f
(print_string): Check validity of a character.
Kenichi Handa <handa@m17n.org>
parents:
23236
diff
changeset
|
1554 if (CHAR_VALID_P (c, 0)) |
|
8c829259606f
(print_string): Check validity of a character.
Kenichi Handa <handa@m17n.org>
parents:
23236
diff
changeset
|
1555 i_byte += len; |
|
8c829259606f
(print_string): Check validity of a character.
Kenichi Handa <handa@m17n.org>
parents:
23236
diff
changeset
|
1556 else |
|
8c829259606f
(print_string): Check validity of a character.
Kenichi Handa <handa@m17n.org>
parents:
23236
diff
changeset
|
1557 c = str[i_byte++]; |
|
22183
3eedfddbbadd
(print_string): Don't ignore garbage bytes following a
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
1558 } |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1559 else |
|
22183
3eedfddbbadd
(print_string): Don't ignore garbage bytes following a
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
1560 c = str[i_byte++]; |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1561 |
| 329 | 1562 QUIT; |
|
20549
ba676f083e7c
(PRINTDECLARE): Declare old_point_byte and start_point_byte.
Richard M. Stallman <rms@gnu.org>
parents:
20377
diff
changeset
|
1563 |
| 329 | 1564 if (c == '\n' && print_escape_newlines) |
| 1565 { | |
| 1566 PRINTCHAR ('\\'); | |
| 1567 PRINTCHAR ('n'); | |
| 1568 } | |
|
5852
f2e341b1f908
(print): If print_escapes_newlines, print '\f' as "\\f".
Roland McGrath <roland@gnu.org>
parents:
5487
diff
changeset
|
1569 else if (c == '\f' && print_escape_newlines) |
|
f2e341b1f908
(print): If print_escapes_newlines, print '\f' as "\\f".
Roland McGrath <roland@gnu.org>
parents:
5487
diff
changeset
|
1570 { |
|
f2e341b1f908
(print): If print_escapes_newlines, print '\f' as "\\f".
Roland McGrath <roland@gnu.org>
parents:
5487
diff
changeset
|
1571 PRINTCHAR ('\\'); |
|
f2e341b1f908
(print): If print_escapes_newlines, print '\f' as "\\f".
Roland McGrath <roland@gnu.org>
parents:
5487
diff
changeset
|
1572 PRINTCHAR ('f'); |
|
f2e341b1f908
(print): If print_escapes_newlines, print '\f' as "\\f".
Roland McGrath <roland@gnu.org>
parents:
5487
diff
changeset
|
1573 } |
|
43668
771bbdee433b
(print_object): Output multibyte chars 128...255
Richard M. Stallman <rms@gnu.org>
parents:
42481
diff
changeset
|
1574 else if (multibyte |
|
771bbdee433b
(print_object): Output multibyte chars 128...255
Richard M. Stallman <rms@gnu.org>
parents:
42481
diff
changeset
|
1575 && ! ASCII_BYTE_P (c) |
|
771bbdee433b
(print_object): Output multibyte chars 128...255
Richard M. Stallman <rms@gnu.org>
parents:
42481
diff
changeset
|
1576 && (SINGLE_BYTE_CHAR_P (c) || print_escape_multibyte)) |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1577 { |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1578 /* When multibyte is disabled, |
|
43668
771bbdee433b
(print_object): Output multibyte chars 128...255
Richard M. Stallman <rms@gnu.org>
parents:
42481
diff
changeset
|
1579 print multibyte string chars using hex escapes. |
|
771bbdee433b
(print_object): Output multibyte chars 128...255
Richard M. Stallman <rms@gnu.org>
parents:
42481
diff
changeset
|
1580 For a char code that could be in a unibyte string, |
|
771bbdee433b
(print_object): Output multibyte chars 128...255
Richard M. Stallman <rms@gnu.org>
parents:
42481
diff
changeset
|
1581 when found in a multibyte string, always use a hex escape |
|
771bbdee433b
(print_object): Output multibyte chars 128...255
Richard M. Stallman <rms@gnu.org>
parents:
42481
diff
changeset
|
1582 so it reads back as multibyte. */ |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1583 unsigned char outbuf[50]; |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1584 sprintf (outbuf, "\\x%x", c); |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1585 strout (outbuf, -1, -1, printcharfun, 0); |
|
21373
e53943cd93b2
(print) <Lisp_String>: Follow a hex escape with `\ ' if nec.
Richard M. Stallman <rms@gnu.org>
parents:
21250
diff
changeset
|
1586 need_nonhex = 1; |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1587 } |
|
42423
fe55eaa5dfb3
(print_object): In multibyte string, use hex escapes.
Richard M. Stallman <rms@gnu.org>
parents:
41525
diff
changeset
|
1588 else if (! multibyte |
|
fe55eaa5dfb3
(print_object): In multibyte string, use hex escapes.
Richard M. Stallman <rms@gnu.org>
parents:
41525
diff
changeset
|
1589 && SINGLE_BYTE_CHAR_P (c) && ! ASCII_BYTE_P (c) |
|
22933
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
1590 && print_escape_nonascii) |
|
20670
b818d996d923
(print) <Lisp_String>: When multibyte is enabled, print
Karl Heuer <kwzh@gnu.org>
parents:
20591
diff
changeset
|
1591 { |
|
22933
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
1592 /* When printing in a multibyte buffer |
|
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
1593 or when explicitly requested, |
|
20670
b818d996d923
(print) <Lisp_String>: When multibyte is enabled, print
Karl Heuer <kwzh@gnu.org>
parents:
20591
diff
changeset
|
1594 print single-byte non-ASCII string chars |
|
b818d996d923
(print) <Lisp_String>: When multibyte is enabled, print
Karl Heuer <kwzh@gnu.org>
parents:
20591
diff
changeset
|
1595 using octal escapes. */ |
|
b818d996d923
(print) <Lisp_String>: When multibyte is enabled, print
Karl Heuer <kwzh@gnu.org>
parents:
20591
diff
changeset
|
1596 unsigned char outbuf[5]; |
|
b818d996d923
(print) <Lisp_String>: When multibyte is enabled, print
Karl Heuer <kwzh@gnu.org>
parents:
20591
diff
changeset
|
1597 sprintf (outbuf, "\\%03o", c); |
|
b818d996d923
(print) <Lisp_String>: When multibyte is enabled, print
Karl Heuer <kwzh@gnu.org>
parents:
20591
diff
changeset
|
1598 strout (outbuf, -1, -1, printcharfun, 0); |
|
b818d996d923
(print) <Lisp_String>: When multibyte is enabled, print
Karl Heuer <kwzh@gnu.org>
parents:
20591
diff
changeset
|
1599 } |
| 329 | 1600 else |
| 1601 { | |
|
21373
e53943cd93b2
(print) <Lisp_String>: Follow a hex escape with `\ ' if nec.
Richard M. Stallman <rms@gnu.org>
parents:
21250
diff
changeset
|
1602 /* If we just had a hex escape, and this character |
|
e53943cd93b2
(print) <Lisp_String>: Follow a hex escape with `\ ' if nec.
Richard M. Stallman <rms@gnu.org>
parents:
21250
diff
changeset
|
1603 could be taken as part of it, |
|
e53943cd93b2
(print) <Lisp_String>: Follow a hex escape with `\ ' if nec.
Richard M. Stallman <rms@gnu.org>
parents:
21250
diff
changeset
|
1604 output `\ ' to prevent that. */ |
|
21480
20aab049dc4a
(print) <Lisp_String>: Fix "\ " handling.
Karl Heuer <kwzh@gnu.org>
parents:
21455
diff
changeset
|
1605 if (need_nonhex) |
|
20aab049dc4a
(print) <Lisp_String>: Fix "\ " handling.
Karl Heuer <kwzh@gnu.org>
parents:
21455
diff
changeset
|
1606 { |
|
20aab049dc4a
(print) <Lisp_String>: Fix "\ " handling.
Karl Heuer <kwzh@gnu.org>
parents:
21455
diff
changeset
|
1607 need_nonhex = 0; |
|
20aab049dc4a
(print) <Lisp_String>: Fix "\ " handling.
Karl Heuer <kwzh@gnu.org>
parents:
21455
diff
changeset
|
1608 if ((c >= 'a' && c <= 'f') |
|
21373
e53943cd93b2
(print) <Lisp_String>: Follow a hex escape with `\ ' if nec.
Richard M. Stallman <rms@gnu.org>
parents:
21250
diff
changeset
|
1609 || (c >= 'A' && c <= 'F') |
|
21480
20aab049dc4a
(print) <Lisp_String>: Fix "\ " handling.
Karl Heuer <kwzh@gnu.org>
parents:
21455
diff
changeset
|
1610 || (c >= '0' && c <= '9')) |
|
20aab049dc4a
(print) <Lisp_String>: Fix "\ " handling.
Karl Heuer <kwzh@gnu.org>
parents:
21455
diff
changeset
|
1611 strout ("\\ ", -1, -1, printcharfun, 0); |
|
20aab049dc4a
(print) <Lisp_String>: Fix "\ " handling.
Karl Heuer <kwzh@gnu.org>
parents:
21455
diff
changeset
|
1612 } |
|
21373
e53943cd93b2
(print) <Lisp_String>: Follow a hex escape with `\ ' if nec.
Richard M. Stallman <rms@gnu.org>
parents:
21250
diff
changeset
|
1613 |
| 329 | 1614 if (c == '\"' || c == '\\') |
| 1615 PRINTCHAR ('\\'); | |
| 1616 PRINTCHAR (c); | |
| 1617 } | |
| 1618 } | |
| 1619 PRINTCHAR ('\"'); | |
| 1967 | 1620 |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
1621 if (!NULL_INTERVAL_P (STRING_INTERVALS (obj))) |
| 1967 | 1622 { |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
1623 traverse_intervals (STRING_INTERVALS (obj), |
|
39856
3fb9aba0cbd4
(Fwith_output_to_temp_buffer): Align with
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
39582
diff
changeset
|
1624 0, print_interval, printcharfun); |
| 1967 | 1625 PRINTCHAR (')'); |
| 1626 } | |
| 1627 | |
| 329 | 1628 UNGCPRO; |
| 1629 } | |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1630 break; |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1631 |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1632 case Lisp_Symbol: |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1633 { |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1634 register int confusing; |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
1635 register unsigned char *p = SDATA (SYMBOL_NAME (obj)); |
|
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
1636 register unsigned char *end = p + SBYTES (SYMBOL_NAME (obj)); |
|
20862
f4efe8aa6133
(print): Declare local variable C as `int' instead of
Richard M. Stallman <rms@gnu.org>
parents:
20816
diff
changeset
|
1637 register int c; |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1638 int i, i_byte, size_byte; |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1639 Lisp_Object name; |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1640 |
|
45409
f8a600a483ff
* print.c (print_error_message, print_object): Use SYMBOL_NAME and
Ken Raeburn <raeburn@raeburn.org>
parents:
43944
diff
changeset
|
1641 name = SYMBOL_NAME (obj); |
| 329 | 1642 |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1643 if (p != end && (*p == '-' || *p == '+')) p++; |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1644 if (p == end) |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1645 confusing = 0; |
|
17509
0c38918fbf13
(print): Symbols like e2 and 2e are not confusing.
Richard M. Stallman <rms@gnu.org>
parents:
17325
diff
changeset
|
1646 /* If symbol name begins with a digit, and ends with a digit, |
|
0c38918fbf13
(print): Symbols like e2 and 2e are not confusing.
Richard M. Stallman <rms@gnu.org>
parents:
17325
diff
changeset
|
1647 and contains nothing but digits and `e', it could be treated |
|
0c38918fbf13
(print): Symbols like e2 and 2e are not confusing.
Richard M. Stallman <rms@gnu.org>
parents:
17325
diff
changeset
|
1648 as a number. So set CONFUSING. |
|
0c38918fbf13
(print): Symbols like e2 and 2e are not confusing.
Richard M. Stallman <rms@gnu.org>
parents:
17325
diff
changeset
|
1649 |
|
0c38918fbf13
(print): Symbols like e2 and 2e are not confusing.
Richard M. Stallman <rms@gnu.org>
parents:
17325
diff
changeset
|
1650 Symbols that contain periods could also be taken as numbers, |
|
0c38918fbf13
(print): Symbols like e2 and 2e are not confusing.
Richard M. Stallman <rms@gnu.org>
parents:
17325
diff
changeset
|
1651 but periods are always escaped, so we don't have to worry |
|
0c38918fbf13
(print): Symbols like e2 and 2e are not confusing.
Richard M. Stallman <rms@gnu.org>
parents:
17325
diff
changeset
|
1652 about them here. */ |
|
0c38918fbf13
(print): Symbols like e2 and 2e are not confusing.
Richard M. Stallman <rms@gnu.org>
parents:
17325
diff
changeset
|
1653 else if (*p >= '0' && *p <= '9' |
|
0c38918fbf13
(print): Symbols like e2 and 2e are not confusing.
Richard M. Stallman <rms@gnu.org>
parents:
17325
diff
changeset
|
1654 && end[-1] >= '0' && end[-1] <= '9') |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1655 { |
|
17223
ed068c0c1648
(print): Generate a backslash in \2e10.
Richard M. Stallman <rms@gnu.org>
parents:
17040
diff
changeset
|
1656 while (p != end && ((*p >= '0' && *p <= '9') |
|
ed068c0c1648
(print): Generate a backslash in \2e10.
Richard M. Stallman <rms@gnu.org>
parents:
17040
diff
changeset
|
1657 /* Needed for \2e10. */ |
|
ed068c0c1648
(print): Generate a backslash in \2e10.
Richard M. Stallman <rms@gnu.org>
parents:
17040
diff
changeset
|
1658 || *p == 'e')) |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1659 p++; |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1660 confusing = (end == p); |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1661 } |
|
17509
0c38918fbf13
(print): Symbols like e2 and 2e are not confusing.
Richard M. Stallman <rms@gnu.org>
parents:
17325
diff
changeset
|
1662 else |
|
0c38918fbf13
(print): Symbols like e2 and 2e are not confusing.
Richard M. Stallman <rms@gnu.org>
parents:
17325
diff
changeset
|
1663 confusing = 0; |
| 329 | 1664 |
|
39582
3416667c2093
(print_preprocess, print_object): Test internedness of
Gerd Moellmann <gerd@gnu.org>
parents:
38622
diff
changeset
|
1665 if (! NILP (Vprint_gensym) && !SYMBOL_INTERNED_P (obj)) |
|
16140
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
1666 { |
|
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
1667 PRINTCHAR ('#'); |
|
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
1668 PRINTCHAR (':'); |
|
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
1669 } |
|
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
1670 |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
1671 size_byte = SBYTES (name); |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1672 |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1673 for (i = 0, i_byte = 0; i_byte < size_byte;) |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1674 { |
|
20549
ba676f083e7c
(PRINTDECLARE): Declare old_point_byte and start_point_byte.
Richard M. Stallman <rms@gnu.org>
parents:
20377
diff
changeset
|
1675 /* Here, we must convert each multi-byte form to the |
|
ba676f083e7c
(PRINTDECLARE): Declare old_point_byte and start_point_byte.
Richard M. Stallman <rms@gnu.org>
parents:
20377
diff
changeset
|
1676 corresponding character code before handing it to PRINTCHAR. */ |
|
29016
35074eb2a443
(print_object): Use FETCH_STRING_CHAR_ADVANCE
Kenichi Handa <handa@m17n.org>
parents:
28932
diff
changeset
|
1677 FETCH_STRING_CHAR_ADVANCE (c, name, i, i_byte); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1678 QUIT; |
|
16496
a4e5a8ee32cc
(printchar, strout): Do QUIT for echo area output.
Richard M. Stallman <rms@gnu.org>
parents:
16140
diff
changeset
|
1679 |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1680 if (escapeflag) |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1681 { |
|
16496
a4e5a8ee32cc
(printchar, strout): Do QUIT for echo area output.
Richard M. Stallman <rms@gnu.org>
parents:
16140
diff
changeset
|
1682 if (c == '\"' || c == '\\' || c == '\'' |
|
a4e5a8ee32cc
(printchar, strout): Do QUIT for echo area output.
Richard M. Stallman <rms@gnu.org>
parents:
16140
diff
changeset
|
1683 || c == ';' || c == '#' || c == '(' || c == ')' |
|
a4e5a8ee32cc
(printchar, strout): Do QUIT for echo area output.
Richard M. Stallman <rms@gnu.org>
parents:
16140
diff
changeset
|
1684 || c == ',' || c =='.' || c == '`' |
|
a4e5a8ee32cc
(printchar, strout): Do QUIT for echo area output.
Richard M. Stallman <rms@gnu.org>
parents:
16140
diff
changeset
|
1685 || c == '[' || c == ']' || c == '?' || c <= 040 |
|
a4e5a8ee32cc
(printchar, strout): Do QUIT for echo area output.
Richard M. Stallman <rms@gnu.org>
parents:
16140
diff
changeset
|
1686 || confusing) |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1687 PRINTCHAR ('\\'), confusing = 0; |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1688 } |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1689 PRINTCHAR (c); |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1690 } |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1691 } |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1692 break; |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1693 |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1694 case Lisp_Cons: |
| 329 | 1695 /* If deeper than spec'd depth, print placeholder. */ |
|
9117
f69e6cf74874
(PRINTPREPARE, PRINTFINISH, float_to_string, print): Use type test macros.
Karl Heuer <kwzh@gnu.org>
parents:
8854
diff
changeset
|
1696 if (INTEGERP (Vprint_level) |
| 329 | 1697 && print_depth > XINT (Vprint_level)) |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1698 strout ("...", -1, -1, printcharfun, 0); |
|
15908
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1699 else if (print_quoted && CONSP (XCDR (obj)) && NILP (XCDR (XCDR (obj))) |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1700 && (EQ (XCAR (obj), Qquote))) |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1701 { |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1702 PRINTCHAR ('\''); |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1703 print_object (XCAR (XCDR (obj)), printcharfun, escapeflag); |
|
15908
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1704 } |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1705 else if (print_quoted && CONSP (XCDR (obj)) && NILP (XCDR (XCDR (obj))) |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1706 && (EQ (XCAR (obj), Qfunction))) |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1707 { |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1708 PRINTCHAR ('#'); |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1709 PRINTCHAR ('\''); |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1710 print_object (XCAR (XCDR (obj)), printcharfun, escapeflag); |
|
15908
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1711 } |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1712 else if (print_quoted && CONSP (XCDR (obj)) && NILP (XCDR (XCDR (obj))) |
|
47864
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1713 && ! old_backquote_output |
|
15908
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1714 && ((EQ (XCAR (obj), Qbackquote) |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1715 || EQ (XCAR (obj), Qcomma) |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1716 || EQ (XCAR (obj), Qcomma_at) |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1717 || EQ (XCAR (obj), Qcomma_dot)))) |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1718 { |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1719 print_object (XCAR (obj), printcharfun, 0); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1720 print_object (XCAR (XCDR (obj)), printcharfun, escapeflag); |
|
15908
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1721 } |
| 10001 | 1722 else |
| 329 | 1723 { |
| 10001 | 1724 PRINTCHAR ('('); |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47864
diff
changeset
|
1725 |
|
47864
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1726 /* If the first element is a backquote form, |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1727 print it old-style so it won't be misunderstood. */ |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1728 if (print_quoted && CONSP (XCAR (obj)) |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1729 && CONSP (XCDR (XCAR (obj))) |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1730 && NILP (XCDR (XCDR (XCAR (obj)))) |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1731 && EQ (XCAR (XCAR (obj)), Qbackquote)) |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1732 { |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1733 Lisp_Object tem; |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1734 tem = XCAR (obj); |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1735 PRINTCHAR ('('); |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1736 |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1737 print_object (Qbackquote, printcharfun, 0); |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1738 PRINTCHAR (' '); |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1739 |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1740 ++old_backquote_output; |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1741 print_object (XCAR (XCDR (tem)), printcharfun, 0); |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1742 --old_backquote_output; |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1743 PRINTCHAR (')'); |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1744 |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1745 obj = XCDR (obj); |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1746 } |
|
c63e96671963
(print): When backquote form is the car of a list,
Richard M. Stallman <rms@gnu.org>
parents:
47526
diff
changeset
|
1747 |
| 329 | 1748 { |
|
28743
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1749 int print_length, i; |
|
22231
35af9a276272
(print) <Lisp_Cons>: Detect circular list.
Richard M. Stallman <rms@gnu.org>
parents:
22183
diff
changeset
|
1750 Lisp_Object halftail = obj; |
| 10001 | 1751 |
|
28932
f8b0ac62f238
Use the term `invalid' instead of `illegal'.
Gerd Moellmann <gerd@gnu.org>
parents:
28743
diff
changeset
|
1752 /* Negative values of print-length are invalid in CL. |
|
28743
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1753 Treat them like nil, as CMUCL does. */ |
|
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1754 if (NATNUMP (Vprint_length)) |
|
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1755 print_length = XFASTINT (Vprint_length); |
|
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1756 else |
|
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1757 print_length = 0; |
|
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1758 |
|
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1759 i = 0; |
| 10001 | 1760 while (CONSP (obj)) |
| 329 | 1761 { |
|
22231
35af9a276272
(print) <Lisp_Cons>: Detect circular list.
Richard M. Stallman <rms@gnu.org>
parents:
22183
diff
changeset
|
1762 /* Detect circular list. */ |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1763 if (NILP (Vprint_circle)) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1764 { |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1765 /* Simple but imcomplete way. */ |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1766 if (i != 0 && EQ (obj, halftail)) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1767 { |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1768 sprintf (buf, " . #%d", i / 2); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1769 strout (buf, -1, -1, printcharfun, 0); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1770 goto end_of_list; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1771 } |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1772 } |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1773 else |
|
22231
35af9a276272
(print) <Lisp_Cons>: Detect circular list.
Richard M. Stallman <rms@gnu.org>
parents:
22183
diff
changeset
|
1774 { |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1775 /* With the print-circle feature. */ |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1776 if (i != 0) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1777 { |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1778 int i; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1779 for (i = 0; i < print_number_index; i++) |
|
28743
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1780 if (EQ (PRINT_NUMBER_OBJECT (Vprint_number_table, i), |
|
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1781 obj)) |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1782 { |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1783 if (NILP (PRINT_NUMBER_STATUS (Vprint_number_table, i))) |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1784 { |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1785 strout (" . ", 3, 3, printcharfun, 0); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1786 print_object (obj, printcharfun, escapeflag); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1787 } |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1788 else |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1789 { |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1790 sprintf (buf, " . #%d#", i + 1); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1791 strout (buf, -1, -1, printcharfun, 0); |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1792 } |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1793 goto end_of_list; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1794 } |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1795 } |
|
22231
35af9a276272
(print) <Lisp_Cons>: Detect circular list.
Richard M. Stallman <rms@gnu.org>
parents:
22183
diff
changeset
|
1796 } |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47864
diff
changeset
|
1797 |
| 10001 | 1798 if (i++) |
| 1799 PRINTCHAR (' '); | |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47864
diff
changeset
|
1800 |
|
21455
4a457fda49b5
* print.c (print): Avoid `min'/`max' as variable names.
Karl Heuer <kwzh@gnu.org>
parents:
21373
diff
changeset
|
1801 if (print_length && i > print_length) |
| 10001 | 1802 { |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1803 strout ("...", 3, 3, printcharfun, 0); |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1804 goto end_of_list; |
| 10001 | 1805 } |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47864
diff
changeset
|
1806 |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1807 print_object (XCAR (obj), printcharfun, escapeflag); |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47864
diff
changeset
|
1808 |
|
15908
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1809 obj = XCDR (obj); |
|
22231
35af9a276272
(print) <Lisp_Cons>: Detect circular list.
Richard M. Stallman <rms@gnu.org>
parents:
22183
diff
changeset
|
1810 if (!(i & 1)) |
|
35af9a276272
(print) <Lisp_Cons>: Detect circular list.
Richard M. Stallman <rms@gnu.org>
parents:
22183
diff
changeset
|
1811 halftail = XCDR (halftail); |
| 329 | 1812 } |
| 1813 } | |
|
28743
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1814 |
|
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1815 /* OBJ non-nil here means it's the end of a dotted list. */ |
|
15908
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
1816 if (!NILP (obj)) |
| 10001 | 1817 { |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1818 strout (" . ", 3, 3, printcharfun, 0); |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1819 print_object (obj, printcharfun, escapeflag); |
| 10001 | 1820 } |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47864
diff
changeset
|
1821 |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1822 end_of_list: |
| 10001 | 1823 PRINTCHAR (')'); |
| 329 | 1824 } |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1825 break; |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1826 |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1827 case Lisp_Vectorlike: |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1828 if (PROCESSP (obj)) |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1829 { |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1830 if (escapeflag) |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1831 { |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1832 strout ("#<process ", -1, -1, printcharfun, 0); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1833 print_string (XPROCESS (obj)->name, printcharfun); |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1834 PRINTCHAR ('>'); |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1835 } |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1836 else |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1837 print_string (XPROCESS (obj)->name, printcharfun); |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1838 } |
|
13147
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1839 else if (BOOL_VECTOR_P (obj)) |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1840 { |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1841 register int i; |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1842 register unsigned char c; |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1843 struct gcpro gcpro1; |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1844 int size_in_chars |
|
55162
4903fe69b0fa
(print_object): Print non-ascii characters in bool vector representation
Andreas Schwab <schwab@suse.de>
parents:
53704
diff
changeset
|
1845 = ((XBOOL_VECTOR (obj)->size + BOOL_VECTOR_BITS_PER_CHAR - 1) |
|
4903fe69b0fa
(print_object): Print non-ascii characters in bool vector representation
Andreas Schwab <schwab@suse.de>
parents:
53704
diff
changeset
|
1846 / BOOL_VECTOR_BITS_PER_CHAR); |
|
13147
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1847 |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1848 GCPRO1 (obj); |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1849 |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1850 PRINTCHAR ('#'); |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1851 PRINTCHAR ('&'); |
|
56069
cef7e1f2e773
(print_object): Always use %ld for printing EMACS_INT.
Andreas Schwab <schwab@suse.de>
parents:
55683
diff
changeset
|
1852 sprintf (buf, "%ld", (long) XBOOL_VECTOR (obj)->size); |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1853 strout (buf, -1, -1, printcharfun, 0); |
|
13147
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1854 PRINTCHAR ('\"'); |
|
15563
e47df82909ff
(print): Obey Vprint_length for vectors, bitvectors.
Richard M. Stallman <rms@gnu.org>
parents:
15270
diff
changeset
|
1855 |
|
28743
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1856 /* Don't print more characters than the specified maximum. |
|
28932
f8b0ac62f238
Use the term `invalid' instead of `illegal'.
Gerd Moellmann <gerd@gnu.org>
parents:
28743
diff
changeset
|
1857 Negative values of print-length are invalid. Treat them |
|
28743
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1858 like a print-length of nil. */ |
|
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1859 if (NATNUMP (Vprint_length) |
|
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1860 && XFASTINT (Vprint_length) < size_in_chars) |
|
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1861 size_in_chars = XFASTINT (Vprint_length); |
|
15563
e47df82909ff
(print): Obey Vprint_length for vectors, bitvectors.
Richard M. Stallman <rms@gnu.org>
parents:
15270
diff
changeset
|
1862 |
|
13147
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1863 for (i = 0; i < size_in_chars; i++) |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1864 { |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1865 QUIT; |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1866 c = XBOOL_VECTOR (obj)->data[i]; |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1867 if (c == '\n' && print_escape_newlines) |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1868 { |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1869 PRINTCHAR ('\\'); |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1870 PRINTCHAR ('n'); |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1871 } |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1872 else if (c == '\f' && print_escape_newlines) |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1873 { |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1874 PRINTCHAR ('\\'); |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1875 PRINTCHAR ('f'); |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1876 } |
|
55162
4903fe69b0fa
(print_object): Print non-ascii characters in bool vector representation
Andreas Schwab <schwab@suse.de>
parents:
53704
diff
changeset
|
1877 else if (c > '\177') |
|
4903fe69b0fa
(print_object): Print non-ascii characters in bool vector representation
Andreas Schwab <schwab@suse.de>
parents:
53704
diff
changeset
|
1878 { |
|
4903fe69b0fa
(print_object): Print non-ascii characters in bool vector representation
Andreas Schwab <schwab@suse.de>
parents:
53704
diff
changeset
|
1879 /* Use octal escapes to avoid encoding issues. */ |
|
4903fe69b0fa
(print_object): Print non-ascii characters in bool vector representation
Andreas Schwab <schwab@suse.de>
parents:
53704
diff
changeset
|
1880 PRINTCHAR ('\\'); |
|
4903fe69b0fa
(print_object): Print non-ascii characters in bool vector representation
Andreas Schwab <schwab@suse.de>
parents:
53704
diff
changeset
|
1881 PRINTCHAR ('0' + ((c >> 6) & 3)); |
|
4903fe69b0fa
(print_object): Print non-ascii characters in bool vector representation
Andreas Schwab <schwab@suse.de>
parents:
53704
diff
changeset
|
1882 PRINTCHAR ('0' + ((c >> 3) & 7)); |
|
4903fe69b0fa
(print_object): Print non-ascii characters in bool vector representation
Andreas Schwab <schwab@suse.de>
parents:
53704
diff
changeset
|
1883 PRINTCHAR ('0' + (c & 7)); |
|
4903fe69b0fa
(print_object): Print non-ascii characters in bool vector representation
Andreas Schwab <schwab@suse.de>
parents:
53704
diff
changeset
|
1884 } |
|
13147
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1885 else |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1886 { |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1887 if (c == '\"' || c == '\\') |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1888 PRINTCHAR ('\\'); |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1889 PRINTCHAR (c); |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1890 } |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1891 } |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1892 PRINTCHAR ('\"'); |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1893 |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1894 UNGCPRO; |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1895 } |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1896 else if (SUBRP (obj)) |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1897 { |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1898 strout ("#<subr ", -1, -1, printcharfun, 0); |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1899 strout (XSUBR (obj)->symbol_name, -1, -1, printcharfun, 0); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1900 PRINTCHAR ('>'); |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1901 } |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1902 else if (WINDOWP (obj)) |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1903 { |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1904 strout ("#<window ", -1, -1, printcharfun, 0); |
|
56069
cef7e1f2e773
(print_object): Always use %ld for printing EMACS_INT.
Andreas Schwab <schwab@suse.de>
parents:
55683
diff
changeset
|
1905 sprintf (buf, "%ld", (long) XFASTINT (XWINDOW (obj)->sequence_number)); |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1906 strout (buf, -1, -1, printcharfun, 0); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1907 if (!NILP (XWINDOW (obj)->buffer)) |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1908 { |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1909 strout (" on ", -1, -1, printcharfun, 0); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1910 print_string (XBUFFER (XWINDOW (obj)->buffer)->name, printcharfun); |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1911 } |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1912 PRINTCHAR ('>'); |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1913 } |
|
25011
12235d1f1871
(print): Add hash table handling.
Gerd Moellmann <gerd@gnu.org>
parents:
24368
diff
changeset
|
1914 else if (HASH_TABLE_P (obj)) |
|
12235d1f1871
(print): Add hash table handling.
Gerd Moellmann <gerd@gnu.org>
parents:
24368
diff
changeset
|
1915 { |
|
12235d1f1871
(print): Add hash table handling.
Gerd Moellmann <gerd@gnu.org>
parents:
24368
diff
changeset
|
1916 struct Lisp_Hash_Table *h = XHASH_TABLE (obj); |
|
12235d1f1871
(print): Add hash table handling.
Gerd Moellmann <gerd@gnu.org>
parents:
24368
diff
changeset
|
1917 strout ("#<hash-table", -1, -1, printcharfun, 0); |
|
12235d1f1871
(print): Add hash table handling.
Gerd Moellmann <gerd@gnu.org>
parents:
24368
diff
changeset
|
1918 if (SYMBOLP (h->test)) |
|
12235d1f1871
(print): Add hash table handling.
Gerd Moellmann <gerd@gnu.org>
parents:
24368
diff
changeset
|
1919 { |
|
12235d1f1871
(print): Add hash table handling.
Gerd Moellmann <gerd@gnu.org>
parents:
24368
diff
changeset
|
1920 PRINTCHAR (' '); |
|
12235d1f1871
(print): Add hash table handling.
Gerd Moellmann <gerd@gnu.org>
parents:
24368
diff
changeset
|
1921 PRINTCHAR ('\''); |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
1922 strout (SDATA (SYMBOL_NAME (h->test)), -1, -1, printcharfun, 0); |
|
25011
12235d1f1871
(print): Add hash table handling.
Gerd Moellmann <gerd@gnu.org>
parents:
24368
diff
changeset
|
1923 PRINTCHAR (' '); |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46317
diff
changeset
|
1924 strout (SDATA (SYMBOL_NAME (h->weak)), -1, -1, printcharfun, 0); |
|
25011
12235d1f1871
(print): Add hash table handling.
Gerd Moellmann <gerd@gnu.org>
parents:
24368
diff
changeset
|
1925 PRINTCHAR (' '); |
|
56069
cef7e1f2e773
(print_object): Always use %ld for printing EMACS_INT.
Andreas Schwab <schwab@suse.de>
parents:
55683
diff
changeset
|
1926 sprintf (buf, "%ld/%ld", (long) XFASTINT (h->count), |
|
cef7e1f2e773
(print_object): Always use %ld for printing EMACS_INT.
Andreas Schwab <schwab@suse.de>
parents:
55683
diff
changeset
|
1927 (long) XVECTOR (h->next)->size); |
|
25011
12235d1f1871
(print): Add hash table handling.
Gerd Moellmann <gerd@gnu.org>
parents:
24368
diff
changeset
|
1928 strout (buf, -1, -1, printcharfun, 0); |
|
12235d1f1871
(print): Add hash table handling.
Gerd Moellmann <gerd@gnu.org>
parents:
24368
diff
changeset
|
1929 } |
|
12235d1f1871
(print): Add hash table handling.
Gerd Moellmann <gerd@gnu.org>
parents:
24368
diff
changeset
|
1930 sprintf (buf, " 0x%lx", (unsigned long) h); |
|
12235d1f1871
(print): Add hash table handling.
Gerd Moellmann <gerd@gnu.org>
parents:
24368
diff
changeset
|
1931 strout (buf, -1, -1, printcharfun, 0); |
|
12235d1f1871
(print): Add hash table handling.
Gerd Moellmann <gerd@gnu.org>
parents:
24368
diff
changeset
|
1932 PRINTCHAR ('>'); |
|
12235d1f1871
(print): Add hash table handling.
Gerd Moellmann <gerd@gnu.org>
parents:
24368
diff
changeset
|
1933 } |
|
10301
aa73a5c0d1f2
(print): Don't drop thru to error for markers and overlays.
Richard M. Stallman <rms@gnu.org>
parents:
10293
diff
changeset
|
1934 else if (BUFFERP (obj)) |
|
aa73a5c0d1f2
(print): Don't drop thru to error for markers and overlays.
Richard M. Stallman <rms@gnu.org>
parents:
10293
diff
changeset
|
1935 { |
|
aa73a5c0d1f2
(print): Don't drop thru to error for markers and overlays.
Richard M. Stallman <rms@gnu.org>
parents:
10293
diff
changeset
|
1936 if (NILP (XBUFFER (obj)->name)) |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1937 strout ("#<killed buffer>", -1, -1, printcharfun, 0); |
|
10301
aa73a5c0d1f2
(print): Don't drop thru to error for markers and overlays.
Richard M. Stallman <rms@gnu.org>
parents:
10293
diff
changeset
|
1938 else if (escapeflag) |
|
aa73a5c0d1f2
(print): Don't drop thru to error for markers and overlays.
Richard M. Stallman <rms@gnu.org>
parents:
10293
diff
changeset
|
1939 { |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1940 strout ("#<buffer ", -1, -1, printcharfun, 0); |
|
10301
aa73a5c0d1f2
(print): Don't drop thru to error for markers and overlays.
Richard M. Stallman <rms@gnu.org>
parents:
10293
diff
changeset
|
1941 print_string (XBUFFER (obj)->name, printcharfun); |
|
aa73a5c0d1f2
(print): Don't drop thru to error for markers and overlays.
Richard M. Stallman <rms@gnu.org>
parents:
10293
diff
changeset
|
1942 PRINTCHAR ('>'); |
|
aa73a5c0d1f2
(print): Don't drop thru to error for markers and overlays.
Richard M. Stallman <rms@gnu.org>
parents:
10293
diff
changeset
|
1943 } |
|
aa73a5c0d1f2
(print): Don't drop thru to error for markers and overlays.
Richard M. Stallman <rms@gnu.org>
parents:
10293
diff
changeset
|
1944 else |
|
aa73a5c0d1f2
(print): Don't drop thru to error for markers and overlays.
Richard M. Stallman <rms@gnu.org>
parents:
10293
diff
changeset
|
1945 print_string (XBUFFER (obj)->name, printcharfun); |
|
aa73a5c0d1f2
(print): Don't drop thru to error for markers and overlays.
Richard M. Stallman <rms@gnu.org>
parents:
10293
diff
changeset
|
1946 } |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1947 else if (WINDOW_CONFIGURATIONP (obj)) |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1948 { |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1949 strout ("#<window-configuration>", -1, -1, printcharfun, 0); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1950 } |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1951 else if (FRAMEP (obj)) |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1952 { |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1953 strout ((FRAME_LIVE_P (XFRAME (obj)) |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1954 ? "#<frame " : "#<dead frame "), |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1955 -1, -1, printcharfun, 0); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1956 print_string (XFRAME (obj)->name, printcharfun); |
|
43944
42291dbdcf4b
(print_object): Delete `\ ' from printed rep of frame.
Richard M. Stallman <rms@gnu.org>
parents:
43668
diff
changeset
|
1957 sprintf (buf, " 0x%lx", (unsigned long) (XFRAME (obj))); |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
1958 strout (buf, -1, -1, printcharfun, 0); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1959 PRINTCHAR ('>'); |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1960 } |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1961 else |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1962 { |
|
53704
47b66024b855
(print_preprocess): Declare size as EMACS_INT to not lose bits.
Andreas Schwab <schwab@suse.de>
parents:
53537
diff
changeset
|
1963 EMACS_INT size = XVECTOR (obj)->size; |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1964 if (COMPILEDP (obj)) |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1965 { |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1966 PRINTCHAR ('#'); |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1967 size &= PSEUDOVECTOR_SIZE_MASK; |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1968 } |
|
13147
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1969 if (CHAR_TABLE_P (obj)) |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1970 { |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1971 /* We print a char-table as if it were a vector, |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1972 lumping the parent and default slots in with the |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1973 character slots. But we add #^ as a prefix. */ |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1974 PRINTCHAR ('#'); |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1975 PRINTCHAR ('^'); |
|
17325
c19c552c486f
(read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents:
17223
diff
changeset
|
1976 if (SUB_CHAR_TABLE_P (obj)) |
|
c19c552c486f
(read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents:
17223
diff
changeset
|
1977 PRINTCHAR ('^'); |
|
13147
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1978 size &= PSEUDOVECTOR_SIZE_MASK; |
|
bd9ff4ee6cd4
(print): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents:
12782
diff
changeset
|
1979 } |
|
10482
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
1980 if (size & PSEUDOVECTOR_FLAG) |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
1981 goto badtype; |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1982 |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1983 PRINTCHAR ('['); |
| 329 | 1984 { |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1985 register int i; |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1986 register Lisp_Object tem; |
|
30461
6c5d35d06409
(print_object): If vector printing is truncated, print "..." to
Kenichi Handa <handa@m17n.org>
parents:
30432
diff
changeset
|
1987 int real_size = size; |
|
15563
e47df82909ff
(print): Obey Vprint_length for vectors, bitvectors.
Richard M. Stallman <rms@gnu.org>
parents:
15270
diff
changeset
|
1988 |
|
e47df82909ff
(print): Obey Vprint_length for vectors, bitvectors.
Richard M. Stallman <rms@gnu.org>
parents:
15270
diff
changeset
|
1989 /* Don't print more elements than the specified maximum. */ |
|
28743
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1990 if (NATNUMP (Vprint_length) |
|
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1991 && XFASTINT (Vprint_length) < size) |
|
cd4858a8d658
(print_object): Treat print-length < 0 as nil.
Gerd Moellmann <gerd@gnu.org>
parents:
28732
diff
changeset
|
1992 size = XFASTINT (Vprint_length); |
|
15563
e47df82909ff
(print): Obey Vprint_length for vectors, bitvectors.
Richard M. Stallman <rms@gnu.org>
parents:
15270
diff
changeset
|
1993 |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1994 for (i = 0; i < size; i++) |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1995 { |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1996 if (i) PRINTCHAR (' '); |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1997 tem = XVECTOR (obj)->contents[i]; |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
1998 print_object (tem, printcharfun, escapeflag); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
1999 } |
|
30461
6c5d35d06409
(print_object): If vector printing is truncated, print "..." to
Kenichi Handa <handa@m17n.org>
parents:
30432
diff
changeset
|
2000 if (size < real_size) |
|
6c5d35d06409
(print_object): If vector printing is truncated, print "..." to
Kenichi Handa <handa@m17n.org>
parents:
30432
diff
changeset
|
2001 strout (" ...", 4, 4, printcharfun, 0); |
| 329 | 2002 } |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2003 PRINTCHAR (']'); |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2004 } |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2005 break; |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2006 |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2007 case Lisp_Misc: |
|
11241
5fed07fb66fb
(print): Use XMISCTYPE.
Richard M. Stallman <rms@gnu.org>
parents:
11235
diff
changeset
|
2008 switch (XMISCTYPE (obj)) |
| 329 | 2009 { |
|
10482
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2010 case Lisp_Misc_Marker: |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2011 strout ("#<marker ", -1, -1, printcharfun, 0); |
| 17040 | 2012 /* Do you think this is necessary? */ |
| 2013 if (XMARKER (obj)->insertion_type != 0) | |
|
40472
25269c1f7a10
(print_object): Clarify indication of insertion type.
Richard M. Stallman <rms@gnu.org>
parents:
40143
diff
changeset
|
2014 strout ("(moves after insertion) ", -1, -1, printcharfun, 0); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2015 if (!(XMARKER (obj)->buffer)) |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2016 strout ("in no buffer", -1, -1, printcharfun, 0); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2017 else |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2018 { |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2019 sprintf (buf, "at %d", marker_position (obj)); |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2020 strout (buf, -1, -1, printcharfun, 0); |
|
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2021 strout (" in ", -1, -1, printcharfun, 0); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2022 print_string (XMARKER (obj)->buffer->name, printcharfun); |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2023 } |
| 329 | 2024 PRINTCHAR ('>'); |
|
10301
aa73a5c0d1f2
(print): Don't drop thru to error for markers and overlays.
Richard M. Stallman <rms@gnu.org>
parents:
10293
diff
changeset
|
2025 break; |
|
10482
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2026 |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2027 case Lisp_Misc_Overlay: |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2028 strout ("#<overlay ", -1, -1, printcharfun, 0); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2029 if (!(XMARKER (OVERLAY_START (obj))->buffer)) |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2030 strout ("in no buffer", -1, -1, printcharfun, 0); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2031 else |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2032 { |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2033 sprintf (buf, "from %d to %d in ", |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2034 marker_position (OVERLAY_START (obj)), |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2035 marker_position (OVERLAY_END (obj))); |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2036 strout (buf, -1, -1, printcharfun, 0); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2037 print_string (XMARKER (OVERLAY_START (obj))->buffer->name, |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2038 printcharfun); |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2039 } |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2040 PRINTCHAR ('>'); |
|
10301
aa73a5c0d1f2
(print): Don't drop thru to error for markers and overlays.
Richard M. Stallman <rms@gnu.org>
parents:
10293
diff
changeset
|
2041 break; |
|
10482
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2042 |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2043 /* Remaining cases shouldn't happen in normal usage, but let's print |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2044 them anyway for the benefit of the debugger. */ |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2045 case Lisp_Misc_Free: |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2046 strout ("#<misc free cell>", -1, -1, printcharfun, 0); |
|
10482
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2047 break; |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2048 |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2049 case Lisp_Misc_Intfwd: |
|
56069
cef7e1f2e773
(print_object): Always use %ld for printing EMACS_INT.
Andreas Schwab <schwab@suse.de>
parents:
55683
diff
changeset
|
2050 sprintf (buf, "#<intfwd to %ld>", (long) *XINTFWD (obj)->intvar); |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2051 strout (buf, -1, -1, printcharfun, 0); |
|
10482
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2052 break; |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2053 |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2054 case Lisp_Misc_Boolfwd: |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2055 sprintf (buf, "#<boolfwd to %s>", |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2056 (*XBOOLFWD (obj)->boolvar ? "t" : "nil")); |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2057 strout (buf, -1, -1, printcharfun, 0); |
|
10482
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2058 break; |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2059 |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2060 case Lisp_Misc_Objfwd: |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2061 strout ("#<objfwd to ", -1, -1, printcharfun, 0); |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2062 print_object (*XOBJFWD (obj)->objvar, printcharfun, escapeflag); |
|
10482
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2063 PRINTCHAR ('>'); |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2064 break; |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2065 |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2066 case Lisp_Misc_Buffer_Objfwd: |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2067 strout ("#<buffer_objfwd to ", -1, -1, printcharfun, 0); |
| 28351 | 2068 print_object (PER_BUFFER_VALUE (current_buffer, |
| 2069 XBUFFER_OBJFWD (obj)->offset), | |
|
28316
869387703a36
(print_object): Use new macros for per-buffer
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
2070 printcharfun, escapeflag); |
|
10583
6736693cb8c8
(print): Handle internal display-local object.
Karl Heuer <kwzh@gnu.org>
parents:
10568
diff
changeset
|
2071 PRINTCHAR ('>'); |
|
6736693cb8c8
(print): Handle internal display-local object.
Karl Heuer <kwzh@gnu.org>
parents:
10568
diff
changeset
|
2072 break; |
|
6736693cb8c8
(print): Handle internal display-local object.
Karl Heuer <kwzh@gnu.org>
parents:
10568
diff
changeset
|
2073 |
|
11010
45ae0022c48a
(print): Rename perdisplay to kboard.
Karl Heuer <kwzh@gnu.org>
parents:
10993
diff
changeset
|
2074 case Lisp_Misc_Kboard_Objfwd: |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2075 strout ("#<kboard_objfwd to ", -1, -1, printcharfun, 0); |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2076 print_object (*(Lisp_Object *)((char *) current_kboard |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2077 + XKBOARD_OBJFWD (obj)->offset), |
|
28316
869387703a36
(print_object): Use new macros for per-buffer
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
2078 printcharfun, escapeflag); |
|
10482
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2079 PRINTCHAR ('>'); |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2080 break; |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2081 |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2082 case Lisp_Misc_Buffer_Local_Value: |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2083 strout ("#<buffer_local_value ", -1, -1, printcharfun, 0); |
|
10482
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2084 goto do_buffer_local; |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2085 case Lisp_Misc_Some_Buffer_Local_Value: |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2086 strout ("#<some_buffer_local_value ", -1, -1, printcharfun, 0); |
|
10482
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2087 do_buffer_local: |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2088 strout ("[realvalue] ", -1, -1, printcharfun, 0); |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2089 print_object (XBUFFER_LOCAL_VALUE (obj)->realvalue, |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2090 printcharfun, escapeflag); |
|
21142
77b24424ae6b
(print): Handle new data structure
Richard M. Stallman <rms@gnu.org>
parents:
20888
diff
changeset
|
2091 if (XBUFFER_LOCAL_VALUE (obj)->found_for_buffer) |
|
77b24424ae6b
(print): Handle new data structure
Richard M. Stallman <rms@gnu.org>
parents:
20888
diff
changeset
|
2092 strout ("[local in buffer] ", -1, -1, printcharfun, 0); |
|
77b24424ae6b
(print): Handle new data structure
Richard M. Stallman <rms@gnu.org>
parents:
20888
diff
changeset
|
2093 else |
|
77b24424ae6b
(print): Handle new data structure
Richard M. Stallman <rms@gnu.org>
parents:
20888
diff
changeset
|
2094 strout ("[buffer] ", -1, -1, printcharfun, 0); |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2095 print_object (XBUFFER_LOCAL_VALUE (obj)->buffer, |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2096 printcharfun, escapeflag); |
|
21142
77b24424ae6b
(print): Handle new data structure
Richard M. Stallman <rms@gnu.org>
parents:
20888
diff
changeset
|
2097 if (XBUFFER_LOCAL_VALUE (obj)->check_frame) |
|
77b24424ae6b
(print): Handle new data structure
Richard M. Stallman <rms@gnu.org>
parents:
20888
diff
changeset
|
2098 { |
|
77b24424ae6b
(print): Handle new data structure
Richard M. Stallman <rms@gnu.org>
parents:
20888
diff
changeset
|
2099 if (XBUFFER_LOCAL_VALUE (obj)->found_for_frame) |
|
77b24424ae6b
(print): Handle new data structure
Richard M. Stallman <rms@gnu.org>
parents:
20888
diff
changeset
|
2100 strout ("[local in frame] ", -1, -1, printcharfun, 0); |
|
77b24424ae6b
(print): Handle new data structure
Richard M. Stallman <rms@gnu.org>
parents:
20888
diff
changeset
|
2101 else |
|
77b24424ae6b
(print): Handle new data structure
Richard M. Stallman <rms@gnu.org>
parents:
20888
diff
changeset
|
2102 strout ("[frame] ", -1, -1, printcharfun, 0); |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2103 print_object (XBUFFER_LOCAL_VALUE (obj)->frame, |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2104 printcharfun, escapeflag); |
|
21142
77b24424ae6b
(print): Handle new data structure
Richard M. Stallman <rms@gnu.org>
parents:
20888
diff
changeset
|
2105 } |
|
77b24424ae6b
(print): Handle new data structure
Richard M. Stallman <rms@gnu.org>
parents:
20888
diff
changeset
|
2106 strout ("[alist-elt] ", -1, -1, printcharfun, 0); |
|
25717
3c6ad00e51a8
Use XCAR, XCDR, and XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25694
diff
changeset
|
2107 print_object (XCAR (XBUFFER_LOCAL_VALUE (obj)->cdr), |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2108 printcharfun, escapeflag); |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2109 strout ("[default-value] ", -1, -1, printcharfun, 0); |
|
25717
3c6ad00e51a8
Use XCAR, XCDR, and XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25694
diff
changeset
|
2110 print_object (XCDR (XBUFFER_LOCAL_VALUE (obj)->cdr), |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2111 printcharfun, escapeflag); |
|
10482
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2112 PRINTCHAR ('>'); |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2113 break; |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2114 |
|
57961
7dd13ac27ed7
(print_object): Print Lisp_Misc_Save_Value objects.
Kim F. Storm <storm@cua.dk>
parents:
56455
diff
changeset
|
2115 case Lisp_Misc_Save_Value: |
|
7dd13ac27ed7
(print_object): Print Lisp_Misc_Save_Value objects.
Kim F. Storm <storm@cua.dk>
parents:
56455
diff
changeset
|
2116 strout ("#<save_value ", -1, -1, printcharfun, 0); |
|
58094
1f8360dd535b
(print_object): Fix format string.
Kim F. Storm <storm@cua.dk>
parents:
57961
diff
changeset
|
2117 sprintf(buf, "ptr=0x%08lx int=%d", |
|
57961
7dd13ac27ed7
(print_object): Print Lisp_Misc_Save_Value objects.
Kim F. Storm <storm@cua.dk>
parents:
56455
diff
changeset
|
2118 (unsigned long) XSAVE_VALUE (obj)->pointer, |
|
7dd13ac27ed7
(print_object): Print Lisp_Misc_Save_Value objects.
Kim F. Storm <storm@cua.dk>
parents:
56455
diff
changeset
|
2119 XSAVE_VALUE (obj)->integer); |
|
7dd13ac27ed7
(print_object): Print Lisp_Misc_Save_Value objects.
Kim F. Storm <storm@cua.dk>
parents:
56455
diff
changeset
|
2120 strout (buf, -1, -1, printcharfun, 0); |
|
7dd13ac27ed7
(print_object): Print Lisp_Misc_Save_Value objects.
Kim F. Storm <storm@cua.dk>
parents:
56455
diff
changeset
|
2121 PRINTCHAR ('>'); |
|
7dd13ac27ed7
(print_object): Print Lisp_Misc_Save_Value objects.
Kim F. Storm <storm@cua.dk>
parents:
56455
diff
changeset
|
2122 break; |
|
7dd13ac27ed7
(print_object): Print Lisp_Misc_Save_Value objects.
Kim F. Storm <storm@cua.dk>
parents:
56455
diff
changeset
|
2123 |
|
10482
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2124 default: |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2125 goto badtype; |
| 329 | 2126 } |
|
10482
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2127 break; |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2128 |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2129 default: |
|
10482
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2130 badtype: |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2131 { |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2132 /* We're in trouble if this happens! |
|
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2133 Probably should just abort () */ |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2134 strout ("#<EMACS BUG: INVALID DATATYPE ", -1, -1, printcharfun, 0); |
|
10482
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2135 if (MISCP (obj)) |
|
11241
5fed07fb66fb
(print): Use XMISCTYPE.
Richard M. Stallman <rms@gnu.org>
parents:
11235
diff
changeset
|
2136 sprintf (buf, "(MISC 0x%04x)", (int) XMISCTYPE (obj)); |
|
10482
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2137 else if (VECTORLIKEP (obj)) |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2138 sprintf (buf, "(PVEC 0x%08x)", (int) XVECTOR (obj)->size); |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2139 else |
|
a15a058ec779
(print): Print internal types too, for debugging.
Karl Heuer <kwzh@gnu.org>
parents:
10418
diff
changeset
|
2140 sprintf (buf, "(0x%02x)", (int) XTYPE (obj)); |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2141 strout (buf, -1, -1, printcharfun, 0); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2142 strout (" Save your buffers immediately and please report this bug>", |
|
20591
0b00b6a96288
(print_string): Now static.
Richard M. Stallman <rms@gnu.org>
parents:
20549
diff
changeset
|
2143 -1, -1, printcharfun, 0); |
|
10293
96cc5c0a7ada
(print): Get size of compiled function as pseudovector.
Richard M. Stallman <rms@gnu.org>
parents:
10001
diff
changeset
|
2144 } |
| 329 | 2145 } |
| 2146 | |
| 2147 print_depth--; | |
| 2148 } | |
| 2149 | |
| 1967 | 2150 |
| 2151 /* Print a description of INTERVAL using PRINTCHARFUN. | |
| 2152 This is part of printing a string that has text properties. */ | |
| 2153 | |
| 2154 void | |
| 2155 print_interval (interval, printcharfun) | |
| 2156 INTERVAL interval; | |
| 2157 Lisp_Object printcharfun; | |
| 2158 { | |
|
4003
49918d6c6dda
* print.c: Get rid of extra space at the end of print syntax for
Jim Blandy <jimb@redhat.com>
parents:
3591
diff
changeset
|
2159 PRINTCHAR (' '); |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2160 print_object (make_number (interval->position), printcharfun, 1); |
| 1967 | 2161 PRINTCHAR (' '); |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2162 print_object (make_number (interval->position + LENGTH (interval)), |
| 1967 | 2163 printcharfun, 1); |
| 2164 PRINTCHAR (' '); | |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2165 print_object (interval->plist, printcharfun, 1); |
| 1967 | 2166 } |
| 2167 | |
| 2168 | |
| 329 | 2169 void |
| 2170 syms_of_print () | |
| 2171 { | |
|
24049
a45f10911408
(Qtemp_buffer_setup_hook): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
23931
diff
changeset
|
2172 Qtemp_buffer_setup_hook = intern ("temp-buffer-setup-hook"); |
|
a45f10911408
(Qtemp_buffer_setup_hook): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
23931
diff
changeset
|
2173 staticpro (&Qtemp_buffer_setup_hook); |
|
a45f10911408
(Qtemp_buffer_setup_hook): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
23931
diff
changeset
|
2174 |
| 329 | 2175 DEFVAR_LISP ("standard-output", &Vstandard_output, |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2176 doc: /* Output stream `print' uses by default for outputting a character. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2177 This may be any function of one argument. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2178 It may also be a buffer (output is inserted before point) |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2179 or a marker (output is inserted and the marker is advanced) |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2180 or the symbol t (output appears in the echo area). */); |
| 329 | 2181 Vstandard_output = Qt; |
| 2182 Qstandard_output = intern ("standard-output"); | |
| 2183 staticpro (&Qstandard_output); | |
| 2184 | |
| 2185 DEFVAR_LISP ("float-output-format", &Vfloat_output_format, | |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2186 doc: /* The format descriptor string used to print floats. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2187 This is a %-spec like those accepted by `printf' in C, |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2188 but with some restrictions. It must start with the two characters `%.'. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2189 After that comes an integer precision specification, |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2190 and then a letter which controls the format. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2191 The letters allowed are `e', `f' and `g'. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2192 Use `e' for exponential notation \"DIG.DIGITSeEXPT\" |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2193 Use `f' for decimal point notation \"DIGITS.DIGITS\". |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2194 Use `g' to choose the shorter of those two formats for the number at hand. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2195 The precision in any of these cases is the number of digits following |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2196 the decimal point. With `f', a precision of 0 means to omit the |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2197 decimal point. 0 is not allowed with `e' or `g'. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2198 |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2199 A value of nil means to use the shortest notation |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2200 that represents the number without losing information. */); |
| 329 | 2201 Vfloat_output_format = Qnil; |
| 2202 Qfloat_output_format = intern ("float-output-format"); | |
| 2203 staticpro (&Qfloat_output_format); | |
| 2204 | |
| 2205 DEFVAR_LISP ("print-length", &Vprint_length, | |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2206 doc: /* Maximum length of list to print before abbreviating. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2207 A value of nil means no limit. See also `eval-expression-print-length'. */); |
| 329 | 2208 Vprint_length = Qnil; |
| 2209 | |
| 2210 DEFVAR_LISP ("print-level", &Vprint_level, | |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2211 doc: /* Maximum depth of list nesting to print before abbreviating. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2212 A value of nil means no limit. See also `eval-expression-print-level'. */); |
| 329 | 2213 Vprint_level = Qnil; |
| 2214 | |
| 2215 DEFVAR_BOOL ("print-escape-newlines", &print_escape_newlines, | |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2216 doc: /* Non-nil means print newlines in strings as `\\n'. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2217 Also print formfeeds as `\\f'. */); |
| 329 | 2218 print_escape_newlines = 0; |
| 2219 | |
|
22240
4e4c377f3310
(print_escape_nonascii): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22231
diff
changeset
|
2220 DEFVAR_BOOL ("print-escape-nonascii", &print_escape_nonascii, |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2221 doc: /* Non-nil means print unibyte non-ASCII chars in strings as \\OOO. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2222 \(OOO is the octal representation of the character code.) |
|
51299
931dc917de11
(syms_of_print) <print-escape-nonascii>: Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
50920
diff
changeset
|
2223 Only single-byte characters are affected, and only in `prin1'. |
|
931dc917de11
(syms_of_print) <print-escape-nonascii>: Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
50920
diff
changeset
|
2224 When the output goes in a multibyte buffer, this feature is |
|
931dc917de11
(syms_of_print) <print-escape-nonascii>: Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
50920
diff
changeset
|
2225 enabled regardless of the value of the variable. */); |
|
22240
4e4c377f3310
(print_escape_nonascii): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22231
diff
changeset
|
2226 print_escape_nonascii = 0; |
|
4e4c377f3310
(print_escape_nonascii): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
22231
diff
changeset
|
2227 |
|
22933
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
2228 DEFVAR_BOOL ("print-escape-multibyte", &print_escape_multibyte, |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2229 doc: /* Non-nil means print multibyte characters in strings as \\xXXXX. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2230 \(XXXX is the hex representation of the character code.) |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2231 This affects only `prin1'. */); |
|
22933
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
2232 print_escape_multibyte = 0; |
|
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
2233 |
|
15908
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
2234 DEFVAR_BOOL ("print-quoted", &print_quoted, |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2235 doc: /* Non-nil means print quoted forms with reader syntax. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2236 I.e., (quote foo) prints as 'foo, (function foo) as #'foo, and backquoted |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2237 forms print as in the new syntax. */); |
|
15908
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
2238 print_quoted = 0; |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
2239 |
|
18961
e537071624ee
(Vprint_gensym_alist): Renamed from printed_gensyms.
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2240 DEFVAR_LISP ("print-gensym", &Vprint_gensym, |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2241 doc: /* Non-nil means print uninterned symbols so they will read as uninterned. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2242 I.e., the value of (make-symbol \"foobar\") prints as #:foobar. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2243 When the uninterned symbol appears within a recursive data structure, |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2244 and the symbol appears more than once, in addition use the #N# and #N= |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2245 constructs as needed, so that multiple references to the same symbol are |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2246 shared once again when the text is read back. */); |
|
18961
e537071624ee
(Vprint_gensym_alist): Renamed from printed_gensyms.
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2247 Vprint_gensym = Qnil; |
|
e537071624ee
(Vprint_gensym_alist): Renamed from printed_gensyms.
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2248 |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2249 DEFVAR_LISP ("print-circle", &Vprint_circle, |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2250 doc: /* *Non-nil means print recursive structures using #N= and #N# syntax. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2251 If nil, printing proceeds recursively and may lead to |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2252 `max-lisp-eval-depth' being exceeded or an error may occur: |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2253 \"Apparently circular structure being printed.\" Also see |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2254 `print-length' and `print-level'. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2255 If non-nil, shared substructures anywhere in the structure are printed |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2256 with `#N=' before the first occurrence (in the order of the print |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2257 representation) and `#N#' in place of each subsequent occurrence, |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2258 where N is a positive decimal integer. */); |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2259 Vprint_circle = Qnil; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2260 |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2261 DEFVAR_LISP ("print-continuous-numbering", &Vprint_continuous_numbering, |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2262 doc: /* *Non-nil means number continuously across print calls. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2263 This affects the numbers printed for #N= labels and #M# references. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2264 See also `print-circle', `print-gensym', and `print-number-table'. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2265 This variable should not be set with `setq'; bind it with a `let' instead. */); |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2266 Vprint_continuous_numbering = Qnil; |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2267 |
|
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2268 DEFVAR_LISP ("print-number-table", &Vprint_number_table, |
|
40123
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2269 doc: /* A vector used internally to produce `#N=' labels and `#N#' references. |
|
e528f2adeed4
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39856
diff
changeset
|
2270 The Lisp printer uses this vector to detect Lisp objects referenced more |
|
47526
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
2271 than once. |
|
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
2272 |
|
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
2273 When you bind `print-continuous-numbering' to t, you should probably |
|
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
2274 also bind `print-number-table' to nil. This ensures that the value of |
|
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
2275 `print-number-table' can be garbage-collected once the printing is |
|
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
2276 done. If all elements of `print-number-table' are nil, it means that |
|
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
2277 the printing done so far has not found any shared structure or objects |
|
0055228ad95f
(print): Clear out the unused parts of Vprint_number_table.
Richard M. Stallman <rms@gnu.org>
parents:
46574
diff
changeset
|
2278 that need to be recorded in the table. */); |
|
25694
475a9b6bd640
Support print-circle and related features.
Richard M. Stallman <rms@gnu.org>
parents:
25502
diff
changeset
|
2279 Vprint_number_table = Qnil; |
|
16140
e7de214aac01
Add #n=object, #n#, and #:symbol constructs to printer.
Erik Naggum <erik@naggum.no>
parents:
16051
diff
changeset
|
2280 |
| 329 | 2281 /* prin1_to_string_buffer initialized in init_buffer_once in buffer.c */ |
| 2282 staticpro (&Vprin1_to_string_buffer); | |
| 2283 | |
| 2284 defsubr (&Sprin1); | |
| 2285 defsubr (&Sprin1_to_string); | |
|
13776
8160ed43603e
(Ferror_message_string): New function.
Karl Heuer <kwzh@gnu.org>
parents:
13456
diff
changeset
|
2286 defsubr (&Serror_message_string); |
| 329 | 2287 defsubr (&Sprinc); |
| 2288 defsubr (&Sprint); | |
| 2289 defsubr (&Sterpri); | |
| 2290 defsubr (&Swrite_char); | |
| 2291 defsubr (&Sexternal_debugging_output); | |
|
53158
1025f21ef0c9
(Fredirect_debugging_output) [!GNU_LINUX]: Do not
Kim F. Storm <storm@cua.dk>
parents:
53141
diff
changeset
|
2292 #ifdef WITH_REDIRECT_DEBUGGING_OUTPUT |
|
53141
1679881ea880
(Fredirect_debugging_output): New defun.
Kim F. Storm <storm@cua.dk>
parents:
52538
diff
changeset
|
2293 defsubr (&Sredirect_debugging_output); |
|
53158
1025f21ef0c9
(Fredirect_debugging_output) [!GNU_LINUX]: Do not
Kim F. Storm <storm@cua.dk>
parents:
53141
diff
changeset
|
2294 #endif |
| 329 | 2295 |
| 2296 Qexternal_debugging_output = intern ("external-debugging-output"); | |
| 2297 staticpro (&Qexternal_debugging_output); | |
| 2298 | |
|
15908
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
2299 Qprint_escape_newlines = intern ("print-escape-newlines"); |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
2300 staticpro (&Qprint_escape_newlines); |
|
045bf20a0e7c
(print-quoted): New variable.
Erik Naggum <erik@naggum.no>
parents:
15801
diff
changeset
|
2301 |
|
22933
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
2302 Qprint_escape_multibyte = intern ("print-escape-multibyte"); |
|
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
2303 staticpro (&Qprint_escape_multibyte); |
|
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
2304 |
|
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
2305 Qprint_escape_nonascii = intern ("print-escape-nonascii"); |
|
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
2306 staticpro (&Qprint_escape_nonascii); |
|
f85d55276ec5
(print_escape_multibyte, Qprint_escape_multibyte)
Richard M. Stallman <rms@gnu.org>
parents:
22605
diff
changeset
|
2307 |
| 329 | 2308 defsubr (&Swith_output_to_temp_buffer); |
| 2309 } | |
| 52401 | 2310 |
| 2311 /* arch-tag: bc797170-94ae-41de-86e3-75e20f8f7a39 | |
| 2312 (do not change this comment) */ |
