1858
+ 鐃緒申 1 This file describes various problems that have been encountered
+ 鐃緒申 2 in compiling, installing and running GNU Emacs.
+ 鐃緒申 3
1950
+ 鐃緒申 4 * `Pid xxx killed due to text modification or page I/O error'
+ 鐃緒申 5
+ 鐃緒申 6 On HP/UX, you can get that error when the Emacs executable is on an NFS
+ 鐃緒申 7 file system. HP/UX responds this way if it tries to swap in a page and
+ 鐃緒申 8 does not get a response from the server within a timeout whose default
+ 鐃緒申 9 value is just ten seconds.
+ 鐃緒申 10
+ 鐃緒申 11 If this happens to you, extend the timeout period.
+ 鐃緒申 12
1949
+ 鐃緒申 13 * `expand-file-name' fails to work on any but the machine you dumped Emacs on.
+ 鐃緒申 14
+ 鐃緒申 15 On some systems, if you use any of the functions which look up
+ 鐃緒申 16 information in the passwd database before dumping Emacs (say, by using
+ 鐃緒申 17 expand-file-name in site-init.el), then those functions will not work
+ 鐃緒申 18 in the dumped Emacs on any host but the one Emacs was dumped on.
+ 鐃緒申 19
+ 鐃緒申 20 Apparently, the Yellow Pages (or Network Information Service)
+ 鐃緒申 21 functions cache information the first time they are called in the
+ 鐃緒申 22 undumped emacs, this information gets included in the dumped
+ 鐃緒申 23 executable, and it is then inaccurate if the executable is used on
+ 鐃緒申 24 another host.
+ 鐃緒申 25
+ 鐃緒申 26 The solution? Don't use expand-file-name in site-init.el, or in
+ 鐃緒申 27 anything it loads. Yuck.
+ 鐃緒申 28
1858
+ 鐃緒申 29 * On some variants of SVR4, Emacs does not work at all with X.
+ 鐃緒申 30
+ 鐃緒申 31 Try defining BROKEN_FIONREAD in your config.h file. If this solves
+ 鐃緒申 32 the problem, please send a bug report to tell us this is needed; be
+ 鐃緒申 33 sure to say exactly what type of machine and system you are using.
+ 鐃緒申 34
+ 鐃緒申 35 * Linking says that the functions insque and remque are undefined.
+ 鐃緒申 36
+ 鐃緒申 37 Change oldXMenu/Makefile by adding insque.o to the variable OBJS.
+ 鐃緒申 38
+ 鐃緒申 39 * Emacs fails to understand most Internet host names, even though
+ 鐃緒申 40 the names work properly with other programs on the same system.
+ 鐃緒申 41
+ 鐃緒申 42 This typically happens on Suns and other systems that use shared
+ 鐃緒申 43 libraries. The cause is that the site has installed a version of the
+ 鐃緒申 44 shared library which uses a name server--but has not installed a
+ 鐃緒申 45 similiar version of the unshared library which Emacs uses.
+ 鐃緒申 46
+ 鐃緒申 47 The result is that most programs, using the shared library, work with
+ 鐃緒申 48 the nameserver, but Emacs does not.
+ 鐃緒申 49
+ 鐃緒申 50 The fix is to install an unshared library that corresponds to what you
+ 鐃緒申 51 installed in the shared library, and then relink Emacs.
+ 鐃緒申 52
+ 鐃緒申 53 * On a Sun running SunOS 4.1.1, you get this error message from GNU ld:
+ 鐃緒申 54
+ 鐃緒申 55 /lib/libc.a(_Q_sub.o): Undefined symbol __Q_get_rp_rd referenced from text segment
+ 鐃緒申 56
+ 鐃緒申 57 The problem is in the Sun shared C library, not in GNU ld.
+ 鐃緒申 58
+ 鐃緒申 59 The solution is to install Patch-ID# 100267-03 from Sun.
+ 鐃緒申 60
+ 鐃緒申 61 * Self documentation messages are garbled.
+ 鐃緒申 62
+ 鐃緒申 63 This means that the file `etc/DOC-...' doesn't properly correspond
+ 鐃緒申 64 with the Emacs executable. Redumping Emacs and then installing the
+ 鐃緒申 65 corresponding pair of files should fix the problem.
+ 鐃緒申 66
+ 鐃緒申 67 * M-x shell immediately responds "Process shell exited abnormally with code 1".
+ 鐃緒申 68
+ 鐃緒申 69 This is often due to inability to run the program `env'.
+ 鐃緒申 70 This should be in the `etc' subdirectory of the directory
+ 鐃緒申 71 where Emacs is installed, and it should be marked executable.
+ 鐃緒申 72
+ 鐃緒申 73 * Trouble using ptys on AIX.
+ 鐃緒申 74
+ 鐃緒申 75 People often instll the pty devices on AIX incorrectly.
+ 鐃緒申 76 Use `smit pty' to reinstall them properly.
+ 鐃緒申 77
+ 鐃緒申 78 * Shell mode on HP/UX gives the message, "`tty`: Ambiguous".
+ 鐃緒申 79
+ 鐃緒申 80 christos@theory.tn.cornell.edu says:
+ 鐃緒申 81
+ 鐃緒申 82 The problem is that in your .cshrc you have something that tries to
+ 鐃緒申 83 execute `tty`. If you are not running the shell on a real tty then
+ 鐃緒申 84 tty will print "not a tty". Csh expects one word in some places,
+ 鐃緒申 85 but tty is giving it back 3.
+ 鐃緒申 86
+ 鐃緒申 87 The solution is to add a pair of quotes around `tty` to make it a single
+ 鐃緒申 88 word:
+ 鐃緒申 89
+ 鐃緒申 90 if (`tty` == "/dev/console")
+ 鐃緒申 91
+ 鐃緒申 92 should be changed to:
+ 鐃緒申 93
+ 鐃緒申 94 if ("`tty`" == "/dev/console")
+ 鐃緒申 95
+ 鐃緒申 96 Even better, move things that set up terminal sections out of .cshrc
+ 鐃緒申 97 and into .login.
+ 鐃緒申 98
+ 鐃緒申 99 * Using X Windows, control-shift-leftbutton makes Emacs hang.
+ 鐃緒申 100
+ 鐃緒申 101 Use the shell command `xset bc' to make the old X Menu package work.
+ 鐃緒申 102
+ 鐃緒申 103 * Emacs running under X Windows does not handle mouse clicks.
+ 鐃緒申 104 * `emacs -geometry 80x20' finds a file named `80x20'.
+ 鐃緒申 105
+ 鐃緒申 106 One cause of such problems is having (setq term-file-prefix nil) in
+ 鐃緒申 107 your .emacs file. Another cause is a bad value of EMACSLOADPATH in
+ 鐃緒申 108 the environment.
+ 鐃緒申 109
+ 鐃緒申 110 * Emacs starts in a directory other than the one that is current in the shell.
+ 鐃緒申 111
+ 鐃緒申 112 If the PWD environment variable exists, Emacs uses this variable as
+ 鐃緒申 113 the initial working directory.
+ 鐃緒申 114
+ 鐃緒申 115 Some shells automatically update this variable, while other shells fail
+ 鐃緒申 116 to do so. If you use two such shells in combination, the variable can
+ 鐃緒申 117 end up wrong. This confuses Emacs.
+ 鐃緒申 118
+ 鐃緒申 119 The solution is to put something in the start-up file for the shell
+ 鐃緒申 120 that does not update PWD, to get rid of that environment variable.
+ 鐃緒申 121 For example, in csh, use `unsetenv PWD'.
+ 鐃緒申 122
+ 鐃緒申 123 * Emacs gets error message from linker on Sun.
+ 鐃緒申 124
+ 鐃緒申 125 If the error message says that a symbol such as `f68881_used' or
+ 鐃緒申 126 `ffpa_used' or `start_float' is undefined, this probably indicates
+ 鐃緒申 127 that you have compiled some libraries, such as the X libraries,
+ 鐃緒申 128 with a floating point option other than the default.
+ 鐃緒申 129
+ 鐃緒申 130 It's not terribly hard to make this work with small changes in
+ 鐃緒申 131 crt0.c together with linking with Fcrt1.o, Wcrt1.o or Mcrt1.o.
+ 鐃緒申 132 However, the easiest approach is to build Xlib with the default
1949
+ 鐃緒申 133 floating point option: -fsoft.
1858
+ 鐃緒申 134
+ 鐃緒申 135 * Emacs fails to get default settings from X Windows server.
+ 鐃緒申 136
+ 鐃緒申 137 The X library in X11R4 has a bug; it interchanges the 2nd and 3rd
+ 鐃緒申 138 arguments to XGetDefaults. Define the macro XBACKWARDS in config.h to
+ 鐃緒申 139 tell Emacs to compensate for this.
+ 鐃緒申 140
+ 鐃緒申 141 I don't believe there is any way Emacs can determine for itself
+ 鐃緒申 142 whether this problem is present on a given system.
+ 鐃緒申 143
+ 鐃緒申 144 * Keyboard input gets confused after a beep when using a DECserver
+ 鐃緒申 145 as a concentrator.
+ 鐃緒申 146
+ 鐃緒申 147 This problem seems to be a matter of configuring the DECserver to use
+ 鐃緒申 148 7 bit characters rather than 8 bit characters.
+ 鐃緒申 149
+ 鐃緒申 150 * M-x shell persistently reports "Process shell exited abnormally with code 1".
+ 鐃緒申 151
+ 鐃緒申 152 This happened on Suns as a result of what is said to be a bug in Sunos
+ 鐃緒申 153 version 4.0.x. The only fix was to reboot the machine.
+ 鐃緒申 154
+ 鐃緒申 155 * Programs running under terminal emulator do not recognize `emacs'
+ 鐃緒申 156 terminal type.
+ 鐃緒申 157
+ 鐃緒申 158 The cause of this is a shell startup file that sets the TERMCAP
+ 鐃緒申 159 environment variable. The terminal emulator uses that variable to
+ 鐃緒申 160 provide the information on the special terminal type that Emacs
+ 鐃緒申 161 emulates.
+ 鐃緒申 162
+ 鐃緒申 163 Rewrite your shell startup file so that it does not change TERMCAP
+ 鐃緒申 164 in such a case. You could use the following conditional which sets
+ 鐃緒申 165 it only if it is undefined.
+ 鐃緒申 166
+ 鐃緒申 167 if ( ! ${?TERMCAP} ) setenv TERMCAP ~/my-termcap-file
+ 鐃緒申 168
+ 鐃緒申 169 Or you could set TERMCAP only when you set TERM--which should not
+ 鐃緒申 170 happen in a non-login shell.
+ 鐃緒申 171
+ 鐃緒申 172 * Error compiling sysdep.c, "sioctl.h: no such file or directory".
+ 鐃緒申 173
+ 鐃緒申 174 Among USG systems with TIOCGWINSZ, some require sysdep.c to include
+ 鐃緒申 175 the file sioctl.h; on others, sioctl.h does not exist. We don't know
+ 鐃緒申 176 how to distinguish these two kind of systems, so currently we try to
+ 鐃緒申 177 include sioctl.h on all of them. If this #include gets an error, just
+ 鐃緒申 178 delete it.
+ 鐃緒申 179
+ 鐃緒申 180 * X Windows doesn't work if DISPLAY uses a hostname.
+ 鐃緒申 181
+ 鐃緒申 182 People have reported kernel bugs in certain systems that cause Emacs
+ 鐃緒申 183 not to work with X Windows if DISPLAY is set using a host name. But
+ 鐃緒申 184 the problem does not occur if DISPLAY is set to `unix:0.0'. I think
+ 鐃緒申 185 the bug has to do with SIGIO or FIONREAD.
+ 鐃緒申 186
+ 鐃緒申 187 You may be able to compensate for the bug by doing (set-input-mode nil nil).
+ 鐃緒申 188 However, that has the disadvantage of turning off interrupts, so that
+ 鐃緒申 189 you are unable to quit out of a Lisp program by typing C-g.
+ 鐃緒申 190
+ 鐃緒申 191 The easy way to do this is to put
+ 鐃緒申 192
+ 鐃緒申 193 (setq x-sigio-bug t)
+ 鐃緒申 194
+ 鐃緒申 195 in your site-init.el file.
+ 鐃緒申 196
+ 鐃緒申 197 * Problem with remote X server on Suns.
+ 鐃緒申 198
+ 鐃緒申 199 On a Sun, running Emacs on one machine with the X server on another
+ 鐃緒申 200 may not work if you have used the unshared system libraries. This
+ 鐃緒申 201 is because the unshared libraries fail to use YP for host name lookup.
+ 鐃緒申 202 As a result, the host name you specify may not be recognized.
+ 鐃緒申 203
+ 鐃緒申 204 * Watch out for .emacs files and EMACSLOADPATH environment vars
+ 鐃緒申 205
+ 鐃緒申 206 These control the actions of Emacs.
+ 鐃緒申 207 ~/.emacs is your Emacs init file.
+ 鐃緒申 208 EMACSLOADPATH overrides which directories the function
+ 鐃緒申 209 "load" will search.
+ 鐃緒申 210
+ 鐃緒申 211 If you observe strange problems, check for these and get rid
+ 鐃緒申 212 of them, then try again.
+ 鐃緒申 213
+ 鐃緒申 214 * Shell mode ignores interrupts on Apollo Domain
+ 鐃緒申 215
+ 鐃緒申 216 You may find that M-x shell prints the following message:
+ 鐃緒申 217
+ 鐃緒申 218 Warning: no access to tty; thus no job control in this shell...
+ 鐃緒申 219
+ 鐃緒申 220 This can happen if there are not enough ptys on your system.
+ 鐃緒申 221 Here is how to make more of them.
+ 鐃緒申 222
+ 鐃緒申 223 % cd /dev
+ 鐃緒申 224 % ls pty*
+ 鐃緒申 225 # shows how many pty's you have. I had 8, named pty0 to pty7)
+ 鐃緒申 226 % /etc/crpty 8
+ 鐃緒申 227 # creates eight new pty's
+ 鐃緒申 228
+ 鐃緒申 229 * Fatal signal in the command temacs -l loadup inc dump
+ 鐃緒申 230
+ 鐃緒申 231 This command is the final stage of building Emacs. It is run by the
+ 鐃緒申 232 Makefile in the src subdirectory, or by build.com on VMS.
+ 鐃緒申 233
+ 鐃緒申 234 It has been known to get fatal errors due to insufficient swapping
+ 鐃緒申 235 space available on the machine.
+ 鐃緒申 236
+ 鐃緒申 237 On 68000's, it has also happened because of bugs in the
+ 鐃緒申 238 subroutine `alloca'. Verify that `alloca' works right, even
+ 鐃緒申 239 for large blocks (many pages).
+ 鐃緒申 240
+ 鐃緒申 241 * test-distrib says that the distribution has been clobbered
+ 鐃緒申 242 * or, temacs prints "Command key out of range 0-127"
+ 鐃緒申 243 * or, temacs runs and dumps xemacs, but xemacs totally fails to work.
+ 鐃緒申 244 * or, temacs gets errors dumping xemacs
+ 鐃緒申 245
+ 鐃緒申 246 This can be because the .elc files have been garbled. Do not be
+ 鐃緒申 247 fooled by the fact that most of a .elc file is text: these are
+ 鐃緒申 248 binary files and can contain all 256 byte values.
+ 鐃緒申 249
+ 鐃緒申 250 In particular `shar' cannot be used for transmitting GNU Emacs.
+ 鐃緒申 251 It typically truncates "lines". What appear to be "lines" in
+ 鐃緒申 252 a binary file can of course be of any length. Even once `shar'
+ 鐃緒申 253 itself is made to work correctly, `sh' discards null characters
+ 鐃緒申 254 when unpacking the shell archive.
+ 鐃緒申 255
+ 鐃緒申 256 I have also seen character \177 changed into \377. I do not know
+ 鐃緒申 257 what transfer means caused this problem. Various network
+ 鐃緒申 258 file transfer programs are suspected of clobbering the high bit.
+ 鐃緒申 259
+ 鐃緒申 260 The only verified ways to transfer GNU Emacs are `tar', kermit (in
+ 鐃緒申 261 binary mode on Unix), and rcp or internet ftp between two Unix systems,
+ 鐃緒申 262 or chaosnet cftp using raw mode.
+ 鐃緒申 263
+ 鐃緒申 264 If you have a copy of Emacs that has been damaged in its
+ 鐃緒申 265 nonprinting characters, you can fix them:
+ 鐃緒申 266
+ 鐃緒申 267 1) Record the names of all the .elc files.
+ 鐃緒申 268 2) Delete all the .elc files.
+ 鐃緒申 269 3) Recompile alloc.c with a value of PURESIZE twice as large.
+ 鐃緒申 270 You might as well save the old alloc.o.
+ 鐃緒申 271 4) Remake xemacs. It should work now.
+ 鐃緒申 272 5) Running xemacs, do Meta-x byte-compile-file repeatedly
+ 鐃緒申 273 to recreate all the .elc files that used to exist.
+ 鐃緒申 274 You may need to increase the value of the variable
+ 鐃緒申 275 max-lisp-eval-depth to succeed in running the compiler interpreted
+ 鐃緒申 276 on certain .el files. 400 was sufficient as of last report.
+ 鐃緒申 277 6) Reinstall the old alloc.o (undoing changes to alloc.c if any)
+ 鐃緒申 278 and remake temacs.
+ 鐃緒申 279 7) Remake xemacs. It should work now, with valid .elc files.
+ 鐃緒申 280
+ 鐃緒申 281 * temacs prints "Pure Lisp storage exhausted"
+ 鐃緒申 282
+ 鐃緒申 283 This means that the Lisp code loaded from the .elc and .el
+ 鐃緒申 284 files during temacs -l loadup inc dump took up more
+ 鐃緒申 285 space than was allocated.
+ 鐃緒申 286
+ 鐃緒申 287 This could be caused by
+ 鐃緒申 288 1) adding code to the preloaded Lisp files
+ 鐃緒申 289 2) adding more preloaded files in loadup.el
+ 鐃緒申 290 3) having a site-init.el or site-load.el which loads files.
+ 鐃緒申 291 Note that ANY site-init.el or site-load.el is nonstandard;
+ 鐃緒申 292 if you have received Emacs from some other site
+ 鐃緒申 293 and it contains a site-init.el or site-load.el file, consider
+ 鐃緒申 294 deleting that file.
+ 鐃緒申 295 4) getting the wrong .el or .elc files
+ 鐃緒申 296 (not from the directory you expected).
+ 鐃緒申 297 5) deleting some .elc files that are supposed to exist.
+ 鐃緒申 298 This would cause the source files (.el files) to be
+ 鐃緒申 299 loaded instead. They take up more room, so you lose.
+ 鐃緒申 300 6) a bug in the Emacs distribution which underestimates
+ 鐃緒申 301 the space required.
+ 鐃緒申 302
+ 鐃緒申 303 If the need for more space is legitimate, change the definition
+ 鐃緒申 304 of PURESIZE in puresize.h.
+ 鐃緒申 305
+ 鐃緒申 306 But in some of the cases listed above, this problem is a consequence
+ 鐃緒申 307 of something else that is wrong. Be sure to check and fix the real
+ 鐃緒申 308 problem.
+ 鐃緒申 309
+ 鐃緒申 310 * Changes made to .el files do not take effect.
+ 鐃緒申 311
+ 鐃緒申 312 You may have forgotten to recompile them into .elc files.
+ 鐃緒申 313 Then the old .elc files will be loaded, and your changes
+ 鐃緒申 314 will not be seen. To fix this, do M-x byte-recompile-directory
+ 鐃緒申 315 and specify the directory that contains the Lisp files.
+ 鐃緒申 316
+ 鐃緒申 317 * The dumped Emacs (xemacs) crashes when run, trying to write pure data.
+ 鐃緒申 318
+ 鐃緒申 319 Two causes have been seen for such problems.
+ 鐃緒申 320
+ 鐃緒申 321 1) On a system where getpagesize is not a system call, it is defined
+ 鐃緒申 322 as a macro. If the definition (in both unexec.c and malloc.c) is wrong,
+ 鐃緒申 323 it can cause problems like this. You might be able to find the correct
+ 鐃緒申 324 value in the man page for a.out (5).
+ 鐃緒申 325
+ 鐃緒申 326 2) Some systems allocate variables declared static among the
+ 鐃緒申 327 initialized variables. Emacs makes all initialized variables in most
+ 鐃緒申 328 of its files pure after dumping, but the variables declared static and
+ 鐃緒申 329 not initialized are not supposed to be pure. On these systems you
+ 鐃緒申 330 may need to add "#define static" to the m- or the s- file.
+ 鐃緒申 331
+ 鐃緒申 332 * Compilation errors on VMS.
+ 鐃緒申 333
+ 鐃緒申 334 You will get warnings when compiling on VMS because there are
+ 鐃緒申 335 variable names longer than 32 (or whatever it is) characters.
+ 鐃緒申 336 This is not an error. Ignore it.
+ 鐃緒申 337
+ 鐃緒申 338 VAX C does not support #if defined(foo). Uses of this construct
+ 鐃緒申 339 were removed, but some may have crept back in. They must be rewritten.
+ 鐃緒申 340
+ 鐃緒申 341 There is a bug in the C compiler which fails to sign extend characters
+ 鐃緒申 342 in conditional expressions. The bug is:
+ 鐃緒申 343 char c = -1, d = 1;
+ 鐃緒申 344 int i;
+ 鐃緒申 345
+ 鐃緒申 346 i = d ? c : d;
+ 鐃緒申 347 The result is i == 255; the fix is to typecast the char in the
+ 鐃緒申 348 conditional expression as an (int). Known occurrences of such
+ 鐃緒申 349 constructs in Emacs have been fixed.
+ 鐃緒申 350
+ 鐃緒申 351 * rmail gets error getting new mail
+ 鐃緒申 352
+ 鐃緒申 353 rmail gets new mail from /usr/spool/mail/$USER using a program
+ 鐃緒申 354 called `movemail'. This program interlocks with /bin/mail using
+ 鐃緒申 355 the protocol defined by /bin/mail.
+ 鐃緒申 356
+ 鐃緒申 357 There are two different protocols in general use. One of them uses
+ 鐃緒申 358 the `flock' system call. The other involves creating a lock file;
+ 鐃緒申 359 `movemail' must be able to write in /usr/spool/mail in order to do
+ 鐃緒申 360 this. You control which one is used by defining, or not defining,
+ 鐃緒申 361 the macro MAIL_USE_FLOCK in config.h or the m- or s- file it includes.
+ 鐃緒申 362 IF YOU DON'T USE THE FORM OF INTERLOCKING THAT IS NORMAL ON YOUR
+ 鐃緒申 363 SYSTEM, YOU CAN LOSE MAIL!
+ 鐃緒申 364
+ 鐃緒申 365 If your system uses the lock file protocol, and fascist restrictions
+ 鐃緒申 366 prevent ordinary users from writing the lock files in /usr/spool/mail,
+ 鐃緒申 367 you may need to make `movemail' setgid to a suitable group such as
+ 鐃緒申 368 `mail'. You can use these commands (as root):
+ 鐃緒申 369
+ 鐃緒申 370 chgrp mail movemail
+ 鐃緒申 371 chmod 2755 movemail
+ 鐃緒申 372
+ 鐃緒申 373 * Emacs won't work with X-windows if the value of DISPLAY is HOSTNAME:0.
+ 鐃緒申 374 * GNUs can't make contact with the specified host for nntp.
+ 鐃緒申 375
+ 鐃緒申 376 Some people have found that Emacs was unable to connect to the local
+ 鐃緒申 377 host by name, as in DISPLAY=prep:0 if you are running on prep, but
+ 鐃緒申 378 could handle DISPLAY=unix:0. Here is what tale@rpi.edu said:
+ 鐃緒申 379
+ 鐃緒申 380 Seems as
+ 鐃緒申 381 though gethostbyname was bombing somewhere along the way. Well, we
+ 鐃緒申 382 had just upgrade from SunOS 3.5 (which X11 was built under) to SunOS
+ 鐃緒申 383 4.0.1. Any new X applications which tried to be built with the pre
+ 鐃緒申 384 OS-upgrade libraries had the same problems which Emacs was having.
+ 鐃緒申 385 Missing /etc/resolv.conf for a little while (when one of the libraries
+ 鐃緒申 386 was built?) also might have had a hand in it.
+ 鐃緒申 387
+ 鐃緒申 388 The result of all of this (with some speculation) was that we rebuilt
+ 鐃緒申 389 X and then rebuilt Emacs with the new libraries. Works as it should
+ 鐃緒申 390 now. Hoorah.
+ 鐃緒申 391
+ 鐃緒申 392 If you have already installed the name resolver in the file libresolv.a,
+ 鐃緒申 393 then you need to compile Emacs to use that library. The easiest way to
+ 鐃緒申 394 do this is to add to config.h a definition of LIBS_SYSTEM, LIBS_MACHINE
+ 鐃緒申 395 or LIB_STANDARD which uses -lresolv. Watch out! If you redefine a macro
+ 鐃緒申 396 that is already in use in your configuration to supply some other libraries,
+ 鐃緒申 397 be careful not to lose the others.
+ 鐃緒申 398
+ 鐃緒申 399 Thus, you could start by adding this to config.h:
+ 鐃緒申 400
+ 鐃緒申 401 #define LIBS_SYSTEM -lresolv
+ 鐃緒申 402
+ 鐃緒申 403 Then if this gives you an error for redefining a macro, and you see that
+ 鐃緒申 404 the s- file defines LIBS_SYSTEM as -lfoo -lbar, you could change config.h
+ 鐃緒申 405 again to say this:
+ 鐃緒申 406
+ 鐃緒申 407 #define LIBS_SYSTEM -lresolv -lfoo -lbar
+ 鐃緒申 408
+ 鐃緒申 409 * Emacs spontaneously displays "I-search: " at the bottom of the screen.
+ 鐃緒申 410
+ 鐃緒申 411 This means that Control-S/Control-Q "flow control" is being used.
+ 鐃緒申 412 C-s/C-q flow control is bad for Emacs editors because it takes away
+ 鐃緒申 413 C-s and C-q as user commands. Since editors do not output long streams
+ 鐃緒申 414 of text without user commands, there is no need for a user-issuable
+ 鐃緒申 415 "stop output" command in an editor; therefore, a properly designed
+ 鐃緒申 416 flow control mechanism would transmit all possible input characters
+ 鐃緒申 417 without interference. Designing such a mechanism is easy, for a person
+ 鐃緒申 418 with at least half a brain.
+ 鐃緒申 419
+ 鐃緒申 420 There are three possible reasons why flow control could be taking place:
+ 鐃緒申 421
+ 鐃緒申 422 1) Terminal has not been told to disable flow control
+ 鐃緒申 423 2) Insufficient padding for the terminal in use
+ 鐃緒申 424 3) Some sort of terminal concentrator or line switch is responsible
+ 鐃緒申 425
+ 鐃緒申 426 First of all, many terminals have a set-up mode which controls
+ 鐃緒申 427 whether they generate flow control characters. This must be
+ 鐃緒申 428 set to "no flow control" in order for Emacs to work. Sometimes
+ 鐃緒申 429 there is an escape sequence that the computer can send to turn
+ 鐃緒申 430 flow control off and on. If so, perhaps the termcap `ti' string
+ 鐃緒申 431 should turn flow control off, and the `te' string should turn it on.
+ 鐃緒申 432
+ 鐃緒申 433 Once the terminal has been told "no flow control", you may find it
+ 鐃緒申 434 needs more padding. The amount of padding Emacs sends is controlled
+ 鐃緒申 435 by the termcap entry for the terminal in use, and by the output baud
+ 鐃緒申 436 rate as known by the kernel. The shell command `stty' will print
+ 鐃緒申 437 your output baud rate; `stty' with suitable arguments will set it if
+ 鐃緒申 438 it is wrong. Setting to a higher speed causes increased padding. If
+ 鐃緒申 439 the results are wrong for the correct speed, there is probably a
+ 鐃緒申 440 problem in the termcap entry. You must speak to a local Unix wizard
+ 鐃緒申 441 to fix this. Perhaps you are just using the wrong terminal type.
+ 鐃緒申 442
+ 鐃緒申 443 For terminals that lack a "no flow control" mode, sometimes just
+ 鐃緒申 444 giving lots of padding will prevent actual generation of flow control
+ 鐃緒申 445 codes. You might as well try it.
+ 鐃緒申 446
+ 鐃緒申 447 If you are really unlucky, your terminal is connected to the computer
+ 鐃緒申 448 through a concentrator which sends flow control to the computer, or it
+ 鐃緒申 449 insists on sending flow control itself no matter how much padding you
+ 鐃緒申 450 give it. You are screwed! You should replace the terminal or
+ 鐃緒申 451 concentrator with a properly designed one. In the mean time,
+ 鐃緒申 452 some drastic measures can make Emacs semi-work.
+ 鐃緒申 453
+ 鐃緒申 454 One drastic measure to ignore C-s and C-q, while sending enough
+ 鐃緒申 455 padding that the terminal will not really lose any output.
+ 鐃緒申 456 Ignoring C-s and C-q can be done by using keyboard-translate-table
+ 鐃緒申 457 to map them into an undefined character such as C-^ or C-\. Sending
+ 鐃緒申 458 lots of padding is done by changing the termcap entry. Here is how
+ 鐃緒申 459 to make such a keyboard-translate-table:
+ 鐃緒申 460
+ 鐃緒申 461 (let ((the-table (make-string 128 0)))
+ 鐃緒申 462 ;; Default is to translate each character into itself.
+ 鐃緒申 463 (let ((i 0))
+ 鐃緒申 464 (while (< i 128)
+ 鐃緒申 465 (aset the-table i i)
+ 鐃緒申 466 (setq i (1+ i))))
+ 鐃緒申 467 ;; Swap C-s with C-\
+ 鐃緒申 468 (aset the-table ?\C-\\ ?\C-s)
+ 鐃緒申 469 (aset the-table ?\C-s ?\C-\\)
+ 鐃緒申 470 ;; Swap C-q with C-^
+ 鐃緒申 471 (aset the-table ?\C-^ ?\C-q)
+ 鐃緒申 472 (aset the-table ?\C-q ?\C-^)
+ 鐃緒申 473 (setq keyboard-translate-table the-table))
+ 鐃緒申 474
+ 鐃緒申 475 An even more drastic measure is to make Emacs use flow control.
+ 鐃緒申 476 To do this, evaluate the Lisp expression (set-input-mode nil t).
+ 鐃緒申 477 Emacs will then interpret C-s and C-q as flow control commands. (More
+ 鐃緒申 478 precisely, it will allow the kernel to do so as it usually does.) You
+ 鐃緒申 479 will lose the ability to use them for Emacs commands. Also, as a
+ 鐃緒申 480 consequence of using CBREAK mode, the terminal's Meta-key, if any,
+ 鐃緒申 481 will not work, and C-g will be liable to cause a loss of output which
+ 鐃緒申 482 will produce garbage on the screen. (These problems apply to 4.2BSD;
+ 鐃緒申 483 they may not happen in 4.3 or VMS, and I don't know what would happen
+ 鐃緒申 484 in sysV.) You can use keyboard-translate-table, as shown above,
+ 鐃緒申 485 to map two other input characters (such as C-^ and C-\) into C-s and
+ 鐃緒申 486 C-q, so that you can still search and quote.
+ 鐃緒申 487
+ 鐃緒申 488 I have no intention of ever redisigning the Emacs command set for
+ 鐃緒申 489 the assumption that terminals use C-s/C-q flow control. This
+ 鐃緒申 490 flow control technique is a bad design, and terminals that need
+ 鐃緒申 491 it are bad merchandise and should not be purchased. If you can
+ 鐃緒申 492 get some use out of GNU Emacs on inferior terminals, I am glad,
+ 鐃緒申 493 but I will not make Emacs worse for properly designed systems
+ 鐃緒申 494 for the sake of inferior systems.
+ 鐃緒申 495
+ 鐃緒申 496 * Control-S and Control-Q commands are ignored completely.
+ 鐃緒申 497
+ 鐃緒申 498 For some reason, your system is using brain-damaged C-s/C-q flow
+ 鐃緒申 499 control despite Emacs's attempts to turn it off. Perhaps your
+ 鐃緒申 500 terminal is connected to the computer through a concentrator
+ 鐃緒申 501 that wants to use flow control.
+ 鐃緒申 502
+ 鐃緒申 503 You should first try to tell the concentrator not to use flow control.
+ 鐃緒申 504 If you succeed in this, try making the terminal work without
+ 鐃緒申 505 flow control, as described in the preceding section.
+ 鐃緒申 506
+ 鐃緒申 507 If that line of approach is not successful, map some other characters
+ 鐃緒申 508 into C-s and C-q using keyboard-translate-table. The example above
+ 鐃緒申 509 shows how to do this with C-^ and C-\.
+ 鐃緒申 510
+ 鐃緒申 511 * Control-S and Control-Q commands are ignored completely on a net connection.
+ 鐃緒申 512
+ 鐃緒申 513 Some versions of rlogin (and possibly telnet) do not pass flow
+ 鐃緒申 514 control characters to the remote system to which they connect.
+ 鐃緒申 515 On such systems, emacs on the remote system cannot disable flow
+ 鐃緒申 516 control on the local system.
+ 鐃緒申 517
+ 鐃緒申 518 One way to cure this is to disable flow control on the local host
+ 鐃緒申 519 (the one running rlogin, not the one running rlogind) using the
+ 鐃緒申 520 stty command, before starting the rlogin process. On many systems,
+ 鐃緒申 521 "stty start u stop u" will do this.
+ 鐃緒申 522
+ 鐃緒申 523 Some versions of tcsh will prevent even this from working. One way
+ 鐃緒申 524 around this is to start another shell before starting rlogin, and
+ 鐃緒申 525 issue the stty command to disable flow control from that shell.
+ 鐃緒申 526
+ 鐃緒申 527 * Screen is updated wrong, but only on one kind of terminal.
+ 鐃緒申 528
+ 鐃緒申 529 This could mean that the termcap entry you are using for that
+ 鐃緒申 530 terminal is wrong, or it could mean that Emacs has a bug handing
+ 鐃緒申 531 the combination of features specified for that terminal.
+ 鐃緒申 532
+ 鐃緒申 533 The first step in tracking this down is to record what characters
+ 鐃緒申 534 Emacs is sending to the terminal. Execute the Lisp expression
+ 鐃緒申 535 (open-termscript "./emacs-script") to make Emacs write all
+ 鐃緒申 536 terminal output into the file ~/emacs-script as well; then do
+ 鐃緒申 537 what makes the screen update wrong, and look at the file
+ 鐃緒申 538 and decode the characters using the manual for the terminal.
+ 鐃緒申 539 There are several possibilities:
+ 鐃緒申 540
+ 鐃緒申 541 1) The characters sent are correct, according to the terminal manual.
+ 鐃緒申 542
+ 鐃緒申 543 In this case, there is no obvious bug in Emacs, and most likely you
+ 鐃緒申 544 need more padding, or possibly the terminal manual is wrong.
+ 鐃緒申 545
+ 鐃緒申 546 2) The characters sent are incorrect, due to an obscure aspect
+ 鐃緒申 547 of the terminal behavior not described in an obvious way
+ 鐃緒申 548 by termcap.
+ 鐃緒申 549
+ 鐃緒申 550 This case is hard. It will be necessary to think of a way for
+ 鐃緒申 551 Emacs to distinguish between terminals with this kind of behavior
+ 鐃緒申 552 and other terminals that behave subtly differently but are
+ 鐃緒申 553 classified the same by termcap; or else find an algorithm for
+ 鐃緒申 554 Emacs to use that avoids the difference. Such changes must be
+ 鐃緒申 555 tested on many kinds of terminals.
+ 鐃緒申 556
+ 鐃緒申 557 3) The termcap entry is wrong.
+ 鐃緒申 558
+ 鐃緒申 559 See the file etc/TERMS for information on changes
+ 鐃緒申 560 that are known to be needed in commonly used termcap entries
+ 鐃緒申 561 for certain terminals.
+ 鐃緒申 562
+ 鐃緒申 563 4) The characters sent are incorrect, and clearly cannot be
+ 鐃緒申 564 right for any terminal with the termcap entry you were using.
+ 鐃緒申 565
+ 鐃緒申 566 This is unambiguously an Emacs bug, and can probably be fixed
+ 鐃緒申 567 in termcap.c, tparam.c, term.c, scroll.c, cm.c or dispnew.c.
+ 鐃緒申 568
+ 鐃緒申 569 * Output from Control-V is slow.
+ 鐃緒申 570
+ 鐃緒申 571 On many bit-map terminals, scrolling operations are fairly slow.
+ 鐃緒申 572 Often the termcap entry for the type of terminal in use fails
+ 鐃緒申 573 to inform Emacs of this. The two lines at the bottom of the screen
+ 鐃緒申 574 before a Control-V command are supposed to appear at the top after
+ 鐃緒申 575 the Control-V command. If Emacs thinks scrolling the lines is fast,
+ 鐃緒申 576 it will scroll them to the top of the screen.
+ 鐃緒申 577
+ 鐃緒申 578 If scrolling is slow but Emacs thinks it is fast, the usual reason is
+ 鐃緒申 579 that the termcap entry for the terminal you are using does not
+ 鐃緒申 580 specify any padding time for the `al' and `dl' strings. Emacs
+ 鐃緒申 581 concludes that these operations take only as much time as it takes to
+ 鐃緒申 582 send the commands at whatever line speed you are using. You must
+ 鐃緒申 583 fix the termcap entry to specify, for the `al' and `dl', as much
+ 鐃緒申 584 time as the operations really take.
+ 鐃緒申 585
+ 鐃緒申 586 Currently Emacs thinks in terms of serial lines which send characters
+ 鐃緒申 587 at a fixed rate, so that any operation which takes time for the
+ 鐃緒申 588 terminal to execute must also be padded. With bit-map terminals
+ 鐃緒申 589 operated across networks, often the network provides some sort of
+ 鐃緒申 590 flow control so that padding is never needed no matter how slow
+ 鐃緒申 591 an operation is. You must still specify a padding time if you want
+ 鐃緒申 592 Emacs to realize that the operation takes a long time. This will
+ 鐃緒申 593 cause padding characters to be sent unnecessarily, but they do
+ 鐃緒申 594 not really cost much. They will be transmitted while the scrolling
+ 鐃緒申 595 is happening and then discarded quickly by the terminal.
+ 鐃緒申 596
+ 鐃緒申 597 Most bit-map terminals provide commands for inserting or deleting
+ 鐃緒申 598 multiple lines at once. Define the `AL' and `DL' strings in the
+ 鐃緒申 599 termcap entry to say how to do these things, and you will have
+ 鐃緒申 600 fast output without wasted padding characters. These strings should
+ 鐃緒申 601 each contain a single %-spec saying how to send the number of lines
+ 鐃緒申 602 to be scrolled. These %-specs are like those in the termcap
+ 鐃緒申 603 `cm' string.
+ 鐃緒申 604
+ 鐃緒申 605 You should also define the `IC' and `DC' strings if your terminal
+ 鐃緒申 606 has a command to insert or delete multiple characters. These
+ 鐃緒申 607 take the number of positions to insert or delete as an argument.
+ 鐃緒申 608
+ 鐃緒申 609 A `cs' string to set the scrolling region will reduce the amount
+ 鐃緒申 610 of motion you see on the screen when part of the screen is scrolled.
+ 鐃緒申 611
+ 鐃緒申 612 * Your Delete key sends a Backspace to the terminal, using an AIXterm.
+ 鐃緒申 613
+ 鐃緒申 614 The solution is to include in your .Xdefaults the lines:
+ 鐃緒申 615
+ 鐃緒申 616 *aixterm.Translations: #override <Key>BackSpace: string(0x7f)
+ 鐃緒申 617 aixterm*ttyModes: erase ^?
+ 鐃緒申 618
+ 鐃緒申 619 This makes your Backspace key send DEL (ASCII 127).
+ 鐃緒申 620
+ 鐃緒申 621 * You type Control-H (Backspace) expecting to delete characters.
+ 鐃緒申 622
+ 鐃緒申 623 Put `stty dec' in your .login file and your problems will disappear
+ 鐃緒申 624 after a day or two.
+ 鐃緒申 625
+ 鐃緒申 626 The choice of Backspace for erasure was based on confusion, caused by
+ 鐃緒申 627 the fact that backspacing causes erasure (later, when you type another
+ 鐃緒申 628 character) on most display terminals. But it is a mistake. Deletion
+ 鐃緒申 629 of text is not the same thing as backspacing followed by failure to
+ 鐃緒申 630 overprint. I do not wish to propagate this confusion by conforming
+ 鐃緒申 631 to it.
+ 鐃緒申 632
+ 鐃緒申 633 For this reason, I believe `stty dec' is the right mode to use,
+ 鐃緒申 634 and I have designed Emacs to go with that. If there were a thousand
+ 鐃緒申 635 other control characters, I would define Control-h to delete as well;
+ 鐃緒申 636 but there are not very many other control characters, and I think
+ 鐃緒申 637 that providing the most mnemonic possible Help character is more
+ 鐃緒申 638 important than adapting to people who don't use `stty dec'.
+ 鐃緒申 639
+ 鐃緒申 640 If you are obstinate about confusing buggy overprinting with deletion,
+ 鐃緒申 641 you can redefine Backspace in your .emacs file:
+ 鐃緒申 642 (global-set-key "\b" 'delete-backward-char)
+ 鐃緒申 643 You may then wish to put the function help-command on some
+ 鐃緒申 644 other key. I leave to you the task of deciding which key.
+ 鐃緒申 645
+ 鐃緒申 646 * Editing files through RFS gives spurious "file has changed" warnings.
+ 鐃緒申 647 It is possible that a change in Emacs 18.37 gets around this problem,
+ 鐃緒申 648 but in case not, here is a description of how to fix the RFS bug that
+ 鐃緒申 649 causes it.
+ 鐃緒申 650
+ 鐃緒申 651 There was a serious pair of bugs in the handling of the fsync() system
+ 鐃緒申 652 call in the RFS server.
+ 鐃緒申 653
+ 鐃緒申 654 The first is that the fsync() call is handled as another name for the
+ 鐃緒申 655 close() system call (!!). It appears that fsync() is not used by very
+ 鐃緒申 656 many programs; Emacs version 18 does an fsync() before closing files
+ 鐃緒申 657 to make sure that the bits are on the disk.
+ 鐃緒申 658
+ 鐃緒申 659 This is fixed by the enclosed patch to the RFS server.
+ 鐃緒申 660
+ 鐃緒申 661 The second, more serious problem, is that fsync() is treated as a
+ 鐃緒申 662 non-blocking system call (i.e., it's implemented as a message that
+ 鐃緒申 663 gets sent to the remote system without waiting for a reply). Fsync is
+ 鐃緒申 664 a useful tool for building atomic file transactions. Implementing it
+ 鐃緒申 665 as a non-blocking RPC call (when the local call blocks until the sync
+ 鐃緒申 666 is done) is a bad idea; unfortunately, changing it will break the RFS
+ 鐃緒申 667 protocol. No fix was supplied for this problem.
+ 鐃緒申 668
+ 鐃緒申 669 (as always, your line numbers may vary)
+ 鐃緒申 670
+ 鐃緒申 671 % rcsdiff -c -r1.2 serversyscall.c
+ 鐃緒申 672 RCS file: RCS/serversyscall.c,v
+ 鐃緒申 673 retrieving revision 1.2
+ 鐃緒申 674 diff -c -r1.2 serversyscall.c
+ 鐃緒申 675 *** /tmp/,RCSt1003677 Wed Jan 28 15:15:02 1987
+ 鐃緒申 676 --- serversyscall.c Wed Jan 28 15:14:48 1987
+ 鐃緒申 677 ***************
+ 鐃緒申 678 *** 163,169 ****
+ 鐃緒申 679 /*
+ 鐃緒申 680 * No return sent for close or fsync!
+ 鐃緒申 681 */
+ 鐃緒申 682 ! if (syscall == RSYS_close || syscall == RSYS_fsync)
+ 鐃緒申 683 proc->p_returnval = deallocate_fd(proc, msg->m_args[0]);
+ 鐃緒申 684 else
+ 鐃緒申 685 {
+ 鐃緒申 686 --- 166,172 ----
+ 鐃緒申 687 /*
+ 鐃緒申 688 * No return sent for close or fsync!
+ 鐃緒申 689 */
+ 鐃緒申 690 ! if (syscall == RSYS_close)
+ 鐃緒申 691 proc->p_returnval = deallocate_fd(proc, msg->m_args[0]);
+ 鐃緒申 692 else
+ 鐃緒申 693 {
+ 鐃緒申 694
+ 鐃緒申 695 * ld complains because `alloca' is not defined on your system.
+ 鐃緒申 696
+ 鐃緒申 697 Alloca is a library function in 4.2bsd, which is used very heavily by
+ 鐃緒申 698 GNU Emacs. Use of malloc instead is very difficult, as you would have
+ 鐃緒申 699 to arrange for the storage to be freed, and do so even in the case of
+ 鐃緒申 700 a longjmp happening inside a subroutine. Many subroutines in Emacs
+ 鐃緒申 701 can do longjmp.
+ 鐃緒申 702
+ 鐃緒申 703 If your system does not support alloca, try defining the symbol
+ 鐃緒申 704 C_ALLOCA in the m-...h file for that machine. This will enable the use
+ 鐃緒申 705 in Emacs of a portable simulation for alloca. But you will find that
+ 鐃緒申 706 Emacs's performance and memory use improve if you write a true
+ 鐃緒申 707 alloca in assembler language.
+ 鐃緒申 708
+ 鐃緒申 709 alloca (N) should return the address of an N-byte block of memory
+ 鐃緒申 710 added dynamically to the current stack frame.
+ 鐃緒申 711
+ 鐃緒申 712 * Vax C compiler bugs affecting Emacs.
+ 鐃緒申 713
+ 鐃緒申 714 You may get one of these problems compiling Emacs:
+ 鐃緒申 715
+ 鐃緒申 716 foo.c line nnn: compiler error: no table entry for op STASG
+ 鐃緒申 717 foo.c: fatal error in /lib/ccom
+ 鐃緒申 718
+ 鐃緒申 719 These are due to bugs in the C compiler; the code is valid C.
+ 鐃緒申 720 Unfortunately, the bugs are unpredictable: the same construct
+ 鐃緒申 721 may compile properly or trigger one of these bugs, depending
+ 鐃緒申 722 on what else is in the source file being compiled. Even changes
+ 鐃緒申 723 in header files that should not affect the file being compiled
+ 鐃緒申 724 can affect whether the bug happens. In addition, sometimes files
+ 鐃緒申 725 that compile correctly on one machine get this bug on another machine.
+ 鐃緒申 726
+ 鐃緒申 727 As a result, it is hard for me to make sure this bug will not affect
+ 鐃緒申 728 you. I have attempted to find and alter these constructs, but more
+ 鐃緒申 729 can always appear. However, I can tell you how to deal with it if it
+ 鐃緒申 730 should happen. The bug comes from having an indexed reference to an
+ 鐃緒申 731 array of Lisp_Objects, as an argument in a function call:
+ 鐃緒申 732 Lisp_Object *args;
+ 鐃緒申 733 ...
+ 鐃緒申 734 ... foo (5, args[i], ...)...
+ 鐃緒申 735 putting the argument into a temporary variable first, as in
+ 鐃緒申 736 Lisp_Object *args;
+ 鐃緒申 737 Lisp_Object tem;
+ 鐃緒申 738 ...
+ 鐃緒申 739 tem = args[i];
+ 鐃緒申 740 ... foo (r, tem, ...)...
+ 鐃緒申 741 causes the problem to go away.
+ 鐃緒申 742 The `contents' field of a Lisp vector is an array of Lisp_Objects,
+ 鐃緒申 743 so you may see the problem happening with indexed references to that.
+ 鐃緒申 744
+ 鐃緒申 745 * 68000 C compiler problems
+ 鐃緒申 746
+ 鐃緒申 747 Various 68000 compilers have different problems.
+ 鐃緒申 748 These are some that have been observed.
+ 鐃緒申 749
+ 鐃緒申 750 ** Using value of assignment expression on union type loses.
+ 鐃緒申 751 This means that x = y = z; or foo (x = z); does not work
+ 鐃緒申 752 if x is of type Lisp_Object.
+ 鐃緒申 753
+ 鐃緒申 754 ** "cannot reclaim" error.
+ 鐃緒申 755
+ 鐃緒申 756 This means that an expression is too complicated. You get the correct
+ 鐃緒申 757 line number in the error message. The code must be rewritten with
+ 鐃緒申 758 simpler expressions.
+ 鐃緒申 759
+ 鐃緒申 760 ** XCONS, XSTRING, etc macros produce incorrect code.
+ 鐃緒申 761
+ 鐃緒申 762 If temacs fails to run at all, this may be the cause.
+ 鐃緒申 763 Compile this test program and look at the assembler code:
+ 鐃緒申 764
+ 鐃緒申 765 struct foo { char x; unsigned int y : 24; };
+ 鐃緒申 766
+ 鐃緒申 767 lose (arg)
+ 鐃緒申 768 struct foo arg;
+ 鐃緒申 769 {
+ 鐃緒申 770 test ((int *) arg.y);
+ 鐃緒申 771 }
+ 鐃緒申 772
+ 鐃緒申 773 If the code is incorrect, your compiler has this problem.
+ 鐃緒申 774 In the XCONS, etc., macros in lisp.h you must replace (a).u.val with
+ 鐃緒申 775 ((a).u.val + coercedummy) where coercedummy is declared as int.
+ 鐃緒申 776
+ 鐃緒申 777 This problem will not happen if the m-...h file for your type
+ 鐃緒申 778 of machine defines NO_UNION_TYPE. That is the recommended setting now.
+ 鐃緒申 779
+ 鐃緒申 780 * C compilers lose on returning unions
+ 鐃緒申 781
+ 鐃緒申 782 I hear that some C compilers cannot handle returning
+ 鐃緒申 783 a union type. Most of the functions in GNU Emacs return
+ 鐃緒申 784 type Lisp_Object, which is currently defined as a union.
+ 鐃緒申 785
+ 鐃緒申 786 This problem will not happen if the m-...h file for your type
+ 鐃緒申 787 of machine defines NO_UNION_TYPE. That is the recommended setting now.
+ 鐃緒申 788