annotate src/print.c @ 72367:12fa9bdadf0a

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