# HG changeset patch # User Jim Blandy # Date 660806056 0 # Node ID 93491679e7e923c61bf7e4073bf612ec6c2bf6cf # Parent 2f5b3f50773d13ecacf02d2425145f2f8d5ec7b1 Initial revision diff -r 2f5b3f50773d -r 93491679e7e9 etc/FAQ --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/etc/FAQ Mon Dec 10 05:14:16 1990 +0000 @@ -0,0 +1,2400 @@ +This is a list of frequently asked questions (FAQ) about GNU Emacs with +answers. This list is designed to cut down on the noise in the +gnu.emacs.help newsgroup (which is also the help-gnu-emacs mailing list) +that results from people repeatedly asking many of the same questions. + +This list is maintained by me, Joe Wells. My e-mail address is +jbw@bu.edu. If jbw@bu.edu doesn't work try jbw@bucsf.bu.edu. + +Feel free to contribute text for the answers that I haven't written yet, +to suggest new questions, to suggest changes in the wording, to suggest +deletions, etc. Please include either "FAQ" or "frequently asked +questions" in the subject of messages you send to me to help keep me from +accidentally filing your message in the wrong mail folder. + +Here is a short list of new questions and questions that are now answered: + +New questions: + + Why doesn't "C-c C-c" interrupt subprocesses under HP/UX? + How do I make Emacs send 8-bit characters to my terminal? + Why does ispell sometimes ignore the local dictionary? + Where can I get Emacs with NeWS support? + +Questions with improved answers: + + Has someone written an GNU Emacs Lisp package that does XXX? + How do I get Emacs running on VMS under DECwindows? + Why does Emacs crash from a bus error in XLookupString under OpenLook? + Why does Emacs hang with message "Unknown XMenu" with X11R4? + How do I use regexps (regular expressions) in Emacs? + How do I make Emacs "typeover" or "overwrite" when I type instead of + always inserting? + How do I get Emacs for my PC? + How can I highlight a region? + Where can I get GNU Emacs Lisp packages that don't come with Emacs? + Where can I get the latest VM, Supercite, GNUS, Calc, Calendar, or Patch? + +Minor changes: + + Where does the name "Emacs" come from? + In C mode, can I show just the lines that will be left after #ifdef + commands are handled by the compiler? + What does "M-x command" mean? + How do I get a printed copy of the GNU Emacs manual? + What do things like this mean: C-h, M-C-a, RET, etc.? + Why doesn't GNUS work anymore via NNTP? + What does Emacs do every time it starts up? + +Enjoy, + +-- +Joe Wells +------------------------------------------------- +GNU Emacs Frequently Asked Questions with Answers (part 1 of 2) + +Sat Dec 8 01:30:53 1990 + + +If you are viewing this file in a GNU Emacs Buffer, you can type "M-2 C-x +$" to get an overview of just the questions. Then, when you want to look +at the text of the answers, just type "C-x $". + +To search for a question numbered XXX, type "M-C-s ^XXX:", followed by a +C-r if that doesn't work, then type ESC to end the search. + + +Notation Used in the Answers (READ THIS SECTION FIRST!) + + You may skip this section if you are reasonably familiar with GNU Emacs. + Some of these are not actually frequently asked questions, but knowing + them is important for understanding the answers to the rest of the + questions. + +1: What do things like this mean: C-h, M-C-a, RET, etc.? + + C-a means while holding down the "Control" key press the "a" key. The + ASCII code this sends will generally be the value that would be sent by + pressing just "a" minus 96 or 64. Either way it will be a number from 0 + to 31. + + M-a means while holding down the "Meta" key press the "a" key. The + ASCII code this sends is the sum of the ASCII code that would be sent by + pressing just "a" and 128. + + M-C-a means while holding down both the "Control" key and the "Meta" key + press the "a" key. + + C-M-a is a synonym for M-C-a. + + RET means press the "Return" key. RET is the same as C-m. This sends + ASCII code 13. + + LFD means press the "Linefeed" key. LFD is also the same as C-j. This + sends ASCII code 10. Under Unix, ASCII code 10 is more often called + "Newline". + + DEL means press the "Delete" key. DEL is the same as C-?. This sends + ASCII code 127. + + ESC means press the "Escape" key. ESC is the same as C-[. This sends + ASCII code 27. + + SPC means press the "Space" key. This send ASCII code 32. + + TAB means press the "Tab" key. TAB is the same as C-i. This send ASCII + code 9. + + To read more about this online, type "C-h i m emacs RET m characters + RET", and also "C-h i m emacs RET m keys RET". + +2: What do you mean when you write things like this: type "ESC a"? + + I will enclose key sequences that are longer than one key inside double + quotes. These notations refer to single keys (some with modifiers): + + C-x, M-x, M-C-x + RET, LFD, DEL, ESC, SPC, TAB + + I separate these from other keys within double quotes by spaces. Any + real spaces that I write inside double quotes can be ignored, only SPC + means press the space key. All other characters within double quotes + represent single keys (some shifted). + +3: What if I don't have a Meta key? + + Instead of typing M-a, you can type "ESC a" instead. In fact, Emacs + converts M-a internally into "ESC a" anyway. + +4: What if I don't have an Escape key? + + Type C-[ instead. This should send ASCII code 27 just like an Escape + key would. + +5: What does "M-x command" mean? + + "M-x command" means type M-x, then type the name of the command, then + type RET. + + M-x is simply the default key sequence that invokes the command + "execute-extended-command". This command allows you to run any Emacs + command if you can remember the command's name. If you can't remember + the command's name, you can type TAB and SPC for completion, and ? for a + list of possibilities. An Emacs "command" is any "interactive" Emacs + function. + + NOTE: Your system administrator may have bound other key sequences to + invoke execute-extended-command. A function key labeled "Do" is a good + candidate for this. + + To run non-interactive Emacs functions, use M-ESC instead and type a + Lisp form. + +6: What do things like this mean: etc/SERVICE, src/config.h, + lisp/default.el? + + These are the names of files that are part of the GNU Emacs + distribution. The GNU Emacs distribution is so big that it is divided + into several subdirectories; the important subdirectories are named + "etc", "lisp", and "src". + + If you use GNU Emacs, but don't know where it is kept on your system, + start Emacs, then type "C-h v exec-directory RET". The directory name + that is displayed by this will be the full pathname of the "etc" + directory of your installed GNU Emacs distribution. + + Some of these files are available individually via FTP or e-mail, see + question 16. + +7: What are FSF, LPF, OSF, GNU, RMS, FTP, BTW, and GPL? + + FSF == Free Software Foundation + LPF == League for Programming Freedom + OSF == Open Software Foundation + GNU == GNU's Not Unix + RMS == Richard M. Stallman + FTP == File Transfer Protocol + BTW == By the way + GPL == GNU General Public Licence + + NOTE: Avoid confusing the FSF, the LPF, and the OSF. The LPF only + opposes look-and-feel copyrights and software patents. The FSF aims to + make high quality free software available for everyone. The OSF is a + commercial organization which wants to provide an alternative, + standardized version of Unix not controlled by AT&T. + + + +Sources of Information and Help + +8: I'm just starting GNU Emacs; how do I do basic editing? + + Type "C-h t" to invoke the self-paced tutorial. Typing just C-h is + how to enter the help system. + + WARNING: your system administrator may have changed C-h to act like DEL. + You can use M-x help-for-help instead to invoke help. To discover what + key (if any) invokes help on your system, type "M-x where-is RET + help-for-help RET". This will print a comma-separated list of key + sequences in the echo area. Ignore the last character in each key + sequence listed. Each of the resulting key sequences invokes help. + + NOTE: Emacs's help facility works best if help is invoked by a single + key. The variable help-char should hold the value of this character. + +9: How do I find out how to do something in GNU Emacs? + + There are several methods for finding out how to do things in Emacs. + + You should become familiar with the online documentation for Emacs. The + complete text of the Emacs manual is available online in a hypertext + format via the "Info" manual reader. Type "C-h i" to invoke Info. + + You can order a hardcopy of the manual from the FSF. See question 12. + + You can list all of the commands whose names contain a certain word + (actually which match a regular expression) using the "command-apropos" + command. Type "C-h a" to invoke this command. + + You can list all of the functions and variables whose names contain a + certain word using the "apropos" command. M-x apropos invokes this + command. + + You may find that command-apropos and apropos are extremely slow on your + system. This will be fixed in Emacs 19. If you can't wait that long, + I can send you the "fast-apropos.el" file that contains the fix. This + file also contains a "super-apropos" command that will list all the + functions and variables whose documentation strings contain a certain + word. + + There are many other commands in Emacs for getting help and information. + To get a list of these commands, type "C-h C-h C-h". + +10: Where can I get GNU Emacs on the net (or by snail mail)? + + Look in the files etc/DISTRIB and etc/FTP for information. If you don't + already have GNU Emacs, see question 16. + +11: Where can I get help in installing GNU Emacs? + + Look in the file etc/SERVICE for names of companies and individuals who + will sell you this type of service. + + This file in the version 18.55 distribution is not completely up to + date. The imminent release of 18.56 will help that. An up-to-date + version of the SERVICE file is available on prep.ai.mit.edu. See + question 16 for how to retrieve this file. + +12: How do I get a printed copy of the GNU Emacs manual? + + You can order a printed copy of the GNU Emacs manual from the FSF for + $15. A set of 6 manuals is $60. + + The full TeX source for the manual also comes with Emacs, if you're + daring enough to try to print out this 300 page manual yourself. (We're + talking about killing an entire tree here. This kind of printer usage + can make you very unpopular. Besides, if you order it from the FSF, the + price may be tax-deductible as a business expense.) + + If you absolutely have to print your own copy, and you don't have TeX, + you can get a PostScript version from: + + Anonymous FTP: + site: abcfd20.larc.nasa.gov + file: /pub/docs/emacs-18.55.PS.Z (size: 472K) + + Carl Witty writes: + + The Emacs manual is also available online in the Info system, which is + available by typing "C-h i". In this form, it has hypertext links and + is very easy to browse or search; many people prefer it to the printed + manual. + +13: Has someone written an GNU Emacs Lisp package that does XXX? + + Probably. A listing of Emacs Lisp packages, called the Lisp Code + Directory, is being maintained by Dave Brennan . + You can search through this list to find if someone has written + something that fits your needs. + + This list is file "LCD-datafile.Z" in the Emacs Lisp Archive. (See + question 14.) The files "lispdir.el.Z" and "lispdir.doc.Z" + in the archive contain information to help you use the list. + +14: Where can I get GNU Emacs Lisp packages that don't come with Emacs? + + First, check the Lisp Code Directory to find the name of the package you + are looking for. (See question 13). Then check local archives and + the Emacs Lisp Archive to find a copy of the relevant files. Then, if + you still haven't found it, you can send e-mail to the author asking for + a copy. + + You can access the Emacs Lisp Archive via: + + Anonymous FTP: + site: tut.cis.ohio-state.edu + directory: /pub/gnu/emacs/elisp-archive + file: README.Z + + NOTE: Any files with names ending in ".Z" are compressed, and you should + use "binary" mode in FTP to retrive them. You should also use binary + mode whenever you retrieve any files with names ending in ".elc". + + Submissions for the archive should be sent to Dave Sill . + If you have ftp access, the submission can be deposited in the directory + /pub/gnu/emacs/elisp-archive/incoming on tut.cis.ohio-state.edu. + Whenever possible submissions should contain an LCD-datafile entry since + this helps reduce administrative overhead for the maintainers. Before + submitting anything, first read the file "guidelines.Z", which is + available in the archive. + +15: Where can I get documentation on GNU Emacs Lisp? + + Obtain the GNU Emacs Lisp Reference Manual for Emacs 18 under Unix. It + is available from the FSF for $50. The latest revision is edition 1.02 + dated July 1990. + + Within Emacs, you can type "C-h f" to get the documentation for a + function, "C-h v" for a variable. + + Also, as a popular USENET saying goes, "Use the Force, Read the Source". + + You can also get the Texinfo source for the manual, if you are daring + enough to try to print this 550 page manual out yourself. This is + available in the Emacs Lisp Archive and also via: + + Anonymous FTP: + site: prep.ai.mit.edu + file: /pub/gnu/elisp.tar.Z + + A set of pregenerated Info files comes with the Texinfo source for the + Emacs Lisp manual, so you don't have to format it yourself for online + use. (You can create the Info files from the Texinfo source.) See + question 21 for details on how to install these files online. + +16: What informational files are available? + + This isn't a frequently asked question, but it should be! + + The following files are available in the "etc" directory of the GNU + Emacs distribution, and also the latest versions are available + individually via: + + Anonymous FTP: + site: prep.ai.mit.edu + directory: /pub/gnu/etc + + APPLE -- Special Report: Apple's New Look and Feel + DISTRIB -- GNU Emacs Availability Information, + including the popular "Free Software Foundation Order Form" + FTP -- How to get GNU Software by Internet FTP or by UUCP + GNU -- The GNU Manifesto + INTERVIEW -- Richard Stallman discusses his public-domain + UNIX-compatible software system + with BYTE editors + MACHINES -- Status of GNU Emacs on Various Machines and Systems + MAILINGLISTS -- GNU Project Electronic Mailing Lists + SERVICE -- GNU Service Directory + SUN-SUPPORT -- includes the popular "Using Emacstool with GNU Emacs" + + These files are available in the "etc" directory of the GNU Emacs + distribution: + + DIFF -- Differences between GNU Emacs and Twenex Emacs + CCADIFF -- Differences between GNU Emacs and CCA Emacs + GOSDIFF -- Differences between GNU Emacs and Gosling (Unipress??) Emacs + COPYING -- GNU Emacs General Public License + NEWS -- GNU Emacs News, a history of user-visible changes + + In addition, all of the above files are available directly from the FSF + via e-mail. Of course, please try to get them from a local source + first. + + These files are available from the FSF via e-mail: + + * GNU's Bulletin, June, 1990 -- this file includes: + GNU'S Who + What Is the Free Software Foundation? + What Is Copyleft? + GNUs Flashes + Possible New Terms for GNU Libraries by Richard Stallman + "League for Programming Freedom" by Michael Bloom and Richard Stallman + Free Software Support + GNU Project Status Report + GNU Wish List + GNU Documentation + GNU Software Available Now + Contents of the Emacs Release Tape + Contents of the Pre-Release Tape + Contents of the X11 Tapes + VMS Emacs and Compiler Tapes + How to Get GNU Software + Freemacs, an Extensible Editor for MS-DOS + Thank GNUs + FSF Order Form + * GNU Task List + * GNU Coding Standards + * Legal issues about contributing code to GNU + * GNU Project Status Report + +17: What is the current address of the FSF? + + Snail mail address: + Free Software Foundation + 675 Massachusetts Avenue + Cambridge, MA 02139, USA + + Phone number: + (617) 876-3296 + + E-mail addresses: + gnu@prep.ai.mit.edu {probably read by Len Tower} + gnulists@prep + +18: What is the current address of the LPF? + + Snail mail address: + League for Programming Freedom + 1 Kendall Square, Number 143 + Post Office Box 9171 + Cambridge, MA 02139, USA + + Phone number: + (617) 243-4061 { or 243-4091, I'm not sure ... } + + E-mail address: + league@prep.ai.mit.edu + +19: Where can I get the up-to-date GNU stuff? + + The most up-to-date official GNU stuff is normally kept on + prep.ai.mit.edu and is available for anonymous FTP. See the files + etc/DISTRIB and etc/FTP for more information. (To get copies of these + files, see question 16.) + +20: Where can I get the latest VM, Supercite, GNUS, Calc, Calendar, or Patch? + + 1. VM: + + Author: Kyle Jones + + Mailing lists: info-vm-request@uunet.uu.net + info-vm@uunet.uu.net + bug-vm-request@uunet.uu.net + bug-vm@uunet.uu.net + + Anonymous FTP: + + Last released version: 4.41 + site: tut.cis.ohio-state.edu + file: /pub/gnu/vm/vm-4.41.tar.Z + + Beta test version: 5.18 + site: abcfd20.larc.nasa.gov + directory: /pub/vm + + 2. Supercite: + + Author: Barry Warsaw + + Latest version: 2.1 + + Mailing lists: supercite@warsaw.nlm.nih.gov + supercite-request@warsaw.nlm.nih.gov + + Anonymous FTP: + site: durer.cme.nist.gov [129.6.32.4] + files:/pub/gnu/elisp/supercite-2.1.shar.0# (where # is replaced by 1 or 2) + + NOTE: Superyank is an old version of Supercite. + + 3. GNUS: + + Author: Masanobu Umeda + + Latest version: 3.13 + + Anonymous FTP: + site: tut.cis.ohio-state.edu + files: /pub/gnu/gnus/3.13.##-of-11.Z (where ## is replaced by 00 -- 11) + + 4. Calc: + + Author: Dave Gillespie + + Latest version: 1.06 + + Anonymous FTP: + site: csvax.cs.caltech.edu [131.215.131.131] + or any comp.sources.misc archive + + 5. Calendar/Diary + + Author: Ed Reingold + + Latest version: 4 + + E-mail: + Subject: send-emacs-cal + body: your best internet e-mail address + + 6. Patch + + Author: Larry Wall + + Latest version: 2.0 patchlevel 12 + + Anonymous FTP: + site: any comp.sources.unix archive + + or, for Europeans: + + site: archive.cs.ruu.nl [131.211.80.5] + file: /pub/UNIX/patch-2.0.tar.Z + +21: How do I install a piece of Texinfo documentation? + + First create Info files from the Texinfo files with M-x + texinfo-format-buffer. There is also a program called "makeinfo" that + provides better error checking and runs faster. Currently, it comes + with the Emacs Lisp manual (which comes on the GNU Emacs tape). + + For information about the Texinfo format, read the Texinfo manual which + comes with Emacs. This manual also comes installed in Info format, so + you can read it online. + + Neither texinfo-format-buffer nor the makeinfo program install the + resulting Info files in Emacs's Info tree. To install Info files: + + 1. Move the files to the "info" directory in the installed Emacs + distribution. See question 6 if you don't know where that + is. + + 2. Edit the file info/dir in the installed Emacs distribution, and add a + line for the top level node in the Info package that you are + installing. + +22: What is the real legal meaning of the GNU copyleft? + + RMS writes: + + The legal meaning of the GNU copyleft is less important than the spirit, + which is that Emacs is a free software project and that work pertaining + to Emacs should also be free software. "Free" means that all users have + the freedom to study, share, change and improve Emacs. To make sure + everyone has this freedom, pass along source code when you distribute + any version of Emacs or a related program, and give the recipients the + same freedom that you enjoyed. + + If you still want to find out about the legal meaning of the copyleft, + please ask yourself if this means you are not paying attention to the + spirit. + +23: What are appropriate messages for gnu.emacs.help/gnu.emacs.bug/comp.emacs + etc.? + + The file etc/MAILINGLISTS discusses the purpose of each GNU + mailing-list. (See question 16 on how to get a copy.) For + those which are gatewayed with newsgroups, it lists both the newsgroup + name and the mailing list address. + + comp.emacs is for discussion of Emacs programs in general. This + includes GNU Emacs along with various other implementations like JOVE, + MicroEmacs, Freemacs, MG, Unipress, CCA, etc. + + Many people post GNU Emacs questions to comp.emacs because they don't + receive any of the gnu.* newsgroups. Arguments have been made both for + and against posting GNU-Emacs-specific material to comp.emacs. You have + to decide for yourself. + +24: Should I send questions directly to people who post a lot on the net, + instead of posting myself? + + I don't know about the others, but please don't send such messages to me + just because you don't want to disturb a lot of people. Send messages + to individuals that concern things that individual has written. + + + +GNU Emacs, all its Variants, and other Editors + +25: Where does the name "Emacs" come from? + + EMACS originally was an acronym for Editor MACroS. The first Emacs was + a set of macros written by Richard Stallman for the editor TECO (Tape + Editor and COrrector {Text Editor and COrrector?}) on a PDP-10. + (Amusing fact: many people have told me that TECO code looks a lot like + line noise.) + +26: What is the latest version of GNU Emacs? + + GNU Emacs 18.55. GNU Emacs 18.56 is coming out with some bug fixes, but + no additional functionality. + +27: When will GNU Emacs 19 be available? + + Good question, I don't know. For that matter, neither do the + developers. It will undoubtedly be available sometime in the 1990s. + +28: What will be different about GNU Emacs 19? + + From the latest "GNU's Bulletin": + + Version 19 approaches release with a host of new features: before and + after change hooks; X selection processing (including CLIPBOARD + selections); scrollbars; support for European character sets; floating + point numbers; per-buffer mouse commands; interfacing with the X + resource manager; mouse-tracking; Lisp-level binding of function keys; + and multiple X windows (`screens' to Emacs). + + Thanks go to Alan Carroll and the people who worked on Epoch for + generating initial feedback to a multi-windowed Emacs. Emacs 19 + supports two styles of multiple windows, one with a separate screen for + the minibuffer, and another with a minibuffer attached to each screen. + + More features of Version 19 are buffer allocation, which uses a new + mechanism capable of returning storage to the system when a buffer is + killed, and a new input system---all input now arrives in the form of + Lisp objects. + + Other features being considered for Version 19 include: + + * Associating property lists with regions of text in a buffer. + * Multiple font, color, and pixmaps defined by those properties. + * Different visibility conditions for the regions, and for the various + windows showing one buffer. + * Incremental syntax analysis for various programming languages. + * Hooks to be run if point or mouse moves outside a certain range. + * Source-level debugging for Emacs Lisp. + * Incrementally saving undo history in a file, so that recover-file also + reinstalls buffer's undo history. + * Static menu bars, and better pop-up menus. + * A more sophisticated emacsclient/server model, which would provide + network transparent Emacs widget functionality. + + Also, Emacs 19 will have a Emacs Lisp source code debugger. + +29: Is there an Emacs that has better mouse and X window support? + + Emacs 18 has some limited X Window System support, but there are + problems. Emacs 19 will have amazing mouse and window support. Right + now, there is a modified version of Emacs 18.55 called "Epoch" which has + greatly improved mouse and window support. The latest version of Epoch + is available via: + + Anonymous FTP: + site: cs.uiuc.edu + directory: pub/epoch-files/epoch + file: epoch-3.2b (b stands for beta) + + NOTE: Epoch only works with the X Window System; it does not work on + ordinary terminals. + +30: How do I get Emacs for my PC? + + GNU Emacs won't run on a PC directly under MS-DOS. There have been + reports of people running GNU Emacs under a special program under MS-DOS + on 286 or 386 machines, but I don't know the details. + + You can try a variety of similar programs such as MG, MicroEmacs, + Freemacs, etc. + + Russ Nelson , the author, describes + Freemacs: + + * Freemacs is free, and it was designed from the start to be + programmable. + * Freemacs is the only IBM-PC editor that tries to be like GNU Emacs. + * Freemacs can only edit files less than 64K in length. + * Freemacs doesn't have undo. + + Carl Witty writes about Freemacs: + + Better is Freemacs, which follows the tradition of ITS and GNU Emacs + by having an full, turing-complete extension language which is + incompatible with everything else. In fact, it's even closer to ITS + Emacs than GNU Emacs is, because Mint (Freemacs' extension language) + is absolutely illegible without weeks of study, much like TECO. + + You can get Freemacs several ways: + + 1. Anonymous FTP: + site: simtel20.army.mil, directory: PD: + site: grape.ecs.clarkson.edu [128.153.13.196], directory: /e/freemacs + + 2. E-mail: + address: archive-server@sun.soe.clarkson.edu, or + archive-server%sun.soe@omnigate (BITNET), or + {smart-host}!sun.soe.clarkson.edu!archive-server (UUCP) + body: help + + 3. Snail mail: + address: Russell Nelson, 11 Grant St., Potsdam, NY 13676 + Send $15 copying fee, and specify preferred floppy disk format: + 5.25", 1.2 Meg, or 5.25", 360K, or 3.50", 720K + + I don't know much about MicroEmacs. All I know is that the latest + version is 3.10 and it is available via: + + Anonymous FTP: + site: durer.cme.nist.gov + + Another Emacs for small machines is Jove (Jonathan's Own Version of + Emacs). The latest version is 4.9. It is available via: + + Anonymous FTP: + sites: hipl.psych.nyu.edu, cs.toronto.edu, cayuga.cs.rochester.edu + + Yet another Emacs is "mg", which used to stand for MicroGNUEmacs, but + now just stands for "mg". It is available via: + + Anonymous FTP: + site: snow.white.toronto.edu + +31: Where can I get Emacs for my Atari ST? + + The latest version for the ST is available via: + + Anonymous FTP: + site: cs.uni-sb.de [134.96.7.254] + directory: /pub/atari/emacs + +32: Where can I get Emacs with NeWS support? + + Chris Maio's NeWS support package for GNU Emacs is available via: + + Anonymous FTP: + site: columbia.edu + file: /pub/ps-emacs.tar.Z + + site: tut.cis.ohio-state.edu + file: /pub/gnu/emacs/ps-emacs.tar.Z + + + +Binding Keys to Commands + +33: Why does my key binding fail? + + Most likely, it failed because "ESC [" was already defined. Evaluate + this form first: + + (define-key esc-map "[" nil) + +34: Why doesn't this [terminal or window-system setup] code work in my + .emacs file, but it works just fine after Emacs starts up? + + This is because you're trying to do something in your .emacs file that + needs to be postponed until after the terminal/window-system setup code + is loaded. This is a result of the order in which things are done + during the startup of Emacs. + + In order to postpone the execution of Emacs Lisp code until after the + terminal/window-system setup, set the value of the variable + term-setup-hook or window-setup-hook to be a function which does what + you want. + + See question 72 for a complete explanation of what Emacs + does every time it is started. + + Here is a simple example of how to set term-setup-hook: + + (setq term-setup-hook + (function + (lambda () + (if (string-match "^vt220" (or (getenv "TERM") "")) + ;; Make vt220's "Do" key behave like M-x: + (define-key CSI-map "29~" 'execute-extended-command))))) + +35: How do I use function keys under X Windows? + + If compiled on a Sun, Emacs recognizes the function keys that are + normally on a Sun keyboard, and you can bind them the same way you + normally bind Sun keys. Each function key will generate a key sequence + that looks like "ESC [ ### z", where ### is replaced by a number. + + If not compiled on a Sun, the function keys will appear to Emacs in a + way remarkably similar to the keys of a VT220 terminal. Each function + key will generate a key sequence that looks like "ESC [ ### ~". + + For the complete list of the numbers which are generated by the function + keys, look in the file src/x11term.c. + + However, this may be inadequate for you if you have function keys Emacs + doesn't know about. Johan Vromans explains: + + There are a number of tricks that can be helpful. The most elegant + solution, however, is to use the function "x-rebind-key". This function + is commented out in the source for good reasons --- it's buggy. + + It is rather easy to replace this function with the function + epoch:rebind-key from the Epoch distribution. + + After implementing this, all keyboard keys can be configured to send + user definable sequences, e.g. + + (x-rebind-key "KP_F1" 0 "\033OP") + + This will have the keypad key PF1 send the sequence \eOP, just like an + ordinary VTxxx terminal. + + Another method is to handle the keys in the C source. Although this may + be slightly more efficient, it is much less flexible. + + Finally, some people have established a convention to have the special + keys send a sequence of characters that indicate the key and its + modifiers instead of a plain escape sequence. This is also a good + method. The advantage of sending the plain escape sequences is that you + require only one setup for Emacs running under X and on normal + terminals, e.g. + + (x-rebind-key "KP_F1" 0 "\033OP") + + will have key PF1 send \eOP, and, probably in another setup file: + + (global-set-key "\eOP" 'specific-function) + + to bind PF1 to a function. The last statement applies for normal VTxxx + terminal also. + +36: How do I tell what characters my function keys emit? + + Use this function by Randal L. Schwartz : + + (defun see-chars () + "Displays characters typed, terminated by a 3-second timeout." + (interactive) + (let ((chars "") + (inhibit-quit t)) + (message "Enter characters, terminated by 3-second timeout.") + (while (not (sit-for 3)) + (setq chars (concat chars (list (read-char))) + quit-flag nil)) ; quit-flag maybe set by C-g + (message "Characters entered: %s" (key-description chars)))) + + + +Problems with Key Bindings and Input + +37: Why does Emacs spontaneously go into "I-search:" mode? + + Your terminal (or something between your terminal and the computer) is + sending C-s and C-q for flow control, and Emacs is receiving these + characters and interpreting them as commands. (The C-s character + normally invokes the isearch-forward command.) + + For a more detailed discussion, read the file PROBLEMS in the Emacs + distribution. + +38: What do I do if my terminal is sending C-s and C-q for flow control and + I can't disable it? + + Use this piece of Emacs Lisp: + + (set-input-mode nil t) + +39: How do I make Emacs use C-s and C-q for flow control instead of for + commands? + + Same answer as previous question. + +40: How do I use commands bound to C-s and C-q (or any key) if these keys + are filtered out? + + I suggest swapping C-s with C-\ and C-q with C-^: + + (swap-keys ?\C-s ?\C-\\) + (swap-keys ?\C-q ?\C-^) + + See question 41 for the implementation of swap-keys. + +41: How do I "swap" two keys? + + When Emacs receives a character, you can make Emacs behave as though it + received another character by setting the value of + keyboard-translate-table. The following Emacs Lisp will do this for + you, allowing you to "swap" keys. + + WARNING: the value of C-g (7) is hard coded in several places both + before and after the translation specified by keyboard-translate-table + is carried out. Thus, swapping C-g with another key may cause problems; + rebinding C-g may also cause problems. (Well, I've never done it, so I + don't know for sure.) + + (defun swap-keys (key1 key2) + "Swap keys KEY1 and KEY2 using map-key." + (map-key key1 key2 t) + (map-key key2 key1)) + + (defvar map-keys-alist nil + "Association list of key mappings currently in effect. + If (FROM . TO) is an element, that means key FROM is currently mapped to TO.") + + (defun map-key (from to &optional no-update) + "Make key FROM behave as though key TO was typed instead. + If optional argument NO-UPDATE is non-nil, the key-mapping does not take + effect until a subsequent map-key or unmap-key." + (let ((alist-entry (assq from map-keys-alist))) + (if alist-entry + (setcdr alist-entry to) + (setq map-keys-alist (cons (cons from to) map-keys-alist)))) + (or no-update (map-keys-update))) + + (defun unmap-key (key) + "Undo any mapping of key KEY." + (setq map-keys-alist (delq (assq key map-keys-alist) map-keys-alist)) + (map-keys-update)) + + ;; Makes keyboard-translate-table reflect the key mappings in + ;; map-keys-alist. + + (defun map-keys-update () + (if (null map-keys-alist) + ;; Emacs runs fasted if keyboard-translate-table is nil + (setq keyboard-translate-table nil) + (let ((max-key-mapped + ;; Find the mapped key with largest value + (apply 'max + (mapcar + (function + (lambda (x) + (car x))) + map-keys-alist))) + (i 0)) + ;; keyboard-translate-table doesn't have to be any longer than + ;; necessary. This speeds up Emacs. + (setq keyboard-translate-table (make-string (1+ max-key-mapped) 0)) + (while (<= i max-key-mapped) + (aset keyboard-translate-table i (or (cdr (assq i map-keys-alist)) i)) + (setq i (1+ i)))))) + +42: Why does the "Backspace" key invoke help? + + The Backspace key (on every keyboard I've used) sends ASCII code 8. C-h + sends the same code. In Emacs by default C-h invokes "help-command". + The easiest solution to this problem is to use C-h (and Backspace) for + help and DEL (the Delete key) for deleting the previous character. + + For some people this solution may be problematic: + + 1. They normally use Backspace outside of Emacs for deleting the + previous character typed. This can be solved by making DEL be the + command for deleting the previous character outside of Emacs. This + command will do this on many Unix systems: + + stty erase ^? + + 2. The person may prefer using the Backspace key for deleting the + previous character because it is more conveniently located on their + keyboard or because they don't even have a separate Delete key. In + this case, the best solution is to swap C-h and DEL: + + (swap-keys ?\C-h ?\C-?) + + See question 41 for the implementation of swap-keys. + +43: How do I type DEL on PC terminal emulators? + + Someone whose name I forgot wrote: + + Most PCs have deficient keyboards that don't have both Backspace and + Delete keys. Whether C-h (backspace) or DEL is generated by the + "Backspace" key varies from one terminal emulator to another. If you're + lucky, you can reconfigure the keyboard so that it generates DEL. If + not, you will have to hunt to figure out what keystroke will do it --- + possibilities include various shifted and controlled versions of + "Backspace", the "Del" key on the numeric keypad (which might depend on + "Shift" or "NumLock"), or perhaps C-? (Control-?). + + If this is too hard, you may want to swap the delete key with some other + key. See question 42. + + + +Building/Installing/Porting Emacs and Machine/OS-Specific Bugs: + +44: Why do I get an "f68881_used undefined" error, when I build Emacs on my + Sun 3? + + Barry A. Warsaw writes: + + Some of the code that is being linked on the "ld" line of emacs' + build command has been compiled with the -f68881 option. Most + common reason is that you're linking with X libraries which were + built with -f68881 option set. You need to either remove all + dependencies to the 68881 (may mean a recompile of the X libraries + with -fswitch or -fsoft option), or you need to link emacs with + the 68881 startup file /usr/lib/Mcrt1.o. Make this change to + src/ymakefile: + + change: #define START_FILES crt0.o + to: #define START_FILES crt0.o /usr/lib/Mcrt1.o + + The order of these start files is critical. + +45: Why does Emacs crash under SunOS 4.1? + + Under SunOS 4.1, Emacs dies with this message: + + Fatal error (6).Abort + + There is a bug in the "localtime" routine supplied with SunOS 4.1. + A private function called by tzsetwall zeroes the byte just past an + eight byte region it mallocs. This corrupts GNU malloc's memory pool. + + Put "#define SYSTEM_MALLOC" in src/config.h. + + Or, for the purists: + + Put "#define SUNOS_LOCALTIME_BUG" in src/config.h and apply the following + patch to src/malloc.c. + + (Patch by Eirik Fuller .) + + >*** malloc.c~ Fri Apr 7 22:12:10 1989 + >--- malloc.c Tue May 8 07:07:22 1990 + >*************** + >*** 476,482 **** + >--- 476,487 ---- + > multiple of 8, then figure out which nestf[] area to use. + > Both the beginning of the header and the beginning of the + > block should be on an eight byte boundary. */ + >+ #ifdef SUNOS_LOCALTIME_BUG + >+ /* SunOS 4.1 localtime scribbles on the ninth byte. */ + >+ nbytes = (n + ((sizeof *p + 15) & ~15) + EXTRA + 15) & ~15; + >+ #else + > nbytes = (n + ((sizeof *p + 7) & ~7) + EXTRA + 7) & ~7; + >+ #endif + > { + > register unsigned int shiftr = (nbytes - 1) >> 2; + > + +46: Why does Emacs occasionally cause segmentation faults and machine + panics on my DECstation 3100? + + Bruce Cole writes: + + > We're running Emacs 18.54 on an Ultrix Risc DECsystem 5400. Three + > times we've had the machine hang with the following message: + > + > panic: tblmod on invalid pte + > + > Ultrix support tells us this is caused by Emacs. Has anyone + > experienced this? DEC says it only happens on RISC boxes. + + This is due to a MIPS specific Ultrix kernel bug. I sent DEC a + description of the bug with a bug fix. The Kernel bug manifests itself + with Emacs since Emacs uses a non-standard data start address on Ultrix + MIPS machines. + + I haven't often seen Emacs cause MIPS machines to panic. Usually you + just see one of the following errors when you try to start up Emacs: + + segmentation fault (core dumped) + emacs: Bad address + Out of memory + data size rlimit exceeded, pid 6523, process tcsh (for example) + + Until DEC fixes their kernel, you can avoid the bug by changing the data + start address used by Emacs. + + > I have built two newer versions of GNU Emacs and it still happens. I + > should also mention that these faults happen quite rarely to some + > users (I may see it once a month), while other users see it a few + > times a week or even daily! + + The problem only occurs when a MIPS machine is doing a lot of paging. + Users who don't cause their workstation to page will not see this + problem. + + Patch to GNU Emacs 18.55: + + >*** m-pmax.h Thu Jun 8 11:53:55 1989 + >--- m-pmax.h.new Mon Jul 9 10:21:21 1990 + >*************** + >*** 1,3 **** + >--- 1,7 ---- + > #include "m-mips.h" + > #undef LIBS_MACHINE + > #undef BIG_ENDIAN + >+ #undef LD_SWITCH_MACHINE + >+ #undef DATA_START + >+ #define DATA_START 0x10000000 + >+ #define DATA_SEG_BITS 0x10000000 + +47: How do I get Emacs running on VMS under DECwindows? + + Hal R. Brand is said to have a VMS save set with + a ready-to-run VMS version of Emacs for X Windows. It is available via: + + Anonymous FTP: + site: addvax.llnl.gov + + Johan Vromans writes: + + Getting Emacs to run on VMS with DECwindows requires a number of changes + to the sources. Fortunately this has been done already. Joshua Marantz + did most of the work for Emacs 18.52, and the mods + were ported to 18.55 by Johan Vromans . Also included is the + handling of DEC's LK201 keyboard. You need to apply the changes to a + fresh Emacs 18.55 distribution on a Unix system, and then you can copy + the sources to VMS to perform the compile/link/build. + + The set of changes have been posted a number of times three times the + last 12 months, so they should be widely available. + +48: Why won't src/alloc.c compile on a SPARCstation? + + {Could someone send me a better description of the symptoms ... Does it + really not compile, or does it refuse to link, or does it die when it's + run?} + + An object in src/alloc.c is declared as an array of char. However, on a + SPARCstation, this object must be aligned on a longword boundary. + gcc will align this object not on a longword boundary because it thinks + this is ok because the object is an array of char. + + Here is a solution: + + (Patch from the Epoch source code.) + + >*** dist-18.55.dist/src/alloc.c Mon Feb 13 05:23:35 1989 + >--- dist-18.55/src/alloc.c Mon Nov 27 23:30:13 1989 + >*************** + >*** 665,673 **** + > #define NSTATICS 200 + > + >- char staticvec1[NSTATICS * sizeof (Lisp_Object *)] = {0}; + >- + > int staticidx = 0; + > + > #define staticvec ((Lisp_Object **) staticvec1) + > + > /* Put an entry in staticvec, pointing at the variable whose address is given */ + >--- 665,676 ---- + > #define NSTATICS 200 + > + > int staticidx = 0; + > + >+ #ifdef __GNUC__ + >+ Lisp_Object *staticvec[NSTATICS] = {0}; + >+ #else + >+ char staticvec1[NSTATICS * sizeof (Lisp_Object *)] = {0}; + > #define staticvec ((Lisp_Object **) staticvec1) + >+ #endif + > + > /* Put an entry in staticvec, pointing at the variable whose address is given */ + + {Does anyone understand why one might want to declare staticvec as an + array of char instead of an array of LispObject?} + +49: Why do shells started from Emacs suspend themselves under SunOS 4.1? + + In SunOS 4.1, when subprocesses are started by an Emacs process started + by "rsh", the process stops with a message like this: + + Process shell stopped (tty input) + + SunOS 4.1 uses the POSIX standard's specification for job control. + Basically, a process must be a session leader to acquire a new + controlling terminal. + + A quick fix is to run Emacs as "/usr/etc/setsid emacs" instead. + + To fix it in Emacs, use this patch: + + (Patch by Eirik Fuller .) + + >*** /tmp/,RCSt1a12635 Fri Jul 6 11:29:10 1990 + >--- process.c Sat Jun 16 14:04:55 1990 + >*************** + >*** 1031,1036 **** + >--- 1031,1039 ---- + > int j = open ("/dev/tty", O_RDWR, 0); + > ioctl (j, TIOCNOTTY, 0); + > close (j); + >+ #ifndef USG + >+ setpgrp (0, 0); + >+ #endif + > } + > #endif /* TIOCNOTTY */ + > + +50: Why does Emacs crash from a bus error in XLookupString under OpenLook? + + The Sun OpenLook libraries use the XComposeStatus parameter on + XLookupString for composing key sequences. I'm told this is actually + supposed to be an optional parameter. + + (Patch by David J. MacKenzie .) + + >*** dist-18.55.dist/src/x11term.c Wed Aug 2 21:56:42 1989 + >--- dist-18.55/src/x11term.c Fri Jul 13 19:22:32 1990 + >*************** + >*** 1213,1216 **** + >--- 1213,1218 ---- + > #endif /* not sun */ + > + >+ static XComposeStatus status; + >+ + > internal_socket_read(bufp, numchars) + > register unsigned char *bufp; + >*************** + >*** 1223,1227 **** + > BLOCK_INPUT_DECLARE (); + > XEvent event; + >- XComposeStatus status; + > KeySym keysym; + > + >--- 1225,1228 ---- + >*************** + >*** 1330,1334 **** + > nbytes = XLookupString (&event, + > mapping_buf, 20, &keysym, + >! 0); + > /* Someday this will be unnecessary as we will + > be able to use XRebindKeysym so XLookupString + >--- 1331,1335 ---- + > nbytes = XLookupString (&event, + > mapping_buf, 20, &keysym, + >! &status); + > /* Someday this will be unnecessary as we will + > be able to use XRebindKeysym so XLookupString + +51: Why doesn't "C-c C-c" interrupt subprocesses under HP/UX? + + Paul Stravers writes: + + In HP/UX we can (must) combine the two distinct calls + 1. ioctl (fildes, TIOCGPGRP, &gid); + 2. kill (-gid, signo); + into the single call + 1+2. ioctl (fildes, TIOCSIGSEND, signo); + + This is apparently the case under at least HP/UX versions 6.5 and 7.0. + + Here is a set of patches courtesy of Piet van Oostrum + that fixes these problems: + + 1. Signals to child processes work now (like the C-c C-c mentioned above) + + 2. When running under X11, C-g now correctly interrupts long-running commands + + 3. When running under X11, the window is redislayed even if emacs is doing + some work (e.g. if your window becomes visible after being behind another + one. + + 4. A nasty bug in alloca is solved. This bug is very infrequent unless you + apply the other patches. + + {I don't know for sure whether all of these patches are applicable only + under HP/UX. Perhaps someone can tell me.} + + >*** alloca.s.~1~ Fri Sep 15 16:35:39 1989 + >--- alloca.s Tue May 1 17:18:08 1990 + >*************** + >*** 92,103 **** + > sub.l &MAXREG*4,%d1 # space for saving registers + > mov.l %d1,%sp # save new value of sp + > tst.b PROBE(%sp) # create pages (sigh) + > move.w &MAXREG-1,%d0 + > copy_regs_loop: /* save caller's saved registers */ + >! mov.l (%a1)+,(%sp)+ + > dbra %d0,copy_regs_loop + >! mov.l %sp,%d0 # return value + >! mov.l %d1,%sp + > add.l &-4,%sp # adjust tos + > jmp (%a0) # rts + > #endif /* new hp assembler */ + >--- 92,105 ---- + > sub.l &MAXREG*4,%d1 # space for saving registers + > mov.l %d1,%sp # save new value of sp + > tst.b PROBE(%sp) # create pages (sigh) + >+ mov.l %a2,%d1 # save reg a2 + >+ mov.l %sp,%a2 + > move.w &MAXREG-1,%d0 + > copy_regs_loop: /* save caller's saved registers */ + >! mov.l (%a1)+,(%a2)+ + > dbra %d0,copy_regs_loop + >! mov.l %a2,%d0 # return value + >! mov.l %d1,%a2 # restore a2 + > add.l &-4,%sp # adjust tos + > jmp (%a0) # rts + > #endif /* new hp assembler */ + + >*** keyboard.c.~1~ Wed Apr 4 14:53:49 1990 + >--- keyboard.c Thu Apr 26 14:46:27 1990 + >*************** + >*** 719,724 **** + >--- 719,773 ---- + > errno = old_errno; + > } + > + >+ #ifdef HPUX + >+ /* tells if an alarm is outstanding for emptying the socket */ + >+ int socket_alarm; + >+ + >+ static void + >+ empty_socket_interrupt() + >+ { + >+ int nread; + >+ char buf[256 * BUFFER_SIZE_FACTOR]; + >+ register int i; + >+ int old_errno = errno; + >+ + >+ if (waiting_for_input) return; + >+ + >+ fcntl (fileno (stdin), F_SETFL, O_NDELAY); + >+ + >+ /* Read what is waiting. */ + >+ + >+ nread = (*read_socket_hook) (0, buf, sizeof buf); + >+ + >+ #ifdef EBADSLT + >+ if (nread == -1 && (errno == EAGAIN || errno == EBADSLT)) + >+ #else + >+ if (nread == -1 && errno == EAGAIN) + >+ #endif + >+ nread = 0; + >+ + >+ fcntl (fileno (stdin), F_SETFL, 0); + >+ + >+ /* Scan the chars for C-g and store them in kbd_buffer. */ + >+ kbd_ptr = kbd_buffer; + >+ for (i = 0; i < nread; i++) + >+ { + >+ kbd_buffer_store_char (buf[i]); + >+ /* Don't look at input that follows a C-g too closely. + >+ This reduces lossage due to autorepeat on C-g. */ + >+ if (buf[i] == Ctl ('G')) + >+ break; + >+ } + >+ + >+ /* reestablish interrupt */ + >+ signal (SIGALRM, empty_socket_interrupt); + >+ alarm (1); + >+ + >+ errno = old_errno; + >+ } + >+ + >+ #endif /* HPUX */ + >+ + > /* read a character from the keyboard; call the redisplay if needed */ + > /* commandflag 0 means do not do auto-saving, but do do redisplay. + > -1 means do not do redisplay, but do do autosaving. + >*************** + >*** 733,738 **** + >--- 782,794 ---- + > Lisp_Object tem; + > extern request_echo (); + > + >+ #ifdef HPUX + >+ if (socket_alarm) { + >+ alarm (0); + >+ socket_alarm = 0; + >+ } + >+ #endif + >+ + > if ((c = unread_command_char) >= 0) + > { + > unread_command_char = -1; + >*************** + >*** 869,874 **** + >--- 925,938 ---- + > } + > } + > + >+ #ifdef HPUX + >+ if (read_socket_hook) { + >+ socket_alarm = 1; + >+ signal (SIGALRM, empty_socket_interrupt); + >+ alarm (1); + >+ } + >+ #endif + >+ + > return c; + > } + > + >*************** + >*** 1094,1119 **** + > + > #else /* no FIONREAD */ + > #ifdef USG + > if (kbd_count) + > abort (); + > + > fcntl (fileno (stdin), F_SETFL, O_NDELAY); + >! kbd_ptr = kbd_buffer; + > if (read_socket_hook) + >! { + >! kbd_count = (*read_socket_hook) (0, kbd_buffer, sizeof kbd_buffer); + >! } + > else + >! { + >! kbd_count = read (fileno (stdin), kbd_buffer, sizeof kbd_buffer); + >! } + > #ifdef EBADSLT + >! if (kbd_count == -1 && (errno == EAGAIN || errno == EBADSLT)) + > #else + >! if (kbd_count == -1 && errno == EAGAIN) + > #endif + >! kbd_count = 0; + > fcntl (fileno (stdin), F_SETFL, 0); + > #else /* not USG */ + > you lose + > #endif /* not USG */ + >--- 1158,1209 ---- + > + > #else /* no FIONREAD */ + > #ifdef USG + >+ char buf[256 * BUFFER_SIZE_FACTOR]; + >+ register int i; + >+ #ifdef HPUX + >+ int mask; + >+ #endif + >+ + > if (kbd_count) + > abort (); + > + >+ #ifdef HPUX + >+ if (socket_alarm) + >+ mask = sigblock (sigmask (SIGALRM)); + >+ #endif + >+ + > fcntl (fileno (stdin), F_SETFL, O_NDELAY); + >! + >! /* Read what is waiting. */ + > if (read_socket_hook) + >! nread = (*read_socket_hook) (0, buf, sizeof buf); + > else + >! nread = read (fileno(stdin), buf, sizeof buf); + > #ifdef EBADSLT + >! if (nread == -1 && (errno == EAGAIN || errno == EBADSLT)) + > #else + >! if (nread == -1 && errno == EAGAIN) + > #endif + >! nread = 0; + >! + > fcntl (fileno (stdin), F_SETFL, 0); + >+ + >+ /* Scan the chars for C-g and store them in kbd_buffer. */ + >+ kbd_ptr = kbd_buffer; + >+ for (i = 0; i < nread; i++) + >+ { + >+ kbd_buffer_store_char (buf[i]); + >+ /* Don't look at input that follows a C-g too closely. + >+ This reduces lossage due to autorepeat on C-g. */ + >+ if (buf[i] == Ctl ('G')) + >+ break; + >+ } + >+ + >+ #ifdef HPUX + >+ if (socket_alarm) + >+ sigsetmask(mask); + >+ #endif + >+ + > #else /* not USG */ + > you lose + > #endif /* not USG */ + + >*** x11term.h~ Fri Sep 15 15:20:26 1989 + >--- x11term.h Thu Apr 26 14:03:25 1990 + >*************** + >*** 11,17 **** + >--- 11,22 ---- + > #define sigmask(no) (1L << ((no) - 1)) + > #endif + > + >+ #ifdef HPUX + > #define BLOCK_INPUT_DECLARE() int BLOCK_INPUT_mask + >+ #define BLOCK_INPUT() BLOCK_INPUT_mask = sigblock (sigmask (SIGALRM)) + >+ #define UNBLOCK_INPUT() sigsetmask (BLOCK_INPUT_mask) + >+ #else /* not HPUX */ + >+ #define BLOCK_INPUT_DECLARE() int BLOCK_INPUT_mask + > #ifdef SIGIO + > #define BLOCK_INPUT() BLOCK_INPUT_mask = sigblock (sigmask (SIGIO)) + > #define UNBLOCK_INPUT() sigsetmask (BLOCK_INPUT_mask) + >*************** + >*** 19,23 **** + >--- 24,29 ---- + > #define BLOCK_INPUT() + > #define UNBLOCK_INPUT() + > #endif /* SIGIO */ + >+ #endif /* HPUX */ + > + > #define CLASS "emacs" /* class id for GNU Emacs, used in .Xdefaults, etc. */ + + >*** process.c.orig Fri Sep 15 16:28:36 1989 + >--- process.c Fri Apr 20 13:17:06 1990 + >*************** + >*** 1057,1062 **** + >--- 1057,1079 ---- + > signal (SIGHUP, SIG_DFL); + > #endif + > #endif /* HAVE_PTYS */ + >+ + >+ /* Give child clean slate for signals */ + >+ #ifdef SIGCHLD + >+ #ifdef BSD4_1 + >+ sigrelse (SIGCHLD); + >+ #else /* not BSD4_1 */ + >+ #ifdef HPUX + >+ sigsetmask (0); + >+ #endif /* HPUX */ + >+ #if defined (BSD) || defined (UNIPLUS) + >+ sigsetmask (0); + >+ #else /* ordinary USG */ + >+ signal (SIGCHLD, sigchld); + >+ #endif /* ordinary USG */ + >+ #endif /* not BSD4_1 */ + >+ #endif /* SIGCHLD */ + >+ + > child_setup_tty (xforkout); + > child_setup (xforkin, xforkout, xforkout, new_argv, env); + > } + >*************** + >*** 1413,1427 **** + > if (read_kbd && kbd_count) + > nfds = 0; + > else + >! #ifdef IBMRTAIX + > nfds = select (MAXDESC, &Available, 0, 0, &timeout); + > #else + >- #ifdef HPUX + >- nfds = select (MAXDESC, &Available, 0, 0, &timeout); + >- #else + > nfds = select (MAXDESC, &Available, 0, &Exception, &timeout); + > #endif + >- #endif + > xerrno = errno; + > + > if (fix_screen_hook) + >--- 1430,1440 ---- + > if (read_kbd && kbd_count) + > nfds = 0; + > else + >! #if defined (IBMRTAIX) || defined (HPUX) + > nfds = select (MAXDESC, &Available, 0, 0, &timeout); + > #else + > nfds = select (MAXDESC, &Available, 0, &Exception, &timeout); + > #endif + > xerrno = errno; + > + > if (fix_screen_hook) + >*************** + >*** 1771,1776 **** + >--- 1784,1790 ---- + > error ("Process %s is not active", + > XSTRING (p->name)->data); + > + >+ #ifndef HPUX /* Can't get gid of tty's controlling session */ + > #ifdef TIOCGPGRP /* Not sure about this! (fnf) */ + > /* If we are using pgrps, get a pgrp number and make it negative. */ + > if (!NULL (current_group)) + >*************** + >*** 1785,1790 **** + >--- 1799,1805 ---- + > the child itself heads the pgrp. */ + > gid = - XFASTINT (p->pid); + > #endif /* not using pgrps */ + >+ #endif /* not HPUX */ + > + > switch (signo) + > { + >*************** + >*** 1800,1805 **** + >--- 1815,1827 ---- + > flush_pending_output (XFASTINT (p->infd)); + > break; + > } + >+ + >+ #ifdef HPUX + >+ if (!NULL (current_group)) + >+ ioctl (XFASTINT (p->infd), TIOCSIGSEND, signo); + >+ else + >+ kill (XFASTINT (p->pid), signo); + >+ #else /* not HPUX */ + > /* gid may be a pid, or minus a pgrp's number */ + > #ifdef BSD + > /* On bsd, [man says] kill does not accept a negative number to kill a pgrp. + >*************** + >*** 1808,1813 **** + >--- 1830,1836 ---- + > #else /* Not BSD. */ + > kill (gid, signo); + > #endif /* Not BSD. */ + >+ #endif /* Not HPUX */ + > + > /* Put notices in buffers now, since it is safe now. + > Because of this, we know that a process we have just killed + >% + + This is a separate patch to process.c, distinct from the immediately + preceding one. Both should be applied. + + >*** process.c.~1~ Fri Apr 20 13:17:06 1990 + >--- process.c Wed Oct 24 16:38:15 1990 + >*************** + >*** 1085,1095 **** + > /* If the subfork execv fails, and it exits, + > this close hangs. I don't know why. + > So have an interrupt jar it loose. */ + >! signal (SIGALRM, create_process_1); + >! alarm (1); + >! if (forkin >= 0) + >! close (forkin); + >! alarm (0); + > if (forkin != forkout && forkout >= 0) + > close (forkout); + > + >--- 1085,1100 ---- + > /* If the subfork execv fails, and it exits, + > this close hangs. I don't know why. + > So have an interrupt jar it loose. */ + >! + >! { int old_trap = signal (SIGALRM, create_process_1); + >! int old_alarm = alarm (1); + >! if (forkin >= 0) + >! close (forkin); + >! alarm (0); + >! signal (SIGALRM, old_trap); + >! /* don't bother with possible 1 sec loss */ + >! if (old_alarm) alarm (old_alarm); + >! } + > if (forkin != forkout && forkout >= 0) + > close (forkout); + +52: What should I do if I have trouble building Emacs? + + RMS writes: + + If you try to build Emacs and it does not run, the first thing to do is + look in the file called PROBLEMS to see if a solution is given there. + + If none is given, then please send a report by mail to + bug-gnu-emacs@prep.ai.mit.edu. Please do not send it to + help-gnu-emacs@prep.ai.mit.edu. + + Sending to help-gnu-emacs (which has the effect of posting on + gnu.emacs.help) is undesirable because it takes the time of an + unnecessarily large group of people, most of whom are just users and + have no idea how to fix these problem. bug-gnu-emacs reaches a much + smaller group of people who are more likely to know what to do and have + expressed a wish to receive more messages about Emacs than the others. + +Weird/Confusing Problems: + +53: Does Emacs have problems with files larger than 8 Megs? + + Most installed versions of GNU Emacs will use 24 bit signed integers + (and 24 bit pointers!) internally. This limits the file size that Emacs + can handle to 8388608 bytes. + + Leonard N. Zubkoff writes: + + Putting the following two lines in src/config.h before compiling Emacs + allows for 26 bit integers and pointers: + + #define VALBITS 26 + #define GCTYPEBITS 5 + + See question 54 for an explanation. + +54: Why does Emacs use 24 bit integers and pointers? + + David Gillespie writes: + + Emacs is largely written in a dialect of Lisp; Lisp is a freely-typed + language in the sense that you can put any value of any type into any + variable, or return it from a function, and so on. So each value must + carry a "tag" along with it identifying what kind of thing it is, e.g., + integer, pointer to a list, pointer to an editing buffer, and so on. + Emacs uses standard 32-bit integers for data objects, taking the top 8 + bits for the tag and the bottom 24 bits for the value. So integers (and + pointers) are somewhat restricted compared to true C integers and + pointers. + + Emacs uses 8-bit tags because that's a little faster on byte-oriented + machines, but there are only really enough tags to require 6 bits. See + question 53 to find how to recompile Emacs with 6-bit tags and + 26-bit integers and pointers if space is at a premium for you. + +55: Why does Emacs start up using the wrong directory? + + Most likely, you have an environment variable named PWD that is set to a + value other than the name of your current directory. This is most + likely caused by using two different shell programs. "ksh" and (some + versions of) "csh" set and maintain the value of the PWD environment + variable, but "sh" doesn't. If you start sh from ksh, change your + current directory inside sh, and then start Emacs from inside sh, PWD + will have the wrong value but Emacs will use this value. See question + 72. + +56: How do I edit a file with a "$" in its name? + + When entering a filename in the minibuffer, Emacs will attempt to expand + a "$" followed by a word as an environment variable. To suppress this + behavior, type "$$" instead. + +57: Why does Shell Mode lose track of the shell's current directory? + + Emacs has no way of knowing when the shell actually changes its + directory. So it tries to guess by recognizing cd commands. A number + of fixes and enhancements to Shell Mode have been written, check the + Emacs Lisp Archive (question 14). + +58: Why doesn't Emacs expand my aliases when sending mail? + + First, you must separate multiple addresses with commas. + + Emacs normally only reads the ".mailrc" file once per session, when you + start to compose your first mail message. If you edit .mailrc, you can + type "M-ESC (build-mail-aliases) RET" to make Emacs reread .mailrc. + +59: Why doesn't setting default-directory always work? + + There is a separate value of default-directory for each Emacs buffer. + The value in the current buffer is the one that is used. + +60: Why does my change to load-path not work? + + If you added file names with tildes (~) in them to your load-path, + you'll need to do something like this: + + (setq-default load-path (mapcar 'expand-file-name load-path)) + +61: Why does the cursor always go to the wrong column when I move up or + down one line? + + You have inadvertently typed "C-x C-n" (set-goal-column) which sets the + "goal-column" to the column where the cursor was. To undo this type + "C-u C-x C-n". + + If you make this mistake frequently, you might want to unbind this + command by doing (define-key ctl-x-map "\C-n" nil). + +62: Why don't the command line switches documented in the man page work? + + The "man page", ie. the file etc/emacs.1, hasn't been updated in a + while. The command line switches that it says work with X Windows are + for X10. See question 72 for details on what switches are + available using X11. {Would someone like to rewrite the man page? RMS + asked me and I haven't had time yet.} + +63: Why does gnus-Subject-mail-reply chop off the last character of the + article headers? + + There is a bug in some rnews functions that GNUS uses. Here is a patch: + + (Patch supplied by Karl Kleinpaste .) + + >*** rnewspost.el.orig Thu Oct 5 10:32:47 1989 + >--- rnewspost.el Thu Oct 5 10:32:47 1989 + >*************** + >*** 252,258 **** + > (save-restriction + > (narrow-to-region (point-min) (progn (goto-line (point-min)) + > (search-forward "\n\n") + >! (- (point) 2))) + > (setq from (mail-fetch-field "from") + > subject (mail-fetch-field "subject") + > reply-to (mail-fetch-field "reply-to") + >--- 252,258 ---- + > (save-restriction + > (narrow-to-region (point-min) (progn (goto-line (point-min)) + > (search-forward "\n\n") + >! (- (point) 1))) + > (setq from (mail-fetch-field "from") + > subject (mail-fetch-field "subject") + > reply-to (mail-fetch-field "reply-to") + >*************** + >*** 289,295 **** + > ;@@ but rnews.el lacks support + > (narrow-to-region (point-min) (progn (goto-char (point-min)) + > (search-forward "\n\n") + >! (- (point) 2))))) + > (setq from (mail-fetch-field "from") + > news-reply-yank-from from + > ;; @@ not handling old Title: field + >--- 289,295 ---- + > ;@@ but rnews.el lacks support + > (narrow-to-region (point-min) (progn (goto-char (point-min)) + > (search-forward "\n\n") + >! (- (point) 1))))) + > (setq from (mail-fetch-field "from") + > news-reply-yank-from from + > ;; @@ not handling old Title: field + >*************** + >*** 365,371 **** + > ;@@ but rnews.el lacks support + > (narrow-to-region (point-min) (progn (goto-char (point-min)) + > (search-forward "\n\n") + >! (- (point) 2))))) + > (setq news-reply-yank-from (mail-fetch-field "from") + > ;; @@ not handling old Article-I.D.: field + > news-reply-yank-message-id (mail-fetch-field "message-id"))) + >--- 365,371 ---- + > ;@@ but rnews.el lacks support + > (narrow-to-region (point-min) (progn (goto-char (point-min)) + > (search-forward "\n\n") + >! (- (point) 1))))) + > (setq news-reply-yank-from (mail-fetch-field "from") + > ;; @@ not handling old Article-I.D.: field + > news-reply-yank-message-id (mail-fetch-field "message-id"))) + +64: Why does Emacs hang with message "Unknown XMenu" with X11R4? + + Many different X errors can produce this message. Here is the solution + to one problem: + + X11 Release 4 now enforces some conditions in the X protocol that were + previously allowed to pass unnoticed. You need to put the X11R4 server + into X11R3 bug compatibility mode for Emacs's Xmenu code to work. You + can do this with the command "xset bc". + +65: Why isn't the load average displayed by display-time? + + The most likely cause of the problem is that "loadst" can't read the + special file /dev/kmem. To properly install loadst, it should be either + setuid to the owner of /dev/kmem, or is should be setgid to the group to + which /dev/kmem belongs. In either case, /dev/kmem should be readable by + its owner or its group, respectively. + + Another possibility is that your version of Unix doesn't have the load + average data available in /dev/kmem. Your version of Unix might have a + special system call to retrieve this information (eg., inq_stats under + UMAX). + +66: Why doesn't GNUS work anymore via NNTP? + + There is a bug in NNTP version 1.5.10, such that when multiple requests + are sent to the NNTP server, the server only handles the first one before + blocking waiting for more input which never comes. + + You can work around the bug inside Emacs like this: + + (setq nntp-maximum-request 1) + (setq nntp-buggy-select t) + + Or you could fix the NNTP server in one of these ways: + + 1. Test whether there is data in stdin's stdio buffer before calling + "select" using something like "((fileptr)->_cnt > 0)". Best choice. + 2. Remove call to select by not defining "TIMEOUT" in "common/conf.h". + 3. Put "setbuf (stdin, NULL)" in the NNTP server in the right spot. + This would be very inefficient. + 4. Rewrite the server to use an alarm instead of "select". + +67: Why can't I paste a selection I made in Emacs into my xterm window? + + A person whose name I lost writes: + + The strange interaction between Emacs, xterm, and the cut buffers is + because most xterm clients use selections instead of (well, superceding) + cut buffers. If there is a selection around, xterms will use that + instead of the cut buffer. Emacs doesn't know about selections, but you + can convince xterm to always use the cut buffer instead of selections by + adding this to your .Xdefaults: + + ! Solution by Thomas Narten, should work under X11R3 and later + ! GNU Emacs only copies to CUT_BUFFER0. xterm by default wants to paste + ! from the PRIMARY selection. + XTerm*VT100.Translations: #override \ + ~Meta : insert-selection(CUT_BUFFER0) + + +68: Why does ispell sometimes ignore the local dictionary? + + You need to update the version of ispell to 2.0.02. A patch is + available via: + + Anonymous FTP: + site: tut.cis.ohio-state.edu + file: /pub/gnu/ispell/patch2.Z + + You also need to change a line in ispell.el from: + + (defconst ispell-version "2.0.01") ;; Check against output of "ispell -v". + + to: + + (defconst ispell-version "2.0.02") ;; Check against output of "ispell -v". + + + +Configuring Emacs for yourself: + +69: How do I set up a .emacs file properly? + + I'm going to be sending out a sample .emacs file in a separate message + later this month. It will be based largely on AT&T's sample .emacs + file, which was sent to me by Dan Jacobson. In fact it might be + identical. + +70: How do you debug a .emacs file? + + First start Emacs with the "-q" command line option. Then, in the + *scratch* buffer, type the following: + + (setq debug-on-error t) C-j + (load-file "~/.emacs") C-j + + (C-j stands for Control-J, ie., hold the control key and press J.) + + If you have an error in your .emacs file, this will invoke the debugger + when the error occurs. If you don't know how to use the debugger do + (setq stack-trace-on-error t) instead. + + WARNING: this will not discover errors caused by trying to do something + that requires the terminal/window-system initialization code to have + been loaded. See question 34. + +71: How do I turn on abbrevs by default just in mode XXX? + + Put this in your .emacs file: + + (condition-case () + (read-abbrev-file nil t) + (file-error nil)) + + (setq XXX-mode-hook + (function + (lambda () + (setq abbrev-mode t)))) + +72: What does Emacs do every time it starts up? + + This question is not itself frequently asked, but helps to answer other + questions. + + Here is a complete explanation of the order in which things are done + during startup. + + 1. These command line switches are handled, only if they appear before + all other command line arguments, and only if they appear in this + order: + + "-map". Only under VMS. Instead of "undumping", under VMS the + contents of a dump file are mapped over a section of memory (very + quickly initializing lots of variables). + + "-t". The next argument is treated as the name of a terminal to use + instead of whatever is connected to the stdin, stdout, and stderr + FILE pointers. + + "-display" (synonym: "-d"). The next argument is treated as the + name of an X Window System server with which to connect. This + overrides the DISPLAY environment variable. + + "-nw". This means don't connect to an X Window server even if the + DISPLAY environment variable was set or the "-display" switch was + specified. Instead, Emacs talks to a regular dumb terminal. + + "-batch". Emacs is noninteractive. The variable "noninteractive" + is t. This disables any full screen interaction either with a + dumb terminal or with a window system. In addition, Emacs will + die after processing all command line arguments. + + All of Emacs's internal data structures are initialized between steps 2 + and 5. + + 2. The "*scratch*" buffer is created and its value of default-directory + is set from the result of calling the "getwd" library routine. + (getwd does what the "pwd" program does.) + + 3. If X11 is being used, Emacs determines the name under which it looks + for X resource values. (I haven't checked how it does this under + X10.) + + 1. If there is a "-rn" command line switch, it is handled now, no + matter where it is on the command line. (Later it will be + processed again and ignored.) The next argument is used as + Emacs's resource name. + + 2. If the "-rn" switch was missing, Emacs looks for the WM_RES_NAME + environment variable. + + 3. If neither of the previous two steps succeed, Emacs uses the + filename with which it was invoked as its resource name. + + 4. If X11 is being used, these command line switches are handled now, + no matter where they appear in the command line. (Under X10, they + are not handled until step 13.) WARNING: this can cause strange + interactions with the processing of the remaining command line + arguments in step 13. + + In addition, under both X11 and X10, X resources (ie. the stuff in + an .Xdefaults file) are handled now. Command line switches take + precedence over resources. + + After each command line switch are given the equivalent resource + names in this format: (X10 name / X11 instance name / X11 class name). + + "-r". Reverse video. (ReverseVideo/reverseVideo/ReverseVideo) + "-font" (synonym: "-fn"). Font. (BodyFont/font/Font) + "-wn". Window name (X11 only). (/title/Title) + "-in". Icon name (X11 only). (/iconName/Title) + "-i". Use built-in icon bitmap. (BitMapIcon//) + + "-b". Border width (in pixels). + (BorderWidth/borderWidth/BorderWidth) + + "-ib". Internal border width (in pixels) (default: 1). + (/internalBorder/BorderWidth) + + "-geometry" (synonym: "-w"). Window shape and size. "-geometry" is + X11 only, but its synonym "-w" was available under X10. + (/geometry/Geometry) + + Color options only: + + "-fg". Foreground color. (Foreground/foreground/Foreground) + "-bg". Background color. (Background/background/Background) + "-bd". Border color. (Border/borderColor/BorderColor) + "-cr". Cursor color. (Cursor/cursorColor/Foreground) + "-ms". Mouse pointer color. (Mouse/pointerColor/Foreground) + + In addition, under X10, the resource "Keymap" was handled now. + + 5. If your Emacs isn't "dumped", the default Lisp libraries are + "loaded" now. + + 6. Emacs enters a "recursive edit". The first time Emacs does a + recursive edit, steps 7 through 15 are followed, and then Emacs + enters its normal editing mode. + + 7. If the environment variable PWD exists, the value of + default-directory in the *scratch* buffer is set to the value of + PWD. This often causes problems and confusion when the value of PWD + doesn't actually contain the pathname of the current directory. + + 8. Now the "-no-init-file" (synonym: "-q") and "-user" (synonym: "-u") + command line switches are handled. They must follow the switches + mentioned in step 1, and must precede any other command line + arguments. Actually, both of these options can be specified; + whichever is last on the command line wins. + + 9. The user's ".emacs" file is loaded now, if the -no-init-file option + was not specified. If the -user option was specified, that user's + .emacs file is loaded instead. A user's .emacs file is a file named + ".emacs" in the user's "home" directory. If no such file exists, + this step has no effect. + + 10. The system wide "default" file is loaded now, if the variable + inhibit-default-init is nil. The user can set this variable in the + .emacs file to skip this step. + + 11. If the *scratch* buffer still exists now, the value of + initial-major-mode is called as a function in this buffer. + Normally, this puts this buffer in Lisp Interaction mode. + + 12. Now the terminal/window-system setup file is loaded. The name of + this file is determined as follows: + + 1. It starts with the value of term-file-prefix. Normally this is + "term/", but the user can set it to another value. If this + variable is nil, this entire step is skipped. + + 2. For a window system, the prefix is followed by the name of the + value of the variable window-system, followed by "-win". For X + Windows, this means the name is "term/x-win". + + 3. For a terminal, the prefix is followed by the value of the + environment variable TERM, for example, "term/vt200". If Emacs + cannot find such a file to load, it retries by stripping off + suffixes that begin with a hyphen. For example, if TERM is + "vt200-40", first Emacs will try "term/vt200-40", and if that + fails it will try "term/vt200". + + 13. The rest of the command line arguments are handled at this point, in + the order they appear: + + "-funcall" (synonyms: "-f", "-e"). The next argument is treated as + the name of a function, which is called with no arguments. + + "-load" (synonym: "-l"). The next argument is treated as the name + of a file to load. NOTE: the value of the variable load-path + will be restored after this file is done loading. Thus, trying + to change load-path in such a file will fail!! + + "-kill". When this argument is handled, Emacs kills itself. + + "+DDD", where D is a digit. DDD is used as a line number to go to. + When the next ordinary file argument on the command line is + handled, Emacs positions point in that file on line DDD. + + An ordinary filename. Emacs edits this file using the function + find-file. If the filename is not an "absolute" filename, it is + expanded relative to the value that default-directory in the + *scratch* buffer had at the beginning of step 11. The buffer + visiting this file becomes the current buffer. + + "-insert" (synonym: "-i"). The next argument is treated as the name + of a file. This file is inserted in the current buffer. + Initially, this is the *scratch* buffer. Otherwise it is the + buffer visiting the file most recently specified on the command + line. WARNING: the synonym "-i" doesn't work under X11. + + Other command line switches may have been created by modifying the + value of the variable command-switch-alist. If X Windows is being + used, all X-specific switches mentioned above in steps 3 and 4 will + be processed. Under X11, they will have already been handled, and + will be ignored now. Under X10, they are being handled for the + first time. + + 14. The values of the variables term-setup-hook and window-setup-hook + are called as functions with no arguments, in the order listed. + + 15. If the user did not specify any of the command line options handled + in step 13, and the variable inhibit-startup-message is still nil, + the familiar Emacs startup message is displayed. + +73: What are the valid X resource settings (ie., stuff in .Xdefaults file)? + + See question 72. + + WARNING: Don't pay any attention to the documentation in etc/XDOC or + etc/emacs.1. It's way out of date. {Would someone like to rewrite it? + RMS asked me and I haven't had time yet.} + +74: How do I turn down the bell volume in Emacs running under X Windows? + + Under Epoch you can do: + + (setq epoch::bell-volume 20) + + Under normal GNU Emacs you must modify the XTfeep function in + src/x11term.c, and change the number 50 to some other number: + + XTfeep () + { + BLOCK_INPUT_DECLARE (); + #ifdef XDEBUG + fprintf (stderr, "XTfeep\n"); + #endif + BLOCK_INPUT (); + XBell (XXdisplay,50); /* change this 50 */ + UNBLOCK_INPUT (); + } + +75: How do I make Emacs send 8-bit characters to my terminal? + + Johan Widen writes: + + A patch for emacs-18.55 is available by ftp and mail-server from + sics.se. + + Anonymous FTP: + site: sics.se [192.16.123.90] + file: archive/emacs-18.55-8bit-diff + + E-mail: + To: mail-server@sics.se + body: send emacs-18.55-8bit-diff + + + +Emacs Lisp programming: + +76: What dialect of Lisp is Emacs Lisp? + + It's the dialect of Lisp called Emacs Lisp. (No joke!) People also + call it elisp or e-lisp. (NOTE: The term "Elisp" is trademarked by + someone else.) + +77: How close is Emacs Lisp to Common Lisp? + + Pretty far. GNU Emacs Lisp is case-sensitive, uses dynamic scoping, + doesn't have packages, doesn't have multiple return values, doesn't have + reader macros, etc. For people used to Common Lisp, some of the + functions in Common Lisp that are not in Emacs Lisp by default are + provided in the file lisp/cl.el. There is a Texinfo manual describing + these functions in man/cl.texinfo. + +78: How do I execute a piece of Emacs Lisp code? + + There are a number of ways to execute (called "evaluate") an Emacs Lisp + "form": + + * If you want it evaluated every time you run Emacs, put it in a file + named ".emacs" in your home directory. + + * You can type the form in the "*scratch*" buffer, and then type C-j + after it. The result of evaluating the form will be inserted in the + buffer. + + * In in Emacs-Lisp mode, typing M-C-x evaluates a top-level form before + or around point. + + * Typing "C-x C-e" in any buffer evaluates the Lisp form immediately + before point and prints its value in the echo area. + + * Typing M-ESC or M-x eval-expression allows you to type a Lisp form in + the minibuffer which will be evaluated. + + * You can use M-x load-file to have Emacs evaluate all the Lisp forms in + a file. (To do this from Lisp use the function "load" instead.) + +79: How do I make a set of operations fully local to a region? + + Use narrow-to-region inside of save-restriction. + +80: How can I highlight a region? + + There are ways to get highlighting in GNU Emacs 18.55, but they all + require patching the C code of Emacs and rebuilding. They are also slow + and the highlighting disappears if you scroll or redraw the screen. One + patch is by Kenichi Handa . + + You can hightlight regions in a variety of ways in Epoch. GNU Emacs 19 + will have everything you need, but won't be out soon. + +81: How do I change Emacs's idea of the tab character's length? + + Example: (setq default-tab-width 10). + +82: What is the difference between (interactive "P") and (interactive "p")? + + The value that is a result of "P" can be a list, a symbol, or an + integer; the value that is a result of "p" is always an integer: + + Prefix keys typed result of: "P" "p" + nothing nil 1 + "M-1" 1 1 + "C-u 1" 1 1 + "M--" '- -1 + "C-u -" '- -1 + "C-u" (4) 4 + "C-u C-u" (16) 16 + + + +Carrying Out Common Tasks: + +83: How do I insert ">"'s in the beginning of every line in a buffer? + + Type "M-x replace-regexp RET ^ RET > RET". ("replace-regexp" can be + shortened to "repl TAB r".) + + To do this only in the region, type "C-x n M-x replace-regexp RET ^ RET + > RET C-x w". (You're going to remember that, right?) + +84: How do I insert "_^H" characters before each character in a + paragraph to get an underlined paragraph? + + M-x underline-region. + +85: How do I repeat a command as many times as possible? + + Make a keyboard macro that invokes the command and then type "M-0 C-x + e". WARNING: any messages your command prints in the echo area will be + suppressed. + +86: How do I search for an unprintable (8-bit) character that appears + in a buffer as \237? + + C-s C-q 2 3 7 + + (This assumes the value of search-quote-char is 17 (C-q).) + +87: How do I tell Emacs to automatically indent a new line to the + indentation of the previous line? + + M-x indented-text-mode. (This is a major mode.) + + If you have auto-fill mode on (minor mode), you can tell Emacs to prefix + every line with a certain character sequence, the "fill prefix". Type + the prefix at the beginning of a line, position point after it, and then + type "C-x ." (set-fill-prefix) to set the fill prefix. Thereafter, + auto-filling will automatically put the fill prefix at the beginning of + new lines, and M-q (fill-paragraph) will maintain any fill prefix when + refilling the paragraph. + +88: How do I make Emacs "typeover" or "overwrite" when I type instead of + always inserting? + + M-x overwrite-mode (minor mode). + + WARNING: delete-backward-char (usually the delete key) doesn't work + properly in overwrite mode. It deletes the character to the left, + rather than replacing it with a space. + +89: How do I show which parenthesis matches the one I'm looking at? + + If you're looking at a right parenthesis (or brace or bracket) you can + delete it and reinsert it. + + M-C-f (forward-sexp) and M-C-b (backward-sexp) will skip over balanced + parentheses, so you can see which parentheses match. (You can train it + to skip over balanced brackets and braces at the same time by modifying + the syntax table.) + + Here is some Emacs Lisp that will make the % key show the matching + parenthese, like in vi. In addition, if the cursor isn't over a + parenthese, it simply inserts a % like normal. + + (By an unknown contributor.) + + (global-set-key "%" 'match-paren) + + (defun match-paren (arg) + "Go to the matching parenthesis if on parenthesis otherwise insert %." + (interactive "p") + (cond ((looking-at "[([{]") (forward-sexp 1) (backward-char)) + ((looking-at "[])}]") (forward-char) (backward-sexp 1)) + (t (self-insert-command (or arg 1))))) + +90: How do I make Emacs behave like this: when I go up or down, the cursor + should stay in the same column even if the line is too short? + + M-x picture-mode. (This is a minor mode, in theory anyway ...) + +91: How do I read news under Emacs? + + There are at least three news reading packages that operate inside + Emacs. "rnews" comes with Emacs. "GNUS" and "Gnews" come separately. + + {I've never used rnews; could someone write a description? BTW, rnews + will be replaced with GNUS in Emacs 19.} + + Both GNUS and Gnews handle reading news over NNTP. I think both can + also read from a local news spool. GNUS also supports reading mail + stored in MH folders or articles saved by GNUS. + + GNUS is written (mostly) by Masanobu Umeda. His (?) latest e-mail + address was umerin@tc.nagasaki.go.jp, but I don't think he has an e-mail + address right now. The latest version is GNUS 3.13. There is a + newsgroup for discussion of GNUS called gnu.emacs.gnus. This newsgroup + is gatewayed with the mailing list info-gnus-english to subscribe send + mail to info-gnus-english-request@cis.ohio-state.edu. There is also a + mailing list called info-gnus, which includes discussion in Japanese. + + Gnews was written by Matthew Wiener . {Could someone + tell me the # of the latest version, and how long it has been since + anyone has heard from Matthew?}. There is a newsgroup for Gnews called + gnu.emacs.gnews. + +92: In C mode, can I show just the lines that will be left after #ifdef + commands are handled by the compiler? + + M-x hide-ifdef-mode. (This is a minor mode.) + + You may have to (load "hideif") first. If you want to do this + regularly, put this in your .emacs file: + + (autoload 'hide-ifdef-mode "hideif" nil t) + +93: Is there an equivalent to the "." (dot) command of vi? + + ("." is the redo command in vi. It redoes the last insertion/deletion.) + + No, not really. + + You can type "C-x ESC" (repeat-complex-command) to reinvoke commands + that used the minibuffer to get arguments. In repeat-complex-command + you can type M-p and M-n to scan through all the different complex + commands you've typed. + + To repeat something on each line I recommend using keyboard macros. + +94: How do I use emacstool under SunView? + + The file etc/SUN-SUPPORT includes the document "Using Emacstool with GNU + Emacs". Also read the man page for emacstool (etc/emacstool.1). + +95: How do I get Emacs to display the current line number on the mode line? + + There is no "correct" way to constantly display the current line number + on the mode line in Emacs 18. Emacs is not a line-oriented editor, and + really has no idea what "lines" of the buffer are displayed in the + window. It would require a lot of work at the C code level to make + Emacs keep track of this. + + Emacs 19 will probably be able to do this, but probably not with great + efficiency. + + To find out what line of the buffer you are on right now, do "M-x + what-line". Typing "C-x l" will also tell you what line you are on, + provided the buffer isn't separated into "pages" with C-l characters. + In that case, it will only tell you what line of the current "page" you + are on. WARNING: "C-x l" gives the wrong value when point is at the + beginning of a line. + + People have written various kludges to display the current line number + on the mode line. Look in the Lisp Code Directory. (See question 13.) + +96: How do I tell Emacs to iconify itself? + + You need to modify C source and recompile. Either that or get Epoch + instead. For the interested I have a patch to allow Emacs to iconify + itself. + +97: How do I use regexps (regular expressions) in Emacs? + + This is documented in the Emacs manual. To read the manual section + online, type "C-h i m emacs RET m regexps RET". + + WARNING: Unlike in Unix grep, sed, etc., a complement character set + ([^...]) can match a Newline, unless Newline is mentioned as one of the + characters not to match. +