annotate src/lread.c @ 20279:69a6030e443a

(kill-region): Detect read-only text by getting an error trying to delete it. Handle the cases where we can, and can't, get the killed text from the undo list with much the same code.
author Karl Heuer <kwzh@gnu.org>
date Wed, 19 Nov 1997 21:36:56 +0000
parents 13074c25ab06
children b7d23d2eded1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1 /* Lisp parsing and input streams.
18771
c0b6ecdf4a2b (init_lread): Don't add to load-path lisp subdirectories
Richard M. Stallman <rms@gnu.org>
parents: 18665
diff changeset
2 Copyright (C) 1985, 86, 87, 88, 89, 93, 94, 95, 1997
c0b6ecdf4a2b (init_lread): Don't add to load-path lisp subdirectories
Richard M. Stallman <rms@gnu.org>
parents: 18665
diff changeset
3 Free Software Foundation, Inc.
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5 This file is part of GNU Emacs.
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
7 GNU Emacs is free software; you can redistribute it and/or modify
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
8 it under the terms of the GNU General Public License as published by
617
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
9 the Free Software Foundation; either version 2, or (at your option)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
10 any later version.
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
11
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
12 GNU Emacs is distributed in the hope that it will be useful,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
15 GNU General Public License for more details.
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
16
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
17 You should have received a copy of the GNU General Public License
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
18 along with GNU Emacs; see the file COPYING. If not, write to
14186
ee40177f6c68 Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents: 14130
diff changeset
19 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
ee40177f6c68 Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents: 14130
diff changeset
20 Boston, MA 02111-1307, USA. */
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
21
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
22
7898
1d65b2152c4e Put config.h first.
Richard M. Stallman <rms@gnu.org>
parents: 7823
diff changeset
23 #include <config.h>
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
24 #include <stdio.h>
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
25 #include <sys/types.h>
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
26 #include <sys/stat.h>
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
27 #include <sys/file.h>
8083
dc62b2daf48e (readchar): Restart interrupted I/O.
Karl Heuer <kwzh@gnu.org>
parents: 7898
diff changeset
28 #include <errno.h>
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
29 #include "lisp.h"
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
30
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
31 #ifndef standalone
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
32 #include "buffer.h"
17038
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
33 #include "charset.h"
4701
05f6a91c2801 Include <paths.h>, not "paths.h".
Roland McGrath <roland@gnu.org>
parents: 4696
diff changeset
34 #include <paths.h>
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
35 #include "commands.h"
1591
765cb54fa9af * lread.c: #include "keyboard.h".
Jim Blandy <jimb@redhat.com>
parents: 1519
diff changeset
36 #include "keyboard.h"
2044
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
37 #include "termhooks.h"
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
38 #endif
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
39
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
40 #ifdef lint
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
41 #include <sys/inode.h>
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
42 #endif /* lint */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
43
14972
a6889b33d21c [MSDOS]: If DJGPP version 2, include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 14950
diff changeset
44 #ifdef MSDOS
a6889b33d21c [MSDOS]: If DJGPP version 2, include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 14950
diff changeset
45 #if __DJGPP__ < 2
a6889b33d21c [MSDOS]: If DJGPP version 2, include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 14950
diff changeset
46 #include <unistd.h> /* to get X_OK */
a6889b33d21c [MSDOS]: If DJGPP version 2, include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 14950
diff changeset
47 #endif
a6889b33d21c [MSDOS]: If DJGPP version 2, include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 14950
diff changeset
48 #include "msdos.h"
a6889b33d21c [MSDOS]: If DJGPP version 2, include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 14950
diff changeset
49 #endif
a6889b33d21c [MSDOS]: If DJGPP version 2, include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 14950
diff changeset
50
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
51 #ifndef X_OK
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
52 #define X_OK 01
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
53 #endif
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
54
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
55 #ifdef LISP_FLOAT_TYPE
2781
fde05936aebb * lread.c, data.c: If STDC_HEADERS is #defined, include <stdlib.h>
Jim Blandy <jimb@redhat.com>
parents: 2654
diff changeset
56 #ifdef STDC_HEADERS
fde05936aebb * lread.c, data.c: If STDC_HEADERS is #defined, include <stdlib.h>
Jim Blandy <jimb@redhat.com>
parents: 2654
diff changeset
57 #include <stdlib.h>
fde05936aebb * lread.c, data.c: If STDC_HEADERS is #defined, include <stdlib.h>
Jim Blandy <jimb@redhat.com>
parents: 2654
diff changeset
58 #endif
5496
24f0d2908e61 [MSDOS]: Use text mode for all files but ".elc" files.
Richard M. Stallman <rms@gnu.org>
parents: 5243
diff changeset
59
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
60 #include <math.h>
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
61 #endif /* LISP_FLOAT_TYPE */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
62
14950
f5abde0d2904 Include locale.h.
Richard M. Stallman <rms@gnu.org>
parents: 14945
diff changeset
63 #ifdef HAVE_SETLOCALE
f5abde0d2904 Include locale.h.
Richard M. Stallman <rms@gnu.org>
parents: 14945
diff changeset
64 #include <locale.h>
f5abde0d2904 Include locale.h.
Richard M. Stallman <rms@gnu.org>
parents: 14945
diff changeset
65 #endif /* HAVE_SETLOCALE */
f5abde0d2904 Include locale.h.
Richard M. Stallman <rms@gnu.org>
parents: 14945
diff changeset
66
8596
ccd3c3ca2aef (O_RDONLY): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 8182
diff changeset
67 #ifndef O_RDONLY
ccd3c3ca2aef (O_RDONLY): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 8182
diff changeset
68 #define O_RDONLY 0
ccd3c3ca2aef (O_RDONLY): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 8182
diff changeset
69 #endif
ccd3c3ca2aef (O_RDONLY): Defined.
Richard M. Stallman <rms@gnu.org>
parents: 8182
diff changeset
70
8083
dc62b2daf48e (readchar): Restart interrupted I/O.
Karl Heuer <kwzh@gnu.org>
parents: 7898
diff changeset
71 extern int errno;
dc62b2daf48e (readchar): Restart interrupted I/O.
Karl Heuer <kwzh@gnu.org>
parents: 7898
diff changeset
72
2901
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
73 Lisp_Object Qread_char, Qget_file_char, Qstandard_input, Qcurrent_load_list;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
74 Lisp_Object Qvariable_documentation, Vvalues, Vstandard_input, Vafter_load_alist;
10200
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
75 Lisp_Object Qascii_character, Qload, Qload_file_name;
13235
0f83b9eb5478 (read1): Handle #' as prefix.
Richard M. Stallman <rms@gnu.org>
parents: 13146
diff changeset
76 Lisp_Object Qbackquote, Qcomma, Qcomma_at, Qcomma_dot, Qfunction;
16937
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
77 Lisp_Object Qinhibit_file_name_operation;
2044
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
78
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
79 extern Lisp_Object Qevent_symbol_element_mask;
16937
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
80 extern Lisp_Object Qfile_exists_p;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
81
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
82 /* non-zero if inside `load' */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
83 int load_in_progress;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
84
13601
0a091134e047 (Vsource_directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 13455
diff changeset
85 /* Directory in which the sources were found. */
0a091134e047 (Vsource_directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 13455
diff changeset
86 Lisp_Object Vsource_directory;
0a091134e047 (Vsource_directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 13455
diff changeset
87
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
88 /* Search path for files to be loaded. */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
89 Lisp_Object Vload_path;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
90
2545
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
91 /* This is the user-visible association list that maps features to
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
92 lists of defs in their load files. */
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
93 Lisp_Object Vload_history;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
94
10200
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
95 /* This is used to build the load history. */
2545
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
96 Lisp_Object Vcurrent_load_list;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
97
18665
6d7b8b35d878 (Vpreloaded_file_list): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 18530
diff changeset
98 /* List of files that were preloaded. */
6d7b8b35d878 (Vpreloaded_file_list): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 18530
diff changeset
99 Lisp_Object Vpreloaded_file_list;
6d7b8b35d878 (Vpreloaded_file_list): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 18530
diff changeset
100
10200
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
101 /* Name of file actually being read by `load'. */
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
102 Lisp_Object Vload_file_name;
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
103
11079
aeaaa579d967 (Vload_read_function): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11020
diff changeset
104 /* Function to use for reading, in `load' and friends. */
aeaaa579d967 (Vload_read_function): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11020
diff changeset
105 Lisp_Object Vload_read_function;
aeaaa579d967 (Vload_read_function): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11020
diff changeset
106
16141
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
107 /* The association list of objects read with the #n=object form.
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
108 Each member of the list has the form (n . object), and is used to
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
109 look up the object for the corresponding #n# construct.
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
110 It must be set to nil before all top-level calls to read0. */
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
111 Lisp_Object read_objects;
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
112
12780
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
113 /* Nonzero means load should forcibly load all dynamic doc strings. */
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
114 static int load_force_doc_strings;
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
115
17038
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
116 /* Function to use for loading an Emacs lisp source file (not
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
117 compiled) instead of readevalloop. */
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
118 Lisp_Object Vload_source_file_function;
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
119
5568
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
120 /* List of descriptors now open for Fload. */
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
121 static Lisp_Object load_descriptor_list;
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
122
12780
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
123 /* File for get_file_char to read from. Use by load. */
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
124 static FILE *instream;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
125
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
126 /* When nonzero, read conses in pure space */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
127 static int read_pure;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
128
12780
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
129 /* For use within read-from-string (this reader is non-reentrant!!) */
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
130 static int read_from_string_index;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
131 static int read_from_string_limit;
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
132
20048
5324d8b2322b (read_list): Don't recognize Vload_file_name
Karl Heuer <kwzh@gnu.org>
parents: 20024
diff changeset
133 /* This contains the last string skipped with #@, but only on some systems.
5324d8b2322b (read_list): Don't recognize Vload_file_name
Karl Heuer <kwzh@gnu.org>
parents: 20024
diff changeset
134 On other systems we can't put the string here. */
12780
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
135 static char *saved_doc_string;
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
136 /* Length of buffer allocated in saved_doc_string. */
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
137 static int saved_doc_string_size;
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
138 /* Length of actual data in saved_doc_string. */
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
139 static int saved_doc_string_length;
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
140 /* This is the file position that string came from. */
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
141 static int saved_doc_string_position;
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
142
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
143 /* Nonzero means inside a new-style backquote
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
144 with no surrounding parentheses.
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
145 Fread initializes this to zero, so we need not specbind it
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
146 or worry about what happens to it when there is an error. */
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
147 static int new_backquote_flag;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
148
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
149 /* Handle unreading and rereading of characters.
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
150 Write READCHAR to read a character,
17038
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
151 UNREAD(c) to unread c to be read again.
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
152
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
153 These macros actually read/unread a byte code, multibyte characters
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
154 are not handled here. The caller should manage them if necessary.
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
155 */
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
156
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
157 #define READCHAR readchar (readcharfun)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
158 #define UNREAD(c) unreadchar (readcharfun, c)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
159
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
160 static int
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
161 readchar (readcharfun)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
162 Lisp_Object readcharfun;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
163 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
164 Lisp_Object tem;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
165 register struct buffer *inbuffer;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
166 register int c, mpos;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
167
9149
fe6b30db719d (readchar, readchar, unreadchar, read_filtered_event, Fread, read0, read1,
Karl Heuer <kwzh@gnu.org>
parents: 8906
diff changeset
168 if (BUFFERP (readcharfun))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
169 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
170 inbuffer = XBUFFER (readcharfun);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
171
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
172 if (BUF_PT (inbuffer) >= BUF_ZV (inbuffer))
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
173 return -1;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
174 c = *(unsigned char *) BUF_CHAR_ADDRESS (inbuffer, BUF_PT (inbuffer));
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
175 SET_BUF_PT (inbuffer, BUF_PT (inbuffer) + 1);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
176
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
177 return c;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
178 }
9149
fe6b30db719d (readchar, readchar, unreadchar, read_filtered_event, Fread, read0, read1,
Karl Heuer <kwzh@gnu.org>
parents: 8906
diff changeset
179 if (MARKERP (readcharfun))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
180 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
181 inbuffer = XMARKER (readcharfun)->buffer;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
182
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
183 mpos = marker_position (readcharfun);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
184
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
185 if (mpos > BUF_ZV (inbuffer) - 1)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
186 return -1;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
187 c = *(unsigned char *) BUF_CHAR_ADDRESS (inbuffer, mpos);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
188 if (mpos != BUF_GPT (inbuffer))
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
189 XMARKER (readcharfun)->bufpos++;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
190 else
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
191 Fset_marker (readcharfun, make_number (mpos + 1),
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
192 Fmarker_buffer (readcharfun));
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
193 return c;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
194 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
195 if (EQ (readcharfun, Qget_file_char))
8083
dc62b2daf48e (readchar): Restart interrupted I/O.
Karl Heuer <kwzh@gnu.org>
parents: 7898
diff changeset
196 {
dc62b2daf48e (readchar): Restart interrupted I/O.
Karl Heuer <kwzh@gnu.org>
parents: 7898
diff changeset
197 c = getc (instream);
dc62b2daf48e (readchar): Restart interrupted I/O.
Karl Heuer <kwzh@gnu.org>
parents: 7898
diff changeset
198 #ifdef EINTR
dc62b2daf48e (readchar): Restart interrupted I/O.
Karl Heuer <kwzh@gnu.org>
parents: 7898
diff changeset
199 /* Interrupted reads have been observed while reading over the network */
dc62b2daf48e (readchar): Restart interrupted I/O.
Karl Heuer <kwzh@gnu.org>
parents: 7898
diff changeset
200 while (c == EOF && ferror (instream) && errno == EINTR)
dc62b2daf48e (readchar): Restart interrupted I/O.
Karl Heuer <kwzh@gnu.org>
parents: 7898
diff changeset
201 {
dc62b2daf48e (readchar): Restart interrupted I/O.
Karl Heuer <kwzh@gnu.org>
parents: 7898
diff changeset
202 clearerr (instream);
dc62b2daf48e (readchar): Restart interrupted I/O.
Karl Heuer <kwzh@gnu.org>
parents: 7898
diff changeset
203 c = getc (instream);
dc62b2daf48e (readchar): Restart interrupted I/O.
Karl Heuer <kwzh@gnu.org>
parents: 7898
diff changeset
204 }
dc62b2daf48e (readchar): Restart interrupted I/O.
Karl Heuer <kwzh@gnu.org>
parents: 7898
diff changeset
205 #endif
dc62b2daf48e (readchar): Restart interrupted I/O.
Karl Heuer <kwzh@gnu.org>
parents: 7898
diff changeset
206 return c;
dc62b2daf48e (readchar): Restart interrupted I/O.
Karl Heuer <kwzh@gnu.org>
parents: 7898
diff changeset
207 }
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
208
9149
fe6b30db719d (readchar, readchar, unreadchar, read_filtered_event, Fread, read0, read1,
Karl Heuer <kwzh@gnu.org>
parents: 8906
diff changeset
209 if (STRINGP (readcharfun))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
210 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
211 register int c;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
212 /* This used to be return of a conditional expression,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
213 but that truncated -1 to a char on VMS. */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
214 if (read_from_string_index < read_from_string_limit)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
215 c = XSTRING (readcharfun)->data[read_from_string_index++];
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
216 else
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
217 c = -1;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
218 return c;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
219 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
220
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
221 tem = call0 (readcharfun);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
222
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
223 if (NILP (tem))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
224 return -1;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
225 return XINT (tem);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
226 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
227
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
228 /* Unread the character C in the way appropriate for the stream READCHARFUN.
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
229 If the stream is a user function, call it with the char as argument. */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
230
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
231 static void
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
232 unreadchar (readcharfun, c)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
233 Lisp_Object readcharfun;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
234 int c;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
235 {
6471
4e6b54b64d94 (unreadchar): Don't back up the pointer when unreading EOF.
Karl Heuer <kwzh@gnu.org>
parents: 6470
diff changeset
236 if (c == -1)
4e6b54b64d94 (unreadchar): Don't back up the pointer when unreading EOF.
Karl Heuer <kwzh@gnu.org>
parents: 6470
diff changeset
237 /* Don't back up the pointer if we're unreading the end-of-input mark,
4e6b54b64d94 (unreadchar): Don't back up the pointer when unreading EOF.
Karl Heuer <kwzh@gnu.org>
parents: 6470
diff changeset
238 since readchar didn't advance it when we read it. */
4e6b54b64d94 (unreadchar): Don't back up the pointer when unreading EOF.
Karl Heuer <kwzh@gnu.org>
parents: 6470
diff changeset
239 ;
9149
fe6b30db719d (readchar, readchar, unreadchar, read_filtered_event, Fread, read0, read1,
Karl Heuer <kwzh@gnu.org>
parents: 8906
diff changeset
240 else if (BUFFERP (readcharfun))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
241 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
242 if (XBUFFER (readcharfun) == current_buffer)
16039
855c8d8ba0f0 Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents: 16012
diff changeset
243 SET_PT (PT - 1);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
244 else
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
245 SET_BUF_PT (XBUFFER (readcharfun), BUF_PT (XBUFFER (readcharfun)) - 1);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
246 }
9149
fe6b30db719d (readchar, readchar, unreadchar, read_filtered_event, Fread, read0, read1,
Karl Heuer <kwzh@gnu.org>
parents: 8906
diff changeset
247 else if (MARKERP (readcharfun))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
248 XMARKER (readcharfun)->bufpos--;
9149
fe6b30db719d (readchar, readchar, unreadchar, read_filtered_event, Fread, read0, read1,
Karl Heuer <kwzh@gnu.org>
parents: 8906
diff changeset
249 else if (STRINGP (readcharfun))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
250 read_from_string_index--;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
251 else if (EQ (readcharfun, Qget_file_char))
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
252 ungetc (c, instream);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
253 else
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
254 call1 (readcharfun, make_number (c));
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
255 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
256
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
257 static Lisp_Object read0 (), read1 (), read_list (), read_vector ();
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
258
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
259 /* get a character from the tty */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
260
1519
5d0837ebee9c * lread.c (read_char): Add an extern declaration for this,
Jim Blandy <jimb@redhat.com>
parents: 1092
diff changeset
261 extern Lisp_Object read_char ();
5d0837ebee9c * lread.c (read_char): Add an extern declaration for this,
Jim Blandy <jimb@redhat.com>
parents: 1092
diff changeset
262
2654
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
263 /* Read input events until we get one that's acceptable for our purposes.
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
264
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
265 If NO_SWITCH_FRAME is non-zero, switch-frame events are stashed
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
266 until we get a character we like, and then stuffed into
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
267 unread_switch_frame.
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
268
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
269 If ASCII_REQUIRED is non-zero, we check function key events to see
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
270 if the unmodified version of the symbol has a Qascii_character
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
271 property, and use that character, if present.
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
272
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
273 If ERROR_NONASCII is non-zero, we signal an error if the input we
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
274 get isn't an ASCII character with modifiers. If it's zero but
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
275 ASCII_REQUIRED is non-zero, we just re-read until we get an ASCII
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
276 character. */
14483
7f49c41db1e8 (Fread_char_exclusive): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 14300
diff changeset
277
2654
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
278 Lisp_Object
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
279 read_filtered_event (no_switch_frame, ascii_required, error_nonascii)
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
280 int no_switch_frame, ascii_required, error_nonascii;
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
281 {
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
282 #ifdef standalone
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
283 return make_number (getchar ());
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
284 #else
6503
7c566d0e4b3d (read_filtered_event, intern): Use assignment instead of initialization.
Karl Heuer <kwzh@gnu.org>
parents: 6471
diff changeset
285 register Lisp_Object val, delayed_switch_frame;
7c566d0e4b3d (read_filtered_event, intern): Use assignment instead of initialization.
Karl Heuer <kwzh@gnu.org>
parents: 6471
diff changeset
286
7c566d0e4b3d (read_filtered_event, intern): Use assignment instead of initialization.
Karl Heuer <kwzh@gnu.org>
parents: 6471
diff changeset
287 delayed_switch_frame = Qnil;
2654
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
288
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
289 /* Read until we get an acceptable event. */
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
290 retry:
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
291 val = read_char (0, 0, 0, Qnil, 0);
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
292
9149
fe6b30db719d (readchar, readchar, unreadchar, read_filtered_event, Fread, read0, read1,
Karl Heuer <kwzh@gnu.org>
parents: 8906
diff changeset
293 if (BUFFERP (val))
5888
0d02ee7ee659 (read_filtered_event): Retry read_char after a buffer change.
Karl Heuer <kwzh@gnu.org>
parents: 5687
diff changeset
294 goto retry;
0d02ee7ee659 (read_filtered_event): Retry read_char after a buffer change.
Karl Heuer <kwzh@gnu.org>
parents: 5687
diff changeset
295
2654
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
296 /* switch-frame events are put off until after the next ASCII
14036
621a575db6f7 Comment fixes.
Karl Heuer <kwzh@gnu.org>
parents: 13772
diff changeset
297 character. This is better than signaling an error just because
2654
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
298 the last characters were typed to a separate minibuffer frame,
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
299 for example. Eventually, some code which can deal with
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
300 switch-frame events will read it and process it. */
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
301 if (no_switch_frame
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
302 && EVENT_HAS_PARAMETERS (val)
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
303 && EQ (EVENT_HEAD (val), Qswitch_frame))
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
304 {
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
305 delayed_switch_frame = val;
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
306 goto retry;
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
307 }
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
308
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
309 if (ascii_required)
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
310 {
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
311 /* Convert certain symbols to their ASCII equivalents. */
9149
fe6b30db719d (readchar, readchar, unreadchar, read_filtered_event, Fread, read0, read1,
Karl Heuer <kwzh@gnu.org>
parents: 8906
diff changeset
312 if (SYMBOLP (val))
2654
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
313 {
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
314 Lisp_Object tem, tem1, tem2;
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
315 tem = Fget (val, Qevent_symbol_element_mask);
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
316 if (!NILP (tem))
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
317 {
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
318 tem1 = Fget (Fcar (tem), Qascii_character);
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
319 /* Merge this symbol's modifier bits
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
320 with the ASCII equivalent of its basic code. */
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
321 if (!NILP (tem1))
9313
ed68c3822e4b (read_filtered_event, init_obarray): Don't use XFASTINT as an lvalue.
Karl Heuer <kwzh@gnu.org>
parents: 9274
diff changeset
322 XSETFASTINT (val, XINT (tem1) | XINT (Fcar (Fcdr (tem))));
2654
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
323 }
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
324 }
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
325
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
326 /* If we don't have a character now, deal with it appropriately. */
9149
fe6b30db719d (readchar, readchar, unreadchar, read_filtered_event, Fread, read0, read1,
Karl Heuer <kwzh@gnu.org>
parents: 8906
diff changeset
327 if (!INTEGERP (val))
2654
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
328 {
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
329 if (error_nonascii)
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
330 {
7106
06542cc6ddcd (read_filtered_event): Use Vunread_command_events.
Richard M. Stallman <rms@gnu.org>
parents: 7028
diff changeset
331 Vunread_command_events = Fcons (val, Qnil);
2654
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
332 error ("Non-character input-event");
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
333 }
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
334 else
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
335 goto retry;
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
336 }
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
337 }
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
338
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
339 if (! NILP (delayed_switch_frame))
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
340 unread_switch_frame = delayed_switch_frame;
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
341
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
342 return val;
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
343 #endif
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
344 }
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
345
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
346 DEFUN ("read-char", Fread_char, Sread_char, 0, 0, 0,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
347 "Read a character from the command input (keyboard or macro).\n\
851
9620f7edf04d entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 826
diff changeset
348 It is returned as a number.\n\
9620f7edf04d entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 826
diff changeset
349 If the user generates an event which is not a character (i.e. a mouse\n\
1591
765cb54fa9af * lread.c: #include "keyboard.h".
Jim Blandy <jimb@redhat.com>
parents: 1519
diff changeset
350 click or function key event), `read-char' signals an error. As an\n\
765cb54fa9af * lread.c: #include "keyboard.h".
Jim Blandy <jimb@redhat.com>
parents: 1519
diff changeset
351 exception, switch-frame events are put off until non-ASCII events can\n\
765cb54fa9af * lread.c: #include "keyboard.h".
Jim Blandy <jimb@redhat.com>
parents: 1519
diff changeset
352 be read.\n\
765cb54fa9af * lread.c: #include "keyboard.h".
Jim Blandy <jimb@redhat.com>
parents: 1519
diff changeset
353 If you want to read non-character events, or ignore them, call\n\
765cb54fa9af * lread.c: #include "keyboard.h".
Jim Blandy <jimb@redhat.com>
parents: 1519
diff changeset
354 `read-event' or `read-char-exclusive' instead.")
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
355 ()
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
356 {
2654
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
357 return read_filtered_event (1, 1, 1);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
358 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
359
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
360 DEFUN ("read-event", Fread_event, Sread_event, 0, 0, 0,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
361 "Read an event object from the input stream.")
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
362 ()
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
363 {
2654
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
364 return read_filtered_event (0, 0, 0);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
365 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
366
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
367 DEFUN ("read-char-exclusive", Fread_char_exclusive, Sread_char_exclusive, 0, 0, 0,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
368 "Read a character from the command input (keyboard or macro).\n\
14483
7f49c41db1e8 (Fread_char_exclusive): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 14300
diff changeset
369 It is returned as a number. Non-character events are ignored.")
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
370 ()
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
371 {
2654
ba685dcc3750 Arrange for Fy_or_n_p to put off switch-frame events.
Jim Blandy <jimb@redhat.com>
parents: 2545
diff changeset
372 return read_filtered_event (1, 1, 0);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
373 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
374
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
375 DEFUN ("get-file-char", Fget_file_char, Sget_file_char, 0, 0, 0,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
376 "Don't use this yourself.")
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
377 ()
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
378 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
379 register Lisp_Object val;
9274
5c66d8b65a7c (Fget_file_char, Fload, read1, oblookup, map_obarray, defsubr, defalias,
Karl Heuer <kwzh@gnu.org>
parents: 9149
diff changeset
380 XSETINT (val, getc (instream));
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
381 return val;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
382 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
383
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
384 static void readevalloop ();
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
385 static Lisp_Object load_unwind ();
5568
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
386 static Lisp_Object load_descriptor_unwind ();
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
387
19115
266915689f9e (Fload): New optional arg MUST-SUFFIX.
Richard M. Stallman <rms@gnu.org>
parents: 19020
diff changeset
388 DEFUN ("load", Fload, Sload, 1, 5, 0,
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
389 "Execute a file of Lisp code named FILE.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
390 First try FILE with `.elc' appended, then try with `.el',\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
391 then try FILE unmodified.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
392 This function searches the directories in `load-path'.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
393 If optional second arg NOERROR is non-nil,\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
394 report no error if FILE doesn't exist.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
395 Print messages at start and end of loading unless\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
396 optional third arg NOMESSAGE is non-nil.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
397 If optional fourth arg NOSUFFIX is non-nil, don't try adding\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
398 suffixes `.elc' or `.el' to the specified name FILE.\n\
19622
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
399 If optional fifth arg MUST-SUFFIX is non-nil, insist on\n\
19626
a9f87afd5ac6 (Fload): Fix doc syntax.
Richard M. Stallman <rms@gnu.org>
parents: 19622
diff changeset
400 the suffix `.elc' or `.el'; don't accept just FILE unless\n\
19622
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
401 it ends in one of those suffixes or includes a directory name.\n\
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
402 Return t if file exists.")
19115
266915689f9e (Fload): New optional arg MUST-SUFFIX.
Richard M. Stallman <rms@gnu.org>
parents: 19020
diff changeset
403 (file, noerror, nomessage, nosuffix, must_suffix)
266915689f9e (Fload): New optional arg MUST-SUFFIX.
Richard M. Stallman <rms@gnu.org>
parents: 19020
diff changeset
404 Lisp_Object file, noerror, nomessage, nosuffix, must_suffix;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
405 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
406 register FILE *stream;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
407 register int fd = -1;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
408 register Lisp_Object lispstream;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
409 int count = specpdl_ptr - specpdl;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
410 Lisp_Object temp;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
411 struct gcpro gcpro1;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
412 Lisp_Object found;
16012
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
413 /* 1 means we printed the ".el is newer" message. */
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
414 int newer = 0;
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
415 /* 1 means we are loading a compiled file. */
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
416 int compiled = 0;
3625
57174f9b1870 (Fload): Forward all 4 args to magic-name handler.
Richard M. Stallman <rms@gnu.org>
parents: 3041
diff changeset
417 Lisp_Object handler;
9790
637b4664f7a5 Change explicit uses of the Unix directory separator
Richard M. Stallman <rms@gnu.org>
parents: 9552
diff changeset
418 #ifdef DOS_NT
5496
24f0d2908e61 [MSDOS]: Use text mode for all files but ".elc" files.
Richard M. Stallman <rms@gnu.org>
parents: 5243
diff changeset
419 char *dosmode = "rt";
9790
637b4664f7a5 Change explicit uses of the Unix directory separator
Richard M. Stallman <rms@gnu.org>
parents: 9552
diff changeset
420 #endif /* DOS_NT */
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
421
13036
cd0e7903d0a9 (Fload): Rename arg STR to FILE.
Richard M. Stallman <rms@gnu.org>
parents: 12780
diff changeset
422 CHECK_STRING (file, 0);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
423
3625
57174f9b1870 (Fload): Forward all 4 args to magic-name handler.
Richard M. Stallman <rms@gnu.org>
parents: 3041
diff changeset
424 /* If file name is magic, call the handler. */
13036
cd0e7903d0a9 (Fload): Rename arg STR to FILE.
Richard M. Stallman <rms@gnu.org>
parents: 12780
diff changeset
425 handler = Ffind_file_name_handler (file, Qload);
3625
57174f9b1870 (Fload): Forward all 4 args to magic-name handler.
Richard M. Stallman <rms@gnu.org>
parents: 3041
diff changeset
426 if (!NILP (handler))
13036
cd0e7903d0a9 (Fload): Rename arg STR to FILE.
Richard M. Stallman <rms@gnu.org>
parents: 12780
diff changeset
427 return call5 (handler, Qload, file, noerror, nomessage, nosuffix);
3625
57174f9b1870 (Fload): Forward all 4 args to magic-name handler.
Richard M. Stallman <rms@gnu.org>
parents: 3041
diff changeset
428
10014
d149c4dc84f3 (Fload): Call Fsubstitute_in_file_name after trying handler.
Richard M. Stallman <rms@gnu.org>
parents: 9938
diff changeset
429 /* Do this after the handler to avoid
d149c4dc84f3 (Fload): Call Fsubstitute_in_file_name after trying handler.
Richard M. Stallman <rms@gnu.org>
parents: 9938
diff changeset
430 the need to gcpro noerror, nomessage and nosuffix.
d149c4dc84f3 (Fload): Call Fsubstitute_in_file_name after trying handler.
Richard M. Stallman <rms@gnu.org>
parents: 9938
diff changeset
431 (Below here, we care only whether they are nil or not.) */
13036
cd0e7903d0a9 (Fload): Rename arg STR to FILE.
Richard M. Stallman <rms@gnu.org>
parents: 12780
diff changeset
432 file = Fsubstitute_in_file_name (file);
10014
d149c4dc84f3 (Fload): Call Fsubstitute_in_file_name after trying handler.
Richard M. Stallman <rms@gnu.org>
parents: 9938
diff changeset
433
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
434 /* Avoid weird lossage with null string as arg,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
435 since it would try to load a directory as a Lisp file */
13036
cd0e7903d0a9 (Fload): Rename arg STR to FILE.
Richard M. Stallman <rms@gnu.org>
parents: 12780
diff changeset
436 if (XSTRING (file)->size > 0)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
437 {
19622
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
438 int size = XSTRING (file)->size;
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
439
13036
cd0e7903d0a9 (Fload): Rename arg STR to FILE.
Richard M. Stallman <rms@gnu.org>
parents: 12780
diff changeset
440 GCPRO1 (file);
19622
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
441
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
442 if (! NILP (must_suffix))
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
443 {
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
444 /* Don't insist on adding a suffix if FILE already ends with one. */
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
445 if (size > 3
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
446 && !strcmp (XSTRING (file)->data + size - 3, ".el"))
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
447 must_suffix = Qnil;
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
448 else if (size > 4
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
449 && !strcmp (XSTRING (file)->data + size - 4, ".elc"))
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
450 must_suffix = Qnil;
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
451 /* Don't insist on adding a suffix
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
452 if the argument includes a directory name. */
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
453 else if (! NILP (Ffile_name_directory (file)))
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
454 must_suffix = Qnil;
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
455 }
be0876941b71 (Fload): If FILE arg ends in .el or .elc, don't insist on adding a suffix.
Richard M. Stallman <rms@gnu.org>
parents: 19240
diff changeset
456
19115
266915689f9e (Fload): New optional arg MUST-SUFFIX.
Richard M. Stallman <rms@gnu.org>
parents: 19020
diff changeset
457 fd = openp (Vload_path, file,
266915689f9e (Fload): New optional arg MUST-SUFFIX.
Richard M. Stallman <rms@gnu.org>
parents: 19020
diff changeset
458 (!NILP (nosuffix) ? ""
266915689f9e (Fload): New optional arg MUST-SUFFIX.
Richard M. Stallman <rms@gnu.org>
parents: 19020
diff changeset
459 : ! NILP (must_suffix) ? ".elc:.el"
266915689f9e (Fload): New optional arg MUST-SUFFIX.
Richard M. Stallman <rms@gnu.org>
parents: 19020
diff changeset
460 : ".elc:.el:"),
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
461 &found, 0);
6392
58e075552627 (openp, Fload): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6072
diff changeset
462 UNGCPRO;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
463 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
464
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
465 if (fd < 0)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
466 {
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
467 if (NILP (noerror))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
468 while (1)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
469 Fsignal (Qfile_error, Fcons (build_string ("Cannot open load file"),
13036
cd0e7903d0a9 (Fload): Rename arg STR to FILE.
Richard M. Stallman <rms@gnu.org>
parents: 12780
diff changeset
470 Fcons (file, Qnil)));
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
471 else
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
472 return Qnil;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
473 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
474
16937
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
475 /* If FD is 0, that means openp found a remote file. */
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
476 if (fd == 0)
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
477 {
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
478 handler = Ffind_file_name_handler (found, Qload);
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
479 return call5 (handler, Qload, found, noerror, nomessage, Qt);
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
480 }
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
481
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
482 if (!bcmp (&(XSTRING (found)->data[XSTRING (found)->size - 4]),
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
483 ".elc", 4))
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
484 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
485 struct stat s1, s2;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
486 int result;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
487
16012
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
488 compiled = 1;
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
489
9790
637b4664f7a5 Change explicit uses of the Unix directory separator
Richard M. Stallman <rms@gnu.org>
parents: 9552
diff changeset
490 #ifdef DOS_NT
5496
24f0d2908e61 [MSDOS]: Use text mode for all files but ".elc" files.
Richard M. Stallman <rms@gnu.org>
parents: 5243
diff changeset
491 dosmode = "rb";
9790
637b4664f7a5 Change explicit uses of the Unix directory separator
Richard M. Stallman <rms@gnu.org>
parents: 9552
diff changeset
492 #endif /* DOS_NT */
6072
8af8f6b469e1 (Fload): Cast the args to stat.
Richard M. Stallman <rms@gnu.org>
parents: 5888
diff changeset
493 stat ((char *)XSTRING (found)->data, &s1);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
494 XSTRING (found)->data[XSTRING (found)->size - 1] = 0;
6072
8af8f6b469e1 (Fload): Cast the args to stat.
Richard M. Stallman <rms@gnu.org>
parents: 5888
diff changeset
495 result = stat ((char *)XSTRING (found)->data, &s2);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
496 if (result >= 0 && (unsigned) s1.st_mtime < (unsigned) s2.st_mtime)
1758
12c730b89ac8 (Fload): If warn that .elc file is older,
Richard M. Stallman <rms@gnu.org>
parents: 1591
diff changeset
497 {
16012
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
498 /* Make the progress messages mention that source is newer. */
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
499 newer = 1;
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
500
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
501 /* If we won't print another message, mention this anyway. */
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
502 if (! NILP (nomessage))
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
503 message ("Source file `%s' newer than byte-compiled file",
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
504 XSTRING (found)->data);
1758
12c730b89ac8 (Fload): If warn that .elc file is older,
Richard M. Stallman <rms@gnu.org>
parents: 1591
diff changeset
505 }
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
506 XSTRING (found)->data[XSTRING (found)->size - 1] = 'c';
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
507 }
17038
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
508 else
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
509 {
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
510 /* We are loading a source file (*.el). */
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
511 if (!NILP (Vload_source_file_function))
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
512 {
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
513 close (fd);
17125
4a6c43010388 (Fload): Call Vload_source_file_function with 4 args.
Erik Naggum <erik@naggum.no>
parents: 17038
diff changeset
514 return call4 (Vload_source_file_function, found, file,
17038
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
515 NILP (noerror) ? Qnil : Qt,
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
516 NILP (nomessage) ? Qnil : Qt);
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
517 }
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
518 }
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
519
9790
637b4664f7a5 Change explicit uses of the Unix directory separator
Richard M. Stallman <rms@gnu.org>
parents: 9552
diff changeset
520 #ifdef DOS_NT
5496
24f0d2908e61 [MSDOS]: Use text mode for all files but ".elc" files.
Richard M. Stallman <rms@gnu.org>
parents: 5243
diff changeset
521 close (fd);
24f0d2908e61 [MSDOS]: Use text mode for all files but ".elc" files.
Richard M. Stallman <rms@gnu.org>
parents: 5243
diff changeset
522 stream = fopen ((char *) XSTRING (found)->data, dosmode);
9790
637b4664f7a5 Change explicit uses of the Unix directory separator
Richard M. Stallman <rms@gnu.org>
parents: 9552
diff changeset
523 #else /* not DOS_NT */
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
524 stream = fdopen (fd, "r");
9790
637b4664f7a5 Change explicit uses of the Unix directory separator
Richard M. Stallman <rms@gnu.org>
parents: 9552
diff changeset
525 #endif /* not DOS_NT */
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
526 if (stream == 0)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
527 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
528 close (fd);
13036
cd0e7903d0a9 (Fload): Rename arg STR to FILE.
Richard M. Stallman <rms@gnu.org>
parents: 12780
diff changeset
529 error ("Failure to create stdio stream for %s", XSTRING (file)->data);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
530 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
531
18665
6d7b8b35d878 (Vpreloaded_file_list): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 18530
diff changeset
532 if (! NILP (Vpurify_flag))
6d7b8b35d878 (Vpreloaded_file_list): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 18530
diff changeset
533 Vpreloaded_file_list = Fcons (file, Vpreloaded_file_list);
6d7b8b35d878 (Vpreloaded_file_list): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 18530
diff changeset
534
16012
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
535 if (NILP (nomessage))
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
536 {
20168
13074c25ab06 Indicate in messages if source code is being loaded.
Simon Marshall <simon@gnu.org>
parents: 20048
diff changeset
537 if (!compiled)
13074c25ab06 Indicate in messages if source code is being loaded.
Simon Marshall <simon@gnu.org>
parents: 20048
diff changeset
538 message ("Loading %s (source)...", XSTRING (file)->data);
13074c25ab06 Indicate in messages if source code is being loaded.
Simon Marshall <simon@gnu.org>
parents: 20048
diff changeset
539 else if (newer)
16165
a95e975275d8 (Fload): Move ... to ends of messages.
Richard M. Stallman <rms@gnu.org>
parents: 16141
diff changeset
540 message ("Loading %s (compiled; note, source file is newer)...",
16012
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
541 XSTRING (file)->data);
20168
13074c25ab06 Indicate in messages if source code is being loaded.
Simon Marshall <simon@gnu.org>
parents: 20048
diff changeset
542 else /* The typical case; compiled file newer than source file. */
16012
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
543 message ("Loading %s...", XSTRING (file)->data);
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
544 }
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
545
13036
cd0e7903d0a9 (Fload): Rename arg STR to FILE.
Richard M. Stallman <rms@gnu.org>
parents: 12780
diff changeset
546 GCPRO1 (file);
9361
c11cc966dc6a (Fload, load_unwind): Store stream pointer as a cons of two integers,
Karl Heuer <kwzh@gnu.org>
parents: 9358
diff changeset
547 lispstream = Fcons (Qnil, Qnil);
c11cc966dc6a (Fload, load_unwind): Store stream pointer as a cons of two integers,
Karl Heuer <kwzh@gnu.org>
parents: 9358
diff changeset
548 XSETFASTINT (XCONS (lispstream)->car, (EMACS_UINT)stream >> 16);
c11cc966dc6a (Fload, load_unwind): Store stream pointer as a cons of two integers,
Karl Heuer <kwzh@gnu.org>
parents: 9358
diff changeset
549 XSETFASTINT (XCONS (lispstream)->cdr, (EMACS_UINT)stream & 0xffff);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
550 record_unwind_protect (load_unwind, lispstream);
5568
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
551 record_unwind_protect (load_descriptor_unwind, load_descriptor_list);
10200
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
552 specbind (Qload_file_name, found);
16937
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
553 specbind (Qinhibit_file_name_operation, Qnil);
5568
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
554 load_descriptor_list
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
555 = Fcons (make_number (fileno (stream)), load_descriptor_list);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
556 load_in_progress++;
13036
cd0e7903d0a9 (Fload): Rename arg STR to FILE.
Richard M. Stallman <rms@gnu.org>
parents: 12780
diff changeset
557 readevalloop (Qget_file_char, stream, file, Feval, 0);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
558 unbind_to (count, Qnil);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
559
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
560 /* Run any load-hooks for this file. */
13036
cd0e7903d0a9 (Fload): Rename arg STR to FILE.
Richard M. Stallman <rms@gnu.org>
parents: 12780
diff changeset
561 temp = Fassoc (file, Vafter_load_alist);
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
562 if (!NILP (temp))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
563 Fprogn (Fcdr (temp));
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
564 UNGCPRO;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
565
12780
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
566 if (saved_doc_string)
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
567 free (saved_doc_string);
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
568 saved_doc_string = 0;
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
569 saved_doc_string_size = 0;
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
570
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
571 if (!noninteractive && NILP (nomessage))
16012
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
572 {
20168
13074c25ab06 Indicate in messages if source code is being loaded.
Simon Marshall <simon@gnu.org>
parents: 20048
diff changeset
573 if (!compiled)
13074c25ab06 Indicate in messages if source code is being loaded.
Simon Marshall <simon@gnu.org>
parents: 20048
diff changeset
574 message ("Loading %s (source)...done", XSTRING (file)->data);
13074c25ab06 Indicate in messages if source code is being loaded.
Simon Marshall <simon@gnu.org>
parents: 20048
diff changeset
575 else if (newer)
16165
a95e975275d8 (Fload): Move ... to ends of messages.
Richard M. Stallman <rms@gnu.org>
parents: 16141
diff changeset
576 message ("Loading %s (compiled; note, source file is newer)...done",
16012
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
577 XSTRING (file)->data);
20168
13074c25ab06 Indicate in messages if source code is being loaded.
Simon Marshall <simon@gnu.org>
parents: 20048
diff changeset
578 else /* The typical case; compiled file newer than source file. */
16012
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
579 message ("Loading %s...done", XSTRING (file)->data);
3b5ffd35defe (Fload): Add "source is newer" info to the "loading" and "done" messages.
Richard M. Stallman <rms@gnu.org>
parents: 15283
diff changeset
580 }
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
581 return Qt;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
582 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
583
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
584 static Lisp_Object
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
585 load_unwind (stream) /* used as unwind-protect function in load */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
586 Lisp_Object stream;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
587 {
9552
c1d477aec340 (load_unwind): Cast argument of fclose.
Richard M. Stallman <rms@gnu.org>
parents: 9466
diff changeset
588 fclose ((FILE *) (XFASTINT (XCONS (stream)->car) << 16
c1d477aec340 (load_unwind): Cast argument of fclose.
Richard M. Stallman <rms@gnu.org>
parents: 9466
diff changeset
589 | XFASTINT (XCONS (stream)->cdr)));
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
590 if (--load_in_progress < 0) load_in_progress = 0;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
591 return Qnil;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
592 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
593
5568
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
594 static Lisp_Object
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
595 load_descriptor_unwind (oldlist)
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
596 Lisp_Object oldlist;
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
597 {
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
598 load_descriptor_list = oldlist;
9361
c11cc966dc6a (Fload, load_unwind): Store stream pointer as a cons of two integers,
Karl Heuer <kwzh@gnu.org>
parents: 9358
diff changeset
599 return Qnil;
5568
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
600 }
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
601
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
602 /* Close all descriptors in use for Floads.
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
603 This is used when starting a subprocess. */
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
604
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
605 void
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
606 close_load_descs ()
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
607 {
15091
e05dd165b889 (close_load_descs) [WINDOWS_NT]: Don't actually do anything.
Richard M. Stallman <rms@gnu.org>
parents: 14972
diff changeset
608 #ifndef WINDOWSNT
5568
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
609 Lisp_Object tail;
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
610 for (tail = load_descriptor_list; !NILP (tail); tail = XCONS (tail)->cdr)
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
611 close (XFASTINT (XCONS (tail)->car));
15091
e05dd165b889 (close_load_descs) [WINDOWS_NT]: Don't actually do anything.
Richard M. Stallman <rms@gnu.org>
parents: 14972
diff changeset
612 #endif
5568
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
613 }
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
614
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
615 static int
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
616 complete_filename_p (pathname)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
617 Lisp_Object pathname;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
618 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
619 register unsigned char *s = XSTRING (pathname)->data;
9790
637b4664f7a5 Change explicit uses of the Unix directory separator
Richard M. Stallman <rms@gnu.org>
parents: 9552
diff changeset
620 return (IS_DIRECTORY_SEP (s[0])
637b4664f7a5 Change explicit uses of the Unix directory separator
Richard M. Stallman <rms@gnu.org>
parents: 9552
diff changeset
621 || (XSTRING (pathname)->size > 2
637b4664f7a5 Change explicit uses of the Unix directory separator
Richard M. Stallman <rms@gnu.org>
parents: 9552
diff changeset
622 && IS_DEVICE_SEP (s[1]) && IS_DIRECTORY_SEP (s[2]))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
623 #ifdef ALTOS
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
624 || *s == '@'
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
625 #endif
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
626 #ifdef VMS
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
627 || index (s, ':')
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
628 #endif /* VMS */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
629 );
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
630 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
631
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
632 /* Search for a file whose name is STR, looking in directories
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
633 in the Lisp list PATH, and trying suffixes from SUFFIX.
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
634 SUFFIX is a string containing possible suffixes separated by colons.
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
635 On success, returns a file descriptor. On failure, returns -1.
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
636
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
637 EXEC_ONLY nonzero means don't open the files,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
638 just look for one that is executable. In this case,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
639 returns 1 on success.
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
640
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
641 If STOREPTR is nonzero, it points to a slot where the name of
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
642 the file actually found should be stored as a Lisp string.
16937
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
643 nil is stored there on failure.
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
644
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
645 If the file we find is remote, return 0
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
646 but store the found remote file name in *STOREPTR.
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
647 We do not check for remote files if EXEC_ONLY is nonzero. */
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
648
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
649 int
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
650 openp (path, str, suffix, storeptr, exec_only)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
651 Lisp_Object path, str;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
652 char *suffix;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
653 Lisp_Object *storeptr;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
654 int exec_only;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
655 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
656 register int fd;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
657 int fn_size = 100;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
658 char buf[100];
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
659 register char *fn = buf;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
660 int absolute = 0;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
661 int want_size;
16937
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
662 Lisp_Object filename;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
663 struct stat st;
6392
58e075552627 (openp, Fload): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6072
diff changeset
664 struct gcpro gcpro1;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
665
6392
58e075552627 (openp, Fload): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6072
diff changeset
666 GCPRO1 (str);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
667 if (storeptr)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
668 *storeptr = Qnil;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
669
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
670 if (complete_filename_p (str))
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
671 absolute = 1;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
672
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
673 for (; !NILP (path); path = Fcdr (path))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
674 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
675 char *nsuffix;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
676
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
677 filename = Fexpand_file_name (str, Fcar (path));
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
678 if (!complete_filename_p (filename))
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
679 /* If there are non-absolute elts in PATH (eg ".") */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
680 /* Of course, this could conceivably lose if luser sets
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
681 default-directory to be something non-absolute... */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
682 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
683 filename = Fexpand_file_name (filename, current_buffer->directory);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
684 if (!complete_filename_p (filename))
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
685 /* Give up on this path element! */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
686 continue;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
687 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
688
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
689 /* Calculate maximum size of any filename made from
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
690 this path element/specified file name and any possible suffix. */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
691 want_size = strlen (suffix) + XSTRING (filename)->size + 1;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
692 if (fn_size < want_size)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
693 fn = (char *) alloca (fn_size = 100 + want_size);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
694
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
695 nsuffix = suffix;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
696
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
697 /* Loop over suffixes. */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
698 while (1)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
699 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
700 char *esuffix = (char *) index (nsuffix, ':');
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
701 int lsuffix = esuffix ? esuffix - nsuffix : strlen (nsuffix);
16937
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
702 Lisp_Object handler;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
703
16383
497b37552adb (openp): Omit /: from start of file name.
Richard M. Stallman <rms@gnu.org>
parents: 16342
diff changeset
704 /* Concatenate path element/specified name with the suffix.
497b37552adb (openp): Omit /: from start of file name.
Richard M. Stallman <rms@gnu.org>
parents: 16342
diff changeset
705 If the directory starts with /:, remove that. */
497b37552adb (openp): Omit /: from start of file name.
Richard M. Stallman <rms@gnu.org>
parents: 16342
diff changeset
706 if (XSTRING (filename)->size > 2
497b37552adb (openp): Omit /: from start of file name.
Richard M. Stallman <rms@gnu.org>
parents: 16342
diff changeset
707 && XSTRING (filename)->data[0] == '/'
497b37552adb (openp): Omit /: from start of file name.
Richard M. Stallman <rms@gnu.org>
parents: 16342
diff changeset
708 && XSTRING (filename)->data[1] == ':')
497b37552adb (openp): Omit /: from start of file name.
Richard M. Stallman <rms@gnu.org>
parents: 16342
diff changeset
709 {
497b37552adb (openp): Omit /: from start of file name.
Richard M. Stallman <rms@gnu.org>
parents: 16342
diff changeset
710 strncpy (fn, XSTRING (filename)->data + 2,
497b37552adb (openp): Omit /: from start of file name.
Richard M. Stallman <rms@gnu.org>
parents: 16342
diff changeset
711 XSTRING (filename)->size - 2);
497b37552adb (openp): Omit /: from start of file name.
Richard M. Stallman <rms@gnu.org>
parents: 16342
diff changeset
712 fn[XSTRING (filename)->size - 2] = 0;
497b37552adb (openp): Omit /: from start of file name.
Richard M. Stallman <rms@gnu.org>
parents: 16342
diff changeset
713 }
497b37552adb (openp): Omit /: from start of file name.
Richard M. Stallman <rms@gnu.org>
parents: 16342
diff changeset
714 else
497b37552adb (openp): Omit /: from start of file name.
Richard M. Stallman <rms@gnu.org>
parents: 16342
diff changeset
715 {
497b37552adb (openp): Omit /: from start of file name.
Richard M. Stallman <rms@gnu.org>
parents: 16342
diff changeset
716 strncpy (fn, XSTRING (filename)->data, XSTRING (filename)->size);
497b37552adb (openp): Omit /: from start of file name.
Richard M. Stallman <rms@gnu.org>
parents: 16342
diff changeset
717 fn[XSTRING (filename)->size] = 0;
497b37552adb (openp): Omit /: from start of file name.
Richard M. Stallman <rms@gnu.org>
parents: 16342
diff changeset
718 }
497b37552adb (openp): Omit /: from start of file name.
Richard M. Stallman <rms@gnu.org>
parents: 16342
diff changeset
719
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
720 if (lsuffix != 0) /* Bug happens on CCI if lsuffix is 0. */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
721 strncat (fn, nsuffix, lsuffix);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
722
16937
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
723 /* Check that the file exists and is not a directory. */
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
724 if (absolute)
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
725 handler = Qnil;
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
726 else
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
727 handler = Ffind_file_name_handler (filename, Qfile_exists_p);
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
728 if (! NILP (handler) && ! exec_only)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
729 {
16937
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
730 Lisp_Object string;
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
731 int exists;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
732
16937
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
733 string = build_string (fn);
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
734 exists = ! NILP (exec_only ? Ffile_executable_p (string)
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
735 : Ffile_readable_p (string));
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
736 if (exists
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
737 && ! NILP (Ffile_directory_p (build_string (fn))))
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
738 exists = 0;
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
739
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
740 if (exists)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
741 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
742 /* We succeeded; return this descriptor and filename. */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
743 if (storeptr)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
744 *storeptr = build_string (fn);
8906
93f3d6f5753c (openp): Fix Lisp_Object vs. int problems.
Karl Heuer <kwzh@gnu.org>
parents: 8828
diff changeset
745 UNGCPRO;
16937
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
746 return 0;
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
747 }
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
748 }
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
749 else
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
750 {
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
751 int exists = (stat (fn, &st) >= 0
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
752 && (st.st_mode & S_IFMT) != S_IFDIR);
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
753 if (exists)
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
754 {
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
755 /* Check that we can access or open it. */
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
756 if (exec_only)
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
757 fd = (access (fn, X_OK) == 0) ? 1 : -1;
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
758 else
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
759 fd = open (fn, O_RDONLY, 0);
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
760
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
761 if (fd >= 0)
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
762 {
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
763 /* We succeeded; return this descriptor and filename. */
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
764 if (storeptr)
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
765 *storeptr = build_string (fn);
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
766 UNGCPRO;
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
767 return fd;
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
768 }
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
769 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
770 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
771
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
772 /* Advance to next suffix. */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
773 if (esuffix == 0)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
774 break;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
775 nsuffix += lsuffix + 1;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
776 }
6392
58e075552627 (openp, Fload): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6072
diff changeset
777 if (absolute)
8906
93f3d6f5753c (openp): Fix Lisp_Object vs. int problems.
Karl Heuer <kwzh@gnu.org>
parents: 8828
diff changeset
778 break;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
779 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
780
8906
93f3d6f5753c (openp): Fix Lisp_Object vs. int problems.
Karl Heuer <kwzh@gnu.org>
parents: 8828
diff changeset
781 UNGCPRO;
93f3d6f5753c (openp): Fix Lisp_Object vs. int problems.
Karl Heuer <kwzh@gnu.org>
parents: 8828
diff changeset
782 return -1;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
783 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
784
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
785
2545
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
786 /* Merge the list we've accumulated of globals from the current input source
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
787 into the load_history variable. The details depend on whether
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
788 the source has an associated file name or not. */
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
789
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
790 static void
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
791 build_load_history (stream, source)
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
792 FILE *stream;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
793 Lisp_Object source;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
794 {
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
795 register Lisp_Object tail, prev, newelt;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
796 register Lisp_Object tem, tem2;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
797 register int foundit, loading;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
798
2901
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
799 /* Don't bother recording anything for preloaded files. */
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
800 if (!NILP (Vpurify_flag))
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
801 return;
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
802
2545
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
803 loading = stream || !NARROWED;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
804
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
805 tail = Vload_history;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
806 prev = Qnil;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
807 foundit = 0;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
808 while (!NILP (tail))
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
809 {
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
810 tem = Fcar (tail);
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
811
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
812 /* Find the feature's previous assoc list... */
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
813 if (!NILP (Fequal (source, Fcar (tem))))
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
814 {
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
815 foundit = 1;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
816
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
817 /* If we're loading, remove it. */
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
818 if (loading)
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
819 {
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
820 if (NILP (prev))
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
821 Vload_history = Fcdr (tail);
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
822 else
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
823 Fsetcdr (prev, Fcdr (tail));
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
824 }
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
825
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
826 /* Otherwise, cons on new symbols that are not already members. */
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
827 else
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
828 {
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
829 tem2 = Vcurrent_load_list;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
830
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
831 while (CONSP (tem2))
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
832 {
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
833 newelt = Fcar (tem2);
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
834
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
835 if (NILP (Fmemq (newelt, tem)))
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
836 Fsetcar (tail, Fcons (Fcar (tem),
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
837 Fcons (newelt, Fcdr (tem))));
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
838
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
839 tem2 = Fcdr (tem2);
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
840 QUIT;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
841 }
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
842 }
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
843 }
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
844 else
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
845 prev = tail;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
846 tail = Fcdr (tail);
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
847 QUIT;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
848 }
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
849
2901
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
850 /* If we're loading, cons the new assoc onto the front of load-history,
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
851 the most-recently-loaded position. Also do this if we didn't find
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
852 an existing member for the current source. */
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
853 if (loading || !foundit)
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
854 Vload_history = Fcons (Fnreverse (Vcurrent_load_list),
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
855 Vload_history);
2545
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
856 }
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
857
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
858 Lisp_Object
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
859 unreadpure () /* Used as unwind-protect function in readevalloop */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
860 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
861 read_pure = 0;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
862 return Qnil;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
863 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
864
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
865 static void
2545
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
866 readevalloop (readcharfun, stream, sourcename, evalfun, printflag)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
867 Lisp_Object readcharfun;
2545
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
868 FILE *stream;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
869 Lisp_Object sourcename;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
870 Lisp_Object (*evalfun) ();
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
871 int printflag;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
872 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
873 register int c;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
874 register Lisp_Object val;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
875 int count = specpdl_ptr - specpdl;
2901
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
876 struct gcpro gcpro1;
5185
52629d087993 (readevalloop): Get error if buffer being eval'd is killed.
Richard M. Stallman <rms@gnu.org>
parents: 5117
diff changeset
877 struct buffer *b = 0;
52629d087993 (readevalloop): Get error if buffer being eval'd is killed.
Richard M. Stallman <rms@gnu.org>
parents: 5117
diff changeset
878
52629d087993 (readevalloop): Get error if buffer being eval'd is killed.
Richard M. Stallman <rms@gnu.org>
parents: 5117
diff changeset
879 if (BUFFERP (readcharfun))
52629d087993 (readevalloop): Get error if buffer being eval'd is killed.
Richard M. Stallman <rms@gnu.org>
parents: 5117
diff changeset
880 b = XBUFFER (readcharfun);
52629d087993 (readevalloop): Get error if buffer being eval'd is killed.
Richard M. Stallman <rms@gnu.org>
parents: 5117
diff changeset
881 else if (MARKERP (readcharfun))
52629d087993 (readevalloop): Get error if buffer being eval'd is killed.
Richard M. Stallman <rms@gnu.org>
parents: 5117
diff changeset
882 b = XMARKER (readcharfun)->buffer;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
883
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
884 specbind (Qstandard_input, readcharfun);
2901
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
885 specbind (Qcurrent_load_list, Qnil);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
886
2901
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
887 GCPRO1 (sourcename);
2545
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
888
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
889 LOADHIST_ATTACH (sourcename);
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
890
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
891 while (1)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
892 {
5185
52629d087993 (readevalloop): Get error if buffer being eval'd is killed.
Richard M. Stallman <rms@gnu.org>
parents: 5117
diff changeset
893 if (b != 0 && NILP (b->name))
52629d087993 (readevalloop): Get error if buffer being eval'd is killed.
Richard M. Stallman <rms@gnu.org>
parents: 5117
diff changeset
894 error ("Reading from killed buffer");
52629d087993 (readevalloop): Get error if buffer being eval'd is killed.
Richard M. Stallman <rms@gnu.org>
parents: 5117
diff changeset
895
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
896 instream = stream;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
897 c = READCHAR;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
898 if (c == ';')
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
899 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
900 while ((c = READCHAR) != '\n' && c != -1);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
901 continue;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
902 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
903 if (c < 0) break;
10163
70b04b218216 (readevalloop): Ignore ^M here.
Richard M. Stallman <rms@gnu.org>
parents: 10014
diff changeset
904
70b04b218216 (readevalloop): Ignore ^M here.
Richard M. Stallman <rms@gnu.org>
parents: 10014
diff changeset
905 /* Ignore whitespace here, so we can detect eof. */
70b04b218216 (readevalloop): Ignore ^M here.
Richard M. Stallman <rms@gnu.org>
parents: 10014
diff changeset
906 if (c == ' ' || c == '\t' || c == '\n' || c == '\f' || c == '\r')
70b04b218216 (readevalloop): Ignore ^M here.
Richard M. Stallman <rms@gnu.org>
parents: 10014
diff changeset
907 continue;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
908
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
909 if (!NILP (Vpurify_flag) && c == '(')
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
910 {
8182
94f524e0d5cd (readevalloop): Correctly unbind the unwind protect.
Richard M. Stallman <rms@gnu.org>
parents: 8083
diff changeset
911 int count1 = specpdl_ptr - specpdl;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
912 record_unwind_protect (unreadpure, Qnil);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
913 val = read_list (-1, readcharfun);
8182
94f524e0d5cd (readevalloop): Correctly unbind the unwind protect.
Richard M. Stallman <rms@gnu.org>
parents: 8083
diff changeset
914 unbind_to (count1, Qnil);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
915 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
916 else
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
917 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
918 UNREAD (c);
16141
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
919 read_objects = Qnil;
11079
aeaaa579d967 (Vload_read_function): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11020
diff changeset
920 if (NILP (Vload_read_function))
aeaaa579d967 (Vload_read_function): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11020
diff changeset
921 val = read0 (readcharfun);
aeaaa579d967 (Vload_read_function): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11020
diff changeset
922 else
aeaaa579d967 (Vload_read_function): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11020
diff changeset
923 val = call1 (Vload_read_function, readcharfun);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
924 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
925
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
926 val = (*evalfun) (val);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
927 if (printflag)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
928 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
929 Vvalues = Fcons (val, Vvalues);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
930 if (EQ (Vstandard_output, Qt))
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
931 Fprin1 (val, Qnil);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
932 else
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
933 Fprint (val, Qnil);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
934 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
935 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
936
2545
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
937 build_load_history (stream, sourcename);
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
938 UNGCPRO;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
939
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
940 unbind_to (count, Qnil);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
941 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
942
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
943 #ifndef standalone
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
944
19803
7573e51f9c41 (Feval_buffer): New arg FILENAME.
Richard M. Stallman <rms@gnu.org>
parents: 19626
diff changeset
945 DEFUN ("eval-buffer", Feval_buffer, Seval_buffer, 0, 3, "",
675
85fd29f25c75 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 673
diff changeset
946 "Execute the current buffer as Lisp code.\n\
85fd29f25c75 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 673
diff changeset
947 Programs can pass two arguments, BUFFER and PRINTFLAG.\n\
85fd29f25c75 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 673
diff changeset
948 BUFFER is the buffer to evaluate (nil means use current buffer).\n\
85fd29f25c75 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 673
diff changeset
949 PRINTFLAG controls printing of output:\n\
672
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
950 nil means discard it; anything else is stream for print.\n\
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
951 \n\
19803
7573e51f9c41 (Feval_buffer): New arg FILENAME.
Richard M. Stallman <rms@gnu.org>
parents: 19626
diff changeset
952 If the optional third argument FILENAME is non-nil,\n\
7573e51f9c41 (Feval_buffer): New arg FILENAME.
Richard M. Stallman <rms@gnu.org>
parents: 19626
diff changeset
953 it specifies the file name to use for `load-history'.\n\
7573e51f9c41 (Feval_buffer): New arg FILENAME.
Richard M. Stallman <rms@gnu.org>
parents: 19626
diff changeset
954 \n\
16978
71aff157cff2 (Feval_buffer): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 16937
diff changeset
955 This function preserves the position of point.")
19803
7573e51f9c41 (Feval_buffer): New arg FILENAME.
Richard M. Stallman <rms@gnu.org>
parents: 19626
diff changeset
956 (buffer, printflag, filename)
7573e51f9c41 (Feval_buffer): New arg FILENAME.
Richard M. Stallman <rms@gnu.org>
parents: 19626
diff changeset
957 Lisp_Object buffer, printflag, filename;
672
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
958 {
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
959 int count = specpdl_ptr - specpdl;
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
960 Lisp_Object tem, buf;
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
961
14092
279f5f3528a8 (Feval_buffer, Feval_region, Fintern, Fintern_soft): Harmonize arguments
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
962 if (NILP (buffer))
672
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
963 buf = Fcurrent_buffer ();
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
964 else
14092
279f5f3528a8 (Feval_buffer, Feval_region, Fintern, Fintern_soft): Harmonize arguments
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
965 buf = Fget_buffer (buffer);
673
6217fa6e2cab *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 672
diff changeset
966 if (NILP (buf))
19803
7573e51f9c41 (Feval_buffer): New arg FILENAME.
Richard M. Stallman <rms@gnu.org>
parents: 19626
diff changeset
967 error ("No such buffer");
672
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
968
673
6217fa6e2cab *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 672
diff changeset
969 if (NILP (printflag))
672
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
970 tem = Qsymbolp;
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
971 else
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
972 tem = printflag;
19803
7573e51f9c41 (Feval_buffer): New arg FILENAME.
Richard M. Stallman <rms@gnu.org>
parents: 19626
diff changeset
973
7573e51f9c41 (Feval_buffer): New arg FILENAME.
Richard M. Stallman <rms@gnu.org>
parents: 19626
diff changeset
974 if (NILP (filename))
7573e51f9c41 (Feval_buffer): New arg FILENAME.
Richard M. Stallman <rms@gnu.org>
parents: 19626
diff changeset
975 filename = XBUFFER (buf)->filename;
7573e51f9c41 (Feval_buffer): New arg FILENAME.
Richard M. Stallman <rms@gnu.org>
parents: 19626
diff changeset
976
672
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
977 specbind (Qstandard_output, tem);
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
978 record_unwind_protect (save_excursion_restore, save_excursion_save ());
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
979 BUF_SET_PT (XBUFFER (buf), BUF_BEGV (XBUFFER (buf)));
19803
7573e51f9c41 (Feval_buffer): New arg FILENAME.
Richard M. Stallman <rms@gnu.org>
parents: 19626
diff changeset
980 readevalloop (buf, 0, filename, Feval, !NILP (printflag));
1924
21bd3a2189d3 * keyboard.c (recursive_edit_1, command_loop_1): Pass the proper
Jim Blandy <jimb@redhat.com>
parents: 1887
diff changeset
981 unbind_to (count, Qnil);
672
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
982
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
983 return Qnil;
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
984 }
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
985
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
986 #if 0
20024
b0626d6a3f13 Make sure that make-docfile does not see the doc string
Karl Heuer <kwzh@gnu.org>
parents: 19803
diff changeset
987 XDEFUN ("eval-current-buffer", Feval_current_buffer, Seval_current_buffer, 0, 1, "",
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
988 "Execute the current buffer as Lisp code.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
989 Programs can pass argument PRINTFLAG which controls printing of output:\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
990 nil means discard it; anything else is stream for print.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
991 \n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
992 If there is no error, point does not move. If there is an error,\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
993 point remains at the end of the last character read from the buffer.")
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
994 (printflag)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
995 Lisp_Object printflag;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
996 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
997 int count = specpdl_ptr - specpdl;
2545
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
998 Lisp_Object tem, cbuf;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
999
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
1000 cbuf = Fcurrent_buffer ()
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1001
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
1002 if (NILP (printflag))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1003 tem = Qsymbolp;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1004 else
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1005 tem = printflag;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1006 specbind (Qstandard_output, tem);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1007 record_unwind_protect (save_excursion_restore, save_excursion_save ());
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1008 SET_PT (BEGV);
2545
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
1009 readevalloop (cbuf, 0, XBUFFER (cbuf)->filename, Feval, !NILP (printflag));
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1010 return unbind_to (count, Qnil);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1011 }
672
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
1012 #endif
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1013
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1014 DEFUN ("eval-region", Feval_region, Seval_region, 2, 3, "r",
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1015 "Execute the region as Lisp code.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1016 When called from programs, expects two arguments,\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1017 giving starting and ending indices in the current buffer\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1018 of the text to be executed.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1019 Programs can pass third argument PRINTFLAG which controls output:\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1020 nil means discard it; anything else is stream for printing it.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1021 \n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1022 If there is no error, point does not move. If there is an error,\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1023 point remains at the end of the last character read from the buffer.")
14092
279f5f3528a8 (Feval_buffer, Feval_region, Fintern, Fintern_soft): Harmonize arguments
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
1024 (start, end, printflag)
279f5f3528a8 (Feval_buffer, Feval_region, Fintern, Fintern_soft): Harmonize arguments
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
1025 Lisp_Object start, end, printflag;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1026 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1027 int count = specpdl_ptr - specpdl;
2545
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
1028 Lisp_Object tem, cbuf;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
1029
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
1030 cbuf = Fcurrent_buffer ();
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1031
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
1032 if (NILP (printflag))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1033 tem = Qsymbolp;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1034 else
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1035 tem = printflag;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1036 specbind (Qstandard_output, tem);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1037
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
1038 if (NILP (printflag))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1039 record_unwind_protect (save_excursion_restore, save_excursion_save ());
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1040 record_unwind_protect (save_restriction_restore, save_restriction_save ());
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1041
14092
279f5f3528a8 (Feval_buffer, Feval_region, Fintern, Fintern_soft): Harmonize arguments
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
1042 /* This both uses start and checks its type. */
279f5f3528a8 (Feval_buffer, Feval_region, Fintern, Fintern_soft): Harmonize arguments
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
1043 Fgoto_char (start);
279f5f3528a8 (Feval_buffer, Feval_region, Fintern, Fintern_soft): Harmonize arguments
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
1044 Fnarrow_to_region (make_number (BEGV), end);
2545
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
1045 readevalloop (cbuf, 0, XBUFFER (cbuf)->filename, Feval, !NILP (printflag));
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1046
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1047 return unbind_to (count, Qnil);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1048 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1049
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1050 #endif /* standalone */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1051
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1052 DEFUN ("read", Fread, Sread, 0, 1, 0,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1053 "Read one Lisp expression as text from STREAM, return as Lisp object.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1054 If STREAM is nil, use the value of `standard-input' (which see).\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1055 STREAM or the value of `standard-input' may be:\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1056 a buffer (read from point and advance it)\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1057 a marker (read from where it points and advance it)\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1058 a function (call it with no arguments for each character,\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1059 call it with a char as argument to push a char back)\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1060 a string (takes text from string, starting at the beginning)\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1061 t (read text line using minibuffer and use it).")
12545
ccc20d466150 (Fread): Rename arg READCHARFUN to STREAM.
Karl Heuer <kwzh@gnu.org>
parents: 11955
diff changeset
1062 (stream)
ccc20d466150 (Fread): Rename arg READCHARFUN to STREAM.
Karl Heuer <kwzh@gnu.org>
parents: 11955
diff changeset
1063 Lisp_Object stream;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1064 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1065 extern Lisp_Object Fread_minibuffer ();
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1066
12545
ccc20d466150 (Fread): Rename arg READCHARFUN to STREAM.
Karl Heuer <kwzh@gnu.org>
parents: 11955
diff changeset
1067 if (NILP (stream))
ccc20d466150 (Fread): Rename arg READCHARFUN to STREAM.
Karl Heuer <kwzh@gnu.org>
parents: 11955
diff changeset
1068 stream = Vstandard_input;
ccc20d466150 (Fread): Rename arg READCHARFUN to STREAM.
Karl Heuer <kwzh@gnu.org>
parents: 11955
diff changeset
1069 if (EQ (stream, Qt))
ccc20d466150 (Fread): Rename arg READCHARFUN to STREAM.
Karl Heuer <kwzh@gnu.org>
parents: 11955
diff changeset
1070 stream = Qread_char;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1071
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1072 new_backquote_flag = 0;
16141
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1073 read_objects = Qnil;
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1074
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1075 #ifndef standalone
12545
ccc20d466150 (Fread): Rename arg READCHARFUN to STREAM.
Karl Heuer <kwzh@gnu.org>
parents: 11955
diff changeset
1076 if (EQ (stream, Qread_char))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1077 return Fread_minibuffer (build_string ("Lisp expression: "), Qnil);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1078 #endif
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1079
12545
ccc20d466150 (Fread): Rename arg READCHARFUN to STREAM.
Karl Heuer <kwzh@gnu.org>
parents: 11955
diff changeset
1080 if (STRINGP (stream))
ccc20d466150 (Fread): Rename arg READCHARFUN to STREAM.
Karl Heuer <kwzh@gnu.org>
parents: 11955
diff changeset
1081 return Fcar (Fread_from_string (stream, Qnil, Qnil));
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1082
12545
ccc20d466150 (Fread): Rename arg READCHARFUN to STREAM.
Karl Heuer <kwzh@gnu.org>
parents: 11955
diff changeset
1083 return read0 (stream);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1084 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1085
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1086 DEFUN ("read-from-string", Fread_from_string, Sread_from_string, 1, 3, 0,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1087 "Read one Lisp expression which is represented as text by STRING.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1088 Returns a cons: (OBJECT-READ . FINAL-STRING-INDEX).\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1089 START and END optionally delimit a substring of STRING from which to read;\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1090 they default to 0 and (length STRING) respectively.")
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1091 (string, start, end)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1092 Lisp_Object string, start, end;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1093 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1094 int startval, endval;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1095 Lisp_Object tem;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1096
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1097 CHECK_STRING (string,0);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1098
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
1099 if (NILP (end))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1100 endval = XSTRING (string)->size;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1101 else
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1102 { CHECK_NUMBER (end,2);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1103 endval = XINT (end);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1104 if (endval < 0 || endval > XSTRING (string)->size)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1105 args_out_of_range (string, end);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1106 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1107
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
1108 if (NILP (start))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1109 startval = 0;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1110 else
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1111 { CHECK_NUMBER (start,1);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1112 startval = XINT (start);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1113 if (startval < 0 || startval > endval)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1114 args_out_of_range (string, start);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1115 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1116
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1117 read_from_string_index = startval;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1118 read_from_string_limit = endval;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1119
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1120 new_backquote_flag = 0;
16141
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1121 read_objects = Qnil;
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1122
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1123 tem = read0 (string);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1124 return Fcons (tem, make_number (read_from_string_index));
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1125 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1126
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1127 /* Use this for recursive reads, in contexts where internal tokens
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1128 are not allowed. */
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1129 static Lisp_Object
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1130 read0 (readcharfun)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1131 Lisp_Object readcharfun;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1132 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1133 register Lisp_Object val;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1134 char c;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1135
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1136 val = read1 (readcharfun, &c, 0);
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1137 if (c)
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1138 Fsignal (Qinvalid_read_syntax, Fcons (make_string (&c, 1), Qnil));
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1139
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1140 return val;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1141 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1142
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1143 static int read_buffer_size;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1144 static char *read_buffer;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1145
17038
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1146 /* Read multibyte form and return it as a character. C is a first
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1147 byte of multibyte form, and rest of them are read from
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1148 READCHARFUN. */
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1149 static int
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1150 read_multibyte (c, readcharfun)
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1151 register int c;
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1152 Lisp_Object readcharfun;
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1153 {
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1154 /* We need the actual character code of this multibyte
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1155 characters. */
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1156 unsigned char str[MAX_LENGTH_OF_MULTI_BYTE_FORM];
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1157 int len = 0;
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1158
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1159 str[len++] = c;
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1160 while ((c = READCHAR) >= 0xA0
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1161 && len < MAX_LENGTH_OF_MULTI_BYTE_FORM)
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1162 str[len++] = c;
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1163 UNREAD (c);
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1164 return STRING_CHAR (str, len);
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1165 }
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1166
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1167 static int
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1168 read_escape (readcharfun)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1169 Lisp_Object readcharfun;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1170 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1171 register int c = READCHAR;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1172 switch (c)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1173 {
15091
e05dd165b889 (close_load_descs) [WINDOWS_NT]: Don't actually do anything.
Richard M. Stallman <rms@gnu.org>
parents: 14972
diff changeset
1174 case -1:
e05dd165b889 (close_load_descs) [WINDOWS_NT]: Don't actually do anything.
Richard M. Stallman <rms@gnu.org>
parents: 14972
diff changeset
1175 error ("End of file");
e05dd165b889 (close_load_descs) [WINDOWS_NT]: Don't actually do anything.
Richard M. Stallman <rms@gnu.org>
parents: 14972
diff changeset
1176
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1177 case 'a':
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
1178 return '\007';
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1179 case 'b':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1180 return '\b';
2018
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1181 case 'd':
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1182 return 0177;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1183 case 'e':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1184 return 033;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1185 case 'f':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1186 return '\f';
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1187 case 'n':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1188 return '\n';
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1189 case 'r':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1190 return '\r';
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1191 case 't':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1192 return '\t';
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1193 case 'v':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1194 return '\v';
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1195 case '\n':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1196 return -1;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1197
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1198 case 'M':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1199 c = READCHAR;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1200 if (c != '-')
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1201 error ("Invalid escape character syntax");
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1202 c = READCHAR;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1203 if (c == '\\')
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1204 c = read_escape (readcharfun);
2044
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1205 return c | meta_modifier;
2018
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1206
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1207 case 'S':
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1208 c = READCHAR;
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1209 if (c != '-')
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1210 error ("Invalid escape character syntax");
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1211 c = READCHAR;
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1212 if (c == '\\')
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1213 c = read_escape (readcharfun);
2044
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1214 return c | shift_modifier;
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1215
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1216 case 'H':
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1217 c = READCHAR;
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1218 if (c != '-')
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1219 error ("Invalid escape character syntax");
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1220 c = READCHAR;
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1221 if (c == '\\')
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1222 c = read_escape (readcharfun);
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1223 return c | hyper_modifier;
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1224
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1225 case 'A':
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1226 c = READCHAR;
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1227 if (c != '-')
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1228 error ("Invalid escape character syntax");
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1229 c = READCHAR;
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1230 if (c == '\\')
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1231 c = read_escape (readcharfun);
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1232 return c | alt_modifier;
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1233
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1234 case 's':
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1235 c = READCHAR;
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1236 if (c != '-')
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1237 error ("Invalid escape character syntax");
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1238 c = READCHAR;
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1239 if (c == '\\')
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1240 c = read_escape (readcharfun);
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1241 return c | super_modifier;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1242
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1243 case 'C':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1244 c = READCHAR;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1245 if (c != '-')
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1246 error ("Invalid escape character syntax");
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1247 case '^':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1248 c = READCHAR;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1249 if (c == '\\')
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1250 c = read_escape (readcharfun);
2018
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1251 if ((c & 0177) == '?')
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1252 return 0177 | c;
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1253 /* ASCII control chars are made from letters (both cases),
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1254 as well as the non-letters within 0100...0137. */
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1255 else if ((c & 0137) >= 0101 && (c & 0137) <= 0132)
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1256 return (c & (037 | ~0177));
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1257 else if ((c & 0177) >= 0100 && (c & 0177) <= 0137)
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1258 return (c & (037 | ~0177));
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1259 else
2044
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
1260 return c | ctrl_modifier;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1261
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1262 case '0':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1263 case '1':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1264 case '2':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1265 case '3':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1266 case '4':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1267 case '5':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1268 case '6':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1269 case '7':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1270 /* An octal escape, as in ANSI C. */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1271 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1272 register int i = c - '0';
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1273 register int count = 0;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1274 while (++count < 3)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1275 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1276 if ((c = READCHAR) >= '0' && c <= '7')
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1277 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1278 i *= 8;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1279 i += c - '0';
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1280 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1281 else
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1282 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1283 UNREAD (c);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1284 break;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1285 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1286 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1287 return i;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1288 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1289
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1290 case 'x':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1291 /* A hex escape, as in ANSI C. */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1292 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1293 int i = 0;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1294 while (1)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1295 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1296 c = READCHAR;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1297 if (c >= '0' && c <= '9')
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1298 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1299 i *= 16;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1300 i += c - '0';
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1301 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1302 else if ((c >= 'a' && c <= 'f')
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1303 || (c >= 'A' && c <= 'F'))
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1304 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1305 i *= 16;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1306 if (c >= 'a' && c <= 'f')
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1307 i += c - 'a' + 10;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1308 else
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1309 i += c - 'A' + 10;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1310 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1311 else
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1312 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1313 UNREAD (c);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1314 break;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1315 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1316 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1317 return i;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1318 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1319
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1320 default:
17038
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1321 if (BASE_LEADING_CODE_P (c))
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1322 c = read_multibyte (c, readcharfun);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1323 return c;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1324 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1325 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1326
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1327 /* If the next token is ')' or ']' or '.', we store that character
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1328 in *PCH and the return value is not interesting. Else, we store
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1329 zero in *PCH and we read and return one lisp object.
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1330
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1331 FIRST_IN_LIST is nonzero if this is the first element of a list. */
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1332
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1333 static Lisp_Object
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1334 read1 (readcharfun, pch, first_in_list)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1335 register Lisp_Object readcharfun;
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1336 char *pch;
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1337 int first_in_list;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1338 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1339 register int c;
16141
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1340 int uninterned_symbol = 0;
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1341
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1342 *pch = 0;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1343
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1344 retry:
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1345
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1346 c = READCHAR;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1347 if (c < 0) return Fsignal (Qend_of_file, Qnil);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1348
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1349 switch (c)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1350 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1351 case '(':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1352 return read_list (0, readcharfun);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1353
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1354 case '[':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1355 return read_vector (readcharfun);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1356
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1357 case ')':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1358 case ']':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1359 {
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1360 *pch = c;
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1361 return Qnil;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1362 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1363
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1364 case '#':
373
7c6f74ef31a3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 364
diff changeset
1365 c = READCHAR;
13146
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1366 if (c == '^')
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1367 {
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1368 c = READCHAR;
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1369 if (c == '[')
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1370 {
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1371 Lisp_Object tmp;
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1372 tmp = read_vector (readcharfun);
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1373 if (XVECTOR (tmp)->size < CHAR_TABLE_STANDARD_SLOTS
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1374 || XVECTOR (tmp)->size > CHAR_TABLE_STANDARD_SLOTS + 10)
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1375 error ("Invalid size char-table");
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1376 XSETCHAR_TABLE (tmp, XCHAR_TABLE (tmp));
17325
c19c552c486f (read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents: 17125
diff changeset
1377 XCHAR_TABLE (tmp)->top = Qt;
13146
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1378 return tmp;
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1379 }
17325
c19c552c486f (read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents: 17125
diff changeset
1380 else if (c == '^')
c19c552c486f (read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents: 17125
diff changeset
1381 {
c19c552c486f (read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents: 17125
diff changeset
1382 c = READCHAR;
c19c552c486f (read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents: 17125
diff changeset
1383 if (c == '[')
c19c552c486f (read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents: 17125
diff changeset
1384 {
c19c552c486f (read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents: 17125
diff changeset
1385 Lisp_Object tmp;
c19c552c486f (read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents: 17125
diff changeset
1386 tmp = read_vector (readcharfun);
c19c552c486f (read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents: 17125
diff changeset
1387 if (XVECTOR (tmp)->size != SUB_CHAR_TABLE_STANDARD_SLOTS)
c19c552c486f (read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents: 17125
diff changeset
1388 error ("Invalid size char-table");
c19c552c486f (read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents: 17125
diff changeset
1389 XSETCHAR_TABLE (tmp, XCHAR_TABLE (tmp));
c19c552c486f (read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents: 17125
diff changeset
1390 XCHAR_TABLE (tmp)->top = Qnil;
c19c552c486f (read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents: 17125
diff changeset
1391 return tmp;
c19c552c486f (read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents: 17125
diff changeset
1392 }
c19c552c486f (read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents: 17125
diff changeset
1393 Fsignal (Qinvalid_read_syntax,
c19c552c486f (read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents: 17125
diff changeset
1394 Fcons (make_string ("#^^", 3), Qnil));
c19c552c486f (read1): Adjusted for the new structure of Lisp_Char_Table.
Kenichi Handa <handa@m17n.org>
parents: 17125
diff changeset
1395 }
13146
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1396 Fsignal (Qinvalid_read_syntax, Fcons (make_string ("#^", 2), Qnil));
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1397 }
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1398 if (c == '&')
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1399 {
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1400 Lisp_Object length;
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1401 length = read1 (readcharfun, pch, first_in_list);
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1402 c = READCHAR;
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1403 if (c == '"')
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1404 {
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1405 Lisp_Object tmp, val;
16925
2b35e4ccbb32 (read1): Round size of bool-vector properly.
Richard M. Stallman <rms@gnu.org>
parents: 16856
diff changeset
1406 int size_in_chars = ((XFASTINT (length) + BITS_PER_CHAR - 1)
13363
941c37982f37 (BITS_PER_SHORT, BITS_PER_INT, BITS_PER_LONG):
Karl Heuer <kwzh@gnu.org>
parents: 13235
diff changeset
1407 / BITS_PER_CHAR);
13146
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1408
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1409 UNREAD (c);
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1410 tmp = read1 (readcharfun, pch, first_in_list);
16925
2b35e4ccbb32 (read1): Round size of bool-vector properly.
Richard M. Stallman <rms@gnu.org>
parents: 16856
diff changeset
1411 if (size_in_chars != XSTRING (tmp)->size
2b35e4ccbb32 (read1): Round size of bool-vector properly.
Richard M. Stallman <rms@gnu.org>
parents: 16856
diff changeset
1412 /* We used to print 1 char too many
2b35e4ccbb32 (read1): Round size of bool-vector properly.
Richard M. Stallman <rms@gnu.org>
parents: 16856
diff changeset
1413 when the number of bits was a multiple of 8.
2b35e4ccbb32 (read1): Round size of bool-vector properly.
Richard M. Stallman <rms@gnu.org>
parents: 16856
diff changeset
1414 Accept such input in case it came from an old version. */
2b35e4ccbb32 (read1): Round size of bool-vector properly.
Richard M. Stallman <rms@gnu.org>
parents: 16856
diff changeset
1415 && ! (XFASTINT (length)
2b35e4ccbb32 (read1): Round size of bool-vector properly.
Richard M. Stallman <rms@gnu.org>
parents: 16856
diff changeset
1416 == (XSTRING (tmp)->size - 1) * BITS_PER_CHAR))
13146
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1417 Fsignal (Qinvalid_read_syntax,
16856
f838ff9a4d39 Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 16855
diff changeset
1418 Fcons (make_string ("#&...", 5), Qnil));
13146
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1419
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1420 val = Fmake_bool_vector (length, Qnil);
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1421 bcopy (XSTRING (tmp)->data, XBOOL_VECTOR (val)->data,
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1422 size_in_chars);
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1423 return val;
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1424 }
16856
f838ff9a4d39 Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 16855
diff changeset
1425 Fsignal (Qinvalid_read_syntax, Fcons (make_string ("#&...", 5),
16855
d10bb3a79eff (read1): Fix error messages.
Richard M. Stallman <rms@gnu.org>
parents: 16487
diff changeset
1426 Qnil));
13146
6182d95acd14 (read1): Handle chartables and boolvectors.
Richard M. Stallman <rms@gnu.org>
parents: 13036
diff changeset
1427 }
373
7c6f74ef31a3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 364
diff changeset
1428 if (c == '[')
7c6f74ef31a3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 364
diff changeset
1429 {
7c6f74ef31a3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 364
diff changeset
1430 /* Accept compiled functions at read-time so that we don't have to
7c6f74ef31a3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 364
diff changeset
1431 build them using function calls. */
1966
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1432 Lisp_Object tmp;
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1433 tmp = read_vector (readcharfun);
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1434 return Fmake_byte_code (XVECTOR (tmp)->size,
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1435 XVECTOR (tmp)->contents);
373
7c6f74ef31a3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 364
diff changeset
1436 }
1966
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1437 #ifdef USE_TEXT_PROPERTIES
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1438 if (c == '(')
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1439 {
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1440 Lisp_Object tmp;
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1441 struct gcpro gcpro1;
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1442 char ch;
1966
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1443
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1444 /* Read the string itself. */
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1445 tmp = read1 (readcharfun, &ch, 0);
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1446 if (ch != 0 || !STRINGP (tmp))
1966
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1447 Fsignal (Qinvalid_read_syntax, Fcons (make_string ("#", 1), Qnil));
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1448 GCPRO1 (tmp);
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1449 /* Read the intervals and their properties. */
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1450 while (1)
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1451 {
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1452 Lisp_Object beg, end, plist;
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1453
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1454 beg = read1 (readcharfun, &ch, 0);
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1455 if (ch == ')')
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1456 break;
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1457 if (ch == 0)
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1458 end = read1 (readcharfun, &ch, 0);
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1459 if (ch == 0)
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1460 plist = read1 (readcharfun, &ch, 0);
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1461 if (ch)
1966
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1462 Fsignal (Qinvalid_read_syntax,
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1463 Fcons (build_string ("invalid string property list"),
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1464 Qnil));
1966
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1465 Fset_text_properties (beg, end, plist, tmp);
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1466 }
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1467 UNGCPRO;
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1468 return tmp;
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1469 }
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1470 #endif
10200
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1471 /* #@NUMBER is used to skip NUMBER following characters.
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1472 That's used in .elc files to skip over doc strings
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1473 and function definitions. */
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1474 if (c == '@')
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1475 {
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1476 int i, nskip = 0;
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1477
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1478 /* Read a decimal integer. */
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1479 while ((c = READCHAR) >= 0
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1480 && c >= '0' && c <= '9')
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1481 {
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1482 nskip *= 10;
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1483 nskip += c - '0';
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1484 }
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1485 if (c >= 0)
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1486 UNREAD (c);
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1487
12780
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1488 #ifndef DOS_NT /* I don't know if filepos works right on MSDOS and Windoze. */
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1489 if (load_force_doc_strings && EQ (readcharfun, Qget_file_char))
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1490 {
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1491 /* If we are supposed to force doc strings into core right now,
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1492 record the last string that we skipped,
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1493 and record where in the file it comes from. */
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1494 if (saved_doc_string_size == 0)
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1495 {
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1496 saved_doc_string_size = nskip + 100;
14130
99ab26698ab0 (read1): Use xmalloc and xrealloc, not malloc and realloc.
Karl Heuer <kwzh@gnu.org>
parents: 14092
diff changeset
1497 saved_doc_string = (char *) xmalloc (saved_doc_string_size);
12780
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1498 }
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1499 if (nskip > saved_doc_string_size)
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1500 {
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1501 saved_doc_string_size = nskip + 100;
14130
99ab26698ab0 (read1): Use xmalloc and xrealloc, not malloc and realloc.
Karl Heuer <kwzh@gnu.org>
parents: 14092
diff changeset
1502 saved_doc_string = (char *) xrealloc (saved_doc_string,
99ab26698ab0 (read1): Use xmalloc and xrealloc, not malloc and realloc.
Karl Heuer <kwzh@gnu.org>
parents: 14092
diff changeset
1503 saved_doc_string_size);
12780
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1504 }
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1505
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1506 saved_doc_string_position = ftell (instream);
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1507
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1508 /* Copy that many characters into saved_doc_string. */
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1509 for (i = 0; i < nskip && c >= 0; i++)
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1510 saved_doc_string[i] = c = READCHAR;
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1511
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1512 saved_doc_string_length = i;
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1513 }
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1514 else
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1515 #endif /* not DOS_NT */
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1516 {
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1517 /* Skip that many characters. */
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1518 for (i = 0; i < nskip && c >= 0; i++)
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1519 c = READCHAR;
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1520 }
20048
5324d8b2322b (read_list): Don't recognize Vload_file_name
Karl Heuer <kwzh@gnu.org>
parents: 20024
diff changeset
1521
10200
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1522 goto retry;
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1523 }
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1524 if (c == '$')
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1525 return Vload_file_name;
13235
0f83b9eb5478 (read1): Handle #' as prefix.
Richard M. Stallman <rms@gnu.org>
parents: 13146
diff changeset
1526 if (c == '\'')
0f83b9eb5478 (read1): Handle #' as prefix.
Richard M. Stallman <rms@gnu.org>
parents: 13146
diff changeset
1527 return Fcons (Qfunction, Fcons (read0 (readcharfun), Qnil));
16141
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1528 /* #:foo is the uninterned symbol named foo. */
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1529 if (c == ':')
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1530 {
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1531 uninterned_symbol = 1;
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1532 c = READCHAR;
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1533 goto default_label;
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1534 }
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1535 /* Reader forms that can reuse previously read objects. */
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1536 if (c >= '0' && c <= '9')
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1537 {
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1538 int n = 0;
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1539 Lisp_Object tem;
13235
0f83b9eb5478 (read1): Handle #' as prefix.
Richard M. Stallman <rms@gnu.org>
parents: 13146
diff changeset
1540
16141
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1541 /* Read a non-negative integer. */
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1542 while (c >= '0' && c <= '9')
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1543 {
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1544 n *= 10;
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1545 n += c - '0';
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1546 c = READCHAR;
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1547 }
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1548 /* #n=object returns object, but associates it with n for #n#. */
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1549 if (c == '=')
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1550 {
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1551 tem = read0 (readcharfun);
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1552 read_objects = Fcons (Fcons (make_number (n), tem), read_objects);
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1553 return tem;
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1554 }
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1555 /* #n# returns a previously read object. */
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1556 if (c == '#')
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1557 {
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1558 tem = Fassq (make_number (n), read_objects);
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1559 if (CONSP (tem))
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1560 return XCDR (tem);
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1561 /* Fall through to error message. */
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1562 }
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1563 /* Fall through to error message. */
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1564 }
10200
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1565
373
7c6f74ef31a3 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 364
diff changeset
1566 UNREAD (c);
1966
bcc34323a475 (read1--strings with properties case):
Richard M. Stallman <rms@gnu.org>
parents: 1924
diff changeset
1567 Fsignal (Qinvalid_read_syntax, Fcons (make_string ("#", 1), Qnil));
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1568
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1569 case ';':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1570 while ((c = READCHAR) >= 0 && c != '\n');
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1571 goto retry;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1572
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1573 case '\'':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1574 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1575 return Fcons (Qquote, Fcons (read0 (readcharfun), Qnil));
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1576 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1577
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1578 case '`':
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1579 if (first_in_list)
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1580 goto default_label;
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1581 else
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1582 {
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1583 Lisp_Object value;
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1584
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1585 new_backquote_flag = 1;
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1586 value = read0 (readcharfun);
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1587 new_backquote_flag = 0;
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1588
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1589 return Fcons (Qbackquote, Fcons (value, Qnil));
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1590 }
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1591
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1592 case ',':
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1593 if (new_backquote_flag)
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1594 {
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1595 Lisp_Object comma_type = Qnil;
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1596 Lisp_Object value;
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1597 int ch = READCHAR;
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1598
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1599 if (ch == '@')
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1600 comma_type = Qcomma_at;
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1601 else if (ch == '.')
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1602 comma_type = Qcomma_dot;
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1603 else
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1604 {
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1605 if (ch >= 0) UNREAD (ch);
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1606 comma_type = Qcomma;
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1607 }
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1608
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1609 new_backquote_flag = 0;
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1610 value = read0 (readcharfun);
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1611 new_backquote_flag = 1;
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1612 return Fcons (comma_type, Fcons (value, Qnil));
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1613 }
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1614 else
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1615 goto default_label;
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1616
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1617 case '?':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1618 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1619 register Lisp_Object val;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1620
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1621 c = READCHAR;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1622 if (c < 0) return Fsignal (Qend_of_file, Qnil);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1623
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1624 if (c == '\\')
17038
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1625 c = read_escape (readcharfun);
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1626 else if (BASE_LEADING_CODE_P (c))
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1627 c = read_multibyte (c, readcharfun);
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
1628 XSETINT (val, c);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1629
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1630 return val;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1631 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1632
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1633 case '\"':
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1634 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1635 register char *p = read_buffer;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1636 register char *end = read_buffer + read_buffer_size;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1637 register int c;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1638 int cancel = 0;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1639
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1640 while ((c = READCHAR) >= 0
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1641 && c != '\"')
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1642 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1643 if (p == end)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1644 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1645 char *new = (char *) xrealloc (read_buffer, read_buffer_size *= 2);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1646 p += new - read_buffer;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1647 read_buffer += new - read_buffer;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1648 end = read_buffer + read_buffer_size;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1649 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1650 if (c == '\\')
19240
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1651 {
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1652 c = read_escape (readcharfun);
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1653 if (! SINGLE_BYTE_CHAR_P ((c & ~CHAR_META)))
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1654 {
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1655 char workbuf[4];
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1656 char *str = workbuf;
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1657 int length;
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1658
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1659 length = non_ascii_char_to_string (c, workbuf, &str);
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1660
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1661 if (p + length > end)
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1662 {
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1663 char *new = (char *) xrealloc (read_buffer, read_buffer_size *= 2);
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1664 p += new - read_buffer;
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1665 read_buffer += new - read_buffer;
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1666 end = read_buffer + read_buffer_size;
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1667 }
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1668
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1669 bcopy (str, p, length);
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1670 p += length;
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1671 continue;
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1672 }
c962562027d4 (read1): Handle read_escape making a multibyte character.
Richard M. Stallman <rms@gnu.org>
parents: 19115
diff changeset
1673 }
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1674 /* c is -1 if \ newline has just been seen */
2018
7c970ef8949d (read_escape): Handle M-, C- and S- for new convention.
Richard M. Stallman <rms@gnu.org>
parents: 1966
diff changeset
1675 if (c == -1)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1676 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1677 if (p == read_buffer)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1678 cancel = 1;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1679 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1680 else
6470
651b49e52c9e (read1): Check for invalid modifier bits in a string.
Karl Heuer <kwzh@gnu.org>
parents: 6392
diff changeset
1681 {
7144
cf47c0c11bda (read1): Allow `\C- ' and `\C-?'.
Richard M. Stallman <rms@gnu.org>
parents: 7106
diff changeset
1682 /* Allow `\C- ' and `\C-?'. */
cf47c0c11bda (read1): Allow `\C- ' and `\C-?'.
Richard M. Stallman <rms@gnu.org>
parents: 7106
diff changeset
1683 if (c == (CHAR_CTL | ' '))
cf47c0c11bda (read1): Allow `\C- ' and `\C-?'.
Richard M. Stallman <rms@gnu.org>
parents: 7106
diff changeset
1684 c = 0;
cf47c0c11bda (read1): Allow `\C- ' and `\C-?'.
Richard M. Stallman <rms@gnu.org>
parents: 7106
diff changeset
1685 else if (c == (CHAR_CTL | '?'))
cf47c0c11bda (read1): Allow `\C- ' and `\C-?'.
Richard M. Stallman <rms@gnu.org>
parents: 7106
diff changeset
1686 c = 127;
cf47c0c11bda (read1): Allow `\C- ' and `\C-?'.
Richard M. Stallman <rms@gnu.org>
parents: 7106
diff changeset
1687
6470
651b49e52c9e (read1): Check for invalid modifier bits in a string.
Karl Heuer <kwzh@gnu.org>
parents: 6392
diff changeset
1688 if (c & CHAR_META)
651b49e52c9e (read1): Check for invalid modifier bits in a string.
Karl Heuer <kwzh@gnu.org>
parents: 6392
diff changeset
1689 /* Move the meta bit to the right place for a string. */
651b49e52c9e (read1): Check for invalid modifier bits in a string.
Karl Heuer <kwzh@gnu.org>
parents: 6392
diff changeset
1690 c = (c & ~CHAR_META) | 0x80;
651b49e52c9e (read1): Check for invalid modifier bits in a string.
Karl Heuer <kwzh@gnu.org>
parents: 6392
diff changeset
1691 if (c & ~0xff)
651b49e52c9e (read1): Check for invalid modifier bits in a string.
Karl Heuer <kwzh@gnu.org>
parents: 6392
diff changeset
1692 error ("Invalid modifier in string");
651b49e52c9e (read1): Check for invalid modifier bits in a string.
Karl Heuer <kwzh@gnu.org>
parents: 6392
diff changeset
1693 *p++ = c;
651b49e52c9e (read1): Check for invalid modifier bits in a string.
Karl Heuer <kwzh@gnu.org>
parents: 6392
diff changeset
1694 }
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1695 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1696 if (c < 0) return Fsignal (Qend_of_file, Qnil);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1697
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1698 /* If purifying, and string starts with \ newline,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1699 return zero instead. This is for doc strings
604
63a8e7b3c547 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 485
diff changeset
1700 that we are really going to find in etc/DOC.nn.nn */
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
1701 if (!NILP (Vpurify_flag) && NILP (Vdoc_file_name) && cancel)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1702 return make_number (0);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1703
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1704 if (read_pure)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1705 return make_pure_string (read_buffer, p - read_buffer);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1706 else
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1707 return make_string (read_buffer, p - read_buffer);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1708 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1709
762
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1710 case '.':
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1711 {
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1712 #ifdef LISP_FLOAT_TYPE
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1713 /* If a period is followed by a number, then we should read it
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1714 as a floating point number. Otherwise, it denotes a dotted
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1715 pair. */
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1716 int next_char = READCHAR;
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1717 UNREAD (next_char);
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1718
9871
e91d69642eab Don't include ctype.h.
Richard M. Stallman <rms@gnu.org>
parents: 9790
diff changeset
1719 if (! (next_char >= '0' && next_char <= '9'))
762
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1720 #endif
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1721 {
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1722 *pch = c;
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1723 return Qnil;
762
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1724 }
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1725
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1726 /* Otherwise, we fall through! Note that the atom-reading loop
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1727 below will now loop at least once, assuring that we will not
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1728 try to UNREAD two characters in a row. */
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1729 }
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1730 default:
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1731 default_label:
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1732 if (c <= 040) goto retry;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1733 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1734 register char *p = read_buffer;
5017
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1735 int quoted = 0;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1736
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1737 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1738 register char *end = read_buffer + read_buffer_size;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1739
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1740 while (c > 040 &&
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1741 !(c == '\"' || c == '\'' || c == ';' || c == '?'
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1742 || c == '(' || c == ')'
762
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1743 #ifndef LISP_FLOAT_TYPE
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1744 /* If we have floating-point support, then we need
852a2f5838da *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 732
diff changeset
1745 to allow <digits><dot><digits>. */
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1746 || c =='.'
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1747 #endif /* not LISP_FLOAT_TYPE */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1748 || c == '[' || c == ']' || c == '#'
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1749 ))
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1750 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1751 if (p == end)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1752 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1753 register char *new = (char *) xrealloc (read_buffer, read_buffer_size *= 2);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1754 p += new - read_buffer;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1755 read_buffer += new - read_buffer;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1756 end = read_buffer + read_buffer_size;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1757 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1758 if (c == '\\')
5017
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1759 {
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1760 c = READCHAR;
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1761 quoted = 1;
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1762 }
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1763 *p++ = c;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1764 c = READCHAR;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1765 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1766
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1767 if (p == end)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1768 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1769 char *new = (char *) xrealloc (read_buffer, read_buffer_size *= 2);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1770 p += new - read_buffer;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1771 read_buffer += new - read_buffer;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1772 /* end = read_buffer + read_buffer_size; */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1773 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1774 *p = 0;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1775 if (c >= 0)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1776 UNREAD (c);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1777 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1778
16141
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1779 if (!quoted && !uninterned_symbol)
5017
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1780 {
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1781 register char *p1;
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1782 register Lisp_Object val;
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1783 p1 = read_buffer;
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1784 if (*p1 == '+' || *p1 == '-') p1++;
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1785 /* Is it an integer? */
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1786 if (p1 != p)
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1787 {
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1788 while (p1 != p && (c = *p1) >= '0' && c <= '9') p1++;
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1758
diff changeset
1789 #ifdef LISP_FLOAT_TYPE
5017
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1790 /* Integers can have trailing decimal points. */
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1791 if (p1 > read_buffer && p1 < p && *p1 == '.') p1++;
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1758
diff changeset
1792 #endif
5017
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1793 if (p1 == p)
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1794 /* It is an integer. */
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1795 {
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1758
diff changeset
1796 #ifdef LISP_FLOAT_TYPE
5017
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1797 if (p1[-1] == '.')
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1798 p1[-1] = '\0';
1821
04fb1d3d6992 JimB's changes since January 18th
Jim Blandy <jimb@redhat.com>
parents: 1758
diff changeset
1799 #endif
11699
eb4b842ee557 (read1): Handle long EMACS_INT in atol.
Richard M. Stallman <rms@gnu.org>
parents: 11683
diff changeset
1800 if (sizeof (int) == sizeof (EMACS_INT))
eb4b842ee557 (read1): Handle long EMACS_INT in atol.
Richard M. Stallman <rms@gnu.org>
parents: 11683
diff changeset
1801 XSETINT (val, atoi (read_buffer));
eb4b842ee557 (read1): Handle long EMACS_INT in atol.
Richard M. Stallman <rms@gnu.org>
parents: 11683
diff changeset
1802 else if (sizeof (long) == sizeof (EMACS_INT))
eb4b842ee557 (read1): Handle long EMACS_INT in atol.
Richard M. Stallman <rms@gnu.org>
parents: 11683
diff changeset
1803 XSETINT (val, atol (read_buffer));
eb4b842ee557 (read1): Handle long EMACS_INT in atol.
Richard M. Stallman <rms@gnu.org>
parents: 11683
diff changeset
1804 else
eb4b842ee557 (read1): Handle long EMACS_INT in atol.
Richard M. Stallman <rms@gnu.org>
parents: 11683
diff changeset
1805 abort ();
5017
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1806 return val;
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1807 }
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1808 }
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1809 #ifdef LISP_FLOAT_TYPE
5017
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1810 if (isfloat_string (read_buffer))
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1811 return make_float (atof (read_buffer));
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1812 #endif
5017
9c277d938ccd (read1): If token has a \, don't treat it as a number.
Richard M. Stallman <rms@gnu.org>
parents: 4701
diff changeset
1813 }
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1814
16141
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1815 if (uninterned_symbol)
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1816 return make_symbol (read_buffer);
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1817 else
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
1818 return intern (read_buffer);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1819 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1820 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1821 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1822
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1823 #ifdef LISP_FLOAT_TYPE
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1824
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1825 #define LEAD_INT 1
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1826 #define DOT_CHAR 2
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1827 #define TRAIL_INT 4
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1828 #define E_CHAR 8
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1829 #define EXP_INT 16
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1830
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1831 int
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1832 isfloat_string (cp)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1833 register char *cp;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1834 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1835 register state;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1836
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1837 state = 0;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1838 if (*cp == '+' || *cp == '-')
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1839 cp++;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1840
9871
e91d69642eab Don't include ctype.h.
Richard M. Stallman <rms@gnu.org>
parents: 9790
diff changeset
1841 if (*cp >= '0' && *cp <= '9')
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1842 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1843 state |= LEAD_INT;
9871
e91d69642eab Don't include ctype.h.
Richard M. Stallman <rms@gnu.org>
parents: 9790
diff changeset
1844 while (*cp >= '0' && *cp <= '9')
e91d69642eab Don't include ctype.h.
Richard M. Stallman <rms@gnu.org>
parents: 9790
diff changeset
1845 cp++;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1846 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1847 if (*cp == '.')
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1848 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1849 state |= DOT_CHAR;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1850 cp++;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1851 }
9871
e91d69642eab Don't include ctype.h.
Richard M. Stallman <rms@gnu.org>
parents: 9790
diff changeset
1852 if (*cp >= '0' && *cp <= '9')
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1853 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1854 state |= TRAIL_INT;
9871
e91d69642eab Don't include ctype.h.
Richard M. Stallman <rms@gnu.org>
parents: 9790
diff changeset
1855 while (*cp >= '0' && *cp <= '9')
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1856 cp++;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1857 }
16342
b91af71f45f1 (isfloat_string): Accept E like e.
Richard M. Stallman <rms@gnu.org>
parents: 16228
diff changeset
1858 if (*cp == 'e' || *cp == 'E')
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1859 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1860 state |= E_CHAR;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1861 cp++;
11735
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
1862 if (*cp == '+' || *cp == '-')
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
1863 cp++;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1864 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1865
9871
e91d69642eab Don't include ctype.h.
Richard M. Stallman <rms@gnu.org>
parents: 9790
diff changeset
1866 if (*cp >= '0' && *cp <= '9')
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1867 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1868 state |= EXP_INT;
9871
e91d69642eab Don't include ctype.h.
Richard M. Stallman <rms@gnu.org>
parents: 9790
diff changeset
1869 while (*cp >= '0' && *cp <= '9')
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1870 cp++;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1871 }
11172
e1ca77e22c12 (isfloat_string): Permit trailing space.
Richard M. Stallman <rms@gnu.org>
parents: 11079
diff changeset
1872 return (((*cp == 0) || (*cp == ' ') || (*cp == '\t') || (*cp == '\n') || (*cp == '\r') || (*cp == '\f'))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1873 && (state == (LEAD_INT|DOT_CHAR|TRAIL_INT)
826
e9b9a1cff2c9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 796
diff changeset
1874 || state == (DOT_CHAR|TRAIL_INT)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1875 || state == (LEAD_INT|E_CHAR|EXP_INT)
826
e9b9a1cff2c9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 796
diff changeset
1876 || state == (LEAD_INT|DOT_CHAR|TRAIL_INT|E_CHAR|EXP_INT)
e9b9a1cff2c9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 796
diff changeset
1877 || state == (DOT_CHAR|TRAIL_INT|E_CHAR|EXP_INT)));
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1878 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1879 #endif /* LISP_FLOAT_TYPE */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1880
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1881 static Lisp_Object
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1882 read_vector (readcharfun)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1883 Lisp_Object readcharfun;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1884 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1885 register int i;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1886 register int size;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1887 register Lisp_Object *ptr;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1888 register Lisp_Object tem, vector;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1889 register struct Lisp_Cons *otem;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1890 Lisp_Object len;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1891
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1892 tem = read_list (1, readcharfun);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1893 len = Flength (tem);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1894 vector = (read_pure ? make_pure_vector (XINT (len)) : Fmake_vector (len, Qnil));
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1895
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1896
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1897 size = XVECTOR (vector)->size;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1898 ptr = XVECTOR (vector)->contents;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1899 for (i = 0; i < size; i++)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1900 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1901 ptr[i] = read_pure ? Fpurecopy (Fcar (tem)) : Fcar (tem);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1902 otem = XCONS (tem);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1903 tem = Fcdr (tem);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1904 free_cons (otem);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1905 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1906 return vector;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1907 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1908
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1909 /* flag = 1 means check for ] to terminate rather than ) and .
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1910 flag = -1 means check for starting with defun
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1911 and make structure pure. */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1912
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1913 static Lisp_Object
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1914 read_list (flag, readcharfun)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1915 int flag;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1916 register Lisp_Object readcharfun;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1917 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1918 /* -1 means check next element for defun,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1919 0 means don't check,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1920 1 means already checked and found defun. */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1921 int defunflag = flag < 0 ? -1 : 0;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1922 Lisp_Object val, tail;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1923 register Lisp_Object elt, tem;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1924 struct gcpro gcpro1, gcpro2;
12639
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1925 /* 0 is the normal case.
12780
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1926 1 means this list is a doc reference; replace it with the number 0.
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1927 2 means this list is a doc reference; replace it with the doc string. */
12639
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1928 int doc_reference = 0;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1929
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1930 /* Initialize this to 1 if we are reading a list. */
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1931 int first_in_list = flag <= 0;
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1932
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1933 val = Qnil;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1934 tail = Qnil;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1935
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1936 while (1)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1937 {
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1938 char ch;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1939 GCPRO2 (val, tail);
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1940 elt = read1 (readcharfun, &ch, first_in_list);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1941 UNGCPRO;
10200
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1942
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1943 first_in_list = 0;
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1944
12639
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1945 /* While building, if the list starts with #$, treat it specially. */
10200
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1946 if (EQ (elt, Vload_file_name)
20048
5324d8b2322b (read_list): Don't recognize Vload_file_name
Karl Heuer <kwzh@gnu.org>
parents: 20024
diff changeset
1947 && ! NILP (elt)
12639
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1948 && !NILP (Vpurify_flag))
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1949 {
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1950 if (NILP (Vdoc_file_name))
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1951 /* We have not yet called Snarf-documentation, so assume
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1952 this file is described in the DOC-MM.NN file
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1953 and Snarf-documentation will fill in the right value later.
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1954 For now, replace the whole list with 0. */
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1955 doc_reference = 1;
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1956 else
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1957 /* We have already called Snarf-documentation, so make a relative
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1958 file name for this file, so it can be found properly
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1959 in the installed Lisp directory.
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1960 We don't use Fexpand_file_name because that would make
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1961 the directory absolute now. */
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1962 elt = concat2 (build_string ("../lisp/"),
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1963 Ffile_name_nondirectory (elt));
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1964 }
12780
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1965 else if (EQ (elt, Vload_file_name)
20048
5324d8b2322b (read_list): Don't recognize Vload_file_name
Karl Heuer <kwzh@gnu.org>
parents: 20024
diff changeset
1966 && ! NILP (elt)
12780
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1967 && load_force_doc_strings)
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1968 doc_reference = 2;
10200
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
1969
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1970 if (ch)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1971 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1972 if (flag > 0)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1973 {
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1974 if (ch == ']')
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1975 return val;
12639
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1976 Fsignal (Qinvalid_read_syntax,
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1977 Fcons (make_string (") or . in a vector", 18), Qnil));
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1978 }
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1979 if (ch == ')')
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1980 return val;
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1981 if (ch == '.')
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1982 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1983 GCPRO2 (val, tail);
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
1984 if (!NILP (tail))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1985 XCONS (tail)->cdr = read0 (readcharfun);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1986 else
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1987 val = read0 (readcharfun);
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
1988 read1 (readcharfun, &ch, 0);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1989 UNGCPRO;
9358
361c6409e7c1 (read1): New argument for returning out-of-band data, obviating the need for
Karl Heuer <kwzh@gnu.org>
parents: 9313
diff changeset
1990 if (ch == ')')
12639
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1991 {
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1992 if (doc_reference == 1)
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
1993 return make_number (0);
12780
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1994 if (doc_reference == 2)
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1995 {
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1996 /* Get a doc string from the file we are loading.
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1997 If it's in saved_doc_string, get it from there. */
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1998 int pos = XINT (XCONS (val)->cdr);
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
1999 if (pos >= saved_doc_string_position
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2000 && pos < (saved_doc_string_position
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2001 + saved_doc_string_length))
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2002 {
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2003 int start = pos - saved_doc_string_position;
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2004 int from, to;
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2005
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2006 /* Process quoting with ^A,
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2007 and find the end of the string,
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2008 which is marked with ^_ (037). */
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2009 for (from = start, to = start;
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2010 saved_doc_string[from] != 037;)
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2011 {
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2012 int c = saved_doc_string[from++];
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2013 if (c == 1)
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2014 {
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2015 c = saved_doc_string[from++];
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2016 if (c == 1)
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2017 saved_doc_string[to++] = c;
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2018 else if (c == '0')
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2019 saved_doc_string[to++] = 0;
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2020 else if (c == '_')
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2021 saved_doc_string[to++] = 037;
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2022 }
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2023 else
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2024 saved_doc_string[to++] = c;
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2025 }
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2026
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2027 return make_string (saved_doc_string + start,
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2028 to - start);
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2029 }
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2030 else
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2031 return read_doc_string (val);
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2032 }
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2033
12639
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
2034 return val;
1410ce7c4fab (read_list): When a file loaded from site-init.el uses #$,
Richard M. Stallman <rms@gnu.org>
parents: 12545
diff changeset
2035 }
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2036 return Fsignal (Qinvalid_read_syntax, Fcons (make_string (". in wrong context", 18), Qnil));
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2037 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2038 return Fsignal (Qinvalid_read_syntax, Fcons (make_string ("] in a list", 11), Qnil));
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2039 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2040 tem = (read_pure && flag <= 0
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2041 ? pure_cons (elt, Qnil)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2042 : Fcons (elt, Qnil));
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
2043 if (!NILP (tail))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2044 XCONS (tail)->cdr = tem;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2045 else
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2046 val = tem;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2047 tail = tem;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2048 if (defunflag < 0)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2049 defunflag = EQ (elt, Qdefun);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2050 else if (defunflag > 0)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2051 read_pure = 1;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2052 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2053 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2054
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2055 Lisp_Object Vobarray;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2056 Lisp_Object initial_obarray;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2057
11188
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2058 /* oblookup stores the bucket number here, for the sake of Funintern. */
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2059
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2060 int oblookup_last_bucket_number;
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2061
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2062 static int hash_string ();
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2063 Lisp_Object oblookup ();
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2064
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2065 /* Get an error if OBARRAY is not an obarray.
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2066 If it is one, return it. */
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2067
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2068 Lisp_Object
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2069 check_obarray (obarray)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2070 Lisp_Object obarray;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2071 {
9149
fe6b30db719d (readchar, readchar, unreadchar, read_filtered_event, Fread, read0, read1,
Karl Heuer <kwzh@gnu.org>
parents: 8906
diff changeset
2072 while (!VECTORP (obarray) || XVECTOR (obarray)->size == 0)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2073 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2074 /* If Vobarray is now invalid, force it to be valid. */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2075 if (EQ (Vobarray, obarray)) Vobarray = initial_obarray;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2076
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2077 obarray = wrong_type_argument (Qvectorp, obarray);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2078 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2079 return obarray;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2080 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2081
11188
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2082 /* Intern the C string STR: return a symbol with that name,
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2083 interned in the current obarray. */
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2084
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2085 Lisp_Object
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2086 intern (str)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2087 char *str;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2088 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2089 Lisp_Object tem;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2090 int len = strlen (str);
6503
7c566d0e4b3d (read_filtered_event, intern): Use assignment instead of initialization.
Karl Heuer <kwzh@gnu.org>
parents: 6471
diff changeset
2091 Lisp_Object obarray;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2092
6503
7c566d0e4b3d (read_filtered_event, intern): Use assignment instead of initialization.
Karl Heuer <kwzh@gnu.org>
parents: 6471
diff changeset
2093 obarray = Vobarray;
9149
fe6b30db719d (readchar, readchar, unreadchar, read_filtered_event, Fread, read0, read1,
Karl Heuer <kwzh@gnu.org>
parents: 8906
diff changeset
2094 if (!VECTORP (obarray) || XVECTOR (obarray)->size == 0)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2095 obarray = check_obarray (obarray);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2096 tem = oblookup (obarray, str, len);
9149
fe6b30db719d (readchar, readchar, unreadchar, read_filtered_event, Fread, read0, read1,
Karl Heuer <kwzh@gnu.org>
parents: 8906
diff changeset
2097 if (SYMBOLP (tem))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2098 return tem;
18051
b985b9739beb (intern): Don't make a pure string here, since Fintern does that.
Richard M. Stallman <rms@gnu.org>
parents: 17918
diff changeset
2099 return Fintern (make_string (str, len), obarray);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2100 }
16141
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
2101
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
2102 /* Create an uninterned symbol with name STR. */
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
2103
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
2104 Lisp_Object
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
2105 make_symbol (str)
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
2106 char *str;
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
2107 {
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
2108 int len = strlen (str);
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
2109
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
2110 return Fmake_symbol ((!NILP (Vpurify_flag)
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
2111 ? make_pure_string (str, len)
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
2112 : make_string (str, len)));
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
2113 }
11188
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2114
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2115 DEFUN ("intern", Fintern, Sintern, 1, 2, 0,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2116 "Return the canonical symbol whose name is STRING.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2117 If there is none, one is created by this function and returned.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2118 A second optional argument specifies the obarray to use;\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2119 it defaults to the value of `obarray'.")
14092
279f5f3528a8 (Feval_buffer, Feval_region, Fintern, Fintern_soft): Harmonize arguments
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
2120 (string, obarray)
279f5f3528a8 (Feval_buffer, Feval_region, Fintern, Fintern_soft): Harmonize arguments
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
2121 Lisp_Object string, obarray;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2122 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2123 register Lisp_Object tem, sym, *ptr;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2124
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
2125 if (NILP (obarray)) obarray = Vobarray;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2126 obarray = check_obarray (obarray);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2127
14092
279f5f3528a8 (Feval_buffer, Feval_region, Fintern, Fintern_soft): Harmonize arguments
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
2128 CHECK_STRING (string, 0);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2129
14092
279f5f3528a8 (Feval_buffer, Feval_region, Fintern, Fintern_soft): Harmonize arguments
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
2130 tem = oblookup (obarray, XSTRING (string)->data, XSTRING (string)->size);
9149
fe6b30db719d (readchar, readchar, unreadchar, read_filtered_event, Fread, read0, read1,
Karl Heuer <kwzh@gnu.org>
parents: 8906
diff changeset
2131 if (!INTEGERP (tem))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2132 return tem;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2133
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
2134 if (!NILP (Vpurify_flag))
14092
279f5f3528a8 (Feval_buffer, Feval_region, Fintern, Fintern_soft): Harmonize arguments
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
2135 string = Fpurecopy (string);
279f5f3528a8 (Feval_buffer, Feval_region, Fintern, Fintern_soft): Harmonize arguments
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
2136 sym = Fmake_symbol (string);
16141
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
2137 XSYMBOL (sym)->obarray = obarray;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2138
17918
72aec83491a2 (Fintern): Give keywords a value when interned.
Richard M. Stallman <rms@gnu.org>
parents: 17605
diff changeset
2139 if (XSTRING (string)->data[0] == ':')
72aec83491a2 (Fintern): Give keywords a value when interned.
Richard M. Stallman <rms@gnu.org>
parents: 17605
diff changeset
2140 XSYMBOL (sym)->value = sym;
72aec83491a2 (Fintern): Give keywords a value when interned.
Richard M. Stallman <rms@gnu.org>
parents: 17605
diff changeset
2141
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2142 ptr = &XVECTOR (obarray)->contents[XINT (tem)];
9149
fe6b30db719d (readchar, readchar, unreadchar, read_filtered_event, Fread, read0, read1,
Karl Heuer <kwzh@gnu.org>
parents: 8906
diff changeset
2143 if (SYMBOLP (*ptr))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2144 XSYMBOL (sym)->next = XSYMBOL (*ptr);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2145 else
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2146 XSYMBOL (sym)->next = 0;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2147 *ptr = sym;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2148 return sym;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2149 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2150
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2151 DEFUN ("intern-soft", Fintern_soft, Sintern_soft, 1, 2, 0,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2152 "Return the canonical symbol whose name is STRING, or nil if none exists.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2153 A second optional argument specifies the obarray to use;\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2154 it defaults to the value of `obarray'.")
14092
279f5f3528a8 (Feval_buffer, Feval_region, Fintern, Fintern_soft): Harmonize arguments
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
2155 (string, obarray)
279f5f3528a8 (Feval_buffer, Feval_region, Fintern, Fintern_soft): Harmonize arguments
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
2156 Lisp_Object string, obarray;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2157 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2158 register Lisp_Object tem;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2159
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
2160 if (NILP (obarray)) obarray = Vobarray;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2161 obarray = check_obarray (obarray);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2162
14092
279f5f3528a8 (Feval_buffer, Feval_region, Fintern, Fintern_soft): Harmonize arguments
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
2163 CHECK_STRING (string, 0);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2164
14092
279f5f3528a8 (Feval_buffer, Feval_region, Fintern, Fintern_soft): Harmonize arguments
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
2165 tem = oblookup (obarray, XSTRING (string)->data, XSTRING (string)->size);
9149
fe6b30db719d (readchar, readchar, unreadchar, read_filtered_event, Fread, read0, read1,
Karl Heuer <kwzh@gnu.org>
parents: 8906
diff changeset
2166 if (!INTEGERP (tem))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2167 return tem;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2168 return Qnil;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2169 }
11188
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2170
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2171 DEFUN ("unintern", Funintern, Sunintern, 1, 2, 0,
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2172 "Delete the symbol named NAME, if any, from OBARRAY.\n\
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2173 The value is t if a symbol was found and deleted, nil otherwise.\n\
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2174 NAME may be a string or a symbol. If it is a symbol, that symbol\n\
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2175 is deleted, if it belongs to OBARRAY--no other symbol is deleted.\n\
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2176 OBARRAY defaults to the value of the variable `obarray'.")
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2177 (name, obarray)
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2178 Lisp_Object name, obarray;
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2179 {
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2180 register Lisp_Object string, tem;
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2181 int hash;
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2182
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2183 if (NILP (obarray)) obarray = Vobarray;
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2184 obarray = check_obarray (obarray);
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2185
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2186 if (SYMBOLP (name))
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2187 XSETSTRING (string, XSYMBOL (name)->name);
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2188 else
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2189 {
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2190 CHECK_STRING (name, 0);
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2191 string = name;
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2192 }
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2193
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2194 tem = oblookup (obarray, XSTRING (string)->data, XSTRING (string)->size);
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2195 if (INTEGERP (tem))
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2196 return Qnil;
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2197 /* If arg was a symbol, don't delete anything but that symbol itself. */
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2198 if (SYMBOLP (name) && !EQ (name, tem))
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2199 return Qnil;
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2200
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2201 hash = oblookup_last_bucket_number;
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2202
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2203 if (EQ (XVECTOR (obarray)->contents[hash], tem))
12780
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2204 {
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2205 if (XSYMBOL (tem)->next)
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2206 XSETSYMBOL (XVECTOR (obarray)->contents[hash], XSYMBOL (tem)->next);
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2207 else
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2208 XSETINT (XVECTOR (obarray)->contents[hash], 0);
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2209 }
11188
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2210 else
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2211 {
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2212 Lisp_Object tail, following;
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2213
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2214 for (tail = XVECTOR (obarray)->contents[hash];
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2215 XSYMBOL (tail)->next;
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2216 tail = following)
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2217 {
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2218 XSETSYMBOL (following, XSYMBOL (tail)->next);
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2219 if (EQ (following, tem))
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2220 {
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2221 XSYMBOL (tail)->next = XSYMBOL (following)->next;
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2222 break;
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2223 }
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2224 }
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2225 }
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2226
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2227 return Qt;
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2228 }
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2229
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2230 /* Return the symbol in OBARRAY whose names matches the string
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2231 of SIZE characters at PTR. If there is no such symbol in OBARRAY,
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2232 return nil.
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2233
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2234 Also store the bucket number in oblookup_last_bucket_number. */
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2235
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2236 Lisp_Object
11868
129b45ef421b (oblookup): Delete argument hashp.
Karl Heuer <kwzh@gnu.org>
parents: 11735
diff changeset
2237 oblookup (obarray, ptr, size)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2238 Lisp_Object obarray;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2239 register char *ptr;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2240 register int size;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2241 {
8828
2ff6fed642b1 (Fload): Use EMACS_INT.
Richard M. Stallman <rms@gnu.org>
parents: 8596
diff changeset
2242 int hash;
2ff6fed642b1 (Fload): Use EMACS_INT.
Richard M. Stallman <rms@gnu.org>
parents: 8596
diff changeset
2243 int obsize;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2244 register Lisp_Object tail;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2245 Lisp_Object bucket, tem;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2246
9149
fe6b30db719d (readchar, readchar, unreadchar, read_filtered_event, Fread, read0, read1,
Karl Heuer <kwzh@gnu.org>
parents: 8906
diff changeset
2247 if (!VECTORP (obarray)
5243
13cce14b5a0c Line breaking change.
Richard M. Stallman <rms@gnu.org>
parents: 5185
diff changeset
2248 || (obsize = XVECTOR (obarray)->size) == 0)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2249 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2250 obarray = check_obarray (obarray);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2251 obsize = XVECTOR (obarray)->size;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2252 }
13455
4f5a9ce67782 (oblookup): Clear ARRAY_MARK_FLAG in obsize.
Richard M. Stallman <rms@gnu.org>
parents: 13363
diff changeset
2253 /* This is sometimes needed in the middle of GC. */
4f5a9ce67782 (oblookup): Clear ARRAY_MARK_FLAG in obsize.
Richard M. Stallman <rms@gnu.org>
parents: 13363
diff changeset
2254 obsize &= ~ARRAY_MARK_FLAG;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2255 /* Combining next two lines breaks VMS C 2.3. */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2256 hash = hash_string (ptr, size);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2257 hash %= obsize;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2258 bucket = XVECTOR (obarray)->contents[hash];
11188
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2259 oblookup_last_bucket_number = hash;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2260 if (XFASTINT (bucket) == 0)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2261 ;
9149
fe6b30db719d (readchar, readchar, unreadchar, read_filtered_event, Fread, read0, read1,
Karl Heuer <kwzh@gnu.org>
parents: 8906
diff changeset
2262 else if (!SYMBOLP (bucket))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2263 error ("Bad data in guts of obarray"); /* Like CADR error message */
11188
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2264 else
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2265 for (tail = bucket; ; XSETSYMBOL (tail, XSYMBOL (tail)->next))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2266 {
11188
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2267 if (XSYMBOL (tail)->name->size == size
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2268 && !bcmp (XSYMBOL (tail)->name->data, ptr, size))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2269 return tail;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2270 else if (XSYMBOL (tail)->next == 0)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2271 break;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2272 }
9274
5c66d8b65a7c (Fget_file_char, Fload, read1, oblookup, map_obarray, defsubr, defalias,
Karl Heuer <kwzh@gnu.org>
parents: 9149
diff changeset
2273 XSETINT (tem, hash);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2274 return tem;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2275 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2276
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2277 static int
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2278 hash_string (ptr, len)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2279 unsigned char *ptr;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2280 int len;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2281 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2282 register unsigned char *p = ptr;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2283 register unsigned char *end = p + len;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2284 register unsigned char c;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2285 register int hash = 0;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2286
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2287 while (p != end)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2288 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2289 c = *p++;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2290 if (c >= 0140) c -= 40;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2291 hash = ((hash<<3) + (hash>>28) + c);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2292 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2293 return hash & 07777777777;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2294 }
11188
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2295
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2296 void
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2297 map_obarray (obarray, fn, arg)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2298 Lisp_Object obarray;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2299 int (*fn) ();
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2300 Lisp_Object arg;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2301 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2302 register int i;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2303 register Lisp_Object tail;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2304 CHECK_VECTOR (obarray, 1);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2305 for (i = XVECTOR (obarray)->size - 1; i >= 0; i--)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2306 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2307 tail = XVECTOR (obarray)->contents[i];
19020
1ee295d0114a (map_obarray): Don't crash if something strange is in the obarray.
Richard M. Stallman <rms@gnu.org>
parents: 18771
diff changeset
2308 if (SYMBOLP (tail))
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2309 while (1)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2310 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2311 (*fn) (tail, arg);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2312 if (XSYMBOL (tail)->next == 0)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2313 break;
9274
5c66d8b65a7c (Fget_file_char, Fload, read1, oblookup, map_obarray, defsubr, defalias,
Karl Heuer <kwzh@gnu.org>
parents: 9149
diff changeset
2314 XSETSYMBOL (tail, XSYMBOL (tail)->next);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2315 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2316 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2317 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2318
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2319 mapatoms_1 (sym, function)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2320 Lisp_Object sym, function;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2321 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2322 call1 (function, sym);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2323 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2324
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2325 DEFUN ("mapatoms", Fmapatoms, Smapatoms, 1, 2, 0,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2326 "Call FUNCTION on every symbol in OBARRAY.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2327 OBARRAY defaults to the value of `obarray'.")
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2328 (function, obarray)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2329 Lisp_Object function, obarray;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2330 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2331 Lisp_Object tem;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2332
485
8c615e453683 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 463
diff changeset
2333 if (NILP (obarray)) obarray = Vobarray;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2334 obarray = check_obarray (obarray);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2335
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2336 map_obarray (obarray, mapatoms_1, function);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2337 return Qnil;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2338 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2339
5117
951396781a0e (OBARRAY_SIZE): Increase from 509.
Richard M. Stallman <rms@gnu.org>
parents: 5017
diff changeset
2340 #define OBARRAY_SIZE 1511
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2342 void
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2343 init_obarray ()
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2344 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2345 Lisp_Object oblength;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2346 int hash;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2347 Lisp_Object *tem;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2348
9313
ed68c3822e4b (read_filtered_event, init_obarray): Don't use XFASTINT as an lvalue.
Karl Heuer <kwzh@gnu.org>
parents: 9274
diff changeset
2349 XSETFASTINT (oblength, OBARRAY_SIZE);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2350
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2351 Qnil = Fmake_symbol (make_pure_string ("nil", 3));
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2352 Vobarray = Fmake_vector (oblength, make_number (0));
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2353 initial_obarray = Vobarray;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2354 staticpro (&initial_obarray);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2355 /* Intern nil in the obarray */
16141
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
2356 XSYMBOL (Qnil)->obarray = Vobarray;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2357 /* These locals are to kludge around a pyramid compiler bug. */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2358 hash = hash_string ("nil", 3);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2359 /* Separate statement here to avoid VAXC bug. */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2360 hash %= OBARRAY_SIZE;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2361 tem = &XVECTOR (Vobarray)->contents[hash];
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2362 *tem = Qnil;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2363
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2364 Qunbound = Fmake_symbol (make_pure_string ("unbound", 7));
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2365 XSYMBOL (Qnil)->function = Qunbound;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2366 XSYMBOL (Qunbound)->value = Qunbound;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2367 XSYMBOL (Qunbound)->function = Qunbound;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2368
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2369 Qt = intern ("t");
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2370 XSYMBOL (Qnil)->value = Qnil;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2371 XSYMBOL (Qnil)->plist = Qnil;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2372 XSYMBOL (Qt)->value = Qt;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2373
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2374 /* Qt is correct even if CANNOT_DUMP. loadup.el will set to nil at end. */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2375 Vpurify_flag = Qt;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2376
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2377 Qvariable_documentation = intern ("variable-documentation");
16228
fa7a56c543df (init_obarray): staticpro Qvariable_documentation.
Erik Naggum <erik@naggum.no>
parents: 16165
diff changeset
2378 staticpro (&Qvariable_documentation);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2379
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2380 read_buffer_size = 100;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2381 read_buffer = (char *) malloc (read_buffer_size);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2382 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2383
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2384 void
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2385 defsubr (sname)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2386 struct Lisp_Subr *sname;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2387 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2388 Lisp_Object sym;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2389 sym = intern (sname->symbol_name);
9274
5c66d8b65a7c (Fget_file_char, Fload, read1, oblookup, map_obarray, defsubr, defalias,
Karl Heuer <kwzh@gnu.org>
parents: 9149
diff changeset
2390 XSETSUBR (XSYMBOL (sym)->function, sname);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2391 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2392
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2393 #ifdef NOTDEF /* use fset in subr.el now */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2394 void
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2395 defalias (sname, string)
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2396 struct Lisp_Subr *sname;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2397 char *string;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2398 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2399 Lisp_Object sym;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2400 sym = intern (string);
9274
5c66d8b65a7c (Fget_file_char, Fload, read1, oblookup, map_obarray, defsubr, defalias,
Karl Heuer <kwzh@gnu.org>
parents: 9149
diff changeset
2401 XSETSUBR (XSYMBOL (sym)->function, sname);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2402 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2403 #endif /* NOTDEF */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2404
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2405 /* Define an "integer variable"; a symbol whose value is forwarded
9466
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2406 to a C variable of type int. Sample call: */
10606
97b210b19217 (defvar_display): New function.
Karl Heuer <kwzh@gnu.org>
parents: 10200
diff changeset
2407 /* DEFVAR_INT ("indent-tabs-mode", &indent_tabs_mode, "Documentation"); */
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2408 void
7765
688637ba31c5 (defvar_bool, defvar_int, defvar_lisp, defvar_lisp_nopro):
Richard M. Stallman <rms@gnu.org>
parents: 7675
diff changeset
2409 defvar_int (namestring, address)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2410 char *namestring;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2411 int *address;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2412 {
9466
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2413 Lisp_Object sym, val;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2414 sym = intern (namestring);
9466
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2415 val = allocate_misc ();
11242
36e8e27c8625 (defvar_int, defvar_bool, defvar_lisp_nopro, defvar_kboard)
Richard M. Stallman <rms@gnu.org>
parents: 11235
diff changeset
2416 XMISCTYPE (val) = Lisp_Misc_Intfwd;
9913
c921977bb0ce (defvar_int, defvar_bool, defvar_lisp_nopro, defvar_per_buffer): Use accessor
Karl Heuer <kwzh@gnu.org>
parents: 9871
diff changeset
2417 XINTFWD (val)->intvar = address;
9466
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2418 XSYMBOL (sym)->value = val;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2419 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2420
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2421 /* Similar but define a variable whose value is T if address contains 1,
9466
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2422 NIL if address contains 0 */
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2423 void
7765
688637ba31c5 (defvar_bool, defvar_int, defvar_lisp, defvar_lisp_nopro):
Richard M. Stallman <rms@gnu.org>
parents: 7675
diff changeset
2424 defvar_bool (namestring, address)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2425 char *namestring;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2426 int *address;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2427 {
9466
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2428 Lisp_Object sym, val;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2429 sym = intern (namestring);
9466
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2430 val = allocate_misc ();
11242
36e8e27c8625 (defvar_int, defvar_bool, defvar_lisp_nopro, defvar_kboard)
Richard M. Stallman <rms@gnu.org>
parents: 11235
diff changeset
2431 XMISCTYPE (val) = Lisp_Misc_Boolfwd;
9913
c921977bb0ce (defvar_int, defvar_bool, defvar_lisp_nopro, defvar_per_buffer): Use accessor
Karl Heuer <kwzh@gnu.org>
parents: 9871
diff changeset
2432 XBOOLFWD (val)->boolvar = address;
9466
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2433 XSYMBOL (sym)->value = val;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2434 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2435
9466
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2436 /* Similar but define a variable whose value is the Lisp Object stored
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2437 at address. Two versions: with and without gc-marking of the C
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2438 variable. The nopro version is used when that variable will be
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2439 gc-marked for some other reason, since marking the same slot twice
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2440 can cause trouble with strings. */
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2441 void
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2442 defvar_lisp_nopro (namestring, address)
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2443 char *namestring;
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2444 Lisp_Object *address;
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2445 {
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2446 Lisp_Object sym, val;
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2447 sym = intern (namestring);
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2448 val = allocate_misc ();
11242
36e8e27c8625 (defvar_int, defvar_bool, defvar_lisp_nopro, defvar_kboard)
Richard M. Stallman <rms@gnu.org>
parents: 11235
diff changeset
2449 XMISCTYPE (val) = Lisp_Misc_Objfwd;
9913
c921977bb0ce (defvar_int, defvar_bool, defvar_lisp_nopro, defvar_per_buffer): Use accessor
Karl Heuer <kwzh@gnu.org>
parents: 9871
diff changeset
2450 XOBJFWD (val)->objvar = address;
9466
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2451 XSYMBOL (sym)->value = val;
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2452 }
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2453
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2454 void
7765
688637ba31c5 (defvar_bool, defvar_int, defvar_lisp, defvar_lisp_nopro):
Richard M. Stallman <rms@gnu.org>
parents: 7675
diff changeset
2455 defvar_lisp (namestring, address)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2456 char *namestring;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2457 Lisp_Object *address;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2458 {
9466
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2459 defvar_lisp_nopro (namestring, address);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2460 staticpro (address);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2461 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2462
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2463 #ifndef standalone
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2464
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2465 /* Similar but define a variable whose value is the Lisp Object stored in
9363
4ccd5f13788d (defvar_per_buffer): Access buffer_local_flags as Lisp_Object, not int.
Karl Heuer <kwzh@gnu.org>
parents: 9361
diff changeset
2466 the current buffer. address is the address of the slot in the buffer
4ccd5f13788d (defvar_per_buffer): Access buffer_local_flags as Lisp_Object, not int.
Karl Heuer <kwzh@gnu.org>
parents: 9361
diff changeset
2467 that is current now. */
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2468
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2469 void
1009
bf78b5ea9b3a * lread.c (defvar_per_buffer): Support new TYPE argument, by
Jim Blandy <jimb@redhat.com>
parents: 851
diff changeset
2470 defvar_per_buffer (namestring, address, type, doc)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2471 char *namestring;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2472 Lisp_Object *address;
1009
bf78b5ea9b3a * lread.c (defvar_per_buffer): Support new TYPE argument, by
Jim Blandy <jimb@redhat.com>
parents: 851
diff changeset
2473 Lisp_Object type;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2474 char *doc;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2475 {
9466
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2476 Lisp_Object sym, val;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2477 int offset;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2478 extern struct buffer buffer_local_symbols;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2479
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2480 sym = intern (namestring);
9466
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2481 val = allocate_misc ();
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2482 offset = (char *)address - (char *)current_buffer;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2483
11242
36e8e27c8625 (defvar_int, defvar_bool, defvar_lisp_nopro, defvar_kboard)
Richard M. Stallman <rms@gnu.org>
parents: 11235
diff changeset
2484 XMISCTYPE (val) = Lisp_Misc_Buffer_Objfwd;
9913
c921977bb0ce (defvar_int, defvar_bool, defvar_lisp_nopro, defvar_per_buffer): Use accessor
Karl Heuer <kwzh@gnu.org>
parents: 9871
diff changeset
2485 XBUFFER_OBJFWD (val)->offset = offset;
9466
9052bf69f7de (defvar_int, defvar_bool, defvar_lisp, defvar_lisp_nopro, defvar_per_buffer):
Karl Heuer <kwzh@gnu.org>
parents: 9363
diff changeset
2486 XSYMBOL (sym)->value = val;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2487 *(Lisp_Object *)(offset + (char *)&buffer_local_symbols) = sym;
1009
bf78b5ea9b3a * lread.c (defvar_per_buffer): Support new TYPE argument, by
Jim Blandy <jimb@redhat.com>
parents: 851
diff changeset
2488 *(Lisp_Object *)(offset + (char *)&buffer_local_types) = type;
9363
4ccd5f13788d (defvar_per_buffer): Access buffer_local_flags as Lisp_Object, not int.
Karl Heuer <kwzh@gnu.org>
parents: 9361
diff changeset
2489 if (XINT (*(Lisp_Object *)(offset + (char *)&buffer_local_flags)) == 0)
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2490 /* Did a DEFVAR_PER_BUFFER without initializing the corresponding
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2491 slot of buffer_local_flags */
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2492 abort ();
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2493 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2494
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2495 #endif /* standalone */
10606
97b210b19217 (defvar_display): New function.
Karl Heuer <kwzh@gnu.org>
parents: 10200
diff changeset
2496
97b210b19217 (defvar_display): New function.
Karl Heuer <kwzh@gnu.org>
parents: 10200
diff changeset
2497 /* Similar but define a variable whose value is the Lisp Object stored
11020
0951bb12c8ee (defvar_kboard): Renamed from defvar_display.
Karl Heuer <kwzh@gnu.org>
parents: 10650
diff changeset
2498 at a particular offset in the current kboard object. */
10606
97b210b19217 (defvar_display): New function.
Karl Heuer <kwzh@gnu.org>
parents: 10200
diff changeset
2499
97b210b19217 (defvar_display): New function.
Karl Heuer <kwzh@gnu.org>
parents: 10200
diff changeset
2500 void
11020
0951bb12c8ee (defvar_kboard): Renamed from defvar_display.
Karl Heuer <kwzh@gnu.org>
parents: 10650
diff changeset
2501 defvar_kboard (namestring, offset)
10606
97b210b19217 (defvar_display): New function.
Karl Heuer <kwzh@gnu.org>
parents: 10200
diff changeset
2502 char *namestring;
97b210b19217 (defvar_display): New function.
Karl Heuer <kwzh@gnu.org>
parents: 10200
diff changeset
2503 int offset;
97b210b19217 (defvar_display): New function.
Karl Heuer <kwzh@gnu.org>
parents: 10200
diff changeset
2504 {
97b210b19217 (defvar_display): New function.
Karl Heuer <kwzh@gnu.org>
parents: 10200
diff changeset
2505 Lisp_Object sym, val;
97b210b19217 (defvar_display): New function.
Karl Heuer <kwzh@gnu.org>
parents: 10200
diff changeset
2506 sym = intern (namestring);
97b210b19217 (defvar_display): New function.
Karl Heuer <kwzh@gnu.org>
parents: 10200
diff changeset
2507 val = allocate_misc ();
11242
36e8e27c8625 (defvar_int, defvar_bool, defvar_lisp_nopro, defvar_kboard)
Richard M. Stallman <rms@gnu.org>
parents: 11235
diff changeset
2508 XMISCTYPE (val) = Lisp_Misc_Kboard_Objfwd;
11020
0951bb12c8ee (defvar_kboard): Renamed from defvar_display.
Karl Heuer <kwzh@gnu.org>
parents: 10650
diff changeset
2509 XKBOARD_OBJFWD (val)->offset = offset;
10606
97b210b19217 (defvar_display): New function.
Karl Heuer <kwzh@gnu.org>
parents: 10200
diff changeset
2510 XSYMBOL (sym)->value = val;
97b210b19217 (defvar_display): New function.
Karl Heuer <kwzh@gnu.org>
parents: 10200
diff changeset
2511 }
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2512
14130
99ab26698ab0 (read1): Use xmalloc and xrealloc, not malloc and realloc.
Karl Heuer <kwzh@gnu.org>
parents: 14092
diff changeset
2513 /* Record the value of load-path used at the start of dumping
99ab26698ab0 (read1): Use xmalloc and xrealloc, not malloc and realloc.
Karl Heuer <kwzh@gnu.org>
parents: 14092
diff changeset
2514 so we can see if the site changed it later during dumping. */
99ab26698ab0 (read1): Use xmalloc and xrealloc, not malloc and realloc.
Karl Heuer <kwzh@gnu.org>
parents: 14092
diff changeset
2515 static Lisp_Object dump_path;
99ab26698ab0 (read1): Use xmalloc and xrealloc, not malloc and realloc.
Karl Heuer <kwzh@gnu.org>
parents: 14092
diff changeset
2516
364
f4767dc8fff4 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 341
diff changeset
2517 init_lread ()
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2518 {
617
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2519 char *normal;
11735
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2520 int turn_off_warning = 0;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2521
14945
4cd74c2aca79 (init_lread): Specify LC_NUMERIC locale.
Richard M. Stallman <rms@gnu.org>
parents: 14483
diff changeset
2522 #ifdef HAVE_SETLOCALE
4cd74c2aca79 (init_lread): Specify LC_NUMERIC locale.
Richard M. Stallman <rms@gnu.org>
parents: 14483
diff changeset
2523 /* Make sure numbers are parsed as we expect. */
4cd74c2aca79 (init_lread): Specify LC_NUMERIC locale.
Richard M. Stallman <rms@gnu.org>
parents: 14483
diff changeset
2524 setlocale (LC_NUMERIC, "C");
4cd74c2aca79 (init_lread): Specify LC_NUMERIC locale.
Richard M. Stallman <rms@gnu.org>
parents: 14483
diff changeset
2525 #endif /* HAVE_SETLOCALE */
4cd74c2aca79 (init_lread): Specify LC_NUMERIC locale.
Richard M. Stallman <rms@gnu.org>
parents: 14483
diff changeset
2526
364
f4767dc8fff4 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 341
diff changeset
2527 /* Compute the default load-path. */
617
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2528 #ifdef CANNOT_DUMP
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2529 normal = PATH_LOADSEARCH;
638
40b255f55df3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
2530 Vload_path = decode_env_path (0, normal);
617
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2531 #else
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2532 if (NILP (Vpurify_flag))
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2533 normal = PATH_LOADSEARCH;
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2534 else
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2535 normal = PATH_DUMPLOADSEARCH;
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2536
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2537 /* In a dumped Emacs, we normally have to reset the value of
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2538 Vload_path from PATH_LOADSEARCH, since the value that was dumped
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2539 uses ../lisp, instead of the path of the installed elisp
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2540 libraries. However, if it appears that Vload_path was changed
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2541 from the default before dumping, don't override that value. */
621
eca8812e61cd *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 617
diff changeset
2542 if (initialized)
eca8812e61cd *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 617
diff changeset
2543 {
eca8812e61cd *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 617
diff changeset
2544 if (! NILP (Fequal (dump_path, Vload_path)))
4482
09d0f4b26641 (init_lread): Normally put Vinvocation_directory
Richard M. Stallman <rms@gnu.org>
parents: 3704
diff changeset
2545 {
09d0f4b26641 (init_lread): Normally put Vinvocation_directory
Richard M. Stallman <rms@gnu.org>
parents: 3704
diff changeset
2546 Vload_path = decode_env_path (0, normal);
5617
0b312b3fa24e (init_lread): Use Vinstallation_directory.
Richard M. Stallman <rms@gnu.org>
parents: 5568
diff changeset
2547 if (!NILP (Vinstallation_directory))
4482
09d0f4b26641 (init_lread): Normally put Vinvocation_directory
Richard M. Stallman <rms@gnu.org>
parents: 3704
diff changeset
2548 {
5617
0b312b3fa24e (init_lread): Use Vinstallation_directory.
Richard M. Stallman <rms@gnu.org>
parents: 5568
diff changeset
2549 /* Add to the path the lisp subdir of the
7004
0c4d3481bb1b (init_lread): Maybe put build-time Lisp dirs on load-path.
Richard M. Stallman <rms@gnu.org>
parents: 6503
diff changeset
2550 installation dir, if it exists. */
0c4d3481bb1b (init_lread): Maybe put build-time Lisp dirs on load-path.
Richard M. Stallman <rms@gnu.org>
parents: 6503
diff changeset
2551 Lisp_Object tem, tem1;
5617
0b312b3fa24e (init_lread): Use Vinstallation_directory.
Richard M. Stallman <rms@gnu.org>
parents: 5568
diff changeset
2552 tem = Fexpand_file_name (build_string ("lisp"),
0b312b3fa24e (init_lread): Use Vinstallation_directory.
Richard M. Stallman <rms@gnu.org>
parents: 5568
diff changeset
2553 Vinstallation_directory);
7004
0c4d3481bb1b (init_lread): Maybe put build-time Lisp dirs on load-path.
Richard M. Stallman <rms@gnu.org>
parents: 6503
diff changeset
2554 tem1 = Ffile_exists_p (tem);
0c4d3481bb1b (init_lread): Maybe put build-time Lisp dirs on load-path.
Richard M. Stallman <rms@gnu.org>
parents: 6503
diff changeset
2555 if (!NILP (tem1))
0c4d3481bb1b (init_lread): Maybe put build-time Lisp dirs on load-path.
Richard M. Stallman <rms@gnu.org>
parents: 6503
diff changeset
2556 {
0c4d3481bb1b (init_lread): Maybe put build-time Lisp dirs on load-path.
Richard M. Stallman <rms@gnu.org>
parents: 6503
diff changeset
2557 if (NILP (Fmember (tem, Vload_path)))
11735
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2558 {
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2559 turn_off_warning = 1;
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2560 Vload_path = nconc2 (Vload_path, Fcons (tem, Qnil));
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2561 }
7004
0c4d3481bb1b (init_lread): Maybe put build-time Lisp dirs on load-path.
Richard M. Stallman <rms@gnu.org>
parents: 6503
diff changeset
2562 }
0c4d3481bb1b (init_lread): Maybe put build-time Lisp dirs on load-path.
Richard M. Stallman <rms@gnu.org>
parents: 6503
diff changeset
2563 else
0c4d3481bb1b (init_lread): Maybe put build-time Lisp dirs on load-path.
Richard M. Stallman <rms@gnu.org>
parents: 6503
diff changeset
2564 /* That dir doesn't exist, so add the build-time
0c4d3481bb1b (init_lread): Maybe put build-time Lisp dirs on load-path.
Richard M. Stallman <rms@gnu.org>
parents: 6503
diff changeset
2565 Lisp dirs instead. */
0c4d3481bb1b (init_lread): Maybe put build-time Lisp dirs on load-path.
Richard M. Stallman <rms@gnu.org>
parents: 6503
diff changeset
2566 Vload_path = nconc2 (Vload_path, dump_path);
11311
864c3dea8754 (read_escape): Undo Nov 15 change.
Richard M. Stallman <rms@gnu.org>
parents: 11242
diff changeset
2567
18530
94c18a43de33 (init_lread): Add leim subdir, like lisp subdir.
Richard M. Stallman <rms@gnu.org>
parents: 18084
diff changeset
2568 /* Add leim under the installation dir, if it exists. */
94c18a43de33 (init_lread): Add leim subdir, like lisp subdir.
Richard M. Stallman <rms@gnu.org>
parents: 18084
diff changeset
2569 tem = Fexpand_file_name (build_string ("leim"),
94c18a43de33 (init_lread): Add leim subdir, like lisp subdir.
Richard M. Stallman <rms@gnu.org>
parents: 18084
diff changeset
2570 Vinstallation_directory);
94c18a43de33 (init_lread): Add leim subdir, like lisp subdir.
Richard M. Stallman <rms@gnu.org>
parents: 18084
diff changeset
2571 tem1 = Ffile_exists_p (tem);
94c18a43de33 (init_lread): Add leim subdir, like lisp subdir.
Richard M. Stallman <rms@gnu.org>
parents: 18084
diff changeset
2572 if (!NILP (tem1))
94c18a43de33 (init_lread): Add leim subdir, like lisp subdir.
Richard M. Stallman <rms@gnu.org>
parents: 18084
diff changeset
2573 {
94c18a43de33 (init_lread): Add leim subdir, like lisp subdir.
Richard M. Stallman <rms@gnu.org>
parents: 18084
diff changeset
2574 if (NILP (Fmember (tem, Vload_path)))
94c18a43de33 (init_lread): Add leim subdir, like lisp subdir.
Richard M. Stallman <rms@gnu.org>
parents: 18084
diff changeset
2575 Vload_path = nconc2 (Vload_path, Fcons (tem, Qnil));
94c18a43de33 (init_lread): Add leim subdir, like lisp subdir.
Richard M. Stallman <rms@gnu.org>
parents: 18084
diff changeset
2576 }
94c18a43de33 (init_lread): Add leim subdir, like lisp subdir.
Richard M. Stallman <rms@gnu.org>
parents: 18084
diff changeset
2577
11311
864c3dea8754 (read_escape): Undo Nov 15 change.
Richard M. Stallman <rms@gnu.org>
parents: 11242
diff changeset
2578 /* Add site-list under the installation dir, if it exists. */
864c3dea8754 (read_escape): Undo Nov 15 change.
Richard M. Stallman <rms@gnu.org>
parents: 11242
diff changeset
2579 tem = Fexpand_file_name (build_string ("site-lisp"),
864c3dea8754 (read_escape): Undo Nov 15 change.
Richard M. Stallman <rms@gnu.org>
parents: 11242
diff changeset
2580 Vinstallation_directory);
864c3dea8754 (read_escape): Undo Nov 15 change.
Richard M. Stallman <rms@gnu.org>
parents: 11242
diff changeset
2581 tem1 = Ffile_exists_p (tem);
864c3dea8754 (read_escape): Undo Nov 15 change.
Richard M. Stallman <rms@gnu.org>
parents: 11242
diff changeset
2582 if (!NILP (tem1))
864c3dea8754 (read_escape): Undo Nov 15 change.
Richard M. Stallman <rms@gnu.org>
parents: 11242
diff changeset
2583 {
864c3dea8754 (read_escape): Undo Nov 15 change.
Richard M. Stallman <rms@gnu.org>
parents: 11242
diff changeset
2584 if (NILP (Fmember (tem, Vload_path)))
864c3dea8754 (read_escape): Undo Nov 15 change.
Richard M. Stallman <rms@gnu.org>
parents: 11242
diff changeset
2585 Vload_path = nconc2 (Vload_path, Fcons (tem, Qnil));
864c3dea8754 (read_escape): Undo Nov 15 change.
Richard M. Stallman <rms@gnu.org>
parents: 11242
diff changeset
2586 }
18084
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2587
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2588 /* If Emacs was not built in the source directory,
18530
94c18a43de33 (init_lread): Add leim subdir, like lisp subdir.
Richard M. Stallman <rms@gnu.org>
parents: 18084
diff changeset
2589 and it is run from where it was built, add to load-path
94c18a43de33 (init_lread): Add leim subdir, like lisp subdir.
Richard M. Stallman <rms@gnu.org>
parents: 18084
diff changeset
2590 the lisp, leim and site-lisp dirs under that directory. */
18084
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2591
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2592 if (NILP (Fequal (Vinstallation_directory, Vsource_directory)))
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2593 {
18771
c0b6ecdf4a2b (init_lread): Don't add to load-path lisp subdirectories
Richard M. Stallman <rms@gnu.org>
parents: 18665
diff changeset
2594 Lisp_Object tem2;
c0b6ecdf4a2b (init_lread): Don't add to load-path lisp subdirectories
Richard M. Stallman <rms@gnu.org>
parents: 18665
diff changeset
2595
18084
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2596 tem = Fexpand_file_name (build_string ("src/Makefile"),
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2597 Vinstallation_directory);
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2598 tem1 = Ffile_exists_p (tem);
18771
c0b6ecdf4a2b (init_lread): Don't add to load-path lisp subdirectories
Richard M. Stallman <rms@gnu.org>
parents: 18665
diff changeset
2599
c0b6ecdf4a2b (init_lread): Don't add to load-path lisp subdirectories
Richard M. Stallman <rms@gnu.org>
parents: 18665
diff changeset
2600 /* Don't be fooled if they moved the entire source tree
c0b6ecdf4a2b (init_lread): Don't add to load-path lisp subdirectories
Richard M. Stallman <rms@gnu.org>
parents: 18665
diff changeset
2601 AFTER dumping Emacs. If the build directory is indeed
c0b6ecdf4a2b (init_lread): Don't add to load-path lisp subdirectories
Richard M. Stallman <rms@gnu.org>
parents: 18665
diff changeset
2602 different from the source dir, src/Makefile.in and
c0b6ecdf4a2b (init_lread): Don't add to load-path lisp subdirectories
Richard M. Stallman <rms@gnu.org>
parents: 18665
diff changeset
2603 src/Makefile will not be found together. */
c0b6ecdf4a2b (init_lread): Don't add to load-path lisp subdirectories
Richard M. Stallman <rms@gnu.org>
parents: 18665
diff changeset
2604 tem = Fexpand_file_name (build_string ("src/Makefile.in"),
c0b6ecdf4a2b (init_lread): Don't add to load-path lisp subdirectories
Richard M. Stallman <rms@gnu.org>
parents: 18665
diff changeset
2605 Vinstallation_directory);
c0b6ecdf4a2b (init_lread): Don't add to load-path lisp subdirectories
Richard M. Stallman <rms@gnu.org>
parents: 18665
diff changeset
2606 tem2 = Ffile_exists_p (tem);
c0b6ecdf4a2b (init_lread): Don't add to load-path lisp subdirectories
Richard M. Stallman <rms@gnu.org>
parents: 18665
diff changeset
2607 if (!NILP (tem1) && NILP (tem2))
18084
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2608 {
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2609 tem = Fexpand_file_name (build_string ("lisp"),
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2610 Vsource_directory);
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2611
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2612 if (NILP (Fmember (tem, Vload_path)))
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2613 Vload_path = nconc2 (Vload_path, Fcons (tem, Qnil));
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2614
18530
94c18a43de33 (init_lread): Add leim subdir, like lisp subdir.
Richard M. Stallman <rms@gnu.org>
parents: 18084
diff changeset
2615 tem = Fexpand_file_name (build_string ("leim"),
94c18a43de33 (init_lread): Add leim subdir, like lisp subdir.
Richard M. Stallman <rms@gnu.org>
parents: 18084
diff changeset
2616 Vsource_directory);
94c18a43de33 (init_lread): Add leim subdir, like lisp subdir.
Richard M. Stallman <rms@gnu.org>
parents: 18084
diff changeset
2617
94c18a43de33 (init_lread): Add leim subdir, like lisp subdir.
Richard M. Stallman <rms@gnu.org>
parents: 18084
diff changeset
2618 if (NILP (Fmember (tem, Vload_path)))
94c18a43de33 (init_lread): Add leim subdir, like lisp subdir.
Richard M. Stallman <rms@gnu.org>
parents: 18084
diff changeset
2619 Vload_path = nconc2 (Vload_path, Fcons (tem, Qnil));
94c18a43de33 (init_lread): Add leim subdir, like lisp subdir.
Richard M. Stallman <rms@gnu.org>
parents: 18084
diff changeset
2620
18084
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2621 tem = Fexpand_file_name (build_string ("site-lisp"),
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2622 Vsource_directory);
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2623
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2624 if (NILP (Fmember (tem, Vload_path)))
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2625 Vload_path = nconc2 (Vload_path, Fcons (tem, Qnil));
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2626 }
6f264bb70b49 (init_lread): Sometimes add to load-path
Richard M. Stallman <rms@gnu.org>
parents: 18051
diff changeset
2627 }
4482
09d0f4b26641 (init_lread): Normally put Vinvocation_directory
Richard M. Stallman <rms@gnu.org>
parents: 3704
diff changeset
2628 }
09d0f4b26641 (init_lread): Normally put Vinvocation_directory
Richard M. Stallman <rms@gnu.org>
parents: 3704
diff changeset
2629 }
621
eca8812e61cd *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 617
diff changeset
2630 }
eca8812e61cd *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 617
diff changeset
2631 else
14130
99ab26698ab0 (read1): Use xmalloc and xrealloc, not malloc and realloc.
Karl Heuer <kwzh@gnu.org>
parents: 14092
diff changeset
2632 {
17605
83850481ae70 (init_lread): Don't add ../lisp to the dump-time load path.
Richard M. Stallman <rms@gnu.org>
parents: 17325
diff changeset
2633 /* NORMAL refers to the lisp dir in the source directory. */
83850481ae70 (init_lread): Don't add ../lisp to the dump-time load path.
Richard M. Stallman <rms@gnu.org>
parents: 17325
diff changeset
2634 /* We used to add ../lisp at the front here, but
83850481ae70 (init_lread): Don't add ../lisp to the dump-time load path.
Richard M. Stallman <rms@gnu.org>
parents: 17325
diff changeset
2635 that caused trouble because it was copied from dump_path
83850481ae70 (init_lread): Don't add ../lisp to the dump-time load path.
Richard M. Stallman <rms@gnu.org>
parents: 17325
diff changeset
2636 into Vload_path, aboe, when Vinstallation_directory was non-nil.
83850481ae70 (init_lread): Don't add ../lisp to the dump-time load path.
Richard M. Stallman <rms@gnu.org>
parents: 17325
diff changeset
2637 It should be unnecessary. */
83850481ae70 (init_lread): Don't add ../lisp to the dump-time load path.
Richard M. Stallman <rms@gnu.org>
parents: 17325
diff changeset
2638 Vload_path = decode_env_path (0, normal);
14130
99ab26698ab0 (read1): Use xmalloc and xrealloc, not malloc and realloc.
Karl Heuer <kwzh@gnu.org>
parents: 14092
diff changeset
2639 dump_path = Vload_path;
99ab26698ab0 (read1): Use xmalloc and xrealloc, not malloc and realloc.
Karl Heuer <kwzh@gnu.org>
parents: 14092
diff changeset
2640 }
364
f4767dc8fff4 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 341
diff changeset
2641 #endif
f4767dc8fff4 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 341
diff changeset
2642
9790
637b4664f7a5 Change explicit uses of the Unix directory separator
Richard M. Stallman <rms@gnu.org>
parents: 9552
diff changeset
2643 #ifndef WINDOWSNT
637b4664f7a5 Change explicit uses of the Unix directory separator
Richard M. Stallman <rms@gnu.org>
parents: 9552
diff changeset
2644 /* When Emacs is invoked over network shares on NT, PATH_LOADSEARCH is
637b4664f7a5 Change explicit uses of the Unix directory separator
Richard M. Stallman <rms@gnu.org>
parents: 9552
diff changeset
2645 almost never correct, thereby causing a warning to be printed out that
14036
621a575db6f7 Comment fixes.
Karl Heuer <kwzh@gnu.org>
parents: 13772
diff changeset
2646 confuses users. Since PATH_LOADSEARCH is always overridden by the
9790
637b4664f7a5 Change explicit uses of the Unix directory separator
Richard M. Stallman <rms@gnu.org>
parents: 9552
diff changeset
2647 EMACSLOADPATH environment variable below, disable the warning on NT. */
637b4664f7a5 Change explicit uses of the Unix directory separator
Richard M. Stallman <rms@gnu.org>
parents: 9552
diff changeset
2648
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2649 /* Warn if dirs in the *standard* path don't exist. */
11735
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2650 if (!turn_off_warning)
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2651 {
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2652 Lisp_Object path_tail;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2653
11735
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2654 for (path_tail = Vload_path;
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2655 !NILP (path_tail);
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2656 path_tail = XCONS (path_tail)->cdr)
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2657 {
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2658 Lisp_Object dirfile;
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2659 dirfile = Fcar (path_tail);
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2660 if (STRINGP (dirfile))
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2661 {
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2662 dirfile = Fdirectory_file_name (dirfile);
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2663 if (access (XSTRING (dirfile)->data, 0) < 0)
16487
8e154ff6d4bf (dir_warning): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16383
diff changeset
2664 dir_warning ("Warning: Lisp directory `%s' does not exist.\n",
8e154ff6d4bf (dir_warning): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16383
diff changeset
2665 XCONS (path_tail)->car);
11735
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2666 }
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2667 }
f2f0f3b55a7e (isfloat_string): Reject strings like "0.5+".
Richard M. Stallman <rms@gnu.org>
parents: 11699
diff changeset
2668 }
9790
637b4664f7a5 Change explicit uses of the Unix directory separator
Richard M. Stallman <rms@gnu.org>
parents: 9552
diff changeset
2669 #endif /* WINDOWSNT */
617
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2670
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2671 /* If the EMACSLOADPATH environment variable is set, use its value.
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2672 This doesn't apply if we're dumping. */
11955
d972c95e7577 (init_lread) [CANNOT_DUMP]: Set Vload_path to EMACSLOADPATH.
Geoff Voelker <voelker@cs.washington.edu>
parents: 11868
diff changeset
2673 #ifndef CANNOT_DUMP
617
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2674 if (NILP (Vpurify_flag)
cde1f15848c6 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
2675 && egetenv ("EMACSLOADPATH"))
11955
d972c95e7577 (init_lread) [CANNOT_DUMP]: Set Vload_path to EMACSLOADPATH.
Geoff Voelker <voelker@cs.washington.edu>
parents: 11868
diff changeset
2676 #endif
364
f4767dc8fff4 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 341
diff changeset
2677 Vload_path = decode_env_path ("EMACSLOADPATH", normal);
f4767dc8fff4 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 341
diff changeset
2678
f4767dc8fff4 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 341
diff changeset
2679 Vvalues = Qnil;
f4767dc8fff4 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 341
diff changeset
2680
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2681 load_in_progress = 0;
15283
b2be450a8da4 (init_lread): Init Vload_file_name to Qnil.
Karl Heuer <kwzh@gnu.org>
parents: 15091
diff changeset
2682 Vload_file_name = Qnil;
5568
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
2683
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
2684 load_descriptor_list = Qnil;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2685 }
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2686
16487
8e154ff6d4bf (dir_warning): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16383
diff changeset
2687 /* Print a warning, using format string FORMAT, that directory DIRNAME
8e154ff6d4bf (dir_warning): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16383
diff changeset
2688 does not exist. Print it on stderr and put it in *Message*. */
8e154ff6d4bf (dir_warning): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16383
diff changeset
2689
8e154ff6d4bf (dir_warning): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16383
diff changeset
2690 dir_warning (format, dirname)
8e154ff6d4bf (dir_warning): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16383
diff changeset
2691 char *format;
8e154ff6d4bf (dir_warning): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16383
diff changeset
2692 Lisp_Object dirname;
8e154ff6d4bf (dir_warning): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16383
diff changeset
2693 {
8e154ff6d4bf (dir_warning): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16383
diff changeset
2694 char *buffer
8e154ff6d4bf (dir_warning): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16383
diff changeset
2695 = (char *) alloca (XSTRING (dirname)->size + strlen (format) + 5);
8e154ff6d4bf (dir_warning): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16383
diff changeset
2696
8e154ff6d4bf (dir_warning): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16383
diff changeset
2697 fprintf (stderr, format, XSTRING (dirname)->data);
8e154ff6d4bf (dir_warning): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16383
diff changeset
2698 sprintf (buffer, format, XSTRING (dirname)->data);
8e154ff6d4bf (dir_warning): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16383
diff changeset
2699 message_dolog (buffer, strlen (buffer), 0);
8e154ff6d4bf (dir_warning): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16383
diff changeset
2700 }
8e154ff6d4bf (dir_warning): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16383
diff changeset
2701
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2702 void
364
f4767dc8fff4 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 341
diff changeset
2703 syms_of_lread ()
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2704 {
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2705 defsubr (&Sread);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2706 defsubr (&Sread_from_string);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2707 defsubr (&Sintern);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2708 defsubr (&Sintern_soft);
11188
d7f70df00bb0 (oblookup): Save bucket num in oblookup_last_bucket_number.
Richard M. Stallman <rms@gnu.org>
parents: 11172
diff changeset
2709 defsubr (&Sunintern);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2710 defsubr (&Sload);
672
f81a3cf6ec22 *** empty log message ***
Joseph Arceneaux <jla@gnu.org>
parents: 638
diff changeset
2711 defsubr (&Seval_buffer);
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2712 defsubr (&Seval_region);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2713 defsubr (&Sread_char);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2714 defsubr (&Sread_char_exclusive);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2715 defsubr (&Sread_event);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2716 defsubr (&Sget_file_char);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2717 defsubr (&Smapatoms);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2718
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2719 DEFVAR_LISP ("obarray", &Vobarray,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2720 "Symbol table for use by `intern' and `read'.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2721 It is a vector whose length ought to be prime for best results.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2722 The vector's contents don't make sense if examined from Lisp programs;\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2723 to find all the symbols in an obarray, use `mapatoms'.");
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2724
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2725 DEFVAR_LISP ("values", &Vvalues,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2726 "List of values of all expressions which were read, evaluated and printed.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2727 Order is reverse chronological.");
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2728
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2729 DEFVAR_LISP ("standard-input", &Vstandard_input,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2730 "Stream for read to get input from.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2731 See documentation of `read' for possible values.");
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2732 Vstandard_input = Qt;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2733
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2734 DEFVAR_LISP ("load-path", &Vload_path,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2735 "*List of directories to search for files to load.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2736 Each element is a string (directory name) or nil (try default directory).\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2737 Initialized based on EMACSLOADPATH environment variable, if any,\n\
1887
ab56990c27c4 (syms_of_lread): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 1827
diff changeset
2738 otherwise to default specified by file `paths.h' when Emacs was built.");
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2739
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2740 DEFVAR_BOOL ("load-in-progress", &load_in_progress,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2741 "Non-nil iff inside of `load'.");
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2742
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2743 DEFVAR_LISP ("after-load-alist", &Vafter_load_alist,
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2744 "An alist of expressions to be evalled when particular files are loaded.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2745 Each element looks like (FILENAME FORMS...).\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2746 When `load' is run and the file-name argument is FILENAME,\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2747 the FORMS in the corresponding element are executed at the end of loading.\n\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2748 FILENAME must match exactly! Normally FILENAME is the name of a library,\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2749 with no directory specified, since that is how `load' is normally called.\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2750 An error in FORMS does not undo the load,\n\
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2751 but does prevent execution of the rest of the FORMS.");
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2752 Vafter_load_alist = Qnil;
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2753
2545
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
2754 DEFVAR_LISP ("load-history", &Vload_history,
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
2755 "Alist mapping source file names to symbols and features.\n\
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
2756 Each alist element is a list that starts with a file name,\n\
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
2757 except for one element (optional) that starts with nil and describes\n\
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
2758 definitions evaluated from buffers not visiting files.\n\
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
2759 The remaining elements of each list are symbols defined as functions\n\
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
2760 or variables, and cons cells `(provide . FEATURE)' and `(require . FEATURE)'.");
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
2761 Vload_history = Qnil;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
2762
10200
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
2763 DEFVAR_LISP ("load-file-name", &Vload_file_name,
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
2764 "Full name of file being loaded by `load'.");
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
2765 Vload_file_name = Qnil;
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
2766
2901
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
2767 DEFVAR_LISP ("current-load-list", &Vcurrent_load_list,
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
2768 "Used for internal purposes by `load'.");
2545
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
2769 Vcurrent_load_list = Qnil;
d666732c5f41 (readevalloop): New argument is the source file name (or nil if none).
Richard M. Stallman <rms@gnu.org>
parents: 2439
diff changeset
2770
11079
aeaaa579d967 (Vload_read_function): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11020
diff changeset
2771 DEFVAR_LISP ("load-read-function", &Vload_read_function,
aeaaa579d967 (Vload_read_function): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11020
diff changeset
2772 "Function used by `load' and `eval-region' for reading expressions.\n\
aeaaa579d967 (Vload_read_function): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11020
diff changeset
2773 The default is nil, which means use the function `read'.");
aeaaa579d967 (Vload_read_function): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11020
diff changeset
2774 Vload_read_function = Qnil;
aeaaa579d967 (Vload_read_function): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 11020
diff changeset
2775
17038
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
2776 DEFVAR_LISP ("load-source-file-function", &Vload_source_file_function,
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
2777 "Function called in `load' for loading an Emacs lisp source file.\n\
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
2778 This function is for doing code conversion before reading the source file.\n\
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
2779 If nil, loading is done without any code conversion.\n\
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
2780 Arguments are FULLNAME, FILE, NOERROR, NOMESSAGE, where\n\
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
2781 FULLNAME is the full name of FILE.\n\
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
2782 See `load' for the meaning of the remaining arguments.");
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
2783 Vload_source_file_function = Qnil;
f7a1e78fe210 Include charset.h.
Karl Heuer <kwzh@gnu.org>
parents: 16978
diff changeset
2784
12780
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2785 DEFVAR_BOOL ("load-force-doc-strings", &load_force_doc_strings,
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2786 "Non-nil means `load' should force-load all dynamic doc strings.\n\
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2787 This is useful when the file being loaded is a temporary copy.");
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2788 load_force_doc_strings = 0;
2c1f71512d5d (saved_doc_string*): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 12639
diff changeset
2789
13601
0a091134e047 (Vsource_directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 13455
diff changeset
2790 DEFVAR_LISP ("source-directory", &Vsource_directory,
0a091134e047 (Vsource_directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 13455
diff changeset
2791 "Directory in which Emacs sources were found when Emacs was built.\n\
0a091134e047 (Vsource_directory): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 13455
diff changeset
2792 You cannot count on them to still be there!");
14300
f777822a5d81 (syms_of_lread): Set Vsource_directory here.
Karl Heuer <kwzh@gnu.org>
parents: 14186
diff changeset
2793 Vsource_directory
f777822a5d81 (syms_of_lread): Set Vsource_directory here.
Karl Heuer <kwzh@gnu.org>
parents: 14186
diff changeset
2794 = Fexpand_file_name (build_string ("../"),
f777822a5d81 (syms_of_lread): Set Vsource_directory here.
Karl Heuer <kwzh@gnu.org>
parents: 14186
diff changeset
2795 Fcar (decode_env_path (0, PATH_DUMPLOADSEARCH)));
f777822a5d81 (syms_of_lread): Set Vsource_directory here.
Karl Heuer <kwzh@gnu.org>
parents: 14186
diff changeset
2796
18665
6d7b8b35d878 (Vpreloaded_file_list): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 18530
diff changeset
2797 DEFVAR_LISP ("preloaded-file-list", &Vpreloaded_file_list,
6d7b8b35d878 (Vpreloaded_file_list): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 18530
diff changeset
2798 "List of files that were preloaded (when dumping Emacs).");
6d7b8b35d878 (Vpreloaded_file_list): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 18530
diff changeset
2799 Vpreloaded_file_list = Qnil;
6d7b8b35d878 (Vpreloaded_file_list): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 18530
diff changeset
2800
14300
f777822a5d81 (syms_of_lread): Set Vsource_directory here.
Karl Heuer <kwzh@gnu.org>
parents: 14186
diff changeset
2801 /* Vsource_directory was initialized in init_lread. */
f777822a5d81 (syms_of_lread): Set Vsource_directory here.
Karl Heuer <kwzh@gnu.org>
parents: 14186
diff changeset
2802
5568
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
2803 load_descriptor_list = Qnil;
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
2804 staticpro (&load_descriptor_list);
1af95f18f709 (Fload): Record descriptor numbers on load_descriptor_list.
Richard M. Stallman <rms@gnu.org>
parents: 5496
diff changeset
2805
2901
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
2806 Qcurrent_load_list = intern ("current-load-list");
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
2807 staticpro (&Qcurrent_load_list);
510a7ebce564 (syms_of_lread): Make Vcurrent_load_list ordinary Lisp var.
Richard M. Stallman <rms@gnu.org>
parents: 2781
diff changeset
2808
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2809 Qstandard_input = intern ("standard-input");
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2810 staticpro (&Qstandard_input);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2811
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2812 Qread_char = intern ("read-char");
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2813 staticpro (&Qread_char);
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2814
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2815 Qget_file_char = intern ("get-file-char");
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2816 staticpro (&Qget_file_char);
2044
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
2817
11683
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
2818 Qbackquote = intern ("`");
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
2819 staticpro (&Qbackquote);
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
2820 Qcomma = intern (",");
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
2821 staticpro (&Qcomma);
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
2822 Qcomma_at = intern (",@");
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
2823 staticpro (&Qcomma_at);
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
2824 Qcomma_dot = intern (",.");
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
2825 staticpro (&Qcomma_dot);
355d0b23a080 (read1): New arg FIRST_IN_LIST; all callers changed.
Richard M. Stallman <rms@gnu.org>
parents: 11311
diff changeset
2826
16937
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
2827 Qinhibit_file_name_operation = intern ("inhibit-file-name-operation");
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
2828 staticpro (&Qinhibit_file_name_operation);
c46111ba348b (openp): Handle remote file names in path.
Richard M. Stallman <rms@gnu.org>
parents: 16925
diff changeset
2829
2044
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
2830 Qascii_character = intern ("ascii-character");
258362f03d90 (syms_of_lread): Set up Qascii_character.
Richard M. Stallman <rms@gnu.org>
parents: 2018
diff changeset
2831 staticpro (&Qascii_character);
3625
57174f9b1870 (Fload): Forward all 4 args to magic-name handler.
Richard M. Stallman <rms@gnu.org>
parents: 3041
diff changeset
2832
13235
0f83b9eb5478 (read1): Handle #' as prefix.
Richard M. Stallman <rms@gnu.org>
parents: 13146
diff changeset
2833 Qfunction = intern ("function");
0f83b9eb5478 (read1): Handle #' as prefix.
Richard M. Stallman <rms@gnu.org>
parents: 13146
diff changeset
2834 staticpro (&Qfunction);
0f83b9eb5478 (read1): Handle #' as prefix.
Richard M. Stallman <rms@gnu.org>
parents: 13146
diff changeset
2835
3625
57174f9b1870 (Fload): Forward all 4 args to magic-name handler.
Richard M. Stallman <rms@gnu.org>
parents: 3041
diff changeset
2836 Qload = intern ("load");
57174f9b1870 (Fload): Forward all 4 args to magic-name handler.
Richard M. Stallman <rms@gnu.org>
parents: 3041
diff changeset
2837 staticpro (&Qload);
10200
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
2838
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
2839 Qload_file_name = intern ("load-file-name");
899f5bd94bbb (Qload_file_name, Vload_file_name): New variables.
Richard M. Stallman <rms@gnu.org>
parents: 10163
diff changeset
2840 staticpro (&Qload_file_name);
14130
99ab26698ab0 (read1): Use xmalloc and xrealloc, not malloc and realloc.
Karl Heuer <kwzh@gnu.org>
parents: 14092
diff changeset
2841
99ab26698ab0 (read1): Use xmalloc and xrealloc, not malloc and realloc.
Karl Heuer <kwzh@gnu.org>
parents: 14092
diff changeset
2842 staticpro (&dump_path);
16141
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
2843
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
2844 staticpro (&read_objects);
9cbc74969e46 Add #n=object, #n#, and #:symbol constructs to reader.
Erik Naggum <erik@naggum.no>
parents: 16039
diff changeset
2845 read_objects = Qnil;
341
84ec93d39015 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2846 }