1
0
mirror of https://git.savannah.gnu.org/git/emacs.git synced 2025-01-16 17:19:41 +00:00

Merge from emacs--devo--0

Patches applied:

 * emacs--devo--0  (patch 476-489)

   - Update from CVS
   - Merge from gnus--rel--5.10

 * gnus--rel--5.10  (patch 153-160)

   - Merge from emacs--devo--0
   - Update from CVS

Revision: emacs@sv.gnu.org/emacs--unicode--0--patch-127
This commit is contained in:
Miles Bader 2006-10-30 08:54:41 +00:00
commit 503be82149
115 changed files with 5298 additions and 3764 deletions

350
AUTHORS
View File

@ -13,10 +13,11 @@ Abramo Bagnara: changed term.c
Adrian Aichner: changed erc-log.el erc.el erc-autojoin.el erc-backend.el
erc-dcc.el erc-members.el erc-nets.el erc-sound.el etags.c
gnus-score.el
Adrian Colley: changed aix3-2.h
Adrian Lanz: changed mail-source.el
Adrian Lanz: changed mail-source.el spam.el
Agustin Martin: changed flyspell.el ispell.el
@ -57,7 +58,7 @@ and changed erc.el erc-track.el erc-button.el erc-stamp.el erc-match.el
erc-autoaway.el erc-nickserv.el Makefile erc-autojoin.el erc-fill.el
erc-pcomplete.el erc-complete.el erc-ibuffer.el erc-members.el
rcirc.texi comint.el custom.el erc-bbdb.el erc-chess.el erc-ezbounce.el
erc-imenu.el and 24 other files
erc-imenu.el and 26 other files
Alexander Klimov: changed man.el
@ -94,7 +95,10 @@ Andre Spiegel: changed vc.el vc-hooks.el vc-cvs.el vc-rcs.el vc-sccs.el
parse-time.el startup.el tramp-vc.el vc-arch.el vc-mcvs.el vc-svn.el
vcdiff viper-util.el
Andre Srinivasan: changed gnus.texi
Andre Srinivasan: changed gnus-group.el gnus-sum.el gnus.texi
mm-decode.el mml.el nnmail.el
Andrea Russo: changed info-look.el
Andreas B,A|(Bsching: changed emacsclient.c
@ -103,9 +107,11 @@ Andreas Fuchs: wrote erc-ezbounce.el erc-fill.el erc-match.el
and changed erc.el erc-bbdb.el erc-button.el erc-log.el erc-stamp.el
erc-autoaway.el erc-autojoin.el erc-dcc.el erc-imenu.el erc-list.el
erc-members.el erc-menu.el erc-netsplit.el erc-notify.el erc-ring.el
erc-speedbar.el erc-track.el erc-xdcc.el mml-sec.el
erc-speedbar.el erc-track.el erc-xdcc.el gnus-registry.el mml-sec.el
mml2015.el
Andreas Jaeger: changed gnus-msg.el gnus-start.el gnus-xmas.el
nnfolder.el nnml.el
Andreas Leue: changed artist.el
@ -116,9 +122,9 @@ Andreas Schwab: changed Makefile.in files.el lisp.h xdisp.c alloc.c
fileio.c simple.el buffer.c minibuf.c xterm.c emacs.c keyboard.c
process.c and 444 other files
Andreas Seltenreich: changed nnweb.el gnus-art.el gnus-ml.el gnus-srvr.el
gnus-start.el gnus-util.el gnus.el gnus.texi mm-url.el nnslashdot.el
url-cookie.el url-http.el
Andreas Seltenreich: changed nnweb.el gnus.texi gnus-art.el gnus-ml.el
gnus-srvr.el gnus-start.el gnus-util.el gnus.el mm-url.el mm-uu.el
nnslashdot.el url-cookie.el url-http.el
Andrew Choi: wrote mac-win.el
and changed macterm.c mac.c macfns.c INSTALL macmenu.c darwin.h macterm.h
@ -146,6 +152,8 @@ Andy Norman: wrote ange-ftp.el
Andy Petrusenco: changed w32term.c
Anna M. Bigatti: wrote cal-html.el
Ari Roponen: changed atimer.c startup.el
Arisawa Akihiro: changed mm-decode.el mm-view.el ps-print.el time.el
@ -189,8 +197,8 @@ Benjamin Drieu: wrote pong.el
Benjamin Riefenstahl: changed emacs.c mac-win.el macterm.c ms-w32.h
mule-cmds.el runemacs.c tcl.el w32.c w32.h w32select.c
Benjamin Rutt: changed vc.el diff-mode.el ffap.el nnmbox.el simple.el
vc-cvs.el
Benjamin Rutt: changed vc.el gnus-msg.el message.el diff-mode.el ffap.el
gnus-dired.el nnimap.el nnmbox.el simple.el vc-cvs.el
Bill Atkins: changed wdired.el
@ -210,6 +218,8 @@ Bill Rosenblatt: wrote float.el
Bill Rozas: wrote scheme.el
and changed xscheme.el
Bill White: changed gnus-start.el
Bill Wohler: wrote mh-buffers.el mh-comp.el mh-compat.el mh-e.el
mh-folder.el mh-funcs.el mh-letter.el mh-loaddefs.el mh-mime.el
mh-scan.el mh-seq.el mh-show.el mh-utils.el mh-xface.el
@ -227,6 +237,8 @@ Bj,Av(Brn Torkelsson: changed gnus-art.el gnus-group.el gnus-srvr.el
gnus-agent.el gnus-cus.el gnus-gl.el gnus-nocem.el gnus-score.el
gnus-topic.el gnus.el mail-source.el nnmail.el
Bj,Ax(Brn Mork: changed gnus-agent.el message.el mml2015.el
Blitz Product Development Corporation: wrote ispell.el
Boaz Ben-Zvi: wrote profile.el
@ -311,11 +323,11 @@ Charlie Martin: wrote autoinsert.el
Cheng Gao: changed MORE.STUFF flymake.el tips.texi url-dired.el
url-file.el url-handlers.el url-http.el url-nfs.el
Chong Yidong: changed cus-edit.el custom.el simple.el display.texi
longlines.el files.el text.texi custom.texi files.texi wid-edit.el
cus-theme.el info.el keyboard.c xterm.c compile.el frames.texi
Chong Yidong: changed cus-edit.el simple.el custom.el display.texi
longlines.el files.el text.texi custom.texi files.texi keyboard.c
wid-edit.el cus-theme.el frames.texi info.el xterm.c compile.el
image-mode.el keymaps.texi misc.texi mouse.el sendmail.el
and 156 other files
and 162 other files
Chris Hanson: changed xscheme.el scheme.el xterm.c hpux.h x11term.c
hp9000s300.h keyboard.c process.c texinfmt.el emacsclient.c sort.el
@ -341,7 +353,7 @@ Christian Von Roques: changed gnus-start.el
Christoph Bauer: changed configure.in
Christoph Conrad: changed qp.el
Christoph Conrad: changed gnus-agent.el gnus-score.el qp.el
Christoph Wedler: wrote antlr-mode.el
and changed format.el gnus-art.el gnus-picon.el message.el register.el
@ -350,7 +362,7 @@ and changed format.el gnus-art.el gnus-picon.el message.el register.el
Christopher J. Madsen: wrote decipher.el
and changed files.el ispell.el replace.el time.el
Chunyu Wang: changed pcl-cvs.texi
Chunyu Wang: changed gnus-art.el pcl-cvs.texi
Claudio Fontana: changed Makefile.in
@ -369,7 +381,7 @@ Craig Mcdaniel: changed sheap.c
Daiki Ueno: wrote pgg-def.el pgg-gpg.el pgg-parse.el pgg-pgp.el
pgg-pgp5.el pgg.el starttls.el
and changed mml2015.el gnus-agent.el mml1991.el
and changed mml2015.el gnus-agent.el gnus-srvr.el gnus-sum.el mml1991.el
Dale Hagglund: changed unexelf.c
@ -383,7 +395,7 @@ Damien Elmes: changed erc.el erc-dcc.el erc-track.el erc-log.el
Damon Anton Permezel: wrote hanoi.el (public domain)
Dan Christensen: changed gnus-sum.el nnfolder.el gnus-art.el
gnus-group.el gnus-score.el nnmail.el
gnus-group.el gnus-registry.el gnus-score.el nndoc.el nnmail.el
Dan Nicolaescu: wrote iris-ansi.el romanian.el
and changed term.el xterm.el hideshow.el isearch.el icon.el lisp.h
@ -411,7 +423,7 @@ and changed compile.el files.el make-mode.el apropos.el buff-menu.el
bindings.el button.el cc-fonts.el cc-mode.el and 12 other files
Daniel Pittman: wrote tramp-vc.el
and changed gnus-sum.el nnimap.el
and changed gnus-spec.el gnus-sum.el nnimap.el
Daniel Quinlan: changed dired.el info.el
@ -449,6 +461,7 @@ David Byers: changed minibuf.c
David Casperson: changed menu-bar.el tex-mode.el
David Edmondson: changed message.el gnus-cite.el imap.el mm-view.el
nnfolder.el nnml.el
David Gillespie: wrote calc-aent.el calc-alg.el calc-arith.el calc-bin.el
calc-comb.el calc-cplx.el calc-embed.el calc-ext.el calc-fin.el
@ -479,8 +492,8 @@ David J. Mackenzie: changed configure.in etags.c fakemail.c movemail.c
David Kastrup: changed greek.el replace.el search.c ange-ftp.el faq.texi
help.el mouse.el Makefile.in calc.el desktop.el keymaps.texi
meta-mode.el process.c search.texi DEBUG MAILINGLISTS autoload.el
browse-url.el buffer.c building.texi calc-alg.el and 30 other files
meta-mode.el process.c search.texi DEBUG DEVEL.HUMOR MAILINGLISTS
autoload.el browse-url.el buffer.c building.texi and 32 other files
David K,Ae(Bgedal: wrote tempo.el
and changed sendmail.el xmenu.c
@ -523,8 +536,12 @@ and changed commands.h easy-mmode.el emacsbug.el keymap.c macterm.c
David Robinson: changed menu-bar.el x-win.el
David S Goldberg: changed message.el
David S. Goldberg: changed gnus-art.el
David Z Maze: changed nnml.el
David Z. Maze: changed nnrss.el
Decklin Foster: changed nngateway.el
@ -608,9 +625,9 @@ Eli Barzilay: wrote calculator.el
Eli Tziperman: wrote rmail-spam-filter.el
Eli Zaretskii: wrote codepage.el rxvt.el tty-colors.el
and changed msdos.c Makefile.in files.el makefile.w32-in info.el fileio.c
and changed msdos.c Makefile.in makefile.w32-in files.el info.el fileio.c
startup.el mainmake.v2 config.bat menu-bar.el pc-win.el simple.el
internal.el msdos.h xfaces.c frame.c rmail.el dosfns.c faces.el
internal.el msdos.h rmail.el xfaces.c frame.c dosfns.c faces.el
frame.el emacs.c and 517 other files
Emanuele Giaquinta: changed rxvt.el configure.in etags.c frame.el
@ -637,9 +654,15 @@ Eric Decker: changed hp9000s800.h hpux.h sysdep.c
Eric Ding: wrote goto-addr.el
and changed mh-utils.el mh-e.el mh-comp.el mh-mime.el
Eric Eide: changed gnus-xmas.el
Eric Hanchrow: changed TUTORIAL.es abbrev.el autorevert.el delphi.el
dired.el emacsclient.c ispell.el make-dist
,AI(Bric Jacoboni: changed fr-refcard.tex
Eric Knauel: changed gnus.el spam-report.el spam.el
Eric M. Ludlam: wrote checkdoc.el dframe.el ezimage.el sb-image.el
speedbar.el
and changed info.el rmail.el speedbspec.el gud.el Makefile.in comint.el
@ -648,7 +671,7 @@ and changed info.el rmail.el speedbspec.el gud.el Makefile.in comint.el
sb-file.xpm sb-mail.xpm sb-pg-minus.xpm sb-pg-plus.xpm
and 10 other files
Eric Marsden: changed url-util.el
Eric Marsden: changed gnus-cache.el url-util.el
Eric S. Raymond: wrote AT386.el asm-mode.el cookie1.el finder.el gud.el
keyswap.el lisp-mnt.el loadhist.el
@ -685,6 +708,8 @@ Fabrice Bauzac: changed dired-aux.el
Fabrice Popineau: changed etags.c gnus-cache.el
Faried Nawaz: changed message.el
Felix Lee: changed flyspell.el outline.el compile.el data.c gud.el
nntp.el process.c vc.el xdisp.c
@ -692,8 +717,7 @@ Ferenc Wagner: changed nnweb.el
Flemming Hoejstrup Hansen: changed forms.el
Florian Weimer: changed message.el coding.c gnus-art.el gnus.el gnus.texi
mm-util.el
Florian Weimer: changed message.el gnus.el coding.c gnus.texi mm-util.el
Francesc Rocher: changed cus-start.el macterm.c w32term.c xdisp.c xterm.c
@ -709,8 +733,8 @@ and changed dired.el comint.el files.el
Francis Litterio: changed erc.el erc-list.el erc-dcc.el erc-notify.el
erc-button.el erc-goodies.el erc-nets.el erc-ring.el Makefile
erc-pcomplete.el erc-backend.el erc-ibuffer.el erc-match.el
erc-nickserv.el erc-page.el erc-speedbar.el keymaps.texi message.el
os.texi saveplace.el w32term.c and 3 other files
erc-nickserv.el erc-page.el erc-speedbar.el gnus-util.el keymaps.texi
message.el os.texi saveplace.el and 4 other files
Francois Felix Ingrand: changed gnus-salt.el
@ -718,7 +742,7 @@ Frank Bennett: changed nnmail.el
Frank Bresz: wrote diff.el
Frank Schmitt: changed gnus-sum.el
Frank Schmitt: changed gnus-sum.el gnus-util.el
Frank Weinberg: changed gnus-art.el
@ -768,7 +792,11 @@ Gary Oberbrunner: changed gud.el
Gary Wong: changed termcap.c tparam.c
Gaute B Strokkenes: changed process.c
Gaute B Strokkenes: changed imap.el gnus-fun.el process.c
Gaute Strokkenes: changed mail-source.el
Geoff Greene: changed message.el
Geoff Voelker: wrote lisp/makefile.nt nt.c nt.h ntheap.c ntheap.h
ntinevt.c ntproc.c ntterm.c src/makefile.nt w32-fns.el windowsnt.h
@ -788,7 +816,9 @@ Gerd Moellmann: wrote authors.el ebrowse.el jit-lock.el rx.el tooltip.el
and changed xdisp.c xterm.c dispnew.c dispextern.h xfns.c xfaces.c
window.c keyboard.c lisp.h Makefile.in faces.el alloc.c buffer.c
startup.el xterm.h fns.c simple.el term.c configure.in frame.c xmenu.c
and 618 other files
and 619 other files
Gerd M,Av(Bllmann: changed gnus-ems.el gnus-srvr.el mm-uu.el
Gergely Nagy: changed erc.el
@ -796,8 +826,8 @@ Germano Caronni: changed ralloc.c
Gernot Heiser: changed refer.el
Giorgos Keramidas: changed amdx86-64.h configure.in display.texi fringe.c
fringe.el lisp.h windows.texi
Giorgos Keramidas: changed amdx86-64.h apropos.el configure.in
display.texi fringe.c fringe.el lisp.h windows.texi
Giuseppe Scrivano: changed buffer.c configure configure.in sysdep.c
xsmfns.c
@ -851,15 +881,21 @@ Han-Wen Nienhuys: changed emacsclient.c server.el
Hans Chalupsky: wrote advice.el trace.el
and changed bytecomp.el
Hans De Graaff: changed mml.el
Hans Henrik Eriksen: wrote simula.el
Harald Maier: changed w32heap.c
Harald Meland: changed gnus-art.el gnus-salt.el gnus-score.el
gnus-util.el gnus-win.el
Heiko Muenkel: changed b2m.c
Helmut Waitzmann: changed gnus-sum.el gnus.texi
Henrik Enberg: changed lread.c rmailout.el xfaces.c
Henrik Enberg: changed gnus-art.el gnus-msg.el lread.c rmailout.el
xfaces.c
Henry Guillaume: wrote find-file.el
@ -878,6 +914,7 @@ Hiroshi Nakano: changed ralloc.c unexelf.c
Hoan Ton-That: changed erc-log.el
Holger Schauer: wrote fortune.el
and changed message-utils.el
Hovav Shacham: wrote windmove.el
@ -909,7 +946,7 @@ Ilja Weis: wrote gnus-topic.el
Ilya N. Golubev: changed mm-util.el shell.el
Ilya Zakharevich: wrote tmm.el
and changed syntax.c cperl-mode.el syntax.h textprop.c dired.c
and changed cperl-mode.el syntax.c syntax.h textprop.c dired.c
font-lock.el interval.c intervals.c intervals.h regex.c regex.h
search.c
@ -931,6 +968,8 @@ Ishikawa Chiaki: changed aviion.h dgux.h
Istvan Marko: changed gnus-agent.el xfns.c
Ivan Boldyrev: changed mml1991.el
Ivan Zakharyaschev: changed codepage.el lread.c
Ivar Rummelhoff: wrote winner.el
@ -941,6 +980,8 @@ J.D. Smith: changed idlwave.el idlw-shell.el idlw-rinfo.el
idlw-toolbar.el idlw-help.el vc.el bibtex.el comint.el files.texi
idlw-complete-structtag.el idlwave.texi misc.texi mouse.el
Jaap-Henk Hoepman: changed mm-decode.el
Jack Repenning: changed unexelfsgi.c
Jack Twilley: changed message.el
@ -970,13 +1011,15 @@ and changed bytecode.c mail-extr.el subr.el
Jan Dj,Ad(Brv: wrote dnd.el x-dnd.el
and changed gtkutil.c xterm.c xfns.c xmenu.c xterm.h gtkutil.h
configure.in keyboard.c Makefile.in config.in frames.texi configure
x-win.el emacs.c xselect.c alloc.c xlwmenu.c startup.el xdisp.c
configure.in keyboard.c Makefile.in config.in frames.texi x-win.el
configure xselect.c emacs.c alloc.c xlwmenu.c startup.el xdisp.c
xresources.texi cus-start.el and 172 other files
Jan Nieuwenhuizen: changed info.el TUTORIAL.nl emacs.c emacsclient.c
gnus-start.el gud.el nnmh.el server.el startup.el
Jan Rychter: changed gnus-msg.el
Jan Schormann: wrote solitaire.el
Jan Vroonhof: changed gnus-cite.el gnus-msg.el nntp.el
@ -988,7 +1031,7 @@ Jari Aalto: changed add-log.el filecache.el gnus-art.el lisp-mnt.el
executable.el files.el finder.el font-lock.el gnus.texi grep.el
ls-lisp.el man.el sendmail.el terminal.el
Jason Merrill: changed imap.el
Jason Merrill: changed gnus-sum.el gnus-salt.el imap.el nnfolder.el
Jason Rumney: wrote w32-vars.el
and changed w32fns.c w32term.c w32menu.c w32-win.el w32term.h
@ -1040,13 +1083,13 @@ Jeremy Bertram Maitin-Shepard: changed erc.el erc-backend.el
Jerry Frain: changed systime.h usg5-4.h
Jerry James: changed format.el
Jerry James: changed format.el dns.el gnus-util.el gnus-xmas.el
Jesper Harder: wrote yenc.el
and changed gnus-art.el gnus-sum.el message.el gnus-msg.el gnus.el
gnus-group.el mm-bodies.el gnus-util.el mm-decode.el mm-util.el
rfc2047.el mml.el mml1991.el mailcap.el mm-uu.el pgg-gpg.el smtpmail.el
gnus-srvr.el gnus-uu.el info.el nnmail.el and 179 other files
gnus-group.el mm-bodies.el gnus-util.el mm-util.el mm-decode.el mml.el
rfc2047.el mailcap.el mm-uu.el mml1991.el pgg-gpg.el smtpmail.el
gnus-srvr.el info.el nnmail.el pgg.el and 178 other files
Jhair Tocancipa Triana: changed gnus-audio.el
@ -1079,6 +1122,8 @@ Joakim Verona: changed nnrss.el
Joanna Pluta: changed TUTORIAL.pl
Jochen Hein: changed gnus-art.el
Jochen K,A|(Bpper: changed calc-units.el gnus.texi
Joe Buehler: changed Makefile.in cygwin.h MACHINES browse-url.el
@ -1087,6 +1132,8 @@ Joe Buehler: changed Makefile.in cygwin.h MACHINES browse-url.el
gnus-util.el hippie-exp.el keyboard.c lastfile.c loadup.el
and 12 other files
Joe Casadonte: changed gnus-srvr.el
Joe Corneli: changed subr.el
Joe Edmonds: changed lisp-mode.el
@ -1110,7 +1157,7 @@ Johan Bockg,Ae(Brd: changed erc.el erc-backend.el cl-macs.el erc-match.el
erc-nickserv.el erc-ring.el erc-speak.el erc-track.el simple.el
align.el calendar.el cl.texi custom.el dired-aux.el display.texi
erc-bbdb.el erc-button.el erc-compat.el erc-dcc.el erc-list.el
erc-log.el and 10 other files
erc-log.el and 11 other files
Johan Vromans: wrote forms-d2.el forms.el iso-acc.el
and changed complete.el
@ -1121,6 +1168,8 @@ John F. Carr: changed dired.c
John F. Whitehead: changed mule-cmds.el mule-diag.el
John Fremlin: changed gnus-msg.el message.el
John Grabowski: changed xfaces.c xfns.c
John H. Palmieri: changed gnus-fun.el
@ -1156,10 +1205,12 @@ and changed erc-chess.el erc.el iswitchb.el Makefile.in allout.el
cal-menu.el calendar.el compile.el desktop.el diary-lib.el erc-bbdb.el
erc-button.el erc-complete.el erc-fill.el erc-ibuffer.el erc-list.el
erc-match.el erc-menu.el erc-nets.el erc-replace.el erc-speak.el
and 9 other files
and 11 other files
John Williams: changed etags.el
Jon Ericson: changed gnus.el spam-report.el
Jon K Hellan: wrote utf7.el
Jonathan I. Kamens: changed pop.c movemail.c rmail.el configure.in
@ -1197,7 +1248,7 @@ Josh Huber: changed mml-sec.el gnus-msg.el message.el mml.el mml2015.el
nnmail.el ChangeLog ChangeLog.1 gnus-cite.el gnus-delay.el gnus-spec.el
mml1991.el nnultimate.el nnwfm.el gnus-cus.el gnus-smiley.el
gnus-start.el gnus-topic.el gnus.el nnbabyl.el nndiary.el
and 7 other files
and 8 other files
Joshua Varner: changed intro.texi
@ -1208,13 +1259,15 @@ and changed files.el perl-mode.el
Juanma Barranquero: changed makefile.w32-in help-fns.el subr.el faces.el
files.el w32fns.c cperl-mode.el replace.el simple.el eval.c
sh-script.el vhdl-mode.el comint.el org.el xdisp.c allout.el bs.el
desktop.el idlwave.el keyboard.c process.c and 550 other files
sh-script.el vhdl-mode.el ada-mode.el comint.el org.el w32-win.el
xdisp.c allout.el bs.el desktop.el idlwave.el and 554 other files
Juergen Hoetzel: changed url-handlers.el
Juergen Nickelsen: wrote ws-mode.el
Julien Avarre: changed gnus-fun.el
Julien Gilles: wrote gnus-ml.el
Junio Hamano: changed window.el
@ -1242,14 +1295,16 @@ Kahlil Hodgson: changed timeclock.el
Kai Gro,A_(Bjohann: wrote gnus-delay.el tramp-util.el tramp-uu.el tramp.el
trampver.el
and changed message.el gnus-agent.el gnus-sum.el gnus-art.el nnmail.el
files.el tramp.texi gnus.el simple.el ange-ftp.el gnus-group.el
gnus-msg.el Makefile.in dired.el nnml.el paragraphs.el bindings.el
files.texi gnus-start.el imap.el man.el and 56 other files
and changed gnus-agent.el message.el gnus-sum.el files.el nnmail.el
tramp.texi gnus.el simple.el ange-ftp.el Makefile.in dired.el
paragraphs.el bindings.el files.texi gnus-art.el gnus-group.el man.el
nntp.el INSTALL crisp.el fileio.c and 45 other files
Kailash C. Chowksey: changed HELLO Makefile.in ind-util.el kannada.el
knd-util.el loadup.el makefile.w32-in
Kanematsu Daiji: changed nnimap.el
Karl Berry: changed info.texi emacs.texi elisp.texi emacs-xtra.texi
filelock.c anti.texi building.texi cmdargs.texi copyright.el
custom.texi customize.texi dired.c display.texi faq.texi frames.texi
@ -1272,20 +1327,21 @@ Karl Heuer: changed keyboard.c lisp.h xdisp.c buffer.c xfns.c xterm.c
editfns.c fns.c process.c fileio.c simple.el keymap.c indent.c sysdep.c
and 444 other files
Karl Kleinpaste: changed gnus-art.el gnus-picon.el gnus-score.el
gnus-sum.el gnus-uu.el gnus-xmas.el mm-uu.el mml.el nnmail.el smiley.el
Karl Kleinpaste: changed gnus-sum.el gnus-art.el gnus-picon.el
gnus-score.el gnus-uu.el gnus-xmas.el gnus.el mm-uu.el mml.el nnmail.el
smiley.el
Karl M. Hegbloom: changed gnus.el
Karl Pfl,Ad(Bsterer: changed spam-stat.el
Karl Pfl,Ad(Bsterer: changed gnus-art.el gnus-score.el spam-stat.el
Katsuhiro Hermit Endo: changed gnus-spec.el
Katsuhiro Hermit Endo: changed gnus-group.el gnus-spec.el
Katsumi Yamaoka: wrote canlock.el
and changed gnus-art.el message.el gnus-sum.el gnus.texi mm-decode.el
mm-view.el gnus-util.el gnus-msg.el gnus.el mm-util.el lpath.el
gnus-start.el rfc2047.el gnus-group.el mm-uu.el dgnushack.el
gnus-agent.el nntp.el mml.el nnrss.el nnheader.el and 71 other files
mm-view.el gnus-util.el gnus-msg.el mm-util.el gnus.el lpath.el
gnus-group.el gnus-start.el rfc2047.el dgnushack.el mm-uu.el
gnus-agent.el nntp.el mml.el nnrss.el rfc2231.el and 71 other files
Kaveh R. Ghazi: changed delta88k.h xterm.c
@ -1324,7 +1380,7 @@ Kenichi Handa: wrote cyrillic.el isearch-x.el py-punct.el pypunct-b5.el
and changed coding.c mule-cmds.el mule.el charset.c fileio.c xterm.c
fns.c ccl.c Makefile.in mule-conf.el fontset.c charset.h coding.h
fontset.el mule-diag.el xdisp.c editfns.c process.c insdel.c
japanese.el characters.el and 277 other files
japanese.el characters.el and 278 other files
Kenneth Stailey: changed alpha.h configure.in ns32000.h openbsd.h pmax.h
sparc.h unexalpha.c unexelf.c
@ -1347,7 +1403,7 @@ and changed dispnew.c addpm.c config.nt dispextern.h emacs.c facemenu.el
Kevin Greiner: changed gnus-agent.el gnus-start.el gnus-sum.el
gnus-int.el gnus.el nntp.el gnus-util.el gnus-group.el gnus-cus.el
legacy-gnus-agent.el gnus-art.el gnus-cache.el gnus-range.el
gnus-range.el legacy-gnus-agent.el gnus-art.el gnus-cache.el
gnus-srvr.el nnagent.el nnheader.el dgnushack.el gnus-async.el
gnus-draft.el gnus-registry.el gnus-salt.el and 4 other files
@ -1363,14 +1419,14 @@ and changed info-look.el info.el gnus-art.el gnus-sum.el mailcap.el
os.texi text.texi MORE.STUFF cc-align.el cmdargs.texi compile.texi
display.texi em-alias.el em-dirs.el em-hist.el em-unix.el
emacs-lisp-intro.texi ffap.el frames.texi glossary.texi gnus.texi
and 12 other files
and 14 other files
Kim F. Storm: wrote bindat.el cua-base.el cua-gmrk.el cua-rect.el
ido.el keypad.el kmacro.el
Kim F. Storm: wrote bindat.el cua-base.el cua-gmrk.el cua-rect.el ido.el
keypad.el kmacro.el
and changed xdisp.c dispextern.h simple.el window.c xterm.c keyboard.c
process.c w32term.c dispnew.c subr.el lisp.h fringe.c macterm.c
process.c subr.el w32term.c dispnew.c lisp.h fringe.c macterm.c
display.texi fns.c alloc.c xfaces.c xfns.c xterm.h keymap.c .gdbinit
and 238 other files
and 240 other files
Kim-Minh Kaplan: changed gnus-picon.el gnus-sum.el gnus-start.el
gnus-win.el gnus-xmas.el gnus.texi message.el nndraft.el nnml.el
@ -1393,6 +1449,8 @@ Kohtala Marko: changed info.el
Koseki Yoshinori: wrote iimage.el
and changed nnmail.el
Kurt B. Kaiser: changed message.el
Kurt Hornik: wrote octave-hlp.el octave-inf.el octave-mod.el
and changed battery.el ielm.el term.el
@ -1443,6 +1501,8 @@ and changed gnus.el gnus-msg.el gnus-score.el gnus-topic.el gnus-xmas.el
Lasse Rasinen: changed gnus-start.el
Laurent Martelli: changed mm-decode.el
Lawrence Mitchell: wrote erc-backend.el erc-log.el erc-nicklist.el
and changed erc.el erc-match.el erc-nets.el erc-nickserv.el erc-button.el
erc-compat.el erc-dcc.el erc-fill.el erc-list.el erc-track.el Makefile
@ -1457,8 +1517,8 @@ and changed fortran.el ispell.el sendmail.el cmuscheme.el comint.el
Leigh Stoller: changed emacsclient.c emacsserver.c server.el
Lennart Borgman: changed window.el mouse.el recentf.el texinfmt.el
w32term.c w32term.h
Lennart Borgman: changed window.el ada-xref.el filesets.el flymake.el
mouse.el recentf.el shell.el texinfmt.el w32term.c w32term.h
Lennart Staflin: changed dired.el diary-ins.el diary-lib.el tq.el xdisp.c
@ -1485,6 +1545,8 @@ Lute Kamstra: changed modes.texi generic.el debug.el generic-x.el
Lynn Slater: wrote help-macro.el
L,Bu(Brentey K,Ba(Broly: changed spam.el gnus-sum.el
MCC: wrote xmenu.c
and changed emacsclient.c emacsserver.c etags.c lisp.h movemail.c
rmail.el rmailedit.el rmailkwd.el rmailmsc.el rmailout.el rmailsum.el
@ -1492,7 +1554,8 @@ and changed emacsclient.c emacsserver.c etags.c lisp.h movemail.c
Maciek Pasternacki: changed nnrss.el
Magnus Henoch: changed ispell.el rcirc.el
Magnus Henoch: changed ispell.el url-http.el autoinsert.el rcirc.el
url-gw.el url-https.el url-parse.el url.el
Manuel Serrano: wrote flyspell.el
@ -1500,6 +1563,8 @@ Marc Fleischeuers: changed files.el
Marc Girod: changed informat.el rmail.el rmailsum.el sendmail.el
Marc Lefranc: changed gnus-art.el
Marc Shapiro: changed bibtex.el
Marcelo Toledo: changed TUTORIAL.pt_BR TUTORIAL.cn TUTORIAL.cs
@ -1529,7 +1594,7 @@ and changed erc.el erc-dcc.el erc-speak.el Makefile erc-bbdb.el
diff.el erc-ezbounce.el erc-identd.el erc-lang.el erc-log.el
erc-macs.el and 5 other files
Mark A. Hershberger: changed xml.el nnrss.el cperl-mode.el mm-url.el
Mark A. Hershberger: changed xml.el nnrss.el mm-url.el cperl-mode.el
gnus-group.el
Mark D. Baushke: changed mh-e.el mh-utils.el mh-mime.el mh-comp.el
@ -1541,6 +1606,8 @@ Mark Diekhans: changed compile.el
Mark H. Weaver: changed comint.el
Mark Hood: changed gnus-uu.el
Mark Lambert: changed process.c process.h
Mark Mitchell: changed font-lock.el
@ -1551,6 +1618,8 @@ Mark Osbourne: changed hexl-mode.el
Mark Plaksin: changed nnrss.el term.el
Mark Thomas: changed gnus-util.el nnmail.el
Mark W Maimone: changed mpuz.el
Mark W. Eichin: changed keyboard.c xterm.c
@ -1581,7 +1650,7 @@ Martin Buchholz: changed etags.c
Martin J. Reed: changed ldap.el
Martin Kretzschmar: changed gnus-spec.el
Martin Kretzschmar: changed gnus-spec.el gnus-sum.el
Martin Larose: changed message.el
@ -1590,10 +1659,10 @@ Martin Lorentzon: changed vc.el vc-cvs.el vc-hooks.el vc-rcs.el
Martin Neitzel: changed sc.el
Martin Rudalics: changed cus-edit.el wid-edit.el cus-start.el files.el
font-lock.el insdel.c syntax.c buffer.c buffer.h casefiddle.c custom.el
dispextern.h editfns.c eldoc.el fileio.c find-func.el hideif.el info.el
jit-lock.el lisp-mode.el lisp.h and 13 other files
Martin Rudalics: changed cus-edit.el wid-edit.el flyspell.el cus-start.el
files.el font-lock.el insdel.c syntax.c buffer.c buffer.h casefiddle.c
cperl-mode.el custom.el dispextern.h dnd.el editfns.c eldoc.el fileio.c
find-func.el help-at-pt.el hideif.el and 20 other files
Martin Stjernholm: wrote cc-bytecomp.el
and changed cc-engine.el cc-cmds.el cc-langs.el cc-defs.el cc-mode.el
@ -1601,6 +1670,8 @@ and changed cc-engine.el cc-cmds.el cc-langs.el cc-defs.el cc-mode.el
cc-mode.texi Makefile.in cc-guess.el cc-mode-19.el ack.texi awk-mode.el
cc-awk.el cc-lobotomy.el cc-make.el cc-style.el and 5 other files
Martin Thornquist: changed gnus-group.el gnus-topic.el
Masahiko Sato: wrote vip.el
Masanobu Umeda: wrote gnus-kill.el gnus-mh.el gnus-msg.el gnus.el
@ -1612,7 +1683,7 @@ Masatake Yamato: wrote cc-subword.el ld-script.el
and changed etags.el asm-mode.el xdisp.c bindings.el hexl.el man.el
simple.el wid-edit.el add-log.el compile.el faces.el pcvs.el
register.el ruler-mode.el buffer.c cus-face.el dired-x.el display.texi
etags.c font-lock.el gdb-ui.el and 57 other files
etags.c font-lock.el gdb-ui.el and 58 other files
Masayuki Ataka: changed texinfmt.el texinfo.el characters.el make-mode.el
@ -1623,7 +1694,7 @@ and changed dired.el dired.texi
Mathias Megyei: changed Makefile.in
Mats Lidell: changed TUTORIAL.sv european.el
Mats Lidell: changed TUTORIAL.sv european.el gnus-art.el
Matt Hodges: changed em-pred.el icon.el paragraphs.el simple.el table.el
telnet.el
@ -1647,21 +1718,23 @@ Matthias Wiehl: changed gnus.el
Matthieu Devin: wrote delsel.el
Matthieu Moy: changed message.el
Matthieu Moy: changed gnus-msg.el message.el
Max Froumentin: changed gnus-art.el mml.el
Michael Albinus: wrote tramp-ftp.el tramp-smb.el
and changed tramp.el tramp.texi tramp-vc.el tramp-util.el ange-ftp.el
files.el files.texi tramp-uu.el vc.el dired-x.el dired.el faq.texi
find-dired.el locate.el mini.texi rcompile.el tramp*.el trampver.el
woman.el
files.el files.texi nnml.el tramp-uu.el vc.el dired-x.el dired.el
faq.texi find-dired.el locate.el mini.texi rcompile.el tramp*.el
trampver.el woman.el
Michael Ben-Gershon: changed acorn.h configure.in riscix1-1.h riscix1-2.h
unexec.c
Michael Cadilhac: changed blackbox.el rect.el subr.el zone.el
Michael Cook: changed gnus-sum.el
Michael D. Ernst: wrote reposition.el
and changed dired-x.el uniquify.el ispell.el bibtex.el rmail.el dired.el
simple.el dired-aux.el gud.el rmailsum.el bytecomp.el compare-w.el
@ -1697,9 +1770,9 @@ Michael Olson: changed erc.el erc-backend.el Makefile erc.texi
erc-stamp.el erc-log.el erc-autoaway.el erc-identd.el erc-track.el
erc-match.el erc-dcc.el erc-notify.el erc-goodies.el erc-ibuffer.el
erc-list.el erc-pcomplete.el erc-spelling.el erc-bbdb.el erc-compat.el
erc-nicklist.el and 42 other files
erc-nicklist.el erc-*.el and 42 other files
Michael Piotrowski: changed ps-print.el
Michael Piotrowski: changed gnus-sum.el ps-print.el
Michael R. Cook: changed gnus-topic.el gnus-art.el gnus-sum.el
@ -1712,8 +1785,8 @@ Michael Schierl: changed pgg-pgp.el
Michael Schmidt: wrote modula2.el (public domain)
Michael Shields: changed gnus-art.el gnus-cite.el gnus-sum.el intel386.h
nndraft.el
Michael Shields: changed spam.el gnus-art.el gnus-sum.el gnus-cite.el
gnus-group.el gnus.el intel386.h nndraft.el pgg-def.el
Michael Sperber [Mr. Preprocessor]: changed aix3-1.h aix4-2.h
@ -1727,7 +1800,7 @@ Michal Jankowski: changed insdel.c keyboard.c
Michal Nazarewicz: changed ispell.el
Micha,Ak(Bl Cadilhac: changed ispell.el cus-edit.el dispnew.c ido.el info.el
Micha,Ak(Bl Cadilhac: changed ido.el ispell.el cus-edit.el dispnew.c info.el
life.el lpr.el make-mode.el pong.el print.c process.c startup.el
uni-input.el
@ -1794,7 +1867,7 @@ N. Raghavendra: changed timezone.el
Nachum Dershowitz: wrote cal-hebrew.el
Nagy Andras: wrote gnus-sieve.el
and changed imap.el
and changed imap.el gnus.el
Nakaji Hiroyuki: changed mm-util.el
@ -1812,19 +1885,21 @@ Nelson H. F. Beebe: changed configure.in
Nelson Jose Dos Santos Ferreira: changed nnsoup.el
Nevin Kapur: changed nnmail.el gnus-group.el gnus-sum.el gnus.el
nnbabyl.el nnfolder.el nnimap.el nnmbox.el nnmh.el nnml.el
Nevin Kapur: changed nnmail.el gnus-sum.el nnimap.el gnus-group.el
gnus.el nnbabyl.el nnfolder.el nnmbox.el nnmh.el nnml.el
Niall Mansfield: changed etags.c
Nick Roberts: wrote gdb-ui.el
and changed gud.el building.texi tooltip.el speedbar.el thumbs.el DEBUG
cc-mode.el frames.texi subr.el xt-mouse.el .gdbinit bindings.el
and changed gud.el building.texi tooltip.el speedbar.el bindings.el
thumbs.el DEBUG cc-mode.el frames.texi subr.el xt-mouse.el .gdbinit
comint.el display.texi help-mode.el descr-text.el gud-display.pbm
speedbar.texi tumme.el xdisp.c byte-run.el and 112 other files
Nico Francois: changed w32fns.c w32inevt.c w32menu.c
Niklas Morberg: changed nnweb.el gnus-art.el nnimap.el spam.el
Noah Friedman: wrote eldoc.el rlogin.el rsz-mini.el type-break.el
and changed comint.el emacs-buffer.gdb files.el mailabbrev.el sendmail.el
subr.el timer.el yow.el battery.el complete.el config.in configure.in
@ -1838,7 +1913,7 @@ Noel Cragg: changed mh-junk.el
Nozomu Ando: changed buffer.c mips.h pmax.h smtpmail.el sysselect.h
unexelf.c unexmacosx.c
Nuutti Kotivuori: changed gnus-cache.el
Nuutti Kotivuori: changed gnus-sum.el flow-fill.el gnus-cache.el
Odd Gripenstam: wrote dcl-mode.el
@ -1920,7 +1995,7 @@ Paul Stodghill: changed gnus-agent.el
Pavel Jan,Bm(Bk: changed COPYING keyboard.c xterm.c xdisp.c Makefile.in
process.c emacs.c lisp.h menu-bar.el ldap.el make-dist xfns.c buffer.c
coding.c eval.c fileio.c flyspell.el fns.c indent.c callint.c
cus-start.el and 693 other files
cus-start.el and 703 other files
Pavel Kobiakov: wrote flymake.el
and changed flymake.texi
@ -1980,6 +2055,8 @@ Peter Seibel: changed cl-indent.el lisp-mode.el
Peter Stephenson: wrote vcursor.el
Peter Von Der Ahe: changed gnus-ems.el
Peter Whaite: changed data.c
Petri Kaurinkoski: changed configure.in iris4d.h irix6-0.h irix6-5.h
@ -2010,6 +2087,8 @@ and changed osf1.h alloc.c buffer.c callint.c data.c dispextern.h doc.c
Raja R Harinath: changed nnml.el
Raja R. Harinath: changed gnus-salt.el
Rajappa Iyer: changed gnus-salt.el
Rajesh Vaidheeswarran: wrote whitespace.el
@ -2037,16 +2116,19 @@ Ray Blaak: wrote delphi.el
Raymond Scholz: wrote deuglify.el
and changed gnus-art.el gnus-msg.el gnus.texi message.el nnmail.el
pgg-gpg.el
Reiner Steib: wrote gmm-utils.el
and changed gnus-art.el message.el gnus.texi gnus-sum.el gnus.el
gnus-group.el mml.el gnus-faq.texi gnus-score.el gnus-start.el
gnus-util.el gnus-msg.el message.texi gnus-agent.el mm-util.el files.el
spam-report.el nnweb.el spam.el deuglify.el mm-decode.el
and 161 other files
gnus-group.el gnus-faq.texi mml.el gnus-start.el gnus-util.el
gnus-msg.el gnus-score.el message.texi mm-util.el files.el
gnus-agent.el spam-report.el mm-decode.el nnweb.el spam.el deuglify.el
and 162 other files
Remek Trzaska: changed gnus-ems.el
Remi Letot: changed nnmaildir.el
Renaud Rioboo: changed nnmail.el
Ren,Ai(B Kyllingstad: changed pcomplete.el
@ -2072,7 +2154,7 @@ Richard M. Stallman: wrote [The original GNU emacs and numerous files]
and changed keyboard.c files.el simple.el xterm.c xdisp.c rmail.el
fileio.c process.c sysdep.c xfns.c buffer.c Makefile.in window.c
configure.in subr.el startup.el emacs.c editfns.c sendmail.el info.el
dispnew.c and 1334 other files
dispnew.c and 1335 other files
Richard Mlynarik: wrote cl-indent.el ebuff-menu.el ehelp.el env.c
rfc822.el terminal.el yow.el
@ -2108,6 +2190,8 @@ and changed texinfmt.el page-ext.el emacs.tex emacs-lisp-intro.texi
Robert Thorpe: changed cus-start.el
Roberto Rodr,Am(Bguez: changed ada-mode.texi widget.texi
Roderick Schertler: changed dgux.h dgux4.h gud.el sysdep.c
Rodrigo Real: changed pt-br-refcard.tex pt-br-refcard.ps
@ -2137,7 +2221,7 @@ Romain Francoise: changed faq.texi dired-x.el ibuf-ext.el compile.el
message.el puresize.h replace.el files.texi gnus-fun.el gnus.texi
help-fns.el make-dist rcirc.el subr.el Makefile.in antlr-mode.el
bookmark.el buffer.c comint.el diary-lib.el dired.el
and 121 other files
and 124 other files
Roman Belenov: changed which-func.el
@ -2171,7 +2255,9 @@ Sam Steingold: wrote gulp.el midnight.el
and changed cl-indent.el font-lock.el ange-ftp.el mouse.el tex-mode.el
vc-cvs.el add-log.el bindings.el bookmark.el debug.el diary-lib.el
dired.el pcvs.el sgml-mode.el simple.el browse-url.el buff-menu.el
bytecomp.el cc-mode.el compile.el etags.el and 94 other files
bytecomp.el cc-mode.el compile.el etags.el and 95 other files
Samuel Tardieu: changed smime.el
Sanghyuk Suh: changed mac-win.el macterm.c
@ -2190,12 +2276,16 @@ and changed mh-e.el mh-utils.el mh-seq.el mh-index.el mh-comp.el
Schlumberger Technology Corporation: changed gud.el
Scott A Crosby: changed gnus-logic.el
Scott Byer: changed gnus-sum.el
Scott Draves: wrote tq.el
Scott M. Meyers: changed cmacexp.el
Sean Neakums: changed gnus-msg.el gnus-uu.el
Sean O'rourke: changed ibuf-ext.el
Sebastian Kremer: wrote dired-aux.el dired-x.el dired.el ls-lisp.el
@ -2216,11 +2306,11 @@ Shawn M. Carey: wrote freebsd.h
Shenghuo Zhu: wrote binhex.el mm-extern.el mm-partial.el mm-url.el
mm-uu.el mml2015.el nnrss.el nnwarchive.el rfc1843.el uudecode.el
webmail.el
and changed message.el gnus-art.el gnus-sum.el gnus-msg.el gnus.el
and changed gnus-art.el message.el gnus-sum.el gnus-msg.el gnus.el
gnus-agent.el mm-decode.el mm-util.el gnus-group.el mml.el
gnus-start.el gnus-util.el nnfolder.el mm-view.el nnmail.el
nnslashdot.el gnus-xmas.el nntp.el gnus-topic.el rfc2047.el
dgnushack.el and 103 other files
gnus-start.el gnus-util.el nnfolder.el mm-view.el nnslashdot.el
nnmail.el nntp.el gnus-topic.el gnus-xmas.el rfc2047.el dgnushack.el
and 101 other files
Shinichirou Sugou: changed etags.c
@ -2236,10 +2326,10 @@ Simon Josefsson: wrote dig.el dns-mode.el flow-fill.el fringe.el imap.el
sieve-manage.el sieve-mode.el sieve.el smime.el starttls.el tls.el
url-imap.el
and changed message.el gnus-sum.el gnus-art.el smtpmail.el pgg.el
pgg-gpg.el gnus-agent.el mml2015.el mml.el mm-decode.el mml1991.el
gnus-group.el gnus-msg.el gnus.el pgg-pgp5.el gnus-cache.el
gnus-sieve.el browse-url.el gnus-int.el mail-source.el pgg-parse.el
and 91 other files
mml2015.el pgg-gpg.el gnus-agent.el mml.el mm-decode.el mml1991.el
gnus-group.el gnus-msg.el pgg-pgp5.el gnus-sieve.el gnus.el
browse-url.el gnus-int.el pgg-parse.el gnus-cache.el mail-source.el
and 89 other files
Simon Leinen: changed smtpmail.el Makefile Makefile.in cm.c cm.h hpux9.h
indent.c process.c sc.texinfo sgml-mode.el term.c xfns.c xmenu.c
@ -2259,6 +2349,8 @@ Slawomir Nowaczyk: changed python.el TUTORIAL.pl emacs.py flyspell.el
Spencer Thomas: changed dabbrev.el emacsclient.c emacsserver.c gnus.texi
server.el tcp.c unexec.c
Sriram Karra: changed message.el
Stanislav Shalunov: wrote uce.el
Stefan Monnier: wrote bibtex.el cvs-status.el diff-mode.el log-edit.el
@ -2266,8 +2358,10 @@ Stefan Monnier: wrote bibtex.el cvs-status.el diff-mode.el log-edit.el
reveal.el smerge-mode.el
and changed vc.el font-lock.el pcvs.el newcomment.el subr.el lisp.h
keyboard.c keymap.c tex-mode.el fill.el alloc.c compile.el files.el
regex.c easy-mmode.el simple.el info.el syntax.c xdisp.c vc-hooks.el
sh-script.el and 511 other files
regex.c easy-mmode.el simple.el info.el syntax.c vc-hooks.el xdisp.c
sh-script.el and 512 other files
Steinar Bang: changed imap.el
Stephan Stahl: changed which-func.el buff-menu.el buffer.c dired-x.texi
ediff-mult.el
@ -2296,11 +2390,13 @@ Steve Nygard: changed unexnext.c
Steve Strassman: wrote spook.el
Steve Youngs: changed mh-utils.el mh-xemacs-compat.el dgnushack.el
mh-customize.el mh-e.el mh-comp.el mh-mime.el Makefile gnus-xmas.el
Makefile.in browse-url.el dns.el gnus-art.el gnus-sum.el gnus-util.el
lpath.el mh-seq.el .cvsignore em-unix.el gnus-async.el mail-source.el
mh-customize.el mh-e.el mh-comp.el mh-mime.el Makefile Makefile.in
browse-url.el gnus-art.el gnus-sum.el gnus-xmas.el lpath.el mh-seq.el
.cvsignore dns.el em-unix.el gnus-async.el gnus-util.el mail-source.el
and 15 other files
Steven E. Harris: changed nnheader.el
Steven Huwig: changed emacs.py python.el
Steven L. Baur: wrote earcon.el footnote.el gnus-audio.el gnus-setup.el
@ -2317,7 +2413,7 @@ Steven Tamm: changed macterm.c make-package mac.c macfns.c configure.in
Stewart M. Clamen: wrote cal-mayan.el
Stuart D. Herring: changed minibuf.c
Stuart D. Herring: changed minibuf.c widget.texi
Stuart Herring: changed isearch.el align.el allout.el comint.el edebug.el
files.el
@ -2360,10 +2456,10 @@ Ted Lemon: changed emacs.c lastfile.c puresize.h
Ted Phelps: changed mh-search.el mh-tool-bar.el
Teodor Zlatanov: wrote gnus-registry.el spam-report.el
and changed spam.el gnus.el gnus-sum.el nnmail.el spam-stat.el
gnus-start.el gnus.texi gnus-group.el lpath.el nnbabyl.el nnfolder.el
nnimap.el nnmbox.el nnmh.el nnml.el replace.el simple.el basic.texi
building.texi commands.texi compile.el and 11 other files
and changed spam.el gnus.el gnus-sum.el nnmail.el gnus-start.el
spam-stat.el gnus.texi lpath.el nnbabyl.el nnfolder.el nnimap.el
nnmbox.el nnmh.el nnml.el replace.el simple.el basic.texi building.texi
commands.texi compile.el dig.el and 12 other files
Terje Rosten: changed xfns.c version.el xterm.c xterm.h
@ -2431,7 +2527,7 @@ and changed subr.el
Tomas Abrahamsson: wrote artist.el
Tommi Vainikainen: changed gnus-sum.el
Tommi Vainikainen: changed gnus-sum.el message.el
Tomohiko Morioka: changed gnus-sum.el nnfolder.el nnmail.el nnmh.el
nnml.el coding.c gnus-art.el gnus-ems.el gnus-mule.el nnheader.el
@ -2455,10 +2551,10 @@ Triet Hoai Lai: changed vntelex.el viet-util.el vietnamese.el
Trung Tran-Duc: changed nntp.el
Tsuchiya Masatoshi: changed gnus-art.el nneething.el mm-view.el
gnus-sum.el nnheader.el nnml.el gnus-agent.el gnus-cache.el gnus-msg.el
lpath.el nndiary.el nnfolder.el nnimap.el nnmaildir.el pgg.el
rfc2047.el
Tsuchiya Masatoshi: changed gnus-art.el gnus-sum.el nneething.el
mm-view.el gnus-group.el nnheader.el nnml.el gnus-agent.el
gnus-cache.el gnus-msg.el lpath.el nndiary.el nnfolder.el nnimap.el
nnmaildir.el pgg.el rfc2047.el
Tsugutomo Enami: changed nnheader.el regex.c regex.h simple.el
@ -2479,6 +2575,8 @@ and changed files.el
Vadim Nasardinov: changed allout.el
Vagn Johansen: changed gnus-cache.el
Valery Alexeev: changed cyril-util.el cyrillic.el
Vasily Korytov: changed cperl-mode.el gnus-art.el gnus-dired.el
@ -2502,6 +2600,8 @@ Vivek Dasmohapatra: changed emacs.c sh-script.el xterm.c xterm.h
Vladimir Alexiev: changed arc-mode.el nnvirtual.el tmm.el
Vladimir Volovich: changed smime.el
Walter C. Pelissero: changed browse-url.el url-methods.el
Wayne Mesard: wrote hscroll.el
@ -2555,14 +2655,14 @@ Wolfram Fenske: changed nnimap.el
Wolfram Gloger: changed emacs.c
Xavier Maillard: changed gnus-faq.texi gnus-score.el
Xavier Maillard: changed gnus-faq.texi gnus-score.el spam.el
Yagi Tatsuya: changed gnus-art.el gnus-start.el
Yamamoto Mitsuharu: changed macterm.c macfns.c mac-win.el mac.c macterm.h
macgui.h image.c macmenu.c macselect.c keyboard.c makefile.MPW xdisp.c
macgui.h image.c macmenu.c macselect.c keyboard.c xdisp.c makefile.MPW
emacs.c config.h macos.texi xfaces.c Makefile.in darwin.h dispextern.h
w32term.c INSTALL and 66 other files
dispnew.c w32term.c and 69 other files
Yann Dirson: changed imenu.el
@ -2584,8 +2684,6 @@ Zoltan Kemenczy: changed gud.el
Zoran Milojevic: changed avoid.el
,AI(Bric Jacoboni: changed fr-refcard.tex
Local Variables:
coding: iso-2022-7bit
End:

View File

@ -1,3 +1,46 @@
2006-10-29 Chong Yidong <cyd@stupidchicken.com>
* configure: Regenerate using autoconf 2.59.
2006-10-29 Jeramey Crawford <jeramey@jeramey.com>
* configure.in: Enable x86-64 OpenBSD compilation.
2006-10-28 Glenn Morris <rgm@gnu.org>
* AUTHORS: Add cal-html.el author.
2006-10-28 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
* make-dist: Make links to mac/make-package and
mac/Emacs.app/Contents/Resources/Emacs.icns.
2006-10-27 Chong Yidong <cyd@stupidchicken.com>
* README: Bump version number to 22.0.90.
* AUTHORS: Regenerate.
* configure: Regenerate.
2006-10-23 Michael Kifer <kifer@cs.stonybrook.edu>
* viper-cmd.el (viper-prefix-arg-com): define gg as G0
* viper-ex.el (ex-read): quote file argument.
* ediff-diff.el (ediff-same-file-contents): expand file names.
* ediff-mult.el (ediff-append-custom-diff): quote shell file arguments.
2006-10-23 Andreas Schwab <schwab@suse.de>
* configure.in: Make sure x_default_search_path is always set even
when x_libraries is empty, and look in .../share as well for each
library directory.
* configure: Regenerate.
2006-10-03 Kim F. Storm <storm@cua.dk>
* AUTHORS: Regenerate.

2
README
View File

@ -1,4 +1,4 @@
This directory tree holds version 22.0.50 of GNU Emacs, the extensible,
This directory tree holds version 22.0.90 of GNU Emacs, the extensible,
customizable, self-documenting real-time display editor.
You may encounter bugs in this release. If you do, please report

View File

@ -1,3 +1,12 @@
2006-10-28 Chong Yidong <cyd@stupidchicken.com>
* make-announcement (OLD): Remove LEIM references in announcement
since it is now built-in.
2006-10-15 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
* admin.el (set-version): Set version numbers in "mac" subdirectory.
2006-10-03 Kenichi Handa <handa@m17n.org>
* FOR-RELEASE (BUGS): "An iso-8859-6 cannot be saved" fixed.

View File

@ -36,15 +36,14 @@ attention of Windows users to fixing them.
** Drew Adams 12 Aug bug rpt: overlay display artifact: trace left behind
Windows only bug. Bug appears only when Cleartype enabled, probably related
to the hack introduced on 2005-07-01 to fix some other Cleartype problem.
to the hack introduced on 2005-07-01 to fix some other Cleartype problem.
** henman@it.to-be.co.jp 09 Aug 2006: ispell.el problem on Cygwin.
(Did we decide that is unreproducible?)
* BUGS
** hashiz@tomba.meridiani.jp, Oct 6: bootstrap failure on FreeBSD 6.2
Can't be reproduced on GNU/Linux.
** david.reitter@gmail.com, Oct 16: url-retrieve may cause hang
* DOCUMENTATION

View File

@ -97,12 +97,12 @@ Root must be the root of an Emacs source tree."
(comma-version
(concat (car version-components) ","
(cadr version-components) ","
(cadr (cdr version-components)) ","
(cadr (cdr version-components)) ","
(cadr (cdr (cdr version-components)))))
(comma-space-version
(concat (car version-components) ", "
(cadr version-components) ", "
(cadr (cdr version-components)) ", "
(cadr (cdr version-components)) ", "
(cadr (cdr (cdr version-components))))))
(set-version-in-file root "nt/emacs.rc" comma-version
(rx (and "FILEVERSION" (1+ space)
@ -116,7 +116,43 @@ Root must be the root of an Emacs source tree."
(set-version-in-file root "nt/emacs.rc" comma-space-version
(rx (and "\"ProductVersion\"" (0+ space) ?,
(0+ space) ?\" (submatch (1+ (in "0-9, ")))
"\\0\"")))))
"\\0\"")))
;; Some files in the "mac" subdirectory also contain the version
;; number.
(set-version-in-file
root "mac/Emacs.app/Contents/Resources/English.lproj/InfoPlist.strings"
version (rx (and "CFBundleShortVersionString" (0+ space) ?= (0+ space) ?\"
(submatch (1+ (in "0-9."))))))
(set-version-in-file
root "mac/Emacs.app/Contents/Resources/English.lproj/InfoPlist.strings"
version (rx (and "CFBundleGetInfoString" (0+ space) ?= (0+ space) ?\"
(submatch (1+ (in "0-9."))))))
(set-version-in-file root "mac/src/Emacs.r" (car version-components)
(rx (and "GNU Emacs " (submatch (1+ (in "0-9")))
" for Mac OS")))
(set-version-in-file root "mac/src/Emacs.r" (car version-components)
(rx (and (submatch (1+ (in "0-9"))) (0+ space) ?\,
(0+ space) "/* Major revision in BCD */")))
(set-version-in-file root "mac/src/Emacs.r" (cadr version-components)
(rx (and (submatch (1+ (in "0-9"))) (0+ space) ?\,
(0+ space) "/* Minor revision in BCD */")))
(set-version-in-file root "mac/src/Emacs.r" (cadr (cdr version-components))
(rx (and (submatch (1+ (in "0-9"))) (0+ space) ?\,
(0+ space) "/* Non-final release # */")))
(set-version-in-file root "mac/src/Emacs.r" version
(rx (and (submatch (1+ (in "0-9."))) (0+ space) ?\" ?\,
(0+ space) "/* Short version number */")))
(set-version-in-file root "mac/src/Emacs.r" version
(rx (and "/* Short version number */" (0+ space) ?\"
(submatch (1+ (in "0-9."))))))
(let* ((third-component (string-to-number (cadr (cdr version-components))))
(release (cond ((>= third-component 90) "alpha")
((>= third-component 50) "development")
(t "final"))))
(set-version-in-file
root "mac/src/Emacs.r" release
(rx (and (submatch (1+ (in "a-z"))) (0+ space) ?\, (0+ space)
"/* development, alpha, beta, or final (release) */"))))))
;;; arch-tag: 4ea83636-2293-408b-884e-ad64f22a3bf5
;; admin.el ends here.

View File

@ -34,18 +34,15 @@ cat <<EOF
There is a new pretest available in
<ftp://alpha.gnu.org/gnu/emacs/pretest/emacs-$NEW.tar.gz>
<ftp://alpha.gnu.org/gnu/emacs/pretest/leim-$NEW.tar.gz>
Please report results from compiling and running the pretest to
<emacs-pretest-bug@gnu.org>. Your feedback is necessary for us
to know on which platforms the pretest has been tried.
Please say whether you built with LEIM or not.
If you have the tars from the previous pretest, and you have the
\`xdelta' utility, you can instead download the much smaller
<ftp://alpha.gnu.org/gnu/emacs/pretest/emacs-$OLD-$NEW.xdelta>
<ftp://alpha.gnu.org/gnu/emacs/pretest/leim-$OLD-$NEW.xdelta>
You can use a command like

589
configure vendored

File diff suppressed because it is too large Load Diff

View File

@ -284,6 +284,7 @@ dnl see the `changequote' comment above.
case "${canonical}" in
alpha*-*-openbsd*) machine=alpha ;;
i386-*-openbsd*) machine=intel386 ;;
x86_64-*-openbsd*) machine=amdx86-64 ;;
m68k-*-openbsd*) machine=hp9000s300 ;;
mipsel-*-openbsd*) machine=pmax ;;
ns32k-*-openbsd*) machine=ns32000 ;;
@ -1729,11 +1730,18 @@ else
window_system=x11
fi
if test "${x_libraries}" != NONE && test -n "${x_libraries}"; then
LD_SWITCH_X_SITE=-L`echo ${x_libraries} | sed -e "s/:/ -L/g"`
LD_SWITCH_X_SITE_AUX=-R`echo ${x_libraries} | sed -e "s/:/ -R/g"`
if test "${x_libraries}" != NONE; then
if test -n "${x_libraries}"; then
LD_SWITCH_X_SITE=-L`echo ${x_libraries} | sed -e "s/:/ -L/g"`
LD_SWITCH_X_SITE_AUX=-R`echo ${x_libraries} | sed -e "s/:/ -R/g"`
fi
x_default_search_path=""
for x_library in `echo ${x_libraries} | sed -e "s/:/ /g"`; do
x_search_path=${x_libraries}
if test -z "${x_search_path}"; then
x_search_path=/usr/lib
fi
for x_library in `echo ${x_search_path}: | \
sed -e "s/:/ /g" -e p -e "s:/lib[[^ /]]* :/share :g"`; do
x_search_path="\
${x_library}/X11/%L/%T/%N%C%S:\
${x_library}/X11/%l/%T/%N%C%S:\

View File

@ -1,3 +1,8 @@
2006-10-22 Chong Yidong <cyd@stupidchicken.com>
* emacs.py (eargs): Return expected _emacs_out string even if
errors occur.
2006-10-09 David Kastrup <dak@gnu.org>
* DEVEL.HUMOR: Add the topic line for last entry since that was

View File

@ -3367,6 +3367,10 @@ the calendar left or right. (The old key bindings still work too.)
*** There is a new calendar package, icalendar.el, that can be used to
convert Emacs diary entries to/from the iCalendar format.
+++
*** The new package cal-html.el writes HTML files with calendar and
diary entries.
+++
*** Diary sexp entries can have custom marking in the calendar.
Diary sexp functions which only apply to certain days (such as

View File

@ -59,13 +59,16 @@ def eargs (name, imports):
return
if inspect.ismethod (func):
func = func.im_func
if not inspect.isfunction (func): return
if not inspect.isfunction (func):
print '_emacs_out '
return
(args, varargs, varkw, defaults) = inspect.getargspec (func)
# No space between name and arglist for consistency with builtins.
print '_emacs_out', \
func.__name__ + inspect.formatargspec (args, varargs, varkw,
defaults)
except: pass
except:
print "_emacs_out "
def all_names (object):
"""Return (an approximation to) a list of all possible attribute

View File

@ -1,3 +1,228 @@
2006-10-29 Stephen Leake <stephen_leake@stephe_leake.org>
* progmodes/ada-mode.el: Change maintainer, apply
whitespace-clean, checkdoc. Minor improvements to many doc
strings.
(ada-mode-version): New function.
(ada-create-menu): Menu operations are available for all supported
compilers.
2006-10-29 Lars Hansen <larsh@soem.dk>
* net/tramp.el (with-parsed-tramp-file-name): Correct debug
spec. Highlight as keyword.
(tramp-do-copy-or-rename-file): Correct data for 'file-already-exists.
Don't call tramp-method-out-of-band-p for local files.
(tramp-touch): Quote file name.
2006-10-28 Glenn Morris <rgm@gnu.org>
* calendar/calendar.el (cal-html-cursor-month)
(cal-html-cursor-year): Add autoloads for this new package.
(calendar-mode-map): Bind cal-html-cursor-month,
cal-html-cursor-year.
2006-10-28 Anna Bigatti <bigatti@dima.unige.it>
* calendar/cal-html.el: New file.
2006-10-28 Chong Yidong <cyd@stupidchicken.com>
* emacs-lisp/authors.el (authors-aliases): Update.
2006-10-27 Chong Yidong <cyd@stupidchicken.com>
* version.el (emacs-version): Bump version number to 22.0.90.
2006-10-26 John W. Eaton <jwe@octave.org>
* progmodes/octave-inf.el (inferior-octave-has-built-in-variables):
New defvar.
(inferior-octave-resync-dirs): Check to see whether Octave has
built-in variables and set inferior-octave-has-built-in-variables.
Check inferior-octave-has-built-in-variables to decide whether to
send commands that set built-in variables or call functions to
change Octave's behavior.
Send "disp (pwd ())" to Octave instead of just "pwd".
(inferior-octave-startup): Send "more off" to Octave instead of
"page_screen_output = 0".
2006-10-26 Chong Yidong <cyd@stupidchicken.com>
* emacs-lisp/cl-indent.el (lisp-indent-259): Indent nil's in the
pattern normally.
2006-10-26 Nick Roberts <nickrob@snap.net.nz>
* bindings.el (mode-line-mode-menu): Remove bindings for global
minor modes (line/column number) as they are on the menubar.
2006-10-25 Juanma Barranquero <lekktu@gmail.com>
* term/w32-win.el (x-handle-name-switch): Doc fix.
(w32-standard-fontset-spec): Fix typo in docstring.
* midnight.el (midnight-buffer-display-time): Doc fix.
(clean-buffer-list-kill-never-buffer-names): Add "*server*".
2006-10-22 martin rudalics <rudalics@gmx.at>
* textmodes/flyspell.el (flyspell-check-region-doublons):
Fix last fix.
2006-10-23 Nick Roberts <nickrob@snap.net.nz>
* bindings.el (mode-line-mode-menu): List global minor modes
before local ones.
2006-10-23 Kim F. Storm <storm@cua.dk>
* subr.el (add-to-list): Optimize if compare-fn is `eq' or `eql'.
(sit-for): If last command was a prefix arg, add the read-ahead
event to unread-command-events as (t . EVENT) so it will be added
to this-command-keys by read-key-sequence.
2006-10-22 martin rudalics <rudalics@gmx.at>
* textmodes/flyspell.el (flyspell-word): Skip past all previous
whitespace when checking doublons.
(flyspell-check-region-doublons): Fix doublon regexp.
(flyspell-highlight-incorrect-region): Highlight doublons using
flyspell-duplicate face.
* progmodes/cperl-mode.el (cperl-invalid-face): Fix defcustom.
2006-10-22 John Wiegley <johnw@newartisans.com>
* progmodes/python.el (python-use-skeletons): python-mode was
auto-inserting templates (for those with abbrev-mode on), not only
by default -- *but without a configuration variable to disable
it*. This rendered python-mode completely useless for me, so I
have added `python-use-skeletons', which is now off by default.
2006-10-22 Chong Yidong <cyd@stupidchicken.com>
* progmodes/cperl-mode.el (cperl-mode): Don't assume
font-lock-multiline is auto-local (it's not).
(cperl-windowed-init): Ensure that cperl-font-lock-multiline is
initialized before calling cperl-init-faces.
2006-10-22 Nick Roberts <nickrob@snap.net.nz>
* progmodes/gdb-ui.el (gdb-info-stack-custom): Don't try to give
gdb-stack-position a value when there is no fringe.
* bindings.el (mode-line-mode-menu): Disable auto-revert-tail-mode
indicator if not visiting a file.
2006-10-20 David Kastrup <dak@gnu.org>
* window.el (kill-buffer-and-window): Fix a bug where an aborted
operation would still cause some window to collapse later.
2006-10-20 Stefan Monnier <monnier@iro.umontreal.ca>
* vc.el (vc-switch-backend): Try to be more careful with unwanted
side-effect due to mixing various backends's file properties.
* vc-svn.el (vc-svn-parse-status): Remove unused arg `localp'.
Add arg `filename' instead. Don't set vc-backend if `filename' is set.
Return `filename's status if applicable. Update callers.
2006-10-19 Kenichi Handa <handa@m17n.org>
* international/kkc.el (kkc-region): When a key sequence is not
defined, append (this-single-command-raw-keys) to
unread-input-method-events.
2006-10-19 Juanma Barranquero <lekktu@gmail.com>
* progmodes/ada-mode.el (ada-in-string-p): Doc fix.
2006-10-19 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
* version.el (emacs-version): Use mac-carbon-version-string.
* term/macterm.el (res-geometry): Apply 2006-10-18 change for x-win.el.
2006-10-19 Jan Dj,Ad(Brv <jan.h.d@swipnet.se>
* select.el (ccl-check-utf-8, string-utf-8-p): New functions
(by Kenichi Handa).
(xselect-convert-to-string): Decline requests for UTF8_STRING if
the selection is not UTF-8.
2006-10-18 Juanma Barranquero <lekktu@gmail.com>
* progmodes/ada-mode.el (ada-83-string-keywords)
(ada-last-which-function-line ada-no-auto-case, ada-indent-region)
(ada-which-compiler, ada-align-modes, ada-adjust-case-buffer)
(ada-looking-at-semi-private, ada-get-body-name):
Fix typos in docstrings.
(ada-create-case-exception, ada-create-case-exception-substring):
Fix typos in error messages.
(ada-goto-matching-end, ada-narrow-to-defun): Doc fixes.
2006-10-18 Jan Dj,Ad(Brv <jan.h.d@swipnet.se>
* term/x-win.el (res-geometry): Don't set geometry from Xresources
to default-frame-alist if default-frame-alist already contains
width/height.
2006-10-18 Richard Stallman <rms@gnu.org>
* emacs-lisp/pp.el (pp-eval-expression): Use `X' to read value.
Non-interactive arg is the value, not the expression.
* simple.el (read-expression-map): Just set it, no defvar.
* subr.el (insert-for-yank-1): If last inserted char has
properties, mark them as rear-nonsticky.
* recentf.el (recentf-mode): Doc fix.
* facemenu.el (facemenu-add-new-face): Defend against symbol
that isn't a face name.
* dired-aux.el (dired-do-copy): Doc fix.
2006-10-18 Chong Yidong <cyd@stupidchicken.com>
* simple.el (line-move-1): Ignore fields when moving to the
beginning of line to avoid getting point stuck.
2006-10-18 Martin Rudalics <rudalics@gmx.at>
* textmodes/flyspell.el (flyspell-word-search-backward):
Set inhibit-point-motion-hooks to avoid looping due to intangibile
text.
2006-10-16 Richard Stallman <rms@gnu.org>
* help-fns.el (describe-function-1): Special case optimization
for self-insert-command.
2006-10-16 Kim F. Storm <storm@cua.dk>
* ido.el (ido-reread-directory): Work in `dir' mode too.
2006-10-15 Martin Rudalics <rudalics@gmx.at>
* textmodes/table.el: Require 'regexp-opt.
2006-10-15 Lennart Borgman <lennart.borgman.073@student.lu.se>
* progmodes/flymake.el (flymake-get-project-include-dirs-imp):
Use shell-quote-argument.
* shell.el (explicit-bash-args): Likewise.
* progmodes/ada-xref.el (ada-find-in-src-path): Likewise.
Use grep -E rather than egrep.
2006-10-15 Micha,Ak(Bl Cadilhac <michael.cadilhac@lrde.org>
* ido.el (ido-exhibit): Allow `-', `_', and trailing `$' in user id.
2006-10-15 Kim F. Storm <storm@cua.dk>
* filesets.el (filesets-run-cmd--repl-fn): Use shell-quote-argument.
@ -9,8 +234,7 @@
2006-10-13 Giorgos Keramidas <keramida@ceid.upatras.gr> (tiny change)
* apropos.el (apropos-pattern-quoted): Fix a typo in a doc
string.
* apropos.el (apropos-pattern-quoted): Fix a typo in a doc string.
2006-10-13 Eli Zaretskii <eliz@gnu.org>
@ -33,8 +257,8 @@
2006-10-12 Carsten Dominik <dominik@science.uva.nl>
* textmodes/reftex-global.el (reftex-create-tags-file): Quote file
arguments.
* textmodes/reftex-global.el (reftex-create-tags-file):
Quote file arguments.
2006-10-12 Richard Stallman <rms@gnu.org>
@ -230,7 +454,7 @@
After 5.10:
This code may lock Emacs hard!!! Use on your own risk!
This code may lock Emacs hard!!! Use at your own risk!
(cperl-font-locking): New internal variable.
(cperl-beginning-of-property): New function.
@ -244,7 +468,7 @@
recursively.
Bound `next-single-property-change' via `point-max'.
(cperl-unwind-to-safe): Bound likewise
(cperl-font-lock-fontify-region-function): Likewise
(cperl-font-lock-fontify-region-function): Likewise.
(cperl-find-pods-heres): Mark as recursive for `cperl-to-comment-or-eol'
Initialization of `cperl-font-lock-multiline-start' could be
missed if the "main" fontification did not run due to the
@ -399,7 +623,7 @@
was inverted;
Support `comment-column' = 0.
2006-10-11 Martin Rudalics <rudalics@gmx.at>
2006-10-11 Martin Rudalics <rudalics@gmx.at>
* dnd.el (dnd-handle-one-url): Fix typo in doc-string.
* help-at-pt.el (scan-buf-move-to-region): Likewise.
@ -443,8 +667,8 @@
2006-10-08 Nick Roberts <nickrob@snap.net.nz>
* progmodes/gdb-ui.el (gdb-speedbar-expand-node): Burp if
GUD buffer has been killed.
* progmodes/gdb-ui.el (gdb-speedbar-expand-node):
Burp if GUD buffer has been killed.
2006-10-07 Stefan Monnier <monnier@iro.umontreal.ca>
@ -471,7 +695,7 @@
* autoinsert.el (auto-insert-alist): Doc fix.
2006-10-07 Johan Bockg,be(Brd <bojohan@dd.chalmers.se>
2006-10-07 Johan Bockg,Ae(Brd <bojohan@dd.chalmers.se>
* mouse-sel.el (mouse-insert-selection-internal):
Use insert-for-yank, so that yank handlers are run.
@ -1972,7 +2196,7 @@
(python-symbol-completions): Use python-imports.
(python-module-path, ffap-alist): Add support for ffap.
(python-skeletons, python-mode-abbrev-table, def-python-skeleton)
(pythin-insert-*, python-default-template, python-expand-template):
(python-insert-*, python-default-template, python-expand-template):
Add templates/skeletons.
(python-setup-brm): Support for Bicycle Repair Man.
(python-abbrev-syntax-table): New var.
@ -26846,7 +27070,7 @@
* emacs-lisp/lisp-mode.el (lisp-mode-variables):
Add ;;;###autoload to `outline-regexp'. Suggested by Stefan Monnier
<monnier@iro.umontreal.ca>
<monnier@iro.umontreal.ca>.
(lisp-outline-level): Improve efficiency. Suggested by David
Kastrup <dak@gnu.org>.
@ -27258,7 +27482,7 @@
* progmodes/gdb-ui.el (gdb-info-breakpoints-custom)
(gdb-goto-breakpoint): Make breakpoint handling work on template
functions in C++. Reported by Martin Reed <mjreed@essex.ac.uk>
functions in C++. Reported by Martin Reed <mjreed@essex.ac.uk>.
(gdb-assembler-custom): Update to recognize breakpoint information
added on 2005-01-19.
@ -27531,10 +27755,10 @@
(tramp-do-copy-or-rename-file-directly): Mask `cp -p' error.
Call `set-file-modes' when appropriate.
(tramp-action-out-of-band): Mask `scp -p' error. Reported by Isak
Johnsson <isak@hypergene.com>
Johnsson <isak@hypergene.com>.
(tramp-get-buffer, tramp-get-debug-buffer): Discard the undo list
of both Tramp buffer and debug buffer. Reported by Joakim Verona
<joakim@verona.se>
<joakim@verona.se>.
(tramp-file-name-for-operation): Mark `shell-command' as magic for
Emacs only.
@ -27580,7 +27804,7 @@
* simple.el (eval-expression-print-format): Avoid warning
about edebug-active.
2005-01-15 James R. Van Zandt <jrvz@comcast.net> (Tiny change)
2005-01-15 James R. Van Zandt <jrvz@comcast.net> (tiny change)
* progmodes/sh-script.el: Code copied from make-mode.el
with small changes,

View File

@ -426,15 +426,14 @@ Menu of mode operations in the mode line.")
"Return the value of symbol VAR if it is bound, else nil."
`(and (boundp (quote ,var)) ,var))
;; Use mode-line-mode-menu for local minor-modes only.
;; Global ones can go on the menubar (Options --> Show/Hide).
(define-key mode-line-mode-menu [overwrite-mode]
`(menu-item ,(purecopy "Overwrite (Ovwrt)") overwrite-mode
:button (:toggle . overwrite-mode)))
(define-key mode-line-mode-menu [outline-minor-mode]
`(menu-item ,(purecopy "Outline (Outl)") outline-minor-mode
:button (:toggle . (bound-and-true-p outline-minor-mode))))
(define-key mode-line-mode-menu [line-number-mode]
`(menu-item ,(purecopy "Line number") line-number-mode
:button (:toggle . line-number-mode)))
(define-key mode-line-mode-menu [highlight-changes-mode]
`(menu-item ,(purecopy "Highlight changes (Chg)") highlight-changes-mode
:button (:toggle . (bound-and-true-p highlight-changes-mode))))
@ -450,11 +449,9 @@ Menu of mode operations in the mode line.")
(define-key mode-line-mode-menu [flyspell-mode]
`(menu-item ,(purecopy "Flyspell (Fly)") flyspell-mode
:button (:toggle . (bound-and-true-p flyspell-mode))))
(define-key mode-line-mode-menu [column-number-mode]
`(menu-item ,(purecopy "Column number") column-number-mode
:button (:toggle . column-number-mode)))
(define-key mode-line-mode-menu [auto-revert-tail-mode]
`(menu-item ,(purecopy "Auto revert tail (Tail)") auto-revert-tail-mode
:enable (buffer-file-name)
:button (:toggle . (bound-and-true-p auto-revert-tail-mode))))
(define-key mode-line-mode-menu [auto-revert-mode]
`(menu-item ,(purecopy "Auto revert (ARev)") auto-revert-mode

445
lisp/calendar/cal-html.el Normal file
View File

@ -0,0 +1,445 @@
;;; cal-html.el --- functions for printing HTML calendars
;; Copyright (C) 2002, 2003, 2004, 2005, 2006 Free Software Foundation, Inc.
;; Author: Anna M. Bigatti <bigatti@dima.unige.it>
;; Keywords: calendar
;; Human-Keywords: calendar, diary, HTML
;; Created: 23 Aug 2002
;; This file is part of GNU Emacs.
;; GNU Emacs is free software; you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation; either version 2, or (at your option)
;; any later version.
;; GNU Emacs is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;; GNU General Public License for more details.
;; You should have received a copy of the GNU General Public License
;; along with GNU Emacs; see the file COPYING. If not, write to the
;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
;; Boston, MA 02110-1301, USA.
;;; Commentary:
;; This package writes HTML calendar files using the user's diary
;; file. See the Emacs manual for details.
;;; Code:
(require 'calendar)
(defgroup calendar-html nil
"Options for HTML calendars."
:prefix "cal-html-"
:group 'calendar)
(defcustom cal-html-directory "~/public_html"
"Directory for HTML pages generated by cal-html."
:type 'string
:group 'calendar-html)
(defcustom cal-html-print-day-number-flag nil
"Non-nil means print the day-of-the-year number in the monthly cal-html page."
:type 'boolean
:group 'calendar-html)
(defcustom cal-html-year-index-cols 3
"Number of columns in the cal-html yearly index page."
:type 'integer
:group 'calendar-html)
(defcustom cal-html-day-abbrev-array
(calendar-abbrev-construct calendar-day-abbrev-array
calendar-day-name-array)
"Array of seven strings for abbreviated day names (starting with Sunday)."
:type '(vector string string string string string string string)
:group 'calendar-html)
(defcustom cal-html-css-default
(concat
"<STYLE TYPE=\"text/css\">\n"
" BODY { background: #bde; }\n"
" H1 { text-align: center; }\n"
" TABLE { padding: 2pt; }\n"
" TH { background: #dee; }\n"
" TABLE.year { width: 100%; }\n"
" TABLE.agenda { width: 100%; }\n"
" TABLE.header { width: 100%; text-align: center; }\n"
" TABLE.minical TD { background: white; text-align: center; }\n"
" TABLE.agenda TD { background: white; text-align: left; }\n"
" TABLE.agenda TH { text-align: left; width: 20%; }\n"
" SPAN.NO-YEAR { color: #0b3; font-weight: bold; }\n"
" SPAN.ANN { color: #0bb; font-weight: bold; }\n"
" SPAN.BLOCK { color: #048; font-style: italic; }\n"
"</STYLE>\n\n")
"Default cal-html css style. You can override this with a \"cal.css\" file."
:type 'string
:group 'calendar-html)
;;; End customizable variables.
;;; HTML and CSS code constants.
(defconst cal-html-e-document-string "<BR><BR>\n</BODY>\n</HTML>"
"HTML code for end of page.")
(defconst cal-html-b-tablerow-string "<TR>\n"
"HTML code for beginning of table row.")
(defconst cal-html-e-tablerow-string "</TR>\n"
"HTML code for end of table row.")
(defconst cal-html-b-tabledata-string " <TD>"
"HTML code for beginning of table data.")
(defconst cal-html-e-tabledata-string " </TD>\n"
"HTML code for end of table data.")
(defconst cal-html-b-tableheader-string " <TH>"
"HTML code for beginning of table header.")
(defconst cal-html-e-tableheader-string " </TH>\n"
"HTML code for end of table header.")
(defconst cal-html-e-table-string
"</TABLE>\n<!-- ================================================== -->\n"
"HTML code for end of table.")
(defconst cal-html-minical-day-format " <TD><a href=%s#%d>%d</TD>\n"
"HTML code for a day in the minical - links NUM to month-page#NUM.")
(defconst cal-html-b-document-string
(concat
"<HTML>\n"
"<HEAD>\n"
"<TITLE>Calendar</TITLE>\n"
"<!--This buffer was produced by cal-html.el-->\n\n"
cal-html-css-default
"<LINK REL=\"stylesheet\" TYPE=\"text/css\" HREF=\"cal.css\">\n"
"</HEAD>\n\n"
"<BODY>\n\n")
"Initial block for html page.")
(defconst cal-html-html-subst-list
'(("&" . "&amp;")
("\n" . "<BR>\n"))
"Alist of symbols and their HTML replacements.")
(defun cal-html-comment (string)
"Return STRING as html comment."
(format "<!-- ====== %s ====== -->\n"
(replace-regexp-in-string "--" "++" string)))
(defun cal-html-href (link string)
"Return a hyperlink to url LINK with text STRING."
(format "<A HREF=\"%s\">%s</A>" link string))
(defun cal-html-h3 (string)
"Return STRING as html header h3."
(format "\n <H3>%s</H3>\n" string))
(defun cal-html-h1 (string)
"Return STRING as html header h1."
(format "\n <H1>%s</H1>\n" string))
(defun cal-html-th (string)
"Return STRING as html table header."
(format "%s%s%s" cal-html-b-tableheader-string string
cal-html-e-tableheader-string))
(defun cal-html-b-table (arg)
"Return table tag with attribute ARG."
(format "\n<TABLE %s>\n" arg))
(defun cal-html-monthpage-name (month year)
"Return name of html page for numeric MONTH and four-digit YEAR.
For example, \"2006-08.html\" for 8 2006."
(format "%d-%.2d.html" year month))
(defun cal-html-insert-link-monthpage (month year &optional change-dir)
"Insert a link to the html page for numeric MONTH and four-digit YEAR.
If optional argument CHANGE-DIR is non-nil and MONTH is 1 or 2,
the link points to a different year and so has a directory part."
(insert (cal-html-h3
(cal-html-href
(concat (and change-dir
(member month '(1 12))
(format "../%d/" year))
(cal-html-monthpage-name month year))
(calendar-month-name month)))))
(defun cal-html-insert-link-yearpage (month year)
"Insert a link to index page for four-digit YEAR, tagged using MONTH name."
(insert (cal-html-h1
(format "%s %s"
(calendar-month-name month)
(cal-html-href "index.html" (number-to-string year))))))
(defun cal-html-year-dir-ask-user (year)
"Prompt for the html calendar output directory for four-digit YEAR.
Return the expanded directory name, which is based on
`cal-html-directory' by default."
(expand-file-name (read-directory-name
"Enter HTML calendar directory name: "
(expand-file-name (format "%d" year)
cal-html-directory))))
;;------------------------------------------------------------
;; page header
;;------------------------------------------------------------
(defun cal-html-insert-month-header (month year)
"Insert the header for the numeric MONTH page for four-digit YEAR.
Contains links to previous and next month and year, and current minical."
(insert (cal-html-b-table "class=header"))
(insert cal-html-b-tablerow-string)
(insert cal-html-b-tabledata-string) ; month links
(increment-calendar-month month year -1) ; previous month
(cal-html-insert-link-monthpage month year t) ; t --> change-dir
(increment-calendar-month month year 1) ; current month
(cal-html-insert-link-yearpage month year)
(increment-calendar-month month year 1) ; next month
(cal-html-insert-link-monthpage month year t) ; t --> change-dir
(insert cal-html-e-tabledata-string)
(insert cal-html-b-tabledata-string) ; minical
(increment-calendar-month month year -1)
(cal-html-insert-minical month year)
(insert cal-html-e-tabledata-string)
(insert cal-html-e-tablerow-string) ; end
(insert cal-html-e-table-string))
;;------------------------------------------------------------
;; minical: a small month calendar with links
;;------------------------------------------------------------
(defun cal-html-insert-minical (month year)
"Insert a minical for numeric MONTH of YEAR."
(let* ((blank-days ; at start of month
(mod (- (calendar-day-of-week (list month 1 year))
calendar-week-start-day)
7))
(last (calendar-last-day-of-month month year))
(end-blank-days ; at end of month
(mod (- 6 (- (calendar-day-of-week (list month last year))
calendar-week-start-day))
7))
(monthpage-name (cal-html-monthpage-name month year))
date)
;; Start writing table.
(insert (cal-html-comment "MINICAL")
(cal-html-b-table "class=minical border=1 align=center"))
;; Weekdays row.
(insert cal-html-b-tablerow-string)
(dotimes (i 7)
(insert (cal-html-th
(aref cal-html-day-abbrev-array
(mod (+ i calendar-week-start-day) 7)))))
(insert cal-html-e-tablerow-string)
;; Initial empty slots.
(insert cal-html-b-tablerow-string)
(dotimes (i blank-days)
(insert
cal-html-b-tabledata-string
cal-html-e-tabledata-string))
;; Numbers.
(dotimes (i last)
(insert (format cal-html-minical-day-format monthpage-name i (1+ i)))
;; New row?
(if (and (zerop (mod (+ i 1 blank-days) 7))
(/= (1+ i) last))
(insert cal-html-e-tablerow-string
cal-html-b-tablerow-string)))
;; End empty slots (for some browsers like konqueror).
(dotimes (i end-blank-days)
(insert
cal-html-b-tabledata-string
cal-html-e-tabledata-string)))
(insert cal-html-e-tablerow-string
cal-html-e-table-string
(cal-html-comment "MINICAL end")))
;;------------------------------------------------------------
;; year index page with minicals
;;------------------------------------------------------------
(defun cal-html-insert-year-minicals (year cols)
"Make a one page yearly mini-calendar for four-digit YEAR.
There are 12/cols rows of COLS months each."
(insert cal-html-b-document-string)
(insert (cal-html-h1 (number-to-string year)))
(insert (cal-html-b-table "class=year")
cal-html-b-tablerow-string)
(dotimes (i 12)
(insert cal-html-b-tabledata-string)
(cal-html-insert-link-monthpage (1+ i) year)
(cal-html-insert-minical (1+ i) year)
(insert cal-html-e-tabledata-string)
(if (zerop (mod (1+ i) cols))
(insert cal-html-e-tablerow-string
cal-html-b-tablerow-string)))
(insert cal-html-e-tablerow-string
cal-html-e-table-string
cal-html-e-document-string))
;;------------------------------------------------------------
;; HTMLify
;;------------------------------------------------------------
(defun cal-html-htmlify-string (string)
"Protect special characters in STRING from HTML.
Characters are replaced according to `cal-html-html-subst-list'."
(if (stringp string)
(replace-regexp-in-string
(regexp-opt (mapcar 'car cal-html-html-subst-list))
(lambda (x)
(cdr (assoc x cal-html-html-subst-list)))
string)
""))
(defun cal-html-htmlify-entry (entry)
"Convert a diary entry ENTRY to html with the appropriate class specifier."
(let ((start
(cond
((string-match "block" (car (cddr entry))) "BLOCK")
((string-match "anniversary" (car (cddr entry))) "ANN")
((not (string-match
(number-to-string (car (cddr (car entry))))
(car (cddr entry))))
"NO-YEAR")
(t "NORMAL"))))
(format "<span class=%s>%s</span>" start
(cal-html-htmlify-string (cadr entry)))))
(defun cal-html-htmlify-list (date-list date)
"Return a string of concatenated, HTMLified diary entries.
DATE-LIST is a list of diary entries. Return only those matching DATE."
(mapconcat (lambda (x) (cal-html-htmlify-entry x))
(let (result)
(dolist (p date-list (reverse result))
(and (car p)
(calendar-date-equal date (car p))
(setq result (cons p result)))))
"<BR>\n "))
;;------------------------------------------------------------
;; Monthly calendar
;;------------------------------------------------------------
(autoload 'diary-list-entries "diary-lib" nil t)
(defun cal-html-list-diary-entries (d1 d2)
"Generate a list of all diary-entries from absolute date D1 to D2."
(let (diary-display-hook)
(diary-list-entries
(calendar-gregorian-from-absolute d1)
(1+ (- d2 d1)))))
(defun cal-html-insert-agenda-days (month year diary-list)
"Insert HTML commands for a range of days in monthly calendars.
HTML commands are inserted for the days of the numeric MONTH in
four-digit YEAR. Diary entries in DIARY-LIST are included."
(let ((blank-days ; at start of month
(mod (- (calendar-day-of-week (list month 1 year))
calendar-week-start-day)
7))
(last (calendar-last-day-of-month month year))
date)
(insert "<a name=0>\n")
(insert (cal-html-b-table "class=agenda border=1"))
(dotimes (i last)
(setq date (list month (1+ i) year))
(insert
(format "<a name=%d></a>\n" (1+ i)) ; link
cal-html-b-tablerow-string
;; Number & day name.
cal-html-b-tableheader-string
(if cal-html-print-day-number-flag
(format "<em>%d</em>&nbsp;&nbsp;"
(calendar-day-number date))
"")
(format "%d&nbsp;%s" (1+ i)
(aref calendar-day-name-array
(calendar-day-of-week date)))
cal-html-e-tableheader-string
;; Diary entries.
cal-html-b-tabledata-string
(cal-html-htmlify-list diary-list date)
cal-html-e-tabledata-string
cal-html-e-tablerow-string)
;; If end of week and not end of month, make new table.
(if (and (zerop (mod (+ i 1 blank-days) 7))
(/= (1+ i) last))
(insert cal-html-e-table-string
(cal-html-b-table
"class=agenda border=1")))))
(insert cal-html-e-table-string))
(defun cal-html-one-month (month year dir)
"Write an HTML calendar file for numeric MONTH of YEAR in directory DIR."
(let ((diary-list (cal-html-list-diary-entries
(calendar-absolute-from-gregorian (list month 1 year))
(calendar-absolute-from-gregorian
(list month
(calendar-last-day-of-month month year)
year)))))
(with-temp-buffer
(insert cal-html-b-document-string)
(cal-html-insert-month-header month year)
(cal-html-insert-agenda-days month year diary-list)
(insert cal-html-e-document-string)
(write-file (expand-file-name
(cal-html-monthpage-name month year) dir)))))
;;; User commands.
(defun cal-html-cursor-month (month year dir)
"Write an HTML calendar file for numeric MONTH of four-digit YEAR.
The output directory DIR is created if necessary. Interactively,
MONTH and YEAR are taken from the calendar cursor position. Note
that any existing output files are overwritten."
(interactive (let* ((date (calendar-cursor-to-date t))
(month (extract-calendar-month date))
(year (extract-calendar-year date)))
(list month year (cal-html-year-dir-ask-user year))))
(make-directory dir t)
(cal-html-one-month month year dir))
(defun cal-html-cursor-year (year dir)
"Write HTML calendar files (index and monthly pages) for four-digit YEAR.
The output directory DIR is created if necessary. Interactively,
YEAR is taken from the calendar cursor position. Note that any
existing output files are overwritten."
(interactive (let ((year (extract-calendar-year
(calendar-cursor-to-date t))))
(list year (cal-html-year-dir-ask-user year))))
(make-directory dir t)
(with-temp-buffer
(cal-html-insert-year-minicals year cal-html-year-index-cols)
(write-file (expand-file-name "index.html" dir)))
(dotimes (i 12)
(cal-html-one-month (1+ i) year dir)))
(provide 'cal-html)
;; arch-tag: 4e73377d-d2c1-46ea-a103-02c111da5f57
;;; cal-html.el ends here

View File

@ -2012,6 +2012,18 @@ Optional prefix argument specifies number of years." t)
"Make a buffer with LaTeX commands for a year's calendar (Filofax).
Optional prefix argument specifies number of years." t)
(autoload 'cal-html-cursor-month "cal-html"
"Write an HTML calendar file for numeric MONTH of four-digit YEAR.
The output directory DIR is created if necessary. Interactively,
MONTH and YEAR are taken from the calendar cursor position. Note
that any existing output files are overwritten." t)
(autoload 'cal-html-cursor-year "cal-html"
"Write HTML calendar files (index and monthly pages) for four-digit YEAR.
The output directory DIR is created if necessary. Interactively,
YEAR is taken from the calendar cursor position. Note that any
existing output files are overwritten." t)
(autoload 'mark-calendar-holidays "holidays"
"Mark notable days in the calendar window."
t)
@ -2288,6 +2300,8 @@ movement commands will not work correctly."
(define-key map "iBm" 'insert-monthly-bahai-diary-entry)
(define-key map "iBy" 'insert-yearly-bahai-diary-entry)
(define-key map "?" 'calendar-goto-info-node)
(define-key map "Hm" 'cal-html-cursor-month)
(define-key map "Hy" 'cal-html-cursor-year)
(define-key map "tm" 'cal-tex-cursor-month)
(define-key map "tM" 'cal-tex-cursor-month-landscape)
(define-key map "td" 'cal-tex-cursor-day)

View File

@ -1560,7 +1560,10 @@ When operating on multiple or marked files, you specify a directory,
and new copies of these files are made in that directory
with the same names that the files currently have. The default
suggested for the target directory depends on the value of
`dired-dwim-target', which see."
`dired-dwim-target', which see.
This command copies symbolic links by creating new ones,
like `cp -d'."
(interactive "P")
(let ((dired-recursive-copies dired-recursive-copies))
(dired-do-create-files 'copy (function dired-copy-file)

View File

@ -1450,7 +1450,9 @@ arguments to `skip-chars-forward'."
(condition-case nil
(let ((res
(apply 'call-process ediff-cmp-program nil nil nil
(append ediff-cmp-options (list f1 f2)))))
(append ediff-cmp-options (list (expand-file-name f1)
(expand-file-name f2))))
))
(and (numberp res) (eq res 0)))
(error (format "Cannot execute program %S." ediff-cmp-program)))
))

View File

@ -1637,11 +1637,15 @@ Useful commands:
(set-buffer (setq tmp-buf (get-buffer-create ediff-tmp-buffer)))
(erase-buffer)
(shell-command
(format "%s %s %s %s"
ediff-custom-diff-program ediff-custom-diff-options
(ediff-get-session-objA-name session)
(ediff-get-session-objB-name session))
t))
(format
"%s %s %s %s"
(shell-quote-argument ediff-custom-diff-program)
ediff-custom-diff-options
(shell-quote-argument (ediff-get-session-objA-name session))
(shell-quote-argument (ediff-get-session-objB-name session))
)
t)
)
(save-excursion
(set-buffer meta-diff-buff)
(goto-char (point-max))

View File

@ -8,7 +8,7 @@
;; Keywords: comparing, merging, patching, tools, unix
(defconst ediff-version "2.81.1" "The current version of Ediff")
(defconst ediff-date "September 18, 2006" "Date of last update")
(defconst ediff-date "October 23, 2006" "Date of last update")
;; This file is part of GNU Emacs.

View File

@ -105,6 +105,7 @@ files.")
("Matt Swift" "Matthew Swift")
("Michael R. Mauger" "Michael Mauger")
("Michael D. Ernst" "Michael Ernst")
("Micha,Ak(Bl Cadilhac" "Michael Cadilhac")
("Michael I. Bushnell" "Michael I Bushnell" "Michael I. Bushnell, P/Bsg")
("Mikio Nakajima" "Nakajima Mikio")
("Paul Eggert" "eggert")

View File

@ -373,14 +373,16 @@ If nil, indent backquoted lists as data, i.e., like quoted lists."
;; Too few elements in pattern.
(throw 'exit normal-indent)))
((eq tem 'nil)
(throw 'exit (list normal-indent containing-form-start)))
((eq tem '&lambda)
(throw 'exit
(cond ((null p)
(list (+ sexp-column 4) containing-form-start))
((null (cdr p))
(+ sexp-column 1))
(t normal-indent))))
(throw 'exit (if (consp normal-indent)
normal-indent
(list normal-indent containing-form-start))))
((eq tem '&lambda)
(throw 'exit
(cond ((null p)
(list (+ sexp-column 4) containing-form-start))
((null (cdr p))
(+ sexp-column 1))
(t normal-indent))))
((integerp tem)
(throw 'exit
(if (null p) ;not in subforms

View File

@ -97,13 +97,16 @@ Output stream is STREAM, or value of `standard-output' (which see)."
(princ (pp-to-string object) (or stream standard-output)))
;;;###autoload
(defun pp-eval-expression (expression)
"Evaluate EXPRESSION and pretty-print value into a new display buffer.
If the pretty-printed value fits on one line, the message line is used
instead. The value is also consed onto the front of the list
in the variable `values'."
(interactive "xPp-eval: ")
(setq values (cons (eval expression) values))
(defun pp-eval-expression (expval)
"Evaluate an expression, then pretty-print value EXPVAL into a new buffer.
If pretty-printed EXPVAL fits on one line, display it in the echo
area instead. Also add EXPVAL to the front of the list
in the variable `values'.
Non-interactively, the argument is the value, EXPVAL, not the expression
to evaluate."
(interactive "XPp-eval: ")
(setq values (cons expval values))
(let* ((old-show-function temp-buffer-show-function)
;; Use this function to display the buffer.
;; This function either decides not to display it at all

View File

@ -408,7 +408,6 @@
)
(defun viper-adjust-keys-for (state)
"Make necessary adjustments to keymaps before entering STATE."
(cond ((memq state '(insert-state replace-state))
@ -1263,65 +1262,69 @@ as a Meta key and any number of multiple escapes is allowed."
(setq com char)
(setq char (read-char))))))
(if (atom com)
;; `com' is a single char, so we construct the command argument
;; and if `char' is `?', we describe the arg; otherwise
;; we prepare the command that will be executed at the end.
(progn
(setq cmd-info (cons value com))
(while (viper= char ?U)
(viper-describe-arg cmd-info)
(setq char (read-char)))
;; `char' is a movement cmd, a digit arg cmd, or a register cmd---so we
;; execute it at the very end
(or (viper-movement-command-p char)
(viper-digit-command-p char)
(viper-regsuffix-command-p char)
(viper= char ?!) ; bang command
(error ""))
(setq cmd-to-exec-at-end
(viper-exec-form-in-vi
`(key-binding (char-to-string ,char)))))
(if (atom com)
;; `com' is a single char, so we construct the command argument
;; and if `char' is `?', we describe the arg; otherwise
;; we prepare the command that will be executed at the end.
(progn
(setq cmd-info (cons value com))
(while (viper= char ?U)
(viper-describe-arg cmd-info)
(setq char (read-char)))
;; `char' is a movement cmd, a digit arg cmd, or a register cmd---so
;; we execute it at the very end
(or (viper-movement-command-p char)
(viper-digit-command-p char)
(viper-regsuffix-command-p char)
(viper= char ?!) ; bang command
(viper= char ?g) ; the gg command (like G0)
(error ""))
(setq cmd-to-exec-at-end
(viper-exec-form-in-vi
`(key-binding (char-to-string ,char)))))
;; as com is non-nil, this means that we have a command to execute
(if (viper-memq-char (car com) '(?r ?R))
;; execute apropriate region command.
(let ((char (car com)) (com (cdr com)))
(setq prefix-arg (cons value com))
(if (viper= char ?r)
(viper-region prefix-arg)
(viper-Region prefix-arg))
;; reset prefix-arg
(setq prefix-arg nil))
;; otherwise, reset prefix arg and call appropriate command
(setq value (if (null value) 1 value))
(setq prefix-arg nil)
(cond
;; If we change ?C to ?c here, then cc will enter replacement mode
;; rather than deleting lines. However, it will affect 1 less line than
;; normal. We decided to not use replacement mode here and follow Vi,
;; since replacement mode on n full lines can be achieved with nC.
((equal com '(?c . ?c)) (viper-line (cons value ?C)))
((equal com '(?d . ?d)) (viper-line (cons value ?D)))
((equal com '(?d . ?y)) (viper-yank-defun))
((equal com '(?y . ?y)) (viper-line (cons value ?Y)))
((equal com '(?< . ?<)) (viper-line (cons value ?<)))
((equal com '(?> . ?>)) (viper-line (cons value ?>)))
((equal com '(?! . ?!)) (viper-line (cons value ?!)))
((equal com '(?= . ?=)) (viper-line (cons value ?=)))
(t (error "")))))
(if cmd-to-exec-at-end
(progn
(setq last-command-char char)
(setq last-command-event
(viper-copy-event
(if viper-xemacs-p (character-to-event char) char)))
(condition-case nil
(funcall cmd-to-exec-at-end cmd-info)
(error
(error "")))))
))
;; as com is non-nil, this means that we have a command to execute
(if (viper-memq-char (car com) '(?r ?R))
;; execute apropriate region command.
(let ((char (car com)) (com (cdr com)))
(setq prefix-arg (cons value com))
(if (viper= char ?r)
(viper-region prefix-arg)
(viper-Region prefix-arg))
;; reset prefix-arg
(setq prefix-arg nil))
;; otherwise, reset prefix arg and call appropriate command
(setq value (if (null value) 1 value))
(setq prefix-arg nil)
(cond
;; If we change ?C to ?c here, then cc will enter replacement mode
;; rather than deleting lines. However, it will affect 1 less line
;; than normal. We decided to not use replacement mode here and
;; follow Vi, since replacement mode on n full lines can be achieved
;; with nC.
((equal com '(?c . ?c)) (viper-line (cons value ?C)))
((equal com '(?d . ?d)) (viper-line (cons value ?D)))
((equal com '(?d . ?y)) (viper-yank-defun))
((equal com '(?y . ?y)) (viper-line (cons value ?Y)))
((equal com '(?< . ?<)) (viper-line (cons value ?<)))
((equal com '(?> . ?>)) (viper-line (cons value ?>)))
((equal com '(?! . ?!)) (viper-line (cons value ?!)))
((equal com '(?= . ?=)) (viper-line (cons value ?=)))
;; gg acts as G0
((equal (car com) ?g) (viper-goto-line 0))
(t (error "")))))
(if cmd-to-exec-at-end
(progn
(setq last-command-char char)
(setq last-command-event
(viper-copy-event
(if viper-xemacs-p (character-to-event char) char)))
(condition-case nil
(funcall cmd-to-exec-at-end cmd-info)
(error
(error "")))))
))
(defun viper-describe-arg (arg)
(let (val com)
@ -1733,6 +1736,7 @@ invokes the command before that, etc."
(max viper-com-point (point))))
((viper= char ?g)
(push-mark viper-com-point t)
;; execute the last emacs kbd macro on each line of the region
(viper-global-execute))
((viper= char ?q)
(push-mark viper-com-point t)
@ -3996,6 +4000,7 @@ Null string will repeat previous search."
(defun viper-buffer-search-enable (&optional c)
(cond (c (setq viper-buffer-search-char c))
((null viper-buffer-search-char)
;; ?g acts as a default value for viper-buffer-search-char
(setq viper-buffer-search-char ?g)))
(define-key viper-vi-basic-map
(cond ((viper-characterp viper-buffer-search-char)

View File

@ -1624,8 +1624,9 @@ reversed."
(progn
(setq command
;; replace # and % with the previous/current file
(ex-expand-filsyms (concat ex-file ex-cmdfile-args)
(current-buffer)))
(ex-expand-filsyms
(concat (shell-quote-argument ex-file) ex-cmdfile-args)
(current-buffer)))
(shell-command command t))
(insert-file-contents ex-file)))
(ex-fixup-history viper-last-ex-prompt ex-file ex-cmdfile-args))

View File

@ -9,7 +9,7 @@
;; Author: Michael Kifer <kifer@cs.stonybrook.edu>
;; Keywords: emulations
(defconst viper-version "3.13 of September 18, 2006"
(defconst viper-version "3.13.1 of October 23, 2006"
"The current version of Viper")
;; This file is part of GNU Emacs.

View File

@ -690,6 +690,9 @@ This is called whenever you create a new face, and at other times."
(cond ((facemenu-iterate ; check if equivalent face is already in the menu
(lambda (m) (and (listp m)
(symbolp (car m))
;; Avoid error in face-equal
;; when a non-face is erroneously present.
(facep (car m))
(face-equal (car m) symbol)))
(cdr (symbol-function menu))))
;; Faces with a keyboard equivalent. These go at the front.

View File

@ -1,3 +1,46 @@
2006-10-29 Reiner Steib <Reiner.Steib@gmx.de>
* mm-util.el (mm-codepage-iso-8859-list, mm-codepage-ibm-list): New
variables.
(mm-setup-codepage-iso-8859, mm-setup-codepage-ibm): New functions.
(mm-charset-synonym-alist): Move some entries to
mm-codepage-iso-8859-list.
(mm-charset-synonym-alist, mm-charset-override-alist): Add
iso-8859-8/windows-1255 and iso-8859-9/windows-1254.
2006-10-29 Katsumi Yamaoka <yamaoka@jpl.org>
* gnus-sum.el (gnus-set-mode-line): Quote % in group name.
2006-10-28 Reiner Steib <Reiner.Steib@gmx.de>
* gnus-agent.el (gnus-agent-make-mode-line-string): Make it compatible
with Emacs 21 and XEmacs.
2006-10-26 Reiner Steib <Reiner.Steib@gmx.de>
* mm-view.el: Add interactive arg to html2text autoload.
2006-10-25 Katsumi Yamaoka <yamaoka@jpl.org>
* gnus-sum.el (gnus-summary-move-article): Use no-encode for `B B'.
2006-10-20 Katsumi Yamaoka <yamaoka@jpl.org>
* gnus-group.el (gnus-group-make-doc-group): Work for non-ASCII group
names.
* gnus-sum.el (gnus-select-newsgroup): Decode group name.
2006-10-19 Katsumi Yamaoka <yamaoka@jpl.org>
* message.el (message-headers-to-generate): Fix typo in docstring.
2006-10-19 Reiner Steib <Reiner.Steib@gmx.de>
* gnus.el (gnus-mime): Remove unused custom group.
(gnus-getenv-nntpserver, gnus-select-method): Autoload.
2006-10-13 Andreas Seltenreich <uwi7@rz.uni-karlsruhe.de>
* mm-uu.el (mm-uu-pgp-signed-extract-1): Use RFC 2440 definition of

View File

@ -577,7 +577,17 @@ manipulated as follows:
(fboundp 'make-mode-line-mouse-map))
(propertize string 'local-map
(make-mode-line-mouse-map mouse-button mouse-func)
'mouse-face 'mode-line-highlight)
'mouse-face
(cond ((and (featurep 'xemacs)
;; XEmacs' `facep' only checks for a face
;; object, not for a face name, so it's useless
;; to check with `facep'.
(find-face 'modeline))
'modeline)
((facep 'mode-line-highlight) ;; Emacs 22
'mode-line-highlight)
((facep 'mode-line) ;; Emacs 21
'mode-line)) )
string))
(defun gnus-agent-toggle-plugged (set-to)

View File

@ -2680,13 +2680,18 @@ If called with a prefix argument, ask for the file type."
(t (setq err (format "%c unknown. " char))
nil))))
(setq type found)))
(let* ((file (expand-file-name file))
(name (gnus-generate-new-group-name
(gnus-group-prefixed-name
(file-name-nondirectory file) '(nndoc "")))))
(setq file (expand-file-name file))
(let ((name (gnus-generate-new-group-name
(gnus-group-prefixed-name
(file-name-nondirectory file) '(nndoc ""))))
(encodable (mm-coding-system-p 'utf-8)))
(gnus-group-make-group
(gnus-group-real-name name)
(list 'nndoc file
(if encodable
(mm-encode-coding-string (gnus-group-real-name name) 'utf-8)
(gnus-group-real-name name))
(list 'nndoc (if encodable
(mm-encode-coding-string file 'utf-8)
file)
(list 'nndoc-address file)
(list 'nndoc-article-type (or type 'guess))))))

View File

@ -5208,13 +5208,13 @@ If SELECT-ARTICLES, only select those articles from GROUP."
(when (equal major-mode 'gnus-summary-mode)
(gnus-kill-buffer (current-buffer)))
(error "Couldn't activate group %s: %s"
group (gnus-status-message group))))
(gnus-group-decoded-name group) (gnus-status-message group))))
(unless (gnus-request-group group t)
(when (equal major-mode 'gnus-summary-mode)
(gnus-kill-buffer (current-buffer)))
(error "Couldn't request group %s: %s"
group (gnus-status-message group)))
(gnus-group-decoded-name group) (gnus-status-message group)))
(when gnus-agent
(gnus-agent-possibly-alter-active group (gnus-active group) info)
@ -5711,8 +5711,9 @@ If WHERE is `summary', the summary mode line format will be used."
(let* ((mformat (symbol-value
(intern
(format "gnus-%s-mode-line-format-spec" where))))
(gnus-tmp-group-name (gnus-group-decoded-name
gnus-newsgroup-name))
(gnus-tmp-group-name (gnus-mode-string-quote
(gnus-group-decoded-name
gnus-newsgroup-name)))
(gnus-tmp-article-number (or gnus-current-article 0))
(gnus-tmp-unread gnus-newsgroup-unreads)
(gnus-tmp-unread-and-unticked (length gnus-newsgroup-unreads))
@ -9153,7 +9154,7 @@ ACTION can be either `move' (the default), `crosspost' or `copy'."
(gnus-request-article-this-buffer article gnus-newsgroup-name)
(when (consp (setq art-group
(gnus-request-accept-article
to-newsgroup select-method (not articles))))
to-newsgroup select-method (not articles) t)))
(setq new-xref (concat new-xref " " (car art-group)
":"
(number-to-string (cdr art-group))))
@ -9161,7 +9162,7 @@ ACTION can be either `move' (the default), `crosspost' or `copy'."
;; it and replace the new article.
(nnheader-replace-header "Xref" new-xref)
(gnus-request-replace-article
(cdr art-group) to-newsgroup (current-buffer))
(cdr art-group) to-newsgroup (current-buffer) t)
art-group))))))
(cond
((not art-group)
@ -9259,7 +9260,7 @@ ACTION can be either `move' (the default), `crosspost' or `copy'."
(gnus-request-article-this-buffer article gnus-newsgroup-name)
(nnheader-replace-header "Xref" new-xref)
(gnus-request-replace-article
article gnus-newsgroup-name (current-buffer))))
article gnus-newsgroup-name (current-buffer) t)))
;; run the move/copy/crosspost/respool hook
(run-hook-with-args 'gnus-summary-article-move-hook

View File

@ -279,10 +279,6 @@ is restarted, and sometimes reloaded."
:link '(custom-manual "(gnus)Various Various")
:group 'gnus)
(defgroup gnus-mime nil
"Variables for controlling the Gnus MIME interface."
:group 'gnus)
(defgroup gnus-exit nil
"Exiting Gnus."
:link '(custom-manual "(gnus)Exiting Gnus")
@ -1243,6 +1239,7 @@ used to 899, you would say something along these lines:
:group 'gnus-server
:type 'file)
;;;###autoload
(defun gnus-getenv-nntpserver ()
"Find default nntp server.
Check the NNTPSERVER environment variable and the
@ -1254,6 +1251,7 @@ Check the NNTPSERVER environment variable and the
(when (re-search-forward "[^ \t\n\r]+" nil t)
(match-string 0))))))
;;;###autoload
(defcustom gnus-select-method
(condition-case nil
(nconc

View File

@ -5514,7 +5514,7 @@ between beginning of field and beginning of line."
(defun message-headers-to-generate (headers included-headers excluded-headers)
"Return a list that includes all headers from HEADERS.
If INCLUDED-HEADERS is a list, just include those headers. If if is
If INCLUDED-HEADERS is a list, just include those headers. If it is
t, include all headers. In any case, headers from EXCLUDED-HEADERS
are not included."
(let ((result nil)

View File

@ -205,39 +205,140 @@ the alias. Else windows-NUMBER is used."
;; Not in XEmacs, but it's not a proper MIME charset anyhow.
,@(unless (mm-coding-system-p 'x-ctext)
'((x-ctext . ctext)))
;; ISO-8859-15 is very similar to ISO-8859-1. But it's _different_!
;; ISO-8859-15 is very similar to ISO-8859-1. But it's _different_ in 8
;; positions!
,@(unless (mm-coding-system-p 'iso-8859-15)
'((iso-8859-15 . iso-8859-1)))
;; BIG-5HKSCS is similar to, but different than, BIG-5.
,@(unless (mm-coding-system-p 'big5-hkscs)
'((big5-hkscs . big5)))
;; Windows-1252 is actually a superset of Latin-1. See also
;; `gnus-article-dumbquotes-map'.
,@(unless (mm-coding-system-p 'windows-1252)
(if (mm-coding-system-p 'cp1252)
'((windows-1252 . cp1252))
'((windows-1252 . iso-8859-1))))
;; Windows-1250 is a variant of Latin-2 heavily used by Microsoft
;; Outlook users in Czech republic. Use this to allow reading of their
;; e-mails. cp1250 should be defined by M-x codepage-setup.
,@(if (and (not (mm-coding-system-p 'windows-1250))
(mm-coding-system-p 'cp1250))
'((windows-1250 . cp1250)))
;; A Microsoft misunderstanding.
,@(if (and (not (mm-coding-system-p 'unicode))
(mm-coding-system-p 'utf-16-le))
'((unicode . utf-16-le)))
,@(when (and (not (mm-coding-system-p 'unicode))
(mm-coding-system-p 'utf-16-le))
'((unicode . utf-16-le)))
;; A Microsoft misunderstanding.
,@(unless (mm-coding-system-p 'ks_c_5601-1987)
(if (mm-coding-system-p 'cp949)
'((ks_c_5601-1987 . cp949))
'((ks_c_5601-1987 . euc-kr))))
;; Windows-31J is Windows Codepage 932.
,@(if (and (not (mm-coding-system-p 'windows-31j))
(mm-coding-system-p 'cp932))
'((windows-31j . cp932)))
,@(when (and (not (mm-coding-system-p 'windows-31j))
(mm-coding-system-p 'cp932))
'((windows-31j . cp932)))
)
"A mapping from unknown or invalid charset names to the real charset names.")
"A mapping from unknown or invalid charset names to the real charset names.
See `mm-codepage-iso-8859-list' and `mm-codepage-ibm-list'.")
(defcustom mm-codepage-iso-8859-list
(list 1250 ;; Windows-1250 is a variant of Latin-2 heavily used by Microsoft
;; Outlook users in Czech republic. Use this to allow reading of
;; their e-mails. cp1250 should be defined by M-x codepage-setup
;; (Emacs 21).
'(1252 . 1) ;; Windows-1252 is a superset of iso-8859-1 (West
;; Europe). See also `gnus-article-dumbquotes-map'.
'(1254 . 9) ;; Windows-1254 is a superset of iso-8859-9 (Turkish).
'(1255 . 8));; Windows-1255 is a superset of iso-8859-8 (Hebrew).
"A list of Windows codepage numbers and iso-8859 charset numbers.
If an element is a number corresponding to a supported windows
codepage, appropriate entries to `mm-charset-synonym-alist' are
added by `mm-setup-codepage-iso-8859'. An element may also be a
cons cell where the car is a codepage number and the cdr is the
corresponding number of an iso-8859 charset."
:type '(list (set :inline t
(const 1250 :tag "Central and East European")
(const (1252 . 1) :tag "West European")
(const (1254 . 9) :tag "Turkish")
(const (1255 . 8) :tag "Hebrew"))
(repeat :inline t
:tag "Other options"
(choice
(integer :tag "Windows codepage number")
(cons (integer :tag "Windows codepage number")
(integer :tag "iso-8859 charset number")))))
:version "22.1" ;; Gnus 5.10.9
:group 'mime)
(defcustom mm-codepage-ibm-list
(list 437 ;; (US etc.)
860 ;; (Portugal)
861 ;; (Iceland)
862 ;; (Israel)
863 ;; (Canadian French)
865 ;; (Nordic)
852 ;;
850 ;; (Latin 1)
855 ;; (Cyrillic)
866 ;; (Cyrillic - Russian)
857 ;; (Turkish)
864 ;; (Arabic)
869 ;; (Greek)
874);; (Thai)
;; In Emacs 23 (unicode), cp... and ibm... are aliases.
;; Cf. http://thread.gmane.org/v9lkng5nwy.fsf@marauder.physik.uni-ulm.de
"List of IBM codepage numbers.
The codepage mappings slighly differ between IBM and other vendors.
See \"ftp://ftp.unicode.org/Public/MAPPINGS/VENDORS/IBM/README.TXT\".
If an element is a number corresponding to a supported windows
codepage, appropriate entries to `mm-charset-synonym-alist' are
added by `mm-setup-codepage-ibm'."
:type '(list (set :inline t
(const 437 :tag "US etc.")
(const 860 :tag "Portugal")
(const 861 :tag "Iceland")
(const 862 :tag "Israel")
(const 863 :tag "Canadian French")
(const 865 :tag "Nordic")
(const 852)
(const 850 :tag "Latin 1")
(const 855 :tag "Cyrillic")
(const 866 :tag "Cyrillic - Russian")
(const 857 :tag "Turkish")
(const 864 :tag "Arabic")
(const 869 :tag "Greek")
(const 874 :tag "Thai"))
(repeat :inline t
:tag "Other options"
(integer :tag "Codepage number")))
:version "22.1" ;; Gnus 5.10.9
:group 'mime)
(defun mm-setup-codepage-iso-8859 (&optional list)
"Add appropriate entries to `mm-charset-synonym-alist'.
Unless LIST is given, `mm-codepage-iso-8859-list' is used."
(unless list
(setq list mm-codepage-iso-8859-list))
(dolist (i list)
(let (cp windows iso)
(if (consp i)
(setq cp (intern (format "cp%d" (car i)))
windows (intern (format "windows-%d" (car i)))
iso (intern (format "iso-8859-%d" (cdr i))))
(setq cp (intern (format "cp%d" i))
windows (intern (format "windows-%d" i))))
(unless (mm-coding-system-p windows)
(if (mm-coding-system-p cp)
(add-to-list 'mm-charset-synonym-alist (cons windows cp))
(add-to-list 'mm-charset-synonym-alist (cons windows iso)))))))
(defun mm-setup-codepage-ibm (&optional list)
"Add appropriate entries to `mm-charset-synonym-alist'.
Unless LIST is given, `mm-codepage-ibm-list' is used."
(unless list
(setq list mm-codepage-ibm-list))
(dolist (number list)
(let ((ibm (intern (format "ibm%d" number)))
(cp (intern (format "cp%d" number))))
(when (and (not (mm-coding-system-p ibm))
(mm-coding-system-p cp))
(add-to-list 'mm-charset-synonym-alist (cons ibm cp))))))
;; Initialize:
(mm-setup-codepage-iso-8859)
(mm-setup-codepage-ibm)
(defcustom mm-charset-override-alist
`((iso-8859-1 . windows-1252))

View File

@ -36,7 +36,7 @@
(autoload 'vcard-parse-string "vcard")
(autoload 'vcard-format-string "vcard")
(autoload 'fill-flowed "flow-fill")
(autoload 'html2text "html2text")
(autoload 'html2text "html2text" nil t)
(unless (fboundp 'diff-mode)
(autoload 'diff-mode "diff-mode" "" t nil)))

View File

@ -383,35 +383,40 @@ face (according to `face-differs-from-default-p')."
(princ ".")
(terpri)
(when (commandp function)
(let* ((remapped (command-remapping function))
(keys (where-is-internal
(or remapped function) overriding-local-map nil nil))
non-modified-keys)
;; Which non-control non-meta keys run this command?
(dolist (key keys)
(if (member (event-modifiers (aref key 0)) '(nil (shift)))
(push key non-modified-keys)))
(when remapped
(princ "It is remapped to `")
(princ (symbol-name remapped))
(princ "'"))
(if (and (eq function 'self-insert-command)
(eq (key-binding "a") 'self-insert-command)
(eq (key-binding "b") 'self-insert-command)
(eq (key-binding "c") 'self-insert-command))
(princ "It is bound to many ordinary text characters.\n")
(let* ((remapped (command-remapping function))
(keys (where-is-internal
(or remapped function) overriding-local-map nil nil))
non-modified-keys)
;; Which non-control non-meta keys run this command?
(dolist (key keys)
(if (member (event-modifiers (aref key 0)) '(nil (shift)))
(push key non-modified-keys)))
(when remapped
(princ "It is remapped to `")
(princ (symbol-name remapped))
(princ "'"))
(when keys
(princ (if remapped " which is bound to " "It is bound to "))
;; FIXME: This list can be very long (f.ex. for self-insert-command).
;; If there are many, remove them from KEYS.
(if (< (length non-modified-keys) 10)
(princ (mapconcat 'key-description keys ", "))
(dolist (key non-modified-keys)
(setq keys (delq key keys)))
(if keys
(progn
(princ (mapconcat 'key-description keys ", "))
(princ ", and many ordinary text characters"))
(princ "many ordinary text characters"))))
(when (or remapped keys non-modified-keys)
(princ ".")
(terpri))))
(when keys
(princ (if remapped " which is bound to " "It is bound to "))
;; If lots of ordinary text characters run this command,
;; don't mention them one by one.
(if (< (length non-modified-keys) 10)
(princ (mapconcat 'key-description keys ", "))
(dolist (key non-modified-keys)
(setq keys (delq key keys)))
(if keys
(progn
(princ (mapconcat 'key-description keys ", "))
(princ ", and many ordinary text characters"))
(princ "many ordinary text characters"))))
(when (or remapped keys non-modified-keys)
(princ ".")
(terpri)))))
(let* ((arglist (help-function-arglist def))
(doc (documentation function))
(usage (help-split-fundoc doc function)))

View File

@ -2611,7 +2611,7 @@ C-x C-f ... C-d enter dired on current directory."
May be useful if cached version is no longer valid, but directory
timestamp has not changed (e.g. with ftp or on Windows)."
(interactive)
(if (and ido-mode (eq ido-cur-item 'file))
(if (and ido-mode (memq ido-cur-item '(file dir)))
(progn
(if (ido-is-unc-root)
(setq ido-unc-hosts-cache t)
@ -4168,7 +4168,7 @@ For details of keybindings, do `\\[describe-function] ido-find-file'."
(setq refresh t))
((string-equal contents "./")
(setq refresh t))
((string-match "\\`~[a-zA-Z0-9]+/\\'" contents)
((string-match "\\`~[-_a-zA-Z0-9]+[$]?/\\'" contents)
(ido-trace "new home" contents)
(ido-set-current-home contents)
(setq refresh t))

File diff suppressed because it is too large Load Diff

View File

@ -541,6 +541,17 @@ This is relative to `smtpmail-queue-dir'.")
(decoded (base64-decode-string challenge))
(hash (rfc2104-hash 'md5 64 16 passwd decoded))
(response (concat (smtpmail-cred-user cred) " " hash))
;; Osamu Yamane <yamane@green.ocn.ne.jp>:
;; SMTP auth fails because the SMTP server identifies
;; only the first part of the string (delimited by
;; new line characters) as a response from the
;; client, and the rest as distinct commands.
;; In my case, the response string is 80 characters
;; long. Without the no-line-break option for
;; base64-encode-sting, only the first 76 characters
;; are taken as a response to the server, and the
;; authentication fails.
(encoded (base64-encode-string response t)))
(smtpmail-send-command process (format "%s" encoded))
(if (or (null (car (setq ret (smtpmail-read-response process))))

View File

@ -75,9 +75,9 @@ call `cancel-timer' or `timer-activate' on `midnight-timer' instead."
(list 1st (floor (- num (* (float div) 1st)))
(round (* 10000000 (mod num 1))))))
(defun midnight-buffer-display-time (&optional buf)
"Return the time-stamp of the given buffer, or current buffer, as float."
(with-current-buffer (or buf (current-buffer))
(defun midnight-buffer-display-time (&optional buffer)
"Return the time-stamp of BUFFER, or current buffer, as float."
(with-current-buffer (or buffer (current-buffer))
(when buffer-display-time (float-time buffer-display-time))))
;;; clean-buffer-list stuff
@ -128,7 +128,7 @@ See also `clean-buffer-list-kill-regexps',
:group 'midnight)
(defcustom clean-buffer-list-kill-never-buffer-names
'("*scratch*" "*Messages*")
'("*scratch*" "*Messages*" "*server*")
"*List of buffer names which will never be killed by `clean-buffer-list'.
See also `clean-buffer-list-kill-never-regexps'.
Note that this does override `clean-buffer-list-kill-regexps' and
@ -137,7 +137,6 @@ two lists will NOT be killed if it is also present in this list."
:type '(repeat (string :tag "Buffer Name"))
:group 'midnight)
(defcustom clean-buffer-list-kill-never-regexps '("^ \\*Minibuf-.*\\*$")
"*List of regexp saying which buffers will never be killed at midnight.
See also `clean-buffer-list-kill-never-buffer-names'.

View File

@ -2018,11 +2018,10 @@ If VAR is nil, then we bind `v' to the structure and `multi-method',
,@body))
(put 'with-parsed-tramp-file-name 'lisp-indent-function 2)
;; To be activated for debugging containing this macro
;; It works only when VAR is nil. Otherwise, it can be deactivated by
;; (put 'with-parsed-tramp-file-name 'edebug-form-spec 0)
;; I'm too stupid to write a precise SPEC for it.
(put 'with-parsed-tramp-file-name 'edebug-form-spec t)
;; Enable debugging.
(def-edebug-spec with-parsed-tramp-file-name (form symbolp body))
;; Highlight as keyword.
(font-lock-add-keywords 'emacs-lisp-mode '("\\<with-parsed-tramp-file-name\\>"))
(defmacro tramp-let-maybe (variable value &rest body)
"Let-bind VARIABLE to VALUE in BODY, but only if VARIABLE is not obsolete.
@ -2905,7 +2904,7 @@ and `rename'. FILENAME and NEWNAME must be absolute file names."
(unless ok-if-already-exists
(when (file-exists-p newname)
(signal 'file-already-exists
(list newname))))
(list "File already exists" newname))))
(let ((t1 (tramp-tramp-file-p filename))
(t2 (tramp-tramp-file-p newname))
v1-multi-method v1-method v1-user v1-host v1-localname
@ -2978,10 +2977,10 @@ and `rename'. FILENAME and NEWNAME must be absolute file names."
;; copy-program can be invoked.
(if (and (not v1-multi-method)
(not v2-multi-method)
(or (tramp-method-out-of-band-p
v1-multi-method v1-method v1-user v1-host)
(tramp-method-out-of-band-p
v2-multi-method v2-method v2-user v2-host)))
(or (and t1 (tramp-method-out-of-band-p
v1-multi-method v1-method v1-user v1-host))
(and t2 (tramp-method-out-of-band-p
v2-multi-method v2-method v2-user v2-host))))
(tramp-do-copy-or-rename-file-out-of-band
op filename newname keep-date)
;; Use the generic method via a Tramp buffer.
@ -5045,7 +5044,7 @@ TIME is an Emacs internal time value as returned by `current-time'."
multi-method method user host
(format "TZ=UTC; export TZ; touch -t %s %s"
touch-time
localname)
(tramp-shell-quote-argument localname))
t))
(pop-to-buffer buf)
(error "tramp-touch: touch failed, see buffer `%s' for details"

File diff suppressed because it is too large Load Diff

View File

@ -1916,8 +1916,12 @@ is using."
(set-buffer (get-buffer-create "*grep*"))
(while dirs
(insert (shell-command-to-string
(concat "egrep -i -h '^X|" regexp "( |$)' "
(file-name-as-directory (car dirs)) "*.ali")))
(concat
"grep -E -i -h "
(shell-quote-argument (concat "^X|" regexp "( |$)"))
" "
(shell-quote-argument (file-name-as-directory (car dirs)))
"*.ali")))
(set 'dirs (cdr dirs)))
;; Now parse the output

View File

@ -445,12 +445,8 @@ Font for POD headers."
;;; Some double-evaluation happened with font-locks... Needed with 21.2...
(defvar cperl-singly-quote-face cperl-xemacs-p)
(defcustom cperl-invalid-face ; Does not customize with '' on XEmacs
(if cperl-singly-quote-face
'underline ''underline) ; On older Emacsen was evaluated by `font-lock'
(if cperl-singly-quote-face
"*This face is used for highlighting trailing whitespace."
"*Face for highlighting trailing whitespace.")
(defcustom cperl-invalid-face 'underline
"*Face for highlighting trailing whitespace."
:type 'face
:version "21.1"
:group 'cperl-faces)
@ -1835,7 +1831,7 @@ or as help on variables `cperl-tips', `cperl-problems',
(if (boundp 'font-lock-multiline) ; Newer font-lock; use its facilities
(progn
(setq cperl-font-lock-multiline t) ; Not localized...
(set 'font-lock-multiline t)) ; not present with old Emacs; auto-local
(set (make-local-variable 'font-lock-multiline) t))
(make-local-variable 'font-lock-fontify-region-function)
(set 'font-lock-fontify-region-function ; not present with old Emacs
'cperl-font-lock-fontify-region-function))
@ -5708,19 +5704,22 @@ indentation and initial hashes. Behaves usually outside of comment."
(defun cperl-windowed-init ()
"Initialization under windowed version."
(if (or (featurep 'ps-print) cperl-faces-init)
;; Need to init anyway:
(or cperl-faces-init (cperl-init-faces))
(add-hook 'font-lock-mode-hook
(function
(lambda ()
(if (memq major-mode '(perl-mode cperl-mode))
(progn
(or cperl-faces-init (cperl-init-faces)))))))
(if (fboundp 'eval-after-load)
(eval-after-load
"ps-print"
'(or cperl-faces-init (cperl-init-faces))))))
(cond ((featurep 'ps-print)
(unless cperl-faces-init
(if (boundp 'font-lock-multiline)
(setq cperl-font-lock-multiline t))
(cperl-init-faces)))
((not cperl-faces-init)
(add-hook 'font-lock-mode-hook
(function
(lambda ()
(if (memq major-mode '(perl-mode cperl-mode))
(progn
(or cperl-faces-init (cperl-init-faces)))))))
(if (fboundp 'eval-after-load)
(eval-after-load
"ps-print"
'(or cperl-faces-init (cperl-init-faces)))))))
(defvar cperl-font-lock-keywords-1 nil
"Additional expressions to highlight in Perl mode. Minimal set.")

View File

@ -1021,7 +1021,9 @@ For the format of LINE-ERR-INFO, see `flymake-ler-make-ler'."
(progn
(flymake-get-project-include-dirs-from-cache basedir))
;;else
(let* ((command-line (concat "make -C\"" basedir "\" DUMPVARS=INCLUDE_DIRS dumpvars"))
(let* ((command-line (concat "make -C "
(shell-quote-argument basedir)
" DUMPVARS=INCLUDE_DIRS dumpvars"))
(output (shell-command-to-string command-line))
(lines (flymake-split-string output "\n"))
(count (length lines))

View File

@ -2048,7 +2048,6 @@ static char *magick[] = {
(or gdb-stack-position
(setq gdb-stack-position (make-marker)))
(set-marker gdb-stack-position (point)))
(set-marker gdb-stack-position nil)
(put-text-property bl (+ bl 4)
'face '(:inverse-video t))))
(when (re-search-forward

View File

@ -113,6 +113,9 @@ the regular expression `comint-prompt-regexp', a buffer local variable."
(defvar inferior-octave-complete-impossible nil
"Non-nil means that `inferior-octave-complete' is impossible.")
(defvar inferior-octave-has-built-in-variables nil
"Non-nil means that Octave has built-in variables.")
(defvar inferior-octave-dynamic-complete-functions
'(inferior-octave-complete comint-dynamic-complete-filename)
"List of functions called to perform completion for inferior Octave.
@ -218,11 +221,20 @@ startup file, `~/.emacs-octave'."
'identity inferior-octave-output-list "\n")
"\n"))))
;; Find out whether Octave has built-in variables.
(inferior-octave-send-list-and-digest
(list "exist \"LOADPATH\"\n"))
(setq inferior-octave-has-built-in-variables
(string-match "101$" (car inferior-octave-output-list)))
;; An empty secondary prompt, as e.g. obtained by '--braindead',
;; means trouble.
(inferior-octave-send-list-and-digest (list "PS2\n"))
(if (string-match "^PS2 = *$" (car inferior-octave-output-list))
(inferior-octave-send-list-and-digest (list "PS2 = \"> \"\n")))
(if (string-match "\\(PS2\\|ans\\) = *$" (car inferior-octave-output-list))
(inferior-octave-send-list-and-digest
(list (if inferior-octave-has-built-in-variables
"PS2 = \"> \"\n"
"PS2 (\"> \");\n"))))
;; O.k., now we are ready for the Inferior Octave startup commands.
(let* (commands
@ -230,10 +242,12 @@ startup file, `~/.emacs-octave'."
(file (or inferior-octave-startup-file
(concat "~/.emacs-" program))))
(setq commands
(list "page_screen_output = 0;\n"
(list "more off;\n"
(if (not (string-equal
inferior-octave-output-string ">> "))
"PS1=\"\\\\s> \";\n")
(if inferior-octave-has-built-in-variables
"PS1=\"\\\\s> \";\n"
"PS1 (\"\\\\s> \");\n"))
(if (file-exists-p file)
(format "source (\"%s\");\n" file))))
(inferior-octave-send-list-and-digest commands))
@ -383,7 +397,7 @@ Use \\[inferior-octave-resync-dirs] to resync if Emacs gets confused."
This command queries the inferior Octave process about its current
directory and makes this the current buffer's default directory."
(interactive)
(inferior-octave-send-list-and-digest '("pwd\n"))
(inferior-octave-send-list-and-digest '("disp (pwd ())\n"))
(cd (car inferior-octave-output-list)))
;;; provide ourself

View File

@ -1969,6 +1969,13 @@ Repeating the command scrolls the completion window."
;;;; Skeletons
(defcustom python-use-skeletons nil
"Non-nil means template skeletons will be automagically inserted.
This happens when pressing \"if<SPACE>\", for example, to prompt for
the if condition."
:type 'boolean
:group 'python)
(defvar python-skeletons nil
"Alist of named skeletons for Python mode.
Elements are of the form (NAME . EXPANDER-FUNCTION).")
@ -1986,7 +1993,8 @@ The default contents correspond to the elements of `python-skeletons'.")
(function (intern (concat "python-insert-" name))))
`(progn
(add-to-list 'python-skeletons ',(cons name function))
(define-abbrev python-mode-abbrev-table ,name "" ',function nil t)
(if python-use-skeletons
(define-abbrev python-mode-abbrev-table ,name "" ',function nil t))
(define-skeleton ,function
,(format "Insert Python \"%s\" template." name)
,@elements)))))

View File

@ -1318,9 +1318,7 @@ With prefix argument ARG, turn on if positive, otherwise off.
Returns non-nil if the new state is enabled.
When recentf mode is enabled, it maintains a menu for visiting files
that were operated on recently.
\\{recentf-mode-map}"
that were operated on recently."
:global t
:group 'recentf
:keymap recentf-mode-map

View File

@ -152,6 +152,41 @@ Cut buffers are considered obsolete; you should use selections instead."
;;; Every selection type that Emacs handles is implemented this way, except
;;; for TIMESTAMP, which is a special case.
(eval-when-compile (require 'ccl))
(define-ccl-program ccl-check-utf-8
'(0
((r0 = 1)
(loop
(read-if (r1 < #x80) (repeat)
((r0 = 0)
(if (r1 < #xC2) (end))
(read r2)
(if ((r2 & #xC0) != #x80) (end))
(if (r1 < #xE0) ((r0 = 1) (repeat)))
(read r2)
(if ((r2 & #xC0) != #x80) (end))
(if (r1 < #xF0) ((r0 = 1) (repeat)))
(read r2)
(if ((r2 & #xC0) != #x80) (end))
(if (r1 < #xF8) ((r0 = 1) (repeat)))
(read r2)
(if ((r2 & #xC0) != #x80) (end))
(if (r1 == #xF8) ((r0 = 1) (repeat)))
(end))))))
"Check if the input unibyte string is a valid UTF-8 sequence or not.
If it is valid, set the register `r0' to 1, else set it to 0.")
(defun string-utf-8-p (string)
"Return non-nil iff STRING is a unibyte string of valid UTF-8 sequence."
(if (or (not (stringp string))
(multibyte-string-p string))
(error "Not a unibyte string: %s" string))
(let ((status (make-vector 9 0)))
(ccl-execute-on-string ccl-check-utf-8 status string)
(= (aref status 0) 1)))
(defun xselect-convert-to-string (selection type value)
(let (str coding)
;; Get the actual string from VALUE.
@ -223,11 +258,10 @@ Cut buffers are considered obsolete; you should use selections instead."
(setq str (encode-coding-string str coding))))
((eq type 'UTF8_STRING)
(let ((charsets (find-charset-string str)))
(if (or (memq 'eight-bit-control charsets)
(memq 'eight-bit-graphic charsets))
(setq type 'STRING)
(setq str (encode-coding-string str 'utf-8)))))
(if (multibyte-string-p str)
(setq str (encode-coding-string str 'utf-8)))
(if (not (string-utf-8-p str))
(setq str nil))) ;; Decline request as we don't have UTF-8 data.
(t
(error "Unknow selection type: %S" type))
)))

View File

@ -298,7 +298,9 @@ Value is a list of strings, which may be nil."
(equal name "bash")
(file-executable-p prog)
(string-match "bad option"
(shell-command-to-string (concat prog " --noediting"))))
(shell-command-to-string
(concat (shell-quote-argument prog)
" --noediting"))))
'("-i")
'("--noediting" "-i")))
"Args passed to inferior shell by \\[shell], if the shell is bash.

View File

@ -997,12 +997,11 @@ in *Help* buffer. See also the command `describe-char'."
(single-key-description char))
encoding-msg pos total percent col hscroll))))))
(defvar read-expression-map
(let ((m (make-sparse-keymap)))
(define-key m "\M-\t" 'lisp-complete-symbol)
(set-keymap-parent m minibuffer-local-map)
m)
"Minibuffer keymap used for reading Lisp expressions.")
;; Initialize read-expression-map. It is defined at C level.
(let ((m (make-sparse-keymap)))
(define-key m "\M-\t" 'lisp-complete-symbol)
(set-keymap-parent m minibuffer-local-map)
(setq read-expression-map m))
(defvar read-expression-history nil)
@ -3625,7 +3624,14 @@ Outline mode sets this."
;; The logic of this is the same as the loop above,
;; it just goes in the other direction.
(while (and (< arg 0) (not done))
(beginning-of-line)
;; For completely consistency with the forward-motion
;; case, we should call beginning-of-line here.
;; However, if point is inside a field and on a
;; continued line, the call to (vertical-motion -1)
;; below won't move us back far enough; then we return
;; to the same column in line-move-finish, and point
;; gets stuck -- cyd
(forward-line 0)
(cond
((bobp)
(if (not noerror)

View File

@ -1100,13 +1100,19 @@ until a certain package is loaded, you should put the call to `add-to-list'
into a hook function that will be run only after loading the package.
`eval-after-load' provides one way to do this. In some cases
other hooks, such as major mode hooks, can do the job."
(if (if compare-fn
(let (present)
(dolist (elt (symbol-value list-var))
(if (funcall compare-fn element elt)
(setq present t)))
present)
(if (cond
((null compare-fn)
(member element (symbol-value list-var)))
((eq compare-fn 'eq)
(memq element (symbol-value list-var)))
((eq compare-fn 'eql)
(memql element (symbol-value list-var)))
(t
(let (present)
(dolist (elt (symbol-value list-var))
(if (funcall compare-fn element elt)
(setq present t)))
present)))
(symbol-value list-var)
(set list-var
(if append
@ -1752,8 +1758,14 @@ floating point support.
(or nodisp (redisplay))
(let ((read (read-event nil nil seconds)))
(or (null read)
(progn (push read unread-command-events)
nil))))))
(progn
;; If last command was a prefix arg, e.g. C-u, push this event onto
;; unread-command-events as (t . EVENT) so it will be added to
;; this-command-keys by read-key-sequence.
(if (eq overriding-terminal-local-map universal-argument-map)
(setq read (cons t read)))
(push read unread-command-events)
nil))))))
;;; Atomic change groups.
@ -2195,6 +2207,12 @@ If UNDO is present and non-nil, it is a function that will be called
(unless (nth 2 handler) ;; NOEXCLUDE
(remove-yank-excluded-properties opoint (point)))
;; If last inserted char has properties, mark them as rear-nonsticky.
(if (and (> end opoint)
(text-properties-at (1- end)))
(put-text-property (1- end) end 'rear-nonsticky t))
(if (eq yank-undo-function t) ;; not set by FUNCTION
(setq yank-undo-function (nth 3 handler))) ;; UNDO
(if (nth 4 handler) ;; COMMAND

View File

@ -2398,12 +2398,15 @@ It returns a name of the created fontset."
(cons '(user-size . t) parsed))))
;; All geometry parms apply to the initial frame.
(setq initial-frame-alist (append initial-frame-alist parsed))
;; The size parms apply to all frames.
(if (assq 'height parsed)
;; The size parms apply to all frames. Don't set it if there are
;; sizes there already (from command line).
(if (and (assq 'height parsed)
(not (assq 'height default-frame-alist)))
(setq default-frame-alist
(cons (cons 'height (cdr (assq 'height parsed)))
default-frame-alist)))
(if (assq 'width parsed)
(if (and (assq 'width parsed)
(not (assq 'width default-frame-alist)))
(setq default-frame-alist
(cons (cons 'width (cdr (assq 'width parsed)))
default-frame-alist))))))

View File

@ -208,7 +208,7 @@ the last file dropped is selected."
(setq x-invocation-args (cdr x-invocation-args))))
(defun x-handle-name-switch (switch)
"Handle a \"-name\" SWITCH."
"Handle the \"-name\" SWITCH."
;; Handle the -name option. Set the variable x-resource-name
;; to the option's operand; set the name of the initial frame, too.
(or (consp x-invocation-args)
@ -1091,7 +1091,7 @@ This defines a fontset consisting of the Courier New variations for
European languages which are distributed with Windows as
\"Multilanguage Support\".
See the documentation of `create-fontset-from-fontset-spec for the format.")
See the documentation of `create-fontset-from-fontset-spec' for the format.")
;; Conditional on new-fontset so bootstrapping works on non-GUI compiles
(if (fboundp 'new-fontset)

View File

@ -2427,12 +2427,15 @@ order until succeed.")
(cons '(user-size . t) parsed))))
;; All geometry parms apply to the initial frame.
(setq initial-frame-alist (append initial-frame-alist parsed))
;; The size parms apply to all frames.
(if (assq 'height parsed)
;; The size parms apply to all frames. Don't set it if there are
;; sizes there already (from command line).
(if (and (assq 'height parsed)
(not (assq 'height default-frame-alist)))
(setq default-frame-alist
(cons (cons 'height (cdr (assq 'height parsed)))
default-frame-alist)))
(if (assq 'width parsed)
(if (and (assq 'width parsed)
(not (assq 'width default-frame-alist)))
(setq default-frame-alist
(cons (cons 'width (cdr (assq 'width parsed)))
default-frame-alist))))))

View File

@ -959,6 +959,7 @@ Mostly we check word delimiters."
(defun flyspell-word-search-backward (word bound)
(save-excursion
(let ((r '())
(inhibit-point-motion-hooks t)
p)
(while (and (not r) (setq p (search-backward word bound t)))
(let ((lw (flyspell-get-word '())))
@ -973,6 +974,7 @@ Mostly we check word delimiters."
(defun flyspell-word-search-forward (word bound)
(save-excursion
(let ((r '())
(inhibit-point-motion-hooks t)
p)
(while (and (not r) (setq p (search-forward word bound t)))
(let ((lw (flyspell-get-word '())))
@ -1009,11 +1011,14 @@ Mostly we check word delimiters."
(not (memq (char-after (1- start)) '(?\} ?\\)))))
flyspell-mark-duplications-flag
(save-excursion
(goto-char (1- start))
(let ((p (flyspell-word-search-backward
word
(- start (1+ (- end start))))))
(and p (/= p (1- start))))))
(goto-char start)
(let* ((bound
(- start
(- end start)
(- (skip-chars-backward " \t\n\f"))))
(p (when (>= bound (point-min))
(flyspell-word-search-backward word bound))))
(and p (/= p start)))))
;; yes, this is a doublon
(flyspell-highlight-incorrect-region start end 'doublon)
nil)
@ -1470,7 +1475,7 @@ The buffer to mark them in is `flyspell-large-region-buffer'."
(flyspell-word) ; Make sure current word is checked
(backward-word 1)
(while (and (< (point) end)
(re-search-forward "\\b\\([^ \n\t]+\\)[ \n\t]+\\1\\b"
(re-search-forward "\\<\\(\\w+\\)\\>[ \n\t\f]+\\1\\>"
end 'move))
(flyspell-word)
(backward-word 1))
@ -1706,7 +1711,9 @@ is itself incorrect, but suspiciously repeated."
;; now we can use a new overlay
(setq flyspell-overlay
(make-flyspell-overlay
beg end 'flyspell-incorrect 'highlight)))))))
beg end
(if (eq poss 'doublon) 'flyspell-duplicate 'flyspell-incorrect)
'highlight)))))))
;;*---------------------------------------------------------------------*/
;;* flyspell-highlight-duplicate-region ... */

View File

@ -614,6 +614,7 @@
;;; Code:
(require 'regexp-opt)
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;

View File

@ -1,3 +1,34 @@
2006-10-29 Magnus Henoch <mange@freemail.hu>
* url-gw.el (url-open-stream): Really use asynchronous
connections (accidentally disabled during debugging).
2006-10-28 Magnus Henoch <mange@freemail.hu>
* url-http.el (url-http-parse-headers): Fix misplaced paren.
2006-10-27 Magnus Henoch <mange@freemail.hu>
* url-http.el (url-http-mark-connection-as-free): Verify that
connection is open before saving it.
(url-http-handle-authentication): Use url-retrieve-internal
instead of url-retrieve.
(url-http-parse-headers): Adapt to new callback interface.
(url-http): Handle non-blocking connections.
(url-http-async-sentinel): Create.
* url.el (url-retrieve): Update docstring for new callback interface.
Remove all code.
(url-retrieve-internal): Move code from url-retrieve here.
* url-gw.el (url-open-stream): Use a non-blocking socket for
`native' gateway method, if available.
2006-10-16 Magnus Henoch <mange@freemail.hu>
* url-http.el (url-https-create-secure-wrapper): Always use tls
gateway method.
2006-10-12 Magnus Henoch <mange@freemail.hu>
* url-http.el (url-http-find-free-connection): Handle

View File

@ -210,7 +210,8 @@ linked Emacs under SunOS 4.x"
(defun url-open-stream (name buffer host service)
"Open a stream to HOST, possibly via a gateway.
Args per `open-network-stream'.
Will not make a connection if `url-gateway-unplugged' is non-nil."
Will not make a connection if `url-gateway-unplugged' is non-nil.
Might do a non-blocking connection; use `process-status' to check."
(unless url-gateway-unplugged
(let ((gw-method (if (and url-gateway-local-host-regexp
(not (eq 'tls url-gateway-method))
@ -249,7 +250,11 @@ Will not make a connection if `url-gateway-unplugged' is non-nil."
(ssl
(open-ssl-stream name buffer host service))
((native)
(open-network-stream name buffer host service))
;; Use non-blocking socket if we can.
(make-network-process :name name :buffer buffer
:host host :service service
:nowait
(featurep 'make-network-process '(:nowait t))))
(socks
(socks-open-network-stream name buffer host service))
(telnet

View File

@ -92,11 +92,12 @@ request.")
(defun url-http-mark-connection-as-free (host port proc)
(url-http-debug "Marking connection as free: %s:%d %S" host port proc)
(set-process-buffer proc nil)
(set-process-sentinel proc 'url-http-idle-sentinel)
(puthash (cons host port)
(cons proc (gethash (cons host port) url-http-open-connections))
url-http-open-connections)
(when (memq (process-status proc) '(open run))
(set-process-buffer proc nil)
(set-process-sentinel proc 'url-http-idle-sentinel)
(puthash (cons host port)
(cons proc (gethash (cons host port) url-http-open-connections))
url-http-open-connections))
nil)
(defun url-http-find-free-connection (host port)
@ -336,8 +337,8 @@ This allows us to use `mail-fetch-field', etc."
(let ((url-request-method url-http-method)
(url-request-data url-http-data)
(url-request-extra-headers url-http-extra-headers))
(url-retrieve url url-callback-function
url-callback-arguments)))))))
(url-retrieve-internal url url-callback-function
url-callback-arguments)))))))
(defun url-http-parse-response ()
"Parse just the response code."
@ -520,18 +521,21 @@ should be shown to the user."
(let ((url-request-method url-http-method)
(url-request-data url-http-data)
(url-request-extra-headers url-http-extra-headers))
;; Put in the current buffer a forwarding pointer to the new
;; destination buffer.
;; FIXME: This is a hack to fix url-retrieve-synchronously
;; without changing the API. Instead url-retrieve should
;; either simply not return the "destination" buffer, or it
;; should take an optional `dest-buf' argument.
(set (make-local-variable 'url-redirect-buffer)
(url-retrieve redirect-uri url-callback-function
(cons :redirect
(cons redirect-uri
url-callback-arguments))))
(url-mark-buffer-as-dead (current-buffer))))))
;; Remember that the request was redirected.
(setf (car url-callback-arguments)
(nconc (list :redirect redirect-uri)
(car url-callback-arguments)))
;; Put in the current buffer a forwarding pointer to the new
;; destination buffer.
;; FIXME: This is a hack to fix url-retrieve-synchronously
;; without changing the API. Instead url-retrieve should
;; either simply not return the "destination" buffer, or it
;; should take an optional `dest-buf' argument.
(set (make-local-variable 'url-redirect-buffer)
(url-retrieve-internal
redirect-uri url-callback-function
url-callback-arguments))
(url-mark-buffer-as-dead (current-buffer))))))
(4 ; Client error
;; 400 Bad Request
;; 401 Unauthorized
@ -653,7 +657,13 @@ should be shown to the user."
;; The request could not be understood by the server due to
;; malformed syntax. The client SHOULD NOT repeat the
;; request without modifications.
(setq success t))))
(setq success t)))
;; Tell the callback that an error occurred, and what the
;; status code was.
(when success
(setf (car url-callback-arguments)
(nconc (list :error (list 'error 'http url-http-response-status))
(car url-callback-arguments)))))
(5
;; 500 Internal server error
;; 501 Not implemented
@ -702,7 +712,13 @@ should be shown to the user."
;; which received this status code was the result of a user
;; action, the request MUST NOT be repeated until it is
;; requested by a separate user action.
nil)))
nil))
;; Tell the callback that an error occurred, and what the
;; status code was.
(when success
(setf (car url-callback-arguments)
(nconc (list :error (list 'error 'http url-http-response-status))
(car url-callback-arguments)))))
(otherwise
(error "Unknown class of HTTP response code: %d (%d)"
class url-http-response-status)))
@ -1089,11 +1105,38 @@ CBARGS as the arguments."
url-current-object))
(set-process-buffer connection buffer)
(set-process-sentinel connection 'url-http-end-of-document-sentinel)
(set-process-filter connection 'url-http-generic-filter)
(process-send-string connection (url-http-create-request url))))
(let ((status (process-status connection)))
(cond
((eq status 'connect)
;; Asynchronous connection
(set-process-sentinel connection 'url-http-async-sentinel))
((eq status 'failed)
;; Asynchronous connection failed
(error "Could not create connection to %s:%d" (url-host url)
(url-port url)))
(t
(set-process-sentinel connection 'url-http-end-of-document-sentinel)
(process-send-string connection (url-http-create-request url)))))))
buffer))
(defun url-http-async-sentinel (proc why)
(declare (special url-callback-arguments))
;; We are performing an asynchronous connection, and a status change
;; has occurred.
(with-current-buffer (process-buffer proc)
(cond
((string= (substring why 0 4) "open")
(set-process-sentinel proc 'url-http-end-of-document-sentinel)
(process-send-string proc (url-http-create-request url-current-object)))
(t
(setf (car url-callback-arguments)
(nconc (list :error (list 'error 'connection-failed why
:host (url-host url-current-object)
:service (url-port url-current-object)))
(car url-callback-arguments)))
(url-http-activate-callback)))))
;; Since Emacs 19/20 does not allow you to change the
;; `after-change-functions' hook in the midst of running them, we fake
;; an after change by hooking into the process filter and inserting
@ -1261,9 +1304,7 @@ p3p
(defmacro url-https-create-secure-wrapper (method args)
`(defun ,(intern (format (if method "url-https-%s" "url-https") method)) ,args
,(format "HTTPS wrapper around `%s' call." (or method "url-http"))
(let ((url-gateway-method (condition-case ()
(require 'ssl)
(error 'tls))))
(let ((url-gateway-method 'tls))
(,(intern (format (if method "url-http-%s" "url-http") method))
,@(remove '&rest (remove '&optional args))))))

View File

@ -128,13 +128,39 @@ URL is either a string or a parsed URL.
CALLBACK is called when the object has been completely retrieved, with
the current buffer containing the object, and any MIME headers associated
with it. Normally it gets the arguments in the list CBARGS.
However, if what we find is a redirect, CALLBACK is given
two additional args, `:redirect' and the redirected URL,
followed by CBARGS.
with it. It is called as (apply CALLBACK STATUS CBARGS).
STATUS is a list with an even number of elements representing
what happened during the request, with most recent events first,
or an empty list if no events have occurred. Each pair is one of:
\(:redirect REDIRECTED-TO) - the request was redirected to this URL
\(:error (ERROR-SYMBOL . DATA)) - an error occurred. The error can be
signaled with (signal ERROR-SYMBOL DATA).
Return the buffer URL will load into, or nil if the process has
already completed."
already completed (i.e. URL was a mailto URL or similar; in this case
the callback is not called).
The variables `url-request-data', `url-request-method' and
`url-request-extra-headers' can be dynamically bound around the
request; dynamic binding of other variables doesn't necessarily
take effect."
;;; XXX: There is code in Emacs that does dynamic binding
;;; of the following variables around url-retrieve:
;;; url-standalone-mode, url-gateway-unplugged, w3-honor-stylesheets,
;;; url-confirmation-func, url-cookie-multiple-line,
;;; url-cookie-{{,secure-}storage,confirmation}
;;; url-standalone-mode and url-gateway-unplugged should work as
;;; usual. url-confirmation-func is only used in nnwarchive.el and
;;; webmail.el; the latter should be updated. Is
;;; url-cookie-multiple-line needed anymore? The other url-cookie-*
;;; are (for now) only used in synchronous retrievals.
(url-retrieve-internal url callback (cons nil cbargs)))
(defun url-retrieve-internal (url callback cbargs)
"Internal function; external interface is `url-retrieve'.
CBARGS is what the callback will actually receive - the first item is
the list of events, as described in the docstring of `url-retrieve'."
(url-do-setup)
(url-gc-dead-buffers)
(if (stringp url)
@ -211,6 +237,9 @@ no further processing). URL is either a string or a parsed URL."
;; clear that it's a bug, but even then we need to decide how
;; url-http can then warn us that the download has completed.
;; In the mean time, we use this here workaround.
;; XXX: The callback must always be called. Any
;; exception is a bug that should be fixed, not worked
;; around.
(setq retrieval-done t))
;; We used to use `sit-for' here, but in some cases it wouldn't
;; work because apparently pending keyboard input would always

View File

@ -125,8 +125,7 @@ This is only meaningful if you don't use the implicit checkout model
;; an `error' by vc-do-command.
(error nil))))
(when (eq 0 status)
(vc-svn-parse-status t)
(eq 'SVN (vc-file-getprop file 'vc-backend)))))))
(vc-svn-parse-status file))))))
(defun vc-svn-state (file &optional localp)
"SVN-specific version of `vc-state'."
@ -134,8 +133,7 @@ This is only meaningful if you don't use the implicit checkout model
(with-temp-buffer
(cd (file-name-directory file))
(vc-svn-command t 0 file "status" (if localp "-v" "-u"))
(vc-svn-parse-status localp)
(vc-file-getprop file 'vc-state)))
(vc-svn-parse-status file)))
(defun vc-svn-state-heuristic (file)
"SVN-specific state heuristic."
@ -149,7 +147,7 @@ This is only meaningful if you don't use the implicit checkout model
;; enough. Otherwise it might fail with remote repositories.
(with-temp-buffer
(vc-svn-command t 0 nil "status" (if localp "-v" "-u"))
(vc-svn-parse-status localp))))
(vc-svn-parse-status))))
(defun vc-svn-workfile-version (file)
"SVN-specific version of `vc-workfile-version'."
@ -488,10 +486,10 @@ and that it passes `vc-svn-global-switches' to it before FLAGS."
;; behavior for different modules on the same server.
(match-string 1))))
(defun vc-svn-parse-status (localp)
(defun vc-svn-parse-status (&optional filename)
"Parse output of \"svn status\" command in the current buffer.
Set file properties accordingly. Unless FULL is t, parse only
essential information."
Set file properties accordingly. Unless FILENAME is non-nil, parse only
information about FILENAME and return its status."
(let (file status)
(goto-char (point-min))
(while (re-search-forward
@ -500,7 +498,9 @@ essential information."
(buffer-substring (point) (line-end-position))))
(setq status (char-after (line-beginning-position)))
(unless (eq status ??)
(vc-file-setprop file 'vc-backend 'SVN)
;; `vc-BACKEND-registered' must not set vc-backend,
;; which is instead set in vc-registered.
(unless filename (vc-file-setprop file 'vc-backend 'SVN))
;; Use the last-modified revision, so that searching in vc-print-log
;; output works.
(vc-file-setprop file 'vc-workfile-version (match-string 3))
@ -522,7 +522,8 @@ essential information."
(if (eq (char-after (match-beginning 1)) ?*)
'needs-merge
'edited))
(t 'edited)))))))
(t 'edited)))))
(if filename (vc-file-getprop filename 'vc-state))))
(defun vc-svn-dir-state-heuristic (dir)
"Find the SVN state of all files in DIR, using only local information."

View File

@ -2682,25 +2682,32 @@ To get a prompt, use a prefix argument."
(error "There is no version-controlled file in this buffer"))
(let ((backend (vc-backend buffer-file-name))
(backends nil))
(unless backend
(error "File %s is not under version control" buffer-file-name))
;; Find the registered backends.
(dolist (backend vc-handled-backends)
(when (vc-call-backend backend 'registered buffer-file-name)
(push backend backends)))
;; Find the next backend.
(let ((def (car (delq backend (append (memq backend backends) backends))))
(others (delete backend backends)))
(cond
((null others) (error "No other backend to switch to"))
(current-prefix-arg
(intern
(upcase
(completing-read
(format "Switch to backend [%s]: " def)
(mapcar (lambda (b) (list (downcase (symbol-name b)))) backends)
nil t nil nil (downcase (symbol-name def))))))
(t def))))))
(unwind-protect
(progn
(unless backend
(error "File %s is not under version control" buffer-file-name))
;; Find the registered backends.
(dolist (backend vc-handled-backends)
(when (vc-call-backend backend 'registered buffer-file-name)
(push backend backends)))
;; Find the next backend.
(let ((def (car (delq backend
(append (memq backend backends) backends))))
(others (delete backend backends)))
(cond
((null others) (error "No other backend to switch to"))
(current-prefix-arg
(intern
(upcase
(completing-read
(format "Switch to backend [%s]: " def)
(mapcar (lambda (b) (list (downcase (symbol-name b)))) backends)
nil t nil nil (downcase (symbol-name def))))))
(t def))))
;; Calling the `registered' method can mess up the file
;; properties, so we want to revert them to what they were.
(if (and backend (delete backend backends))
(vc-call-backend backend 'registered buffer-file-name))))))
(unless (eq backend (vc-backend file))
(vc-file-clearprops file)
(vc-file-setprop file 'vc-backend backend)

View File

@ -64,6 +64,8 @@ to the system configuration; look at `system-configuration' instead."
((featurep 'gtk)
(concat ", GTK+ Version " gtk-version-string))
((featurep 'x-toolkit) ", X toolkit")
((boundp 'mac-carbon-version-string)
(concat ", Carbon Version " mac-carbon-version-string))
(t ""))
(if (and (boundp 'x-toolkit-scroll-bars)
(memq x-toolkit-scroll-bars '(xaw xaw3d)))

View File

@ -719,17 +719,25 @@ or if the window is the only window of its frame."
"Kill the current buffer and delete the selected window."
(interactive)
(let ((window-to-delete (selected-window))
(buffer-to-kill (current-buffer))
(delete-window-hook (lambda ()
(condition-case nil
(delete-window)
(error nil)))))
(add-hook 'kill-buffer-hook delete-window-hook t t)
(if (kill-buffer (current-buffer))
;; If `delete-window' failed before, we rerun it to regenerate
;; the error so it can be seen in the minibuffer.
(when (eq (selected-window) window-to-delete)
(delete-window))
(remove-hook 'kill-buffer-hook delete-window-hook t))))
(unwind-protect
(progn
(add-hook 'kill-buffer-hook delete-window-hook t t)
(if (kill-buffer (current-buffer))
;; If `delete-window' failed before, we rerun it to regenerate
;; the error so it can be seen in the echo area.
(when (eq (selected-window) window-to-delete)
(delete-window))))
;; If the buffer is not dead for some reason (probably because
;; of a `quit' signal), remove the hook again.
(condition-case nil
(with-current-buffer buffer-to-kill
(remove-hook 'kill-buffer-hook delete-window-hook t))
(error nil)))))
(defun quit-window (&optional kill window)
"Quit the current buffer. Bury it, and maybe delete the selected frame.

View File

@ -4121,7 +4121,11 @@ If `woman-nofill' is non-nil then indent without filling or adjusting."
(eolp)
(skip-syntax-forward " ")
(setq woman-leave-blank-lines 1))
(beginning-of-line)
;; This shouldn't happen, but in case it does (e.g. for
;; badly-formatted manfiles with no terminating newline),
;; avoid an infinite loop.
(unless (and (eolp) (eobp))
(beginning-of-line))
;; If a single short line then just leave it.
;; This is necessary to preserve some table layouts.
;; PROBABLY NOT NECESSARY WITH SQUEEZE MODIFICATION !!!!!

View File

@ -1,3 +1,10 @@
2006-10-29 Chong Yidong <cyd@stupidchicken.com>
* Makefile.in: Use relative paths to avoid advertising filesystem
contents during compilation.
* makefile.w32-in: Likewise.
2006-08-21 Robert J. Chassell <bob@rattlesnake.com>
* emacs-lisp-intro.texi: deleted in directory copy of texinfo.tex

View File

@ -25,7 +25,7 @@ SHELL = @SHELL@
srcdir = @srcdir@
VPATH = @srcdir@
infodir = ${srcdir}/../info
infodir = ../info
INFO_SOURCES = ${srcdir}/emacs-lisp-intro.texi
# The file name eintr must fit within 5 characters, to allow for
@ -45,7 +45,7 @@ info: $(INFO_TARGETS)
dvi: $(DVI_TARGETS)
${infodir}/eintr: ${INFO_SOURCES}
$(MAKEINFO) -o $@ $(srcdir)/emacs-lisp-intro.texi
cd $(srcdir); $(MAKEINFO) emacs-lisp-intro.texi -o $(infodir)/eintr
emacs-lisp-intro.dvi: ${INFO_SOURCES}
$(ENVADD) $(TEXI2DVI) $(srcdir)/emacs-lisp-intro.texi

View File

@ -21,7 +21,7 @@
srcdir = .
infodir = $(srcdir)/../info
infodir = ../info
INFO_SOURCES = $(srcdir)/emacs-lisp-intro.texi
# The file name eintr must fit within 5 characters, to allow for
@ -46,7 +46,7 @@ $(infodir)/dir:
dvi: $(DVI_TARGETS)
$(infodir)/eintr: $(INFO_SOURCES)
$(MAKEINFO) -o $@ $(srcdir)/emacs-lisp-intro.texi
cd $(srcdir); $(MAKEINFO) emacs-lisp-intro.texi -o $(infodir)/eintr
emacs-lisp-intro.dvi: $(INFO_SOURCES)
$(ENVADD) $(TEXI2DVI) $(srcdir)/emacs-lisp-intro.texi

View File

@ -1,3 +1,47 @@
2006-10-29 Chong Yidong <cyd@stupidchicken.com>
* Makefile.in: Use relative paths to avoid advertising filesystem
contents during compilation.
* makefile.w32-in: Likewise.
2006-10-23 Kim F. Storm <storm@cua.dk>
* commands.texi (Event Input Misc): Update unread-command-events.
2006-10-23 Nick Roberts <nickrob@snap.net.nz>
* lists.texi (Sets And Lists): Fix typos.
2006-10-18 Juanma Barranquero <lekktu@gmail.com>
* control.texi (Processing of Errors): Use @var for an argument,
not @code.
2006-10-16 Richard Stallman <rms@gnu.org>
* edebug.texi (Edebug Recursive Edit): Minor cleanup.
* keymaps.texi (Format of Keymaps): Show all the keymap element
patterns that result from menu items.
(Key Lookup): Minor cleanups.
* modes.texi (Precalculated Fontification): Don't say that
not setting font-lock-defaults avoids loading font-lock.
* help.texi (Documentation): Move xref to Emacs Manual here.
(Documentation Basics): From here.
Also doc emacs-lisp-docstring-fill-column.
* elisp.texi: Update version and ISBN.
* commands.texi (Interactive Call): Clarify KEYS arg to
call-interactively is a vector.
(Command Loop Info): Delete anchor in this-command-keys.
Add anchor in this-command-keys-vector.
(Recursive Editing): Document how recursive-edit
handles the current buffer.
2006-10-13 Chong Yidong <cyd@stupidchicken.com>
* frames.texi (Frame Titles): %c and %l are ignored in
@ -2179,7 +2223,7 @@
* elisp.texi (Top): Update detailed menu for node changes.
* modes.texi (Modes): Update Menu.
(Hooks): Move to beginning of chapter.
(Hooks): Move to beginning of chapter.
Most minor modes run mode hooks too.
`add-hook' can handle void hooks or hooks whose value is a single
function.
@ -3444,7 +3488,7 @@
(Quoted Character Input): Clarify description of
`read-quoted-char' and fix example.
(Quitting): Add `with-local-quit'.
(Disabling Commands): Correct and clarify descriptions of
(Disabling Commands): Correct and clarify descriptions of
`enable-command' and `disable-command'.
Mention what happens if `disabled-command-hook' is nil.
(Keyboard Macros): Mention LOOPFUNC arg to `execute-kbd-macro'.
@ -3758,7 +3802,7 @@
2004-04-04 Luc Teirlinck <teirllm@auburn.edu>
* backups.texi: Various small changes in addition to:
* backups.texi: Various small changes in addition to:
(Making Backups): Mention return value of `backup-buffer'.
(Auto-Saving): Mention optional FORCE argument to
`delete-auto-save-file-if-necessary'.
@ -5339,7 +5383,7 @@ Sat Aug 11 17:39:10 1990 Richard Stallman (rms@sugar-bombs.ai.mit.edu)
Tue Jun 26 09:57:26 1990 David Lawrence (tale@geech)
* files.texi: Noted that completion-ignored-extensions is ignored
* files.texi: Noted that completion-ignored-extensions is ignored
when making *Completions*.
Fri Jun 8 16:44:44 EDT 1990 Jay Fenlason (hack@ai.mit.edu)
@ -5374,7 +5418,7 @@ Mon Apr 24 21:02:55 1989 Robert J. Chassell (bob@rice-chex.ai.mit.edu)
Mon Apr 17 18:56:50 1989 Robert J. Chassell (bob@rice-chex.ai.mit.edu)
* texinfo.tex: temporarily added
* texinfo.tex: Temporarily added
\let\result=\dblarrow
\def\error{{\it ERROR} \longdblarrow}
We need to do this better soon.

View File

@ -26,7 +26,7 @@ srcdir = @srcdir@
# Tell make where to find source files; this is needed for the makefiles.
VPATH=@srcdir@
infodir = $(srcdir)/../info
infodir = ../info
usermanualdir = $(srcdir)/../man
TEXI2DVI = texi2dvi
@ -101,7 +101,7 @@ srcs = \
info: $(infodir)/elisp
$(infodir)/elisp: $(srcs)
$(MAKEINFO) -I. -I$(srcdir) $(srcdir)/elisp.texi -o $(infodir)/elisp
cd $(srcdir); $(MAKEINFO) -I. -I$(infodir) elisp.texi -o $(infodir)/elisp
elisp.dvi: $(srcs)
$(TEXI2DVI) -I $(srcdir) -I $(usermanualdir) $(srcdir)/elisp.texi

View File

@ -575,10 +575,11 @@ arguments are unconditionally added to the list @code{command-history}.
Otherwise, the command is added only if it uses the minibuffer to read
an argument. @xref{Command History}.
The argument @var{keys}, if given, specifies the sequence of events to
supply if the command inquires which events were used to invoke it.
If @var{keys} is omitted or @code{nil}, the return value of
@code{this-command-keys} is used. @xref{Definition of this-command-keys}.
The argument @var{keys}, if given, should be a vector which specifies
the sequence of events to supply if the command inquires which events
were used to invoke it. If @var{keys} is omitted or @code{nil}, the
default is the return value of @code{this-command-keys-vector}.
@xref{Definition of this-command-keys-vector}.
@end defun
@defun command-execute command &optional record-flag keys special
@ -785,7 +786,6 @@ was specified to run but remapped into another command.
@end defvar
@defun this-command-keys
@anchor{Definition of this-command-keys}
This function returns a string or vector containing the key sequence
that invoked the present command, plus any previous commands that
generated the prefix argument for this command. Any events read by the
@ -806,6 +806,7 @@ fit in a string. @xref{Input Events}.
@end defun
@defun this-command-keys-vector
@anchor{Definition of this-command-keys-vector}
Like @code{this-command-keys}, except that it always returns the events
in a vector, so you don't need to deal with the complexities of storing
input events in a string (@pxref{Strings of Events}).
@ -2502,6 +2503,13 @@ put them in @code{unread-command-events} is to use
Normally you add events to the front of this list, so that the events
most recently unread will be reread first.
Events read from this list are not normally added to the current
command's key sequence (as returned by e.g. @code{this-command-keys}),
as the events will already have been added once as they were read for
the first time. An element of the form @code{(@code{t} . @var{event})}
forces @var{event} to be added to the current command's key sequence.
@end defvar
@defun listify-key-sequence key
@ -3021,7 +3029,12 @@ automatically by the initialization of Emacs, to let the user begin
editing. When called from a Lisp program, it enters a recursive editing
level.
In the following example, the function @code{simple-rec} first
If the current buffer is not the same as the selected window's buffer,
@code{recursive-edit} saves and restores the current buffer. Otherwise,
if you switch buffers, the buffer you switched to is current after
@code{recursive-edit} returns.
In the following example, the function @code{simple-rec} first
advances point one word, then enters a recursive edit, printing out a
message in the echo area. The user can then do any editing desired, and
then type @kbd{C-M-c} to exit and continue executing @code{simple-rec}.

View File

@ -862,7 +862,7 @@ handle errors that return control to the Emacs command loop. The
function should take three arguments: @var{data}, a list of the same
form that @code{condition-case} would bind to its variable;
@var{context}, a string describing the situation in which the error
occurred, or (more often) @code{nil}; and @code{caller}, the Lisp
occurred, or (more often) @code{nil}; and @var{caller}, the Lisp
function which called the primitive that signaled the error.
@end defvar

View File

@ -1044,9 +1044,9 @@ The variables @code{last-command}, @code{this-command},
@code{track-mouse}. Commands used within Edebug do not affect these
variables outside of Edebug.
The key sequence returned by @code{this-command-keys} is changed by
executing commands within Edebug and there is no way to reset
the key sequence from Lisp.
Executing commands within Edebug can change the key sequence that
would be returned by @code{this-command-keys}, and there is no way to
reset the key sequence from Lisp.
Edebug cannot save and restore the value of
@code{unread-command-events}. Entering Edebug while this variable has a

View File

@ -7,7 +7,7 @@
@c Version of the manual and of Emacs.
@c Please remember to update the edition number in README as well.
@set VERSION 2.9
@set EMACSVER 22.0.50
@set EMACSVER 22.0.90
@dircategory Emacs
@direntry
@ -74,7 +74,7 @@ Published by the Free Software Foundation @*
51 Franklin St, Fifth Floor @*
Boston, MA 02110-1301 @*
USA @*
ISBN 1-882114-73-6
ISBN 1-882114-74-4
@sp 1
Cover art by Etienne Suvasa.

View File

@ -22,6 +22,9 @@ of documentation strings is not sufficient as a manual because a good
manual is not organized in that fashion; it is organized in terms of
topics of discussion.
For commands to access documentation strings, see @ref{Help, ,
Help, emacs, The GNU Emacs Manual}.
@menu
* Documentation Basics:: Good style for doc strings.
Where to put them. How Emacs stores them.
@ -63,6 +66,10 @@ documentation is displayed. This allows documentation strings to refer
to the keys for related commands and be accurate even when a user
rearranges the key bindings. (@xref{Keys in Documentation}.)
@vindex emacs-lisp-docstring-fill-column
Emacs Lisp mode fills documentation strings to the width
specified by @code{emacs-lisp-docstring-fill-column}.
In Emacs Lisp, a documentation string is accessible through the
function or variable that it describes:
@ -100,9 +107,6 @@ documentation string. The functions @code{documentation} and
documentation string from the appropriate file; this is transparent to
the user.
For information on the uses of documentation strings, see @ref{Help, ,
Help, emacs, The GNU Emacs Manual}.
@c Wordy to prevent overfull hbox. --rjc 15mar92
The @file{emacs/lib-src} directory contains two utilities that you can
use to print nice-looking hardcopy for the file

View File

@ -174,13 +174,18 @@ ordinary binding applies to events of a particular @dfn{event type},
which is always a character or a symbol. @xref{Classifying Events}.
In this kind of binding, @var{binding} is a command.
@item (@var{type} @var{item-name} .@: @var{binding})
This specifies a binding which is also a menu item
named @var{item-name}. @xref{Simple Menu Items}.
@item (@var{type} @var{item-name} @r{[}@var{cache}@r{]} .@: @var{binding})
This specifies a binding which is also a simple menu item that
displays as @var{item-name} in the menu. @var{cache}, if present,
caches certain information for display in the menu. @xref{Simple Menu
Items}.
@item (@var{type} @var{item-name} @var{help-string} @r{[}@var{cache}@r{]} .@: @var{binding})
This is a simple menu item with help string @var{help-string}.
@item (@var{type} menu-item .@: @var{details})
This specifies a binding which is also a menu item and allows use of
other features. @xref{Extended Menu Items}.
This specifies a binding which is also an extended menu item. This
allows use of other features. @xref{Extended Menu Items}.
@item (t .@: @var{binding})
@cindex default key binding
@ -203,9 +208,10 @@ keymap}. Other keymaps are called @dfn{sparse keymaps}.
@cindex keymap prompt string
@cindex overall prompt string
@cindex prompt string of keymap
Aside from bindings, a keymap can also have a string as an element.
This is called the @dfn{overall prompt string} and makes it possible to
use the keymap as a menu. @xref{Defining Menus}.
Aside from elements that specify bindings for keys, a keymap can also
have a string as an element. This is called the @dfn{overall prompt
string} and makes it possible to use the keymap as a menu.
@xref{Defining Menus}.
@end table
When the binding is @code{nil}, it doesn't constitute a definition
@ -932,11 +938,11 @@ keymap.
Let's use the term @dfn{keymap entry} to describe the value found by
looking up an event type in a keymap. (This doesn't include the item
string and other extra elements in menu key bindings, because
string and other extra elements in a keymap element for a menu item, because
@code{lookup-key} and other key lookup functions don't include them in
the returned value.) While any Lisp object may be stored in a keymap as
a keymap entry, not all make sense for key lookup. Here is a table of
the meaningful kinds of keymap entries:
the returned value.) While any Lisp object may be stored in a keymap
as a keymap entry, not all make sense for key lookup. Here is a table
of the meaningful types of keymap entries:
@table @asis
@item @code{nil}
@ -964,7 +970,7 @@ event of the key sequence is looked up in @var{keymap}.
@item @var{list}
@cindex list in keymap
The meaning of a list depends on the types of the elements of the list.
The meaning of a list depends on what it contains:
@itemize @bullet
@item

View File

@ -1396,7 +1396,7 @@ destructively. See @ref{Sets And Lists}.
@end defun
@defun memql object list
The function @code{member} tests to see whether @var{object} is a member
The function @code{memql} tests to see whether @var{object} is a member
of @var{list}, comparing members with @var{object} using @code{eql},
so floating point elements are compared by value.
If @var{object} is a member, @code{memql} returns a list starting with
@ -1406,11 +1406,11 @@ Compare this with @code{memq}:
@example
@group
(memql 1.2 '(1.1 1.2 1.3) ; @r{@code{1.2} and @code{1.2} are @code{eql}.}
(memql 1.2 '(1.1 1.2 1.3)) ; @r{@code{1.2} and @code{1.2} are @code{eql}.}
@result{} (1.2 1.3)
@end group
@group
(memq 1.2 '(1.1 1.2 1.3) ; @r{@code{1.2} and @code{1.2} are not @code{eq}.}
(memq 1.2 '(1.1 1.2 1.3)) ; @r{@code{1.2} and @code{1.2} are not @code{eq}.}
@result{} nil
@end group
@end example

View File

@ -22,7 +22,7 @@
# Standard configure variables.
srcdir = .
infodir = $(srcdir)/../info
infodir = ../info
usermanualdir = $(srcdir)/../man
# Redefine `TEX' if `tex' does not invoke plain TeX. For example:
@ -106,7 +106,7 @@ $(infodir)/dir:
$(INSTALL_INFO) --info-dir=$(infodir) $(infodir)/elisp
$(infodir)/elisp: $(srcs)
$(MAKEINFO) -I. -I$(srcdir) -o $(infodir)/elisp $(srcdir)/elisp.texi
cd $(srcdir); $(MAKEINFO) -I. -I$(infodir) elisp.texi -o $(infodir)/elisp
elisp.dvi: $(srcs)
$(texinputdir) $(TEX) -I $(usermanualdir) $(srcdir)/elisp.texi

View File

@ -2816,8 +2816,7 @@ which construct their text programmatically, such as
If your mode does not use any of the other machinery of Font Lock
(i.e. it only uses the @code{font-lock-face} property), it should not
set the variable @code{font-lock-defaults}. That way, it will not
cause loading of the @file{font-lock} library.
set the variable @code{font-lock-defaults}.
@node Faces for Font Lock
@subsection Faces for Font Lock

View File

@ -1,5 +1,5 @@
/* Localized versions of Info.plist keys */
CFBundleName = "Emacs";
CFBundleShortVersionString = "22.0.50";
CFBundleGetInfoString = "22.0.50, Copyright (C) 2006 Free Software Foundation, Inc.";
CFBundleShortVersionString = "22.0.90";
CFBundleGetInfoString = "22.0.90, Copyright (C) 2006 Free Software Foundation, Inc.";

View File

@ -220,11 +220,11 @@ resource 'FREF' (129) {
resource 'vers' (1) {
0x22, /* Major revision in BCD */
0x0, /* Minor revision in BCD */
development, /* development, alpha, beta, or final (release) */
50, /* Non-final release # */
alpha, /* development, alpha, beta, or final (release) */
90, /* Non-final release # */
0, /* Region code */
"22.0.50", /* Short version number */
"22.0.50, Copyright \0xa9 2006 "
"22.0.90", /* Short version number */
"22.0.90, Copyright \0xa9 2006 "
"Free Software Foundation, Inc." /* Long version number */
};

View File

@ -522,7 +522,7 @@ echo "Making links to \`nt/icons'"
echo "Making links to \`mac'"
(cd mac
ln ChangeLog INSTALL README *.xml *.MPW ../${tempdir}/mac)
ln ChangeLog INSTALL README make-package *.xml *.MPW ../${tempdir}/mac)
echo "Making links to \`mac/inc'"
(cd mac/inc
@ -540,6 +540,10 @@ echo "Making links to \`mac/Emacs.app/Contents'"
(cd mac/Emacs.app/Contents
ln Info.plist PkgInfo ../../../${tempdir}/mac/Emacs.app/Contents)
echo "Making links to \`mac/Emacs.app/Contents/Resources'"
(cd mac/Emacs.app/Contents/Resources
ln Emacs.icns ../../../../${tempdir}/mac/Emacs.app/Contents/Resources)
echo "Making links to \`mac/Emacs.app/Contents/Resources/English.lproj'"
(cd mac/Emacs.app/Contents/Resources/English.lproj
ln InfoPlist.strings ../../../../../${tempdir}/mac/Emacs.app/Contents/Resources/English.lproj)

View File

@ -1,12 +1,60 @@
2006-10-28 Glenn Morris <rgm@gnu.org>
* ack.texi (Acknowledgments): Add cal-html author.
* calendar.texi (Writing Calendar Files): Rename section (was "LaTeX
Calendar"). Describe new package cal-html.
* emacs.texi (Top): Rename old node "LaTeX Calendar" to "Writing
Calendar Files."
2006-10-27 Richard Stallman <rms@gnu.org>
* woman.texi: Downcase nroff/troff/roff.
(Installation): Chapter deleted. Some xrefs deleted.
(Background): woman doesn't advise man ;-).
2006-10-26 Roberto Rodr,Am(Bguez <lanubeblanca@googlemail.com> (tiny change)
* ada-mode.texi (Project files, Identifier completion)
(Automatic Casing, Debugging, Using non-standard file names)
(Working Remotely): Fix typos.
2006-10-23 Richard Stallman <rms@gnu.org>
* abbrevs.texi (Expanding Abbrevs): Expansion happens only when
Abbrev mode is enabled.
2006-10-20 Masatake YAMATO <jet@gyve.org>
* cc-mode.texi (Sample .emacs File): Added missing `)' in
sample code `my-c-initialization-hook'.
2006-10-19 Stuart D. Herring <herring@lanl.gov>
* widget.texi: Fix typos.
2006-10-19 Michael Albinus <michael.albinus@gmx.de>
* tramp.texi (Frequently Asked Questions): Remove questions marked with
"???". There have been no complaints for years, so the information
must be appropriate.
2006-10-16 Richard Stallman <rms@gnu.org>
* widget.texi: Use @var instead of capitalization.
Clarify many widget type descriptions.
* emacs.texi: Update ISBN.
2006-10-13 Andreas Seltenreich <uwi7@rz.uni-karlsruhe.de>
* gnus.texi (Other modes): Fix typo. Add alternative index entry for
gnus-dired-attach.
(Selecting a Group): Fix typo.
2006-10-12 Roberto Rodr,Am(Bguez <lanubeblanca@googlemail.com>
2006-10-12 Roberto Rodr,Am(Bguez <lanubeblanca@googlemail.com> (tiny change)
* widget.texi: Fix typos (tiny change)
* widget.texi: Fix typos.
2006-10-11 Kim F. Storm <storm@cua.dk>

View File

@ -146,12 +146,13 @@ abbrev definitions, both global and local.
@node Expanding Abbrevs
@section Controlling Abbrev Expansion
An abbrev expands whenever it is present in the buffer just before
point and you type a self-inserting whitespace or punctuation character
(@key{SPC}, comma, etc.@:). More precisely, any character that is not a
word constituent expands an abbrev, and any word-constituent character
can be part of an abbrev. The most common way to use an abbrev is to
insert it and then insert a punctuation or whitespace character to expand it.
When Abbrev mode is enabled, an abbrev expands whenever it is
present in the buffer just before point and you type a self-inserting
whitespace or punctuation character (@key{SPC}, comma, etc.@:). More
precisely, any character that is not a word constituent expands an
abbrev, and any word-constituent character can be part of an abbrev.
The most common way to use an abbrev is to insert it and then insert a
punctuation or whitespace character to expand it.
@vindex abbrev-all-caps
Abbrev expansion preserves case; thus, @samp{foo} expands into @samp{find

View File

@ -74,6 +74,9 @@ contributed ERC, an advanced Internet Relay Chat client.
@item
Boaz Ben-Zvi wrote @file{profile.el}, to time Emacs Lisp functions.
@item
Anna M. Bigatti wrote @file{cal-html.el}, which produces HTML calendars.
@item
Ray Blaak wrote @file{delphi.el}, a major mode for editing Delphi
(Object Pascal) source code.

View File

@ -283,7 +283,7 @@ debugging can be performed within Emacs in a convenient and natural way.
To take full advantage of this features, it is possible to create a file
in the main directory of your application, with a @samp{.adp} extension.
This file contain all needed information dealing with the way your
This file contains all needed information dealing with the way your
application is organized between directories, the commands to compile,
run and debug it etc. Creating this file is not mandatory and convenient
defaults are automatically provided for simple setups. It only becomes
@ -329,7 +329,7 @@ This is done through the variable @code{ada-xref-default-prj-file}.
@end example
Note: This has a higher priority than the first variable, so the first
choice is to use this variable settings, and otherwise
choice is to use this variable's settings, and otherwise
@code{ada-prj-default-project-file}.
@end itemize
@ -601,7 +601,7 @@ they will also contain additional cross-referencing information.
Emacs and Ada mode provide two general ways for the completion of
identifiers. This is an easy way to type faster: you just have to type
the first few letters of an identifiers, and then loop through all the
the first few letters of an identifier, and then loop through all the
possible completions.
The first method is general for Emacs. It will work both with Ada
@ -623,7 +623,7 @@ Pressing @key{M-/} once more will bring you back to @samp{my_identifier}.
This is a very fast way to do completion, and the casing of words will
also be respected.
The second method is specific to Ada buffer, and even to users of the
The second method is specific to Ada buffers, and even to users of the
Gnat compiler. Emacs will search the cross-information found in the
@samp{.ali} files generated by Gnat for possible completions.
@ -839,7 +839,7 @@ All letters, except the first one of the word and every letter after the
instance @code{My_vARIable} is converted to @code{My_Variable}.
@item ada-loose-case-word
No letters is modified in the previous word, except the ones after the
No letters are modified in the previous word, except the ones after the
@samp{_} character that are upper cased. For instance @code{My_vARIable} is
converted to @code{My_VARIable}.
@end table
@ -894,7 +894,8 @@ above, the new exception will be added to the first file in the list
only. You can not automatically add an exception to one of the other
files, although you can of course edit the files by hand at any time.
Automatic casing can be performed on port or whole buffer using:
Automatic casing can be performed on part of the buffer, or on the
whole buffer, using:
@table @kbd
@item C-c C-b
@ -1108,7 +1109,7 @@ You can set up in the project file a command to use to debug your
application. Emacs is compatible with a lot of debuggers, and provide an
easy interface to them.
This selection will focus on the gdb debugger, and two of the graphical
This section will focus on the gdb debugger, and two of the graphical
interfaces that exist for it.
In all cases, the main window in Emacs will be split in two: in the
@ -1125,7 +1126,7 @@ also set a breakpoint simply by right-clicking on a line.
You can easily use Emacs as the source window when you are using a
graphical interface for the debugger. The interesting thing is that,
whereas you still have the graphical nifties, you can also you the
whereas you still have the graphical nifties, you can also use the
cross-references features that Ada mode provides to look at the
definition for the identifiers, @enddots{}
@ -1172,7 +1173,7 @@ need to add the following to your @file{.emacs} file:
(ada-add-extensions "_s.ada" "_b.ada")
@end example
Note that it is possible to redefine the extension, even if they already
Note that it is possible to redefine the extensions, even if they already
exist, as in:
@example
@ -1195,7 +1196,7 @@ for an example).
@chapter Working Remotely
@c ---------------------------------------------------------------------
When you work on project that involve a lot of programmers, it is
When you work on a project that involves a lot of programmers, it is
generally the case that you will edit the files on your own machine, but
you want to compile, run and debug your application in another buffer.

View File

@ -35,7 +35,7 @@ about more specialized features.
* Scroll Calendar:: Bringing earlier or later months onto the screen.
* Counting Days:: How many days are there between two dates?
* General Calendar:: Exiting or recomputing the calendar.
* LaTeX Calendar:: Print a calendar using LaTeX.
* Writing Calendar Files:: Writing calendars to files of various formats.
* Holidays:: Displaying dates of holidays.
* Sunrise/Sunset:: Displaying local times of sunrise and sunset.
* Lunar Phases:: Displaying phases of the moon.
@ -341,11 +341,47 @@ buries all buffers related to the calendar, selecting other buffers.
(If a frame contains a dedicated calendar window, exiting from the
calendar iconifies that frame.)
@node LaTeX Calendar
@section LaTeX Calendar
@cindex calendar and La@TeX{}
@node Writing Calendar Files
@section Writing Calendar Files
The Calendar La@TeX{} commands produce a buffer of La@TeX{} code that
These packages produce files of various formats containing calendar
and diary entries, for display purposes.
@cindex calendar and HTML
The Calendar HTML commands produce files of HTML code that contain
calendar and diary entries. Each file applies to one month, and has a
name of the format @file{@var{yyyy}-@var{mm}.html}, where @var{yyyy} and
@var{mm} are the four-digit year and two-digit month, respectively. The
variable @code{cal-html-directory} specifies the default output
directory for the HTML files.
@vindex cal-html-css-default
Diary entries enclosed by @code{<} and @code{>} are interpreted as
HTML tags (for example: this is a diary entry with <font
color=''red''>some red text</font>). You can change the overall
appearance of the displayed HTML pages (for example, the color of
various page elements, header styles) via a stylesheet @file{cal.css} in
the directory containing the HTML files (see the value of the variable
@code{cal-html-css-default} for relevant style settings).
@kindex t @r{(Calendar mode)}
@table @kbd
@item H m
Generate a one-month calendar (@code{cal-html-cursor-month}).
@item H y
Generate a calendar file for each month of a year, as well as an index
page (@code{cal-html-cursor-year}). By default, this command writes
files to a @var{yyyy} subdirectory - if this is altered some hyperlinks
between years will not work.
@end table
If the variable @code{cal-html-print-day-number-flag} is
non-@code{nil}, then the monthly calendars show the day-of-the-year
number. The variable @code{cal-html-year-index-cols} specifies the
number of columns in the yearly index page.
@cindex calendar and La@TeX{}
The Calendar La@TeX{} commands produce a buffer of La@TeX{} code that
prints as a calendar. Depending on the command you use, the printed
calendar covers the day, week, month or year that point is in.
@ -401,7 +437,7 @@ If the variable @code{cal-tex-diary} is non-@code{nil} (the default is
calendars only). If the variable @code{cal-tex-rules} is non-@code{nil}
(the default is @code{nil}), the calendar displays ruled pages
in styles that have sufficient room. You can use the variable
@code{cal-tex-preamble-extra} to insert extra LaTeX commands in the
@code{cal-tex-preamble-extra} to insert extra La@TeX{} commands in the
preamble of the generated document if you need to.
@node Holidays

View File

@ -6560,7 +6560,7 @@ anchoring position to indent the line in that case.
(defun my-c-initialization-hook ()
(define-key c-mode-base-map "\C-m" 'c-context-line-break)
(define-key c-mode-base-map [?\C-\M-a] 'c-beginning-of-defun)
(define-key c-mode-base-map [?\C-\M-e] 'c-end-of-defun)
(define-key c-mode-base-map [?\C-\M-e] 'c-end-of-defun))
(add-hook 'c-initialization-hook 'my-c-initialization-hook)
;; offset customizations not in my-c-style

View File

@ -5,7 +5,7 @@
@c The edition number appears in several places in this file
@set EDITION Sixteenth
@set EMACSVER 22.1
@set EMACSVER 22.0.90
@copying
This is the @value{EDITION} edition of the @cite{GNU Emacs Manual},
@ -71,7 +71,7 @@ Software Foundation raise funds for GNU development.''
@insertcopying
@sp 2
ISBN 1-882114-06-X @*
ISBN 1-882114-86-8*
Published by the Free Software Foundation @*
51 Franklin Street, Fifth Floor @*
Boston, MA 02110-1301 USA
@ -714,7 +714,7 @@ The Calendar and the Diary
* Scroll Calendar:: Bringing earlier or later months onto the screen.
* Counting Days:: How many days are there between two dates?
* General Calendar:: Exiting or recomputing the calendar.
* LaTeX Calendar:: Print a calendar using LaTeX.
* Writing Calendar Files:: Writing calendars to files of various formats.
* Holidays:: Displaying dates of holidays.
* Sunrise/Sunset:: Displaying local times of sunrise and sunset.
* Lunar Phases:: Displaying phases of the moon.

View File

@ -2009,11 +2009,6 @@ Web page with instructions:
@uref{http://www4.ncsu.edu/~tlroche/plinkTramp.html}
@end ignore
??? Is the XEmacs info correct?
??? Can somebody provide some information for getting it to work on NT
Emacs? I think there was some issue with @command{ssh}?
@item
@value{tramp} does not connect to the remote host

View File

@ -178,7 +178,7 @@ in some cases, especially in the Vi Insert state. John Hawkins
<jshawkin@@eecs.umich.edu> has provided a set of customizations, which
enables additional Emacs bindings under Viper. These customizations can be
included in your @file{~/.viper} file and are found at the following URL:
@file{http://www.eecs.umich.edu/~jshawkin/viper-sample}.
@file{http://traeki.freeshell.org/files/viper-sample}.
@menu
* Emacs Preliminaries:: Basic concepts in Emacs.

View File

@ -480,11 +480,11 @@ when not on a button. By default this is @code{global-map}.
@comment node-name, next, previous, up
@section Basic Types
The syntax of a type specification is given below:
This is the general syntax of a type specification:
@example
NAME ::= (NAME [KEYWORD ARGUMENT]... ARGS)
| NAME
@var{name} ::= (@var{name} [@var{keyword} @var{argument}]... @var{args})
| @var{name}
@end example
Where, @var{name} is a widget name, @var{keyword} is the name of a
@ -724,7 +724,7 @@ If non-@code{nil}, allow glyphs to appear on displays where they are supported.
Syntax:
@example
TYPE ::= (link [KEYWORD ARGUMENT]... [ VALUE ])
@var{type} ::= (link [@var{keyword} @var{argument}]... [ @var{value} ])
@end example
The @var{value}, if present, is used to initialize the @code{:value}
@ -749,7 +749,7 @@ String to suffix links.
Syntax:
@example
TYPE ::= (url-link [KEYWORD ARGUMENT]... URL)
@var{type} ::= (url-link [@var{keyword} @var{argument}]... @var{url})
@end example
@findex browse-url-browser-function@r{, and @code{url-link} widget}
@ -764,7 +764,7 @@ When this link is invoked, the @acronym{WWW} browser specified by
Syntax:
@example
TYPE ::= (info-link [KEYWORD ARGUMENT]... ADDRESS)
@var{type} ::= (info-link [@var{keyword} @var{argument}]... @var{address})
@end example
When this link is invoked, the built-in Info reader is started on
@ -778,7 +778,7 @@ When this link is invoked, the built-in Info reader is started on
Syntax:
@example
TYPE ::= (push-button [KEYWORD ARGUMENT]... [ VALUE ])
@var{type} ::= (push-button [@var{keyword} @var{argument}]... [ @var{value} ])
@end example
The @var{value}, if present, is used to initialize the @code{:value}
@ -803,7 +803,7 @@ String to suffix push buttons.
Syntax:
@example
TYPE ::= (editable-field [KEYWORD ARGUMENT]... [ VALUE ])
@var{type} ::= (editable-field [@var{keyword} @var{argument}]... [ @var{value} ])
@end example
The @var{value}, if present, is used to initialize the @code{:value}
@ -863,7 +863,7 @@ does not rebind the @key{RET} key.
Syntax:
@example
TYPE ::= (menu-choice [KEYWORD ARGUMENT]... TYPE ... )
@var{type} ::= (menu-choice [@var{keyword} @var{argument}]... @var{type} ... )
@end example
The @var{type} argument represents each possible choice. The widget's
@ -904,13 +904,13 @@ The list of types.
Syntax:
@example
TYPE ::= (radio-button-choice [KEYWORD ARGUMENT]... TYPE ... )
@var{type} ::= (radio-button-choice [@var{keyword} @var{argument}]... @var{type} ... )
@end example
The @var{type} argument represents each possible choice. The widget's
value will be that of the chosen @var{type} argument. This widget will
match any value matching at least one of the specified @var{type}
arguments.
The component types specify the choices, with one radio button for
each. The widget's value will be that of the chosen @var{type}
argument. This widget matches any value that matches at least one of
the specified @var{type} arguments.
The following extra properties are recognized.
@ -971,7 +971,7 @@ you call @code{widget-delete}.
Syntax:
@example
ITEM ::= (item [KEYWORD ARGUMENT]... VALUE)
@var{item} ::= (item [@var{keyword} @var{argument}]... @var{value})
@end example
The @var{value}, if present, is used to initialize the @code{:value}
@ -986,7 +986,7 @@ buffer. This widget will only match the specified value.
Syntax:
@example
ITEM ::= (choice-item [KEYWORD ARGUMENT]... VALUE)
@var{item} ::= (choice-item [@var{keyword} @var{argument}]... @var{value})
@end example
The @var{value}, if present, is used to initialize the @code{:value}
@ -1003,7 +1003,7 @@ the specified value.
Syntax:
@example
TYPE ::= (toggle [KEYWORD ARGUMENT]...)
@var{type} ::= (toggle [@var{keyword} @var{argument}]...)
@end example
The widget has two possible states, @samp{on} and @samp{off}, which
@ -1039,7 +1039,7 @@ This widget has two possible states, @samp{selected} and
Syntax:
@example
TYPE ::= (checkbox [KEYWORD ARGUMENT]...)
@var{type} ::= (checkbox [@var{keyword} @var{argument}]...)
@end example
@node checklist, editable-list, checkbox, Basic Types
@ -1050,7 +1050,7 @@ TYPE ::= (checkbox [KEYWORD ARGUMENT]...)
Syntax:
@example
TYPE ::= (checklist [KEYWORD ARGUMENT]... TYPE ... )
@var{type} ::= (checklist [@var{keyword} @var{argument}]... @var{type} ... )
@end example
The @var{type} arguments represent each checklist item. The widget's
@ -1108,7 +1108,7 @@ The list of types.
Syntax:
@example
TYPE ::= (editable-list [KEYWORD ARGUMENT]... TYPE)
@var{type} ::= (editable-list [@var{keyword} @var{argument}]... @var{type})
@end example
The value is a list, where each member represents one widget of type
@ -1168,7 +1168,7 @@ This widget simply group other widgets together.
Syntax:
@example
TYPE ::= (group [KEYWORD ARGUMENT]... TYPE...)
@var{type} ::= (group [@var{keyword} @var{argument}]... @var{type}...)
@end example
The value is a list, with one member for each @var{type}.
@ -1201,7 +1201,7 @@ of the composite widgets.
The syntax for the @code{const} widget is:
@example
TYPE ::= (const [KEYWORD ARGUMENT]... [ VALUE ])
@var{type} ::= (const [@var{keyword} @var{argument}]... [ @var{value} ])
@end example
The @var{value}, if present, is used to initialize the @code{:value}
@ -1237,7 +1237,7 @@ user to edit it inline in the buffer.
The syntax for the @code{sexp} widget is:
@example
TYPE ::= (sexp [KEYWORD ARGUMENT]... [ VALUE ])
@var{type} ::= (sexp [@var{keyword} @var{argument}]... [ @var{value} ])
@end example
@deffn Widget sexp
@ -1261,7 +1261,7 @@ following widgets.
The syntax for all the atoms are:
@example
TYPE ::= (NAME [KEYWORD ARGUMENT]... [ VALUE ])
@var{type} ::= (@var{construct} [@var{keyword} @var{argument}]... [ @var{value} ])
@end example
The @var{value}, if present, is used to initialize the @code{:value}
@ -1331,10 +1331,10 @@ either @code{nil} meaning false, or non-@code{nil} meaning true.
@subsection Composite Sexp Widgets
@cindex composite sexp widgets
The syntax for the composite widget is:
The syntax for the composite widget construct is:
@example
TYPE ::= (NAME [KEYWORD ARGUMENT]... COMPONENT...)
@var{type} ::= (@var{construct} [@var{keyword} @var{argument}]... @var{component}...)
@end example
@noindent
@ -1342,30 +1342,54 @@ where each @var{component} must be a widget type. Each component widget
will be displayed in the buffer, and will be editable by the user.
@deffn Widget cons
The value of a @code{cons} widget is a cons-cell where the @sc{car} is
the value of the first component and the @sc{cdr} is the value of the
second component. There must be exactly two components.
The value of a @code{cons} widget must be a cons-cell whose @sc{car}
and @sc{cdr} have two specified types. It uses this syntax:
@example
@var{type} ::= (cons [@var{keyword} @var{argument}]... @var{car-type} @var{cdr-type})
@end example
@end deffn
@deffn Widget choice
The value matched by a @code{choice} widget must have one of a fixed
set of types. The widget's syntax is as follows:
@example
@var{type} ::= (choice [@var{keyword} @var{argument}]... @var{type} ... )
@end example
The value of a @code{choice} widget can be anything that matches any of the
@var{types}.
@end deffn
@deffn Widget list
The value of a @code{list} widget is a list containing the value of
each of its components.
The value of a @code{list} widget must be a list whose element types
match the specified component types:
@example
@var{type} ::= (list [@var{keyword} @var{argument}]... @var{component-type}...)
@end example
Thus, @code{(list string number)} matches lists of two elements,
the first being a string and the second being a number.
@end deffn
@deffn Widget vector
The value of a @code{vector} widget is a vector containing the value of
each of its component.
The @code{vector} widget is like the @code{list} widget but matches
vectors instead of lists. Thus, @code{(vector string number)} matches
vectors of two elements, the first being a string and the second being
a number.
@end deffn
The above suffice for specifying fixed size lists and vectors. To get
variable length lists and vectors, you can use a @code{choice},
@code{set}, or @code{repeat} widget together with the @code{:inline}
keyword. If any component of a composite widget has the @code{:inline}
keyword set, its value must be a list which will then be spliced into
the composite. For example, to specify a list whose first element must
be a file name, and whose remaining arguments should either be the
symbol @code{t} or two files, you can use the following widget
specification:
keyword. If any component of a composite widget has the
@code{:inline} keyword set, its value must be a list which will then
be spliced into the composite. For example, to specify a list whose
first element must be a file name, and whose remaining elements should
either be the symbol @code{t} or two strings (file names), you can use
the following widget specification:
@example
(list file
@ -1376,29 +1400,32 @@ specification:
@end example
The value of a widget of this type will either have the form
@code{(file t)} or @code{(file string string)}.
@code{(file t)} or @code{(file @var{string} @var{string})}.
This concept of inline is probably hard to understand. It was certainly
hard to implement, so instead of confusing you more by trying to explain
it here, I'll just suggest you meditate over it for a while.
@deffn Widget choice
Allows you to edit a sexp which may have one of a fixed set of types.
It is currently implemented with the @code{choice-menu} basic widget,
and has a similar syntax.
@end deffn
This concept of @code{:inline} may be hard to understand. It was
certainly hard to implement, so instead of confusing you more by
trying to explain it here, I'll just suggest you meditate over it for
a while.
@deffn Widget set
Allows you to specify a type which must be a list whose elements all
belong to the given set. The elements of the list are not significant.
This is implemented on top of the @code{checklist} basic widget, and has
a similar syntax.
Specifies a type whose values are the lists whose elements all belong
to a given set. The order of elements of the list is not significant.
Here's the syntax:
@example
@var{type} ::= (set [@var{keyword} @var{argument}]... @var{permitted-element} ... )
@end example
Use @code{const} to specify each permitted element, like this:
@code{(set (const a) (const b))}.
@end deffn
@deffn Widget repeat
Allows you to specify a variable length list whose members are all of
the same type. Implemented on top of the @code{editable-list} basic
widget, and has a similar syntax.
Specifies a list of any number of elements that fit a certain type.
@example
@var{type} ::= (repeat [@var{keyword} @var{argument}]... @var{type})
@end example
@end deffn
@node Widget Properties, Defining New Widgets, Sexp Types, Top

View File

@ -91,7 +91,6 @@ Mile End Road, London E1 4NS, UK
@menu
* Introduction:: Introduction
* Background:: Background
* Installation:: Installation and Setup
* Finding:: Finding and Formatting Man Pages
* Browsing:: Browsing Man Pages
* Customization:: Customization
@ -127,7 +126,7 @@ WoMan implements a subset of the formatting performed by the Emacs
@code{man} (or @code{manual-entry}) command to format a Unix-style
@dfn{manual page} (usually abbreviated to @dfn{man page}) for display,
but without calling any external programs. It is intended to emulate
the whole of the @code{ROFF -man} macro package, plus those @code{ROFF}
the whole of the @code{roff -man} macro package, plus those @code{roff}
requests (@pxref{Background, , Background}) that are most commonly used
in man pages. However, the emulation is modified to include the
reformatting done by the Emacs @code{man} command. No hyphenation is
@ -145,7 +144,7 @@ small- and medium-size pages).
This browser works quite well on simple well-written man files. It
works less well on idiosyncratic files that ``break the rules'' or use
the more obscure @code{ROFF} requests directly. Current test results
the more obscure @code{roff} requests directly. Current test results
are available in the file
@uref{http://centaur.maths.qmw.ac.uk/Emacs/WoMan/files/woman.status,
@file{woman.status}}.
@ -169,7 +168,7 @@ Reporting Bugs}.
@c ===================================================================
@node Background, Installation, Introduction, Top
@node Background, Finding, Introduction, Top
@comment node-name, next, previous, up
@chapter Background
@cindex background
@ -178,31 +177,31 @@ WoMan is a browser for traditional Unix-style manual page documentation.
Each such document is conventionally referred to as a @dfn{manual page},
or @dfn{man page} for short, even though some are very much longer than
one page. A man page is a document written using the Unix ``man''
macros, which are themselves written in the NROFF/TROFF text processing
markup language. @code{NROFF} and @code{TROFF} are text processors
macros, which are themselves written in the nroff/troff text processing
markup language. @code{nroff} and @code{troff} are text processors
originally written for the UNIX operating system by Joseph F. Ossanna at
Bell Laboratories, Murray Hill, New Jersey, USA@. They are closely
related, and except in the few cases where the distinction between them
is important I will refer to them both ambiguously as @dfn{ROFF}.
is important I will refer to them both ambiguously as @code{roff}.
@code{ROFF} markup consists of @dfn{requests} and @dfn{escape
@code{roff} markup consists of @dfn{requests} and @dfn{escape
sequences}. A request occupies a complete line and begins with either a
period or a single forward quote. An escape sequences is embedded
within the input text and begins (by default) with a backslash. The
original man macro package defines 20 new @code{ROFF} requests
original man macro package defines 20 new @code{roff} requests
implemented as macros, which were considered to be sufficient for
writing man pages. But whilst in principle man pages use only the man
macros, in practice a significant number use many other @code{ROFF}
macros, in practice a significant number use many other @code{roff}
requests.
The distinction between @code{TROFF} and @code{NROFF} is that
@code{TROFF} was designed to drive a phototypesetter whereas
@code{NROFF} was designed to produce essentially @acronym{ASCII} output for a
The distinction between @code{troff} and @code{nroff} is that
@code{troff} was designed to drive a phototypesetter whereas
@code{nroff} was designed to produce essentially @acronym{ASCII} output for a
character-based device similar to a teletypewriter (usually abbreviated
to ``teletype'' or ``tty''). Hence, @code{TROFF} supports much finer
control over output positioning than does @code{NROFF} and can be seen
to ``teletype'' or ``tty''). Hence, @code{troff} supports much finer
control over output positioning than does @code{nroff} and can be seen
as a forerunner of @TeX{}. Traditionally, man pages are either
formatted by @code{TROFF} for typesetting or by @code{NROFF} for
formatted by @code{troff} for typesetting or by @code{nroff} for
printing on a character printer or displaying on a screen. Of course,
over the last 25 years or so, the distinction between typeset output on
paper and characters on a screen has become blurred by the fact that
@ -214,8 +213,8 @@ Nevertheless, Unix-style manual page documentation is still normally
browsed on screen by running a program called @code{man}. This program
looks in a predefined set of directories for the man page matching a
specified topic, then either formats the source file by running
@code{NROFF} or recovers a pre-formatted file, and displays it via a
pager such as @code{more}. @code{NROFF} normally formats for a printer,
@code{nroff} or recovers a pre-formatted file, and displays it via a
pager such as @code{more}. @code{nroff} normally formats for a printer,
so it paginates the output, numbers the pages, etc., most of which is
irrelevant when the document is browsed as a continuous scrollable
document on screen. The only concession to on-screen browsing normally
@ -228,7 +227,7 @@ command, see @ref{Documentation, man, Documentation Commands, emacs, GNU
Emacs Manual}.
This command runs @code{man} as described above, perhaps in
the background, and then post-processes the output to remove much of the
@code{NROFF} pagination such as page headers and footers, and places the
@code{nroff} pagination such as page headers and footers, and places the
result into an Emacs buffer. It puts this buffer into a special major
mode, which is tailored for man page browsing, and provides a number of
useful navigation commands, support for following references, etc. It
@ -236,7 +235,7 @@ provides some support for special display faces (fonts), but no special
menu or mouse support. The Emacs man package appears to have been
developed over about 10 years, from the late 1980s to the late 1990s.
There is considerable inefficiency in having @code{NROFF} paginate a
There is considerable inefficiency in having @code{nroff} paginate a
document and then removing most of the pagination!
WoMan is an Emacs Lisp library that provides an emulation of the
@ -253,22 +252,22 @@ with Unix-style manual page documentation. This may be difficult to
read because ports of the Unix-style @code{man} program can be a little
awkward to set up. I decided that it should not be too hard to emulate
the 20 @code{man} macros directly, without treating them as macros and
largely ignoring the underlying @code{ROFF} requests, given the text
largely ignoring the underlying @code{roff} requests, given the text
processing capabilities of Emacs. This proved to be essentially true,
and it did not take a great deal of work to be able to format simple man
pages acceptably.
One problem arose with the significant number of man pages that use
@code{ROFF} requests in addition to the @code{man} macros, and since
@code{roff} requests in addition to the @code{man} macros, and since
releasing the first version of WoMan I have been continually extending
it to support more @code{ROFF} requests. WoMan can now format a
it to support more @code{roff} requests. WoMan can now format a
significant proportion of the man pages that I have tested, either well
or at least readably. However, I have added capabilities partly by
making additional passes through the document, a design that is
fundamentally flawed. This can only be solved by a major re-design of
WoMan to handle the major formatting within a single recursive pass,
rather than the present multiple passes without any significant
recursion. There are some @code{ROFF} requests that cannot be handled
recursion. There are some @code{roff} requests that cannot be handled
satisfactorily within the present design. Some of these are currently
handled by kludges that ``usually more or less work.''
@ -288,227 +287,18 @@ WoMan has (this) texinfo documentation!
WoMan @emph{does not} replace @code{man}, although it does use a number
of the facilities implemented in the Emacs @code{man} library. WoMan
and man can happily co-exist, which is very useful for comparison and
debugging purposes. The only way in which WoMan affects @code{man} is
that it adds a timer to indicate how long @code{man} has taken to format
a man page. The timing is as compatible as possible with the timing
built into WoMan, for as fair a comparison as possible. The time
comparison seems to depend on the details of the platform, the version
of @code{man} in use, etc, but times are similar and WoMan is never
significantly slower than @code{man}. This is despite the fact that
WoMan is running byte code whereas most of the formatting done by
@code{man} uses machine code, and is a testimony to the quality of the
Emacs Lisp system.
debugging purposes.
@code{NROFF} simulates non-@acronym{ASCII} characters by using one or more
@code{nroff} simulates non-@acronym{ASCII} characters by using one or more
@acronym{ASCII} characters. WoMan should be able to do much better than
this. I have recently begun to add support for WoMan to use more of the
characters in its default font and to use a symbol font, and it is an
aspect that I intend to develop further in the near future. It should
be possible to move WoMan from an emulation of @code{NROFF} to an
emulation of @code{TROFF} as GNU Emacs moves to providing bit-mapped
be possible to move WoMan from an emulation of @code{nroff} to an
emulation of @code{troff} as GNU Emacs moves to providing bit-mapped
display facilities.
@c ===================================================================
@node Installation, Finding, Background, Top
@comment node-name, next, previous, up
@chapter Installation and Setup
@cindex installation
@cindex setup
No installation is necessary if you just want to run the version of
WoMan distributed with GNU Emacs 21 or later, although some additional
setup may still be desirable.
If you are installing @file{woman.el}, either to update the version
distributed with GNU Emacs or because WoMan was not distributed with
your version of Emacs, then you need to put the file in a directory in
your Emacs load path and byte compile it. A good directory to use is
the @file{site-lisp} directory in your Emacs file tree, e.g.@:
@file{/usr/local/share/emacs/@var{version}/site-lisp/} (where
@var{version} is your Emacs version), provided you have write access to
it. If you use a directory that is not included by default in your
Emacs load path then you need to add something like this to your
@file{.emacs} initialization file:
@lisp
(add-to-list 'load-path "my-lisp")
@end lisp
@noindent
where @file{my-lisp} is the pathname of the directory. @xref{Init File, ,
The Init File ~/.emacs, emacs, The Emacs Editor}, for further details on
customizing Emacs in general.
You can byte-compile the file by using the Emacs command
@code{byte-compile-file} or by opening the directory containing the
file, putting point on it and pressing the key @kbd{B}. (In fact, if
the file is compiled then it is only the compiled file that needs to be
in the Emacs load path, but leaving the source file there will do no
harm.)
@heading Setup
Setup that is either necessary or desirable consists of adding a small
amount of Emacs Lisp code to your @file{.emacs} initialization file. It
may be necessary (or at least convenient) to make WoMan autoload (if you
are not running GNU Emacs 21 or later) and to set the search path used
by the @code{woman} interface. You may also find it convenient to make
various WoMan menu and key bindings available and to make WoMan
customizable even before WoMan has been loaded.
It is possible to run WoMan from a command line (from outside or even
from inside Emacs) by suitably configuring your command interpreter.
@menu
* Autoloading:: Autoloading
* Search Path:: Search Path
* Auto Bindings:: Preloading Menu and Key Bindings
* Auto Customization:: Preloading Customization
* Command Line:: Command Line Access
@end menu
@node Autoloading, Search Path, Installation, Installation
@comment node-name, next, previous, up
@section Autoloading
@cindex autoloading
If you are not running GNU Emacs 21 or later then you are recommended to
add these autoloads to your @file{.emacs} file:
@lisp
(autoload 'woman "woman"
"Decode and browse a Unix man page." t)
(autoload 'woman-find-file "woman"
"Find, decode and browse a specific Unix man-page file." t)
(autoload 'woman-dired-find-file "woman"
"In dired, run the WoMan man-page browser on this file." t)
@end lisp
@noindent
(In GNU Emacs 21 and later these autoloads are predefined.)
@node Search Path, Auto Bindings, Autoloading, Installation
@comment node-name, next, previous, up
@section Search Path
@cindex search path
The next step is necessary if you want to use the friendliest WoMan
interface, which is recommended in general. If the @code{MANPATH}
environment variable is set then WoMan will use it; alternatively (or
additionally), if your platform uses a man configuration file (as do
many versions of Linux) then WoMan will use it, provided it can find it.
(This may need configuration. @xref{Interface Options, , Interface
Options}.) If these mechanisms correctly define the search path for man
pages then no further action is required.
Otherwise you may need to customize the user option
@code{woman-manpath}, and you may also want to customize the user option
@code{woman-path}. @xref{Customization, , Customization}. Now you can
execute the extended command @code{woman} and enter or select a manual
topic using completion, and if necessary select a filename, again using
completion. By default, WoMan suggests the word nearest to point in the
current buffer as the topic.
@node Auto Bindings, Auto Customization, Search Path, Installation
@comment node-name, next, previous, up
@section Preloading Menu and Key Bindings
@cindex preloading menu and key bindings
@cindex menu bindings, preloading
@cindex key bindings, preloading
@cindex bindings, preloading
Once WoMan is loaded it adds an item to the @samp{Help} menu and defines
one or more keys in dired mode to run WoMan on the current file. If you
would like these facilities always to be available, even before WoMan is
loaded, then add the following to your @file{.emacs} file:
@lisp
(define-key-after menu-bar-manuals-menu [woman]
'(menu-item "Read Man Page (WoMan)..." woman
:help "Man-page documentation Without Man") t)
(add-hook 'dired-mode-hook
(lambda ()
(define-key dired-mode-map "W" 'woman-dired-find-file)))
@end lisp
(By default, WoMan will automatically define the dired keys @kbd{W} and
@kbd{w} when it loads, but only if they are not already defined. This
behavior is controlled by the user option @code{woman-dired-keys}.
Note that the @code{dired-x} (dired extra) package binds
@code{dired-copy-filename-as-kill} to the key @kbd{w}, although @kbd{W}
appears to be unused. The @code{dired-x} package will over-write the
WoMan binding for @kbd{w}, whereas (by default) WoMan will not overwrite
the @code{dired-x} binding.)
@node Auto Customization, Command Line, Auto Bindings, Installation
@comment node-name, next, previous, up
@section Preloading Customization
@cindex preloading customization
@cindex customization, preloading
WoMan supports the GNU Emacs 20+ customization facility, and puts a
customization group called @code{WoMan} in the @code{Help} group under
the top-level @code{Emacs} group. In order to be able to customize
WoMan without first loading it, add the following to your @file{.emacs}
file:
@lisp
(defgroup woman nil
"Browse UNIX manual pages `wo (without) man'."
:tag "WoMan" :group 'help :load "woman")
@end lisp
@node Command Line, , Auto Customization, Installation
@comment node-name, next, previous, up
@section Command Line Access
@cindex command line access
If you really want to square the man-woman circle then you can! If you
run the GNU command interpreter @code{bash} then you might care to
define the following @code{bash} function in your @code{bash}
initialization file @file{.bashrc}:
@example
man() @{ gnudoit -q '(raise-frame (selected-frame)) (woman' \"$1\" ')' ; @}
@end example
If you use a Microsoft command interpreter (@file{command.com} or
@file{cmd.exe}) then you can create a file called @file{man.bat}
somewhere in your path containing the two lines:
@example
@@echo off
gnudoit -q (raise-frame (selected-frame)) (woman \"%1\")
@end example
and then (e.g.@: from a command prompt or the @samp{Run...} option in the
Windows @samp{Start} menu) just execute
@example
man man_page_name
@end example
(Of course, if you already have a @code{man} command installed then you
could call these commands @code{woman} instead of @code{man}.)
The above examples assume that you have the @code{gnuserv} Emacs
client-server package installed (which I recommend). It would be
possible to do something similar by calling Emacs directly, but that is
less satisfactory, because you are likely to end up with multiple copies
of Emacs running, which is generally inelegant, inefficient and
inconvenient. If you run a different command interpreter then something
similar to the above suggestions should be possible.
@c ===================================================================
@node Finding, Browsing, Installation, Top
@node Finding, Browsing, Background, Top
@comment node-name, next, previous, up
@chapter Finding and Formatting Man Pages
@cindex using, finding man pages
@ -572,19 +362,18 @@ setting WoMan file paths.
The topic interface is accessed principally via the command
@code{woman}. The same command can be accessed via the menu item
@samp{Help->Manuals->Read Man Page (WoMan)...} either once WoMan has been
loaded or if it is set up specially. @xref{Installation, , Installation
and Setup}. The command reads a manual topic in the minibuffer, which
can be the @dfn{basename} of a man file anywhere in the man file
structure. The ``basename'' in this context means the filename without
any directory component and without any extension or suffix components
that relate to the file type. So, for example, if there is a compressed
source file in Chapter 5 of the UNIX Programmer's Manual with the full
pathname @file{/usr/local/man/man5/man.conf.5.gz} then the topic is
@code{man.conf}. Provided WoMan is configured correctly, this topic
will appear among the completions offered by @code{woman}. If more than
one file has the same topic name then WoMan will prompt for which file
to format. Completion of topics is case insensitive.
@samp{Help->Manuals->Read Man Page (WoMan)...} once WoMan has been
loaded. The command reads a manual topic in the minibuffer, which can
be the @dfn{basename} of a man file anywhere in the man file
structure. The ``basename'' in this context means the filename
without any directory component and without any extension or suffix
components that relate to the file type. So, for example, if there is
a compressed source file in Chapter 5 of the UNIX Programmer's Manual
with the full pathname @file{/usr/local/man/man5/man.conf.5.gz} then
the topic is @code{man.conf}. Provided WoMan is configured correctly,
this topic will appear among the completions offered by @code{woman}.
If more than one file has the same topic name then WoMan will prompt
for which file to format. Completion of topics is case insensitive.
Clearly, @code{woman} has to know where to look for man files and there
are two customizable user options that store this information:
@ -834,7 +623,7 @@ blank lines squeezed to a single blank line.
@cindex fonts
@cindex faces
Fonts used by @code{ROFF} are handled by WoMan as faces, the details of
Fonts used by @code{roff} are handled by WoMan as faces, the details of
which are customizable. @xref{Faces, , Faces}. WoMan supports both the
italic and bold fonts normally used in man pages, together with a single
face to represent all unknown fonts (which are occasionally used in
@ -1070,15 +859,12 @@ is distributed with GNU Emacs.
@chapter Customization
@cindex customization
All WoMan user options are customizable, and it is recommended to change
them only via the standard Emacs customization facilities. WoMan
defines a top-level customization group called @code{WoMan} under the
parent group @code{Help}. The WoMan customization group is available
only once WoMan has been loaded unless it is specially set up to be
automatically available. @xref{Auto Customization, , Preloading
Customization}. It can be accessed either via the standard Emacs
facilities, e.g.@: via the @samp{Help->Customize} submenu, or via the
WoMan major mode menu.
All WoMan user options are customizable, and it is recommended to
change them only via the standard Emacs customization facilities.
WoMan defines a top-level customization group called @code{WoMan}
under the parent group @code{Help}. It can be accessed either via the
standard Emacs facilities, e.g.@: via the @samp{Help->Customize}
submenu, or via the WoMan major mode menu.
The top-level WoMan group contains only a few general options and three
subgroups. The hooks are provided only for special purposes that, for
@ -1385,7 +1171,7 @@ headings. Default is @code{t}. [Heading emboldening is @emph{not} standard
@item woman-ignore
A boolean value. If non-@code{nil} then unrecognised requests etc. are
ignored. Default is @code{t}. This gives the standard @code{ROFF} behavior.
ignored. Default is @code{t}. This gives the standard @code{roff} behavior.
If @code{nil} then they are left in the buffer, which may aid debugging.
@item woman-preserve-ascii
@ -1395,8 +1181,8 @@ WoMan buffer. Otherwise, non-@acronym{ASCII} characters (that display as
saved to a file. Default is @code{nil}.
@item woman-emulation
WoMan emulation, currently either @code{NROFF} or @code{TROFF}. Default
is @code{NROFF}. @code{TROFF} emulation is experimental and largely
WoMan emulation, currently either @code{nroff} or @code{troff}. Default
is @code{nroff}. @code{troff} emulation is experimental and largely
untested.
@end vtable
@ -1417,8 +1203,8 @@ either colors or different fonts.
@item woman-italic-face
Face for italic font in man pages. Default: italic, underlined,
foreground red. This is overkill! @code{TROFF} uses just italic;
@code{NROFF} uses just underline. You should probably select either
foreground red. This is overkill! @code{troff} uses just italic;
@code{nroff} uses just underline. You should probably select either
italic or underline as you prefer, but not both, although italic and
underline work together perfectly well!
@ -1494,7 +1280,7 @@ At present, all warnings should be treated with some suspicion.
Uninterpreted escape sequences are also logged (in some cases).
By resetting the variable @code{woman-ignore} to @code{nil} (by default
it is @code{t}), uninterpreted @code{ROFF} requests can optionally be
it is @code{t}), uninterpreted @code{roff} requests can optionally be
left in the formatted buffer to indicate precisely where they occurred.
@xref{Interface Options, , Interface Options}.
@ -1514,7 +1300,7 @@ left in the formatted buffer to indicate precisely where they occurred.
WoMan currently assumes 10 characters per inch horizontally, hence a
horizontal resolution of 24 basic units, and 5 lines per inch
vertically, hence a vertical resolution of 48 basic units.
(@code{NROFF} uses 240 per inch.)
(@code{nroff} uses 240 per inch.)
@heading Vertical spacing and blank lines

View File

@ -1,3 +1,8 @@
2006-10-29 Juanma Barranquero <lekktu@gmail.com>
* runemacs.c (WinMain): Process all recognized arguments, not just
the first one. Remove unused variable sec_desc.
2006-09-24 Eli Zaretskii <eliz@gnu.org>
* config.nt (HAVE_LANGINFO_CODESET): Define.
@ -63,7 +68,7 @@
2005-07-30 Eli Zaretskii <eliz@gnu.org>
* config.nt: (HAVE_GETOPT_H, HAVE_GETOPT_LONG_ONLY): Undefine.
* config.nt (HAVE_GETOPT_H, HAVE_GETOPT_LONG_ONLY): Undefine.
2005-07-29 Juanma Barranquero <lekktu@gmail.com>
@ -437,7 +442,7 @@
2001-03-26 Eli Zaretskii <eliz@is.elta.co.il>
* configure.bat: Make the checkw32api* labels be distinct in the
first 8 characters.
first 8 characters.
2001-03-17 Andrew Innes <andrewi@gnu.org>

View File

@ -6,8 +6,8 @@ Emacs ICON icons\emacs.ico
#endif
VS_VERSION_INFO VERSIONINFO
FILEVERSION 22,0,50,0
PRODUCTVERSION 22,0,50,0
FILEVERSION 22,0,90,0
PRODUCTVERSION 22,0,90,0
FILEFLAGSMASK 0x3FL
#ifdef EMACSDEBUG
FILEFLAGS 0x1L
@ -24,12 +24,12 @@ BEGIN
BEGIN
VALUE "CompanyName", "Free Software Foundation\0"
VALUE "FileDescription", "GNU Emacs for Windows NT/95/98/2000/ME/XP\0"
VALUE "FileVersion", "22, 0, 50, 0\0"
VALUE "FileVersion", "22, 0, 90, 0\0"
VALUE "InternalName", "Emacs\0"
VALUE "LegalCopyright", "Copyright (C) 2002, 2003, 2004, 2005, 2006\0"
VALUE "OriginalFilename", "emacs.exe"
VALUE "ProductName", "Emacs: The extensible self-documenting text editor\0"
VALUE "ProductVersion", "22, 0, 50, 0\0"
VALUE "ProductVersion", "22, 0, 90, 0\0"
VALUE "OLESelfRegister", "\0"
END
END

View File

@ -33,7 +33,7 @@ Boston, MA 02110-1301, USA. */
is running emacs.exe already, you cannot install a newer version.
By defining CHOOSE_NEWEST_EXE, you can name your new emacs.exe
something else which matches "emacs*.exe", and runemacs will
automatically select the newest emacs executeable in the bin directory.
automatically select the newest emacs executable in the bin directory.
(So you'll probably be able to delete the old version some hours/days
later).
*/
@ -49,7 +49,6 @@ WinMain (HINSTANCE hSelf, HINSTANCE hPrev, LPSTR cmdline, int nShow)
{
STARTUPINFO start;
SECURITY_ATTRIBUTES sec_attrs;
SECURITY_DESCRIPTOR sec_desc;
PROCESS_INFORMATION child;
int wait_for_child = FALSE;
DWORD priority_class = NORMAL_PRIORITY_CLASS;
@ -85,13 +84,13 @@ WinMain (HINSTANCE hSelf, HINSTANCE hPrev, LPSTR cmdline, int nShow)
goto error;
do
{
if (wfd.ftLastWriteTime.dwHighDateTime > best_time.dwHighDateTime
|| (wfd.ftLastWriteTime.dwHighDateTime == best_time.dwHighDateTime
&& wfd.ftLastWriteTime.dwLowDateTime > best_time.dwLowDateTime))
{
best_time = wfd.ftLastWriteTime;
strcpy (best_name, wfd.cFileName);
}
if (wfd.ftLastWriteTime.dwHighDateTime > best_time.dwHighDateTime
|| (wfd.ftLastWriteTime.dwHighDateTime == best_time.dwHighDateTime
&& wfd.ftLastWriteTime.dwLowDateTime > best_time.dwLowDateTime))
{
best_time = wfd.ftLastWriteTime;
strcpy (best_name, wfd.cFileName);
}
}
while (FindNextFile (fh, &wfd));
FindClose (fh);
@ -109,9 +108,9 @@ WinMain (HINSTANCE hSelf, HINSTANCE hPrev, LPSTR cmdline, int nShow)
{
if (strncmp (cmdline+1, "wait", 4) == 0)
{
wait_for_child = TRUE;
cmdline += 5;
}
wait_for_child = TRUE;
cmdline += 5;
}
else if (strncmp (cmdline+1, "high", 4) == 0)
{
priority_class = HIGH_PRIORITY_CLASS;
@ -124,7 +123,10 @@ WinMain (HINSTANCE hSelf, HINSTANCE hPrev, LPSTR cmdline, int nShow)
}
else
break;
/* Look for next argument. */
while (*++cmdline == ' ');
}
strcat (new_cmdline, cmdline);
/* Set emacs_dir variable if runemacs was in "%emacs_dir%\bin". */

View File

@ -1,3 +1,90 @@
2006-10-29 Mark Davies <mark@mcs.vuw.ac.nz> (tiny change)
* ralloc.c (relinquish): Use a long for excess space counter to
handle 64-bit case correctly.
2006-10-29 Jeramey Crawford <jeramey@jeramey.com>
* m/amdx86-64.h: Add defines for OpenBSD x86-64.
2006-10-29 Juanma Barranquero <lekktu@gmail.com>
* window.c (Fdisplay_buffer): Fix typo in docstring.
2006-10-27 Ben North <ben@redfrontdoor.org> (tiny change)
* w32term.c (x_draw_glyph_string_foreground): Set background mode
to TRANSPARENT before using overstrike to simulate bold faces.
* xfaces.c (best_matching_font): Fix logic to decide whether to
use overstriking to simulate bold-face (it was reversed).
2006-10-23 Kim F. Storm <storm@cua.dk>
* xdisp.c (remember_mouse_glyph): Do nothing if glyphs are not
initialized.
* keyboard.c (read_char): Make an element (t . EVENT) in
unread-command-events add EVENT to the current command's key sequence.
(syms_of_keyboard) <unread-command-events>: Update doc.
2006-10-21 Richard Stallman <rms@gnu.org>
* minibuf.c (Vread_expression_map): Define here.
(Qread_expression_history): New variable.
(syms_of_minibuf): Initialize them.
(Feval_minibuffer): Use Vread_expression_map and
Qread_expression_history.
2006-10-21 Kenichi Handa <handa@m17n.org>
* xfns.c (xic_create_fontsetname): If ADSTYLE field is not a wild
card, change it to "*".
(xic_create_xfontset): Call XCreateFontSet for each single
fontname in fontsetname.
2006-10-19 Chong Yidong <cyd@stupidchicken.com>
* callint.c (callint_message): Convert to a Lisp string.
(syms_of_callint): Initialize it.
(callint_message_size): Var deleted.
(Fcall_interactively): Use Fformat instead of doprnt to construct
prompt string.
2006-10-19 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
* xdisp.c (display_mode_line): Clear enabled_p flag on mode-line row.
2006-10-19 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
* macfns.c (Vmac_carbon_version_string) [TARGET_API_MAC_CARBON]:
New variable.
(syms_of_macfns) [TARGET_API_MAC_CARBON]: Defvar it.
2006-10-19 Jan Dj,Ad(Brv <jan.h.d@swipnet.se>
* xselect.c (x_handle_selection_request): If the converted_selection
is NIL or XCDR (converted_selection) is NIL, decline the request.
2006-10-16 Jan Dj,Ad(Brv <jan.h.d@swipnet.se>
* gtkutil.c (get_utf8_string): Remove warnings with casts.
(xg_tool_bar_button_cb): Ditto
(xg_tool_bar_callback): Ditto.
2006-10-16 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
* dispnew.c (adjust_frame_glyphs_for_frame_redisplay): Remove unused
variable ch_dim.
(adjust_frame_glyphs_for_window_redisplay): Likewise. Don't allocate
menu bar window matrices on non-X systems.
* mac.c (Fmac_get_preference, Fmac_code_convert_string): Add GCPROs.
* macterm.c (mac_query_char_extents): Don't return glyph ID if layout
adjustment is needed.
(mac_load_query_font): Check if width and height are positive.
2006-10-14 Richard Stallman <rms@gnu.org>
* sysdep.c (init_sys_modes): Delete DEFVAR_LISP in the wrong place.
@ -48,8 +135,8 @@
(x_draw_glyph_string_foreground): Use overstrike when needed.
(x_draw_composite_glyph_string_foreground): Likewise.
Use mac_draw_image_string_16 instead of mac_draw_string_16.
(mac_load_query_font): Rename from XLoadQueryFont. Take argument F
instead of DPY. All uses changed. Don't save/restore font.
(mac_load_query_font): Rename from XLoadQueryFont. Take argument
F instead of DPY. All uses changed. Don't save/restore font.
2006-10-07 Ralf Angeli <angeli@caeruleus.net>
@ -92,7 +179,7 @@
2006-09-30 Eli Zaretskii <eliz@gnu.org>
* config.in Regenerated.
* config.in: Regenerated.
2006-09-29 Juri Linkov <juri@jurta.org>
@ -357,7 +444,7 @@
avoid confusing redisplay by placing the cursor outside the visible
window area.
2006-09-13 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
2006-09-13 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
* xterm.c (x_initialize): Don't install Xt event timer here.
(x_timeout_atimer_activated_flag): New var.
@ -2102,7 +2189,7 @@
* xdisp.c (display_tool_bar_line): Restore entire tool-bar
geometry when backtracking in case last image doesn't fit on line.
2006-05-18 MIYOSHI Masanori <miyoshi@meadowy.org> (tiny change)
2006-05-18 MIYOSHI Masanori <miyoshi@meadowy.org> (tiny change)
* xdisp.c (display_tool_bar_line): Don't adjust tool-bar height by
more than height of one frame default line.

View File

@ -58,11 +58,8 @@ static Lisp_Object preserved_fns;
/* Marker used within call-interactively to refer to point. */
static Lisp_Object point_marker;
/* Buffer for the prompt text used in Fcall_interactively. */
static char *callint_message;
/* Allocated length of that buffer. */
static int callint_message_size;
/* String for the prompt text used in Fcall_interactively. */
static Lisp_Object callint_message;
/* ARGSUSED */
DEFUN ("interactive", Finteractive, Sinteractive, 0, UNEVALLED, 0,
@ -266,7 +263,6 @@ invoke it. If KEYS is omitted or nil, the return value of
Lisp_Object function, record_flag, keys;
{
Lisp_Object *args, *visargs;
unsigned char **argstrings;
Lisp_Object fun;
Lisp_Object specs;
Lisp_Object filter_specs;
@ -492,7 +488,6 @@ invoke it. If KEYS is omitted or nil, the return value of
args = (Lisp_Object *) alloca ((count + 1) * sizeof (Lisp_Object));
visargs = (Lisp_Object *) alloca ((count + 1) * sizeof (Lisp_Object));
argstrings = (unsigned char **) alloca ((count + 1) * sizeof (char *));
varies = (int *) alloca ((count + 1) * sizeof (int));
for (i = 0; i < (count + 1); i++)
@ -516,34 +511,17 @@ invoke it. If KEYS is omitted or nil, the return value of
prompt1[sizeof prompt1 - 1] = 0;
tem1 = (char *) index (prompt1, '\n');
if (tem1) *tem1 = 0;
/* Fill argstrings with a vector of C strings
corresponding to the Lisp strings in visargs. */
for (j = 1; j < i; j++)
argstrings[j]
= (EQ (visargs[j], Qnil)
? (unsigned char *) ""
: SDATA (visargs[j]));
/* Process the format-string in prompt1, putting the output
into callint_message. Make callint_message bigger if necessary.
We don't use a buffer on the stack, because the contents
need to stay stable for a while. */
while (1)
{
int nchars = doprnt (callint_message, callint_message_size,
prompt1, (char *)0,
j - 1, (char **) argstrings + 1);
if (nchars < callint_message_size - 1)
break;
callint_message_size *= 2;
callint_message
= (char *) xrealloc (callint_message, callint_message_size);
}
visargs[0] = build_string (prompt1);
if (index (prompt1, '%'))
callint_message = Fformat (i, visargs);
else
callint_message = visargs[0];
switch (*tem)
{
case 'a': /* Symbol defined as a function */
visargs[i] = Fcompleting_read (build_string (callint_message),
visargs[i] = Fcompleting_read (callint_message,
Vobarray, Qfboundp, Qt,
Qnil, Qnil, Qnil, Qnil);
/* Passing args[i] directly stimulates compiler bug */
@ -555,17 +533,17 @@ invoke it. If KEYS is omitted or nil, the return value of
args[i] = Fcurrent_buffer ();
if (EQ (selected_window, minibuf_window))
args[i] = Fother_buffer (args[i], Qnil, Qnil);
args[i] = Fread_buffer (build_string (callint_message), args[i], Qt);
args[i] = Fread_buffer (callint_message, args[i], Qt);
break;
case 'B': /* Name of buffer, possibly nonexistent */
args[i] = Fread_buffer (build_string (callint_message),
args[i] = Fread_buffer (callint_message,
Fother_buffer (Fcurrent_buffer (), Qnil, Qnil),
Qnil);
break;
case 'c': /* Character */
args[i] = Fread_char (build_string (callint_message), Qnil, Qnil);
args[i] = Fread_char (callint_message, Qnil, Qnil);
message1_nolog ((char *) 0);
/* Passing args[i] directly stimulates compiler bug */
teml = args[i];
@ -573,7 +551,7 @@ invoke it. If KEYS is omitted or nil, the return value of
break;
case 'C': /* Command: symbol with interactive function */
visargs[i] = Fcompleting_read (build_string (callint_message),
visargs[i] = Fcompleting_read (callint_message,
Vobarray, Qcommandp,
Qt, Qnil, Qnil, Qnil, Qnil);
/* Passing args[i] directly stimulates compiler bug */
@ -589,24 +567,24 @@ invoke it. If KEYS is omitted or nil, the return value of
break;
case 'D': /* Directory name. */
args[i] = Fread_file_name (build_string (callint_message), Qnil,
args[i] = Fread_file_name (callint_message, Qnil,
current_buffer->directory, Qlambda, Qnil,
Qfile_directory_p);
break;
case 'f': /* Existing file name. */
args[i] = Fread_file_name (build_string (callint_message),
args[i] = Fread_file_name (callint_message,
Qnil, Qnil, Qlambda, Qnil, Qnil);
break;
case 'F': /* Possibly nonexistent file name. */
args[i] = Fread_file_name (build_string (callint_message),
args[i] = Fread_file_name (callint_message,
Qnil, Qnil, Qnil, Qnil, Qnil);
break;
case 'G': /* Possibly nonexistent file name,
default to directory alone. */
args[i] = Fread_file_name (build_string (callint_message),
args[i] = Fread_file_name (callint_message,
Qnil, Qnil, Qnil, build_string (""), Qnil);
break;
@ -618,7 +596,7 @@ invoke it. If KEYS is omitted or nil, the return value of
{
int speccount1 = SPECPDL_INDEX ();
specbind (Qcursor_in_echo_area, Qt);
args[i] = Fread_key_sequence (build_string (callint_message),
args[i] = Fread_key_sequence (callint_message,
Qnil, Qnil, Qnil, Qnil);
unbind_to (speccount1, Qnil);
teml = args[i];
@ -646,7 +624,7 @@ invoke it. If KEYS is omitted or nil, the return value of
{
int speccount1 = SPECPDL_INDEX ();
specbind (Qcursor_in_echo_area, Qt);
args[i] = Fread_key_sequence (build_string (callint_message),
args[i] = Fread_key_sequence (callint_message,
Qnil, Qt, Qnil, Qnil);
teml = args[i];
visargs[i] = Fkey_description (teml, Qnil);
@ -706,7 +684,7 @@ invoke it. If KEYS is omitted or nil, the return value of
case 'M': /* String read via minibuffer with
inheriting the current input method. */
args[i] = Fread_string (build_string (callint_message),
args[i] = Fread_string (callint_message,
Qnil, Qnil, Qnil, Qt);
break;
@ -726,7 +704,7 @@ invoke it. If KEYS is omitted or nil, the return value of
}
first = 0;
tem = Fread_from_minibuffer (build_string (callint_message),
tem = Fread_from_minibuffer (callint_message,
Qnil, Qnil, Qnil, Qnil, Qnil,
Qnil);
if (! STRINGP (tem) || SCHARS (tem) == 0)
@ -736,7 +714,7 @@ invoke it. If KEYS is omitted or nil, the return value of
}
while (! NUMBERP (args[i]));
}
visargs[i] = last_minibuf_string;
visargs[i] = args[i];
break;
case 'P': /* Prefix arg in raw form. Does no I/O. */
@ -766,12 +744,12 @@ invoke it. If KEYS is omitted or nil, the return value of
case 's': /* String read via minibuffer without
inheriting the current input method. */
args[i] = Fread_string (build_string (callint_message),
args[i] = Fread_string (callint_message,
Qnil, Qnil, Qnil, Qnil);
break;
case 'S': /* Any symbol. */
visargs[i] = Fread_string (build_string (callint_message),
visargs[i] = Fread_string (callint_message,
Qnil, Qnil, Qnil, Qnil);
/* Passing args[i] directly stimulates compiler bug */
teml = visargs[i];
@ -780,17 +758,17 @@ invoke it. If KEYS is omitted or nil, the return value of
case 'v': /* Variable name: symbol that is
user-variable-p. */
args[i] = Fread_variable (build_string (callint_message), Qnil);
args[i] = Fread_variable (callint_message, Qnil);
visargs[i] = last_minibuf_string;
break;
case 'x': /* Lisp expression read but not evaluated */
args[i] = Fread_minibuffer (build_string (callint_message), Qnil);
args[i] = Fread_minibuffer (callint_message, Qnil);
visargs[i] = last_minibuf_string;
break;
case 'X': /* Lisp expression read and evaluated */
args[i] = Feval_minibuffer (build_string (callint_message), Qnil);
args[i] = Feval_minibuffer (callint_message, Qnil);
visargs[i] = last_minibuf_string;
break;
@ -804,13 +782,13 @@ invoke it. If KEYS is omitted or nil, the return value of
else
{
args[i]
= Fread_non_nil_coding_system (build_string (callint_message));
= Fread_non_nil_coding_system (callint_message);
visargs[i] = last_minibuf_string;
}
break;
case 'z': /* Coding-system symbol or nil */
args[i] = Fread_coding_system (build_string (callint_message), Qnil);
args[i] = Fread_coding_system (callint_message, Qnil);
visargs[i] = last_minibuf_string;
break;
@ -915,6 +893,9 @@ syms_of_callint ()
point_marker = Fmake_marker ();
staticpro (&point_marker);
callint_message = Qnil;
staticpro (&callint_message);
preserved_fns = Fcons (intern ("region-beginning"),
Fcons (intern ("region-end"),
Fcons (intern ("point"),
@ -954,10 +935,6 @@ syms_of_callint ()
Qmouse_leave_buffer_hook = intern ("mouse-leave-buffer-hook");
staticpro (&Qmouse_leave_buffer_hook);
callint_message_size = 100;
callint_message = (char *) xmalloc (callint_message_size);
DEFVAR_KBOARD ("prefix-arg", Vprefix_arg,
doc: /* The value of the prefix argument for the next editing command.
It may be a number, or the symbol `-' for just a minus sign as arg,

Some files were not shown because too many files have changed in this diff Show More