diff -Nrc2 readline-4.1/CHANGELOG readline-4.2/CHANGELOG *** readline-4.1/CHANGELOG Fri Feb 4 12:30:39 2000 --- readline-4.2/CHANGELOG Fri Apr 6 15:15:12 2001 *************** *** 338,339 **** --- 338,465 ---- configure.in - changed LIBVERSION to 4.1-beta5 + + 3/17/2000 + --------- + [readline-4.1 released] + + 3/23 + ---- + Makefile.in + - remove the `-t' argument to ranlib in the install recipe; some + ranlibs don't have it and attempt to create a file named `-t' + + 3/27 + ---- + support/shlib-install + - install shared libraries unwritable by anyone on HP-UX + - changed symlinks to relative pathnames on all platforms + + shlib/Makefile.in + - added missing `includedir' assignment, substituted by configure + + Makefile.in + - added missing @SET_MAKE@ so configure can set $MAKE appropriately + + configure.in + - add call to AC_PROG_MAKE_SET + + 8/30 + ---- + shlib/Makefile.in + - change the soname bound into the shared libraries, so it includes + only the major version number. If it includes the minor version, + programs depending on it must be rebuilt (which may or may not be + a bad thing) + + 9/6 + --- + examples/rlfe.c + - add -l option to log input and output (-a option appends to logfile) + - add -n option to set readline application name + - add -v, -h options for version and help information + - change a few things because getopt() is now used to parse arguments + + 9/12 + ---- + support/shlib-install + - fix up the libname on HPUX 11 + + 10/18 + ----- + configure.in + - changed library version to 4.2-alpha + + 10/30 + ----- + configure.in + - add -fsigned-char to LOCAL_CFLAGS for Linux running on the IBM + S/390 + + Makefile.in + - added new file, rltypedefs.h, installed by default with `make install' + + 11/2 + ---- + compat.c + - new file, with backwards-compatibility function definitions + + Makefile.in,shlib/Makefile.in + - make sure that compat.o/compat.so are built and linked apppropriately + + support/shobj-conf + - picked up bash version, which means that shared libs built on + linux and BSD/OS 4.x will have an soname that does not include + the minor version number + + 11/13 + ----- + examples/rlfe.c + - rlfe can perform filename completion for relative pathnames in the + inferior process's context if the OS supports /proc/PID/cwd (linux + does it OK, Solaris is slightly warped, none of the BSDs have it) + + 11/17/2000 + ---------- + [readline-4.2-alpha released] + + 11/27 + ----- + Makefile.in,shlib/Makefile.in + - added dependencies for rltypedefs.h + + shlib/Makefile.in + - changed dependencies on histlib.h to $(topdir)/histlib.h + + 1/22 + ---- + configure.in + - changed release version to 4.2-beta + + 2/2 + --- + examples/Makefile.in + - build histexamp as part of the examples + + 2/5 + --- + doc/Makefile.in + - don't remove the dvi, postscript, html, info, and text `objects' + on a `make distclean', only on a `make maintainer-clean' + + 3/6 + --- + doc/history.{0,3}, doc/history_3.ps + - new manual page for history library + + doc/Makefile.in + - rules to install and uninstall history.3 in ${man3dir} + - rules to build history.0 and history_3.ps + + 4/2 + --- + configure.in + - changed LIBVERSION to `4.2' + + 4/5 + --- + [readline-4.2 frozen] diff -Nrc2 readline-4.1/CHANGES readline-4.2/CHANGES *** readline-4.1/CHANGES Wed Sep 22 12:07:50 1999 --- readline-4.2/CHANGES Tue Apr 3 10:34:07 2001 *************** *** 1,2 **** --- 1,155 ---- + This document details the changes between this version, readline-4.2, + and the previous version, readline-4.1. + + 1. Changes to Readline + + a. When setting the terminal attributes on systems using `struct termio', + readline waits for output to drain before changing the attributes. + + b. A fix was made to the history word tokenization code to avoid attempts to + dereference a null pointer. + + c. Readline now defaults rl_terminal_name to $TERM if the calling application + has left it unset, and tries to initialize with the resultant value. + + d. Instead of calling (*rl_getc_function)() directly to get input in certain + places, readline now calls rl_read_key() consistently. + + e. Fixed a bug in the completion code that allowed a backslash to quote a + single quote inside a single-quoted string. + + f. rl_prompt is no longer assigned directly from the argument to readline(), + but uses memory allocated by readline. This allows constant strings to + be passed to readline without problems arising when the prompt processing + code wants to modify the string. + + g. Fixed a bug that caused non-interactive history searches to return the + wrong line when performing multiple searches backward for the same string. + + h. Many variables, function arguments, and function return values are now + declared `const' where appropriate, to improve behavior when linking with + C++ code. + + i. The control character detection code now works better on systems where + `char' is unsigned by default. + + j. The vi-mode numeric argument is now capped at 999999, just like emacs mode. + + k. The Function, CPFunction, CPPFunction, and VFunction typedefs have been + replaced with a set of specific prototyped typedefs, though they are + still in the readline header files for backwards compatibility. + + m. Nearly all of the (undocumented) internal global variables in the library + now have an _rl_ prefix -- there were a number that did not, like + screenheight, screenwidth, alphabetic, etc. + + n. The ding() convenience function has been renamed to rl_ding(), though the + old function is still defined for backwards compatibility. + + o. The completion convenience functions filename_completion_function, + username_completion_function, and completion_matches now have an rl_ + prefix, though the old names are still defined for backwards compatibility. + + p. The functions shared by readline and bash (linkage is satisfied from bash + when compiling with bash, and internally otherwise) now have an sh_ prefix. + + q. Changed the shared library creation procedure on Linux and BSD/OS 4.x so + that the `soname' contains only the major version number rather than the + major and minor numbers. + + r. Fixed a redisplay bug that occurred when the prompt spanned more than one + physical line and contained invisible characters. + + s. Added a missing `includedir' variable to the Makefile. + + t. When installing the shared libraries, make sure symbolic links are relative. + + u. Added configure test so that it can set `${MAKE}' appropriately. + + v. Fixed a bug in rl_forward that could cause the point to be set to before + the beginning of the line in vi mode. + + w. Fixed a bug in the callback read-char interface to make it work when a + readline function pushes some input onto the input stream with + rl_execute_next (like the incremental search functions). + + x. Fixed a file descriptor leak in the history file manipulation code that + was tripped when attempting to truncate a non-regular file (like + /dev/null). + + y. Changes to make all of the exported readline functions declared in + readline.h have an rl_ prefix (rltty_set_default_bindings is now + rl_tty_set_default_bindings, crlf is now rl_crlf, etc.) + + z. The formatted documentation included in the base readline distribution + is no longer removed on a `make distclean'. + + aa. Some changes were made to avoid gcc warnings with -Wall. + + bb. rl_get_keymap_by_name now finds keymaps case-insensitively, so + `set keymap EMACS' works. + + cc. The history file writing and truncation functions now return a useful + status on error. + + dd. Fixed a bug that could cause applications to dereference a NULL pointer + if a NULL second argument was passed to history_expand(). + + ee. If a hook function assigned to rl_event_hook sets rl_done to a non-zero + value, rl_read_key() now immediately returns '\n' (which is assumed to + be bound to accept-line). + + 2. New Features in Readline + + a. The blink timeout for paren matching is now settable by applications, + via the rl_set_paren_blink_timeout() function. + + b. _rl_executing_macro has been renamed to rl_executing_macro, which means + it's now part of the public interface. + + c. Readline has a new variable, rl_readline_state, which is a bitmap that + encapsulates the current state of the library; intended for use by + callbacks and hook functions. + + d. rlfe has a new -l option to log input and output (-a appends to logfile), + a new -n option to set the readline application name, and -v and -h + options for version and help information. + + e. rlfe can now perform filename completion for the inferior process if the + OS has a /proc//cwd that can be read with readlink(2) to get the + inferior's current working directory. + + f. A new file, rltypedefs.h, contains the new typedefs for function pointers + and is installed by `make install'. + + g. New application-callable function rl_set_prompt(const char *prompt): + expands its prompt string argument and sets rl_prompt to the result. + + h. New application-callable function rl_set_screen_size(int rows, int cols): + public method for applications to set readline's idea of the screen + dimensions. + + i. The history example program (examples/histexamp.c) is now built as one + of the examples. + + j. The documentation has been updated to cover nearly all of the public + functions and variables declared in readline.h. + + k. New function, rl_get_screen_size (int *rows, int *columns), returns + readline's idea of the screen dimensions. + + l. The timeout in rl_gather_tyi (readline keyboard input polling function) + is now settable via a function (rl_set_keyboard_input_timeout()). + + m. Renamed the max_input_history variable to history_max_entries; the old + variable is maintained for backwards compatibility. + + n. The list of characters that separate words for the history tokenizer is + now settable with a variable: history_word_delimiters. The default + value is as before. + + o. There is a new history.3 manual page documenting the history library. + + ------------------------------------------------------------------------------- This document details the changes between this version, readline-4.1, and the previous version, readline-4.0. diff -Nrc2 readline-4.1/MANIFEST readline-4.2/MANIFEST *** readline-4.1/MANIFEST Mon Sep 13 14:09:41 1999 --- readline-4.2/MANIFEST Mon Mar 5 14:34:36 2001 *************** *** 33,36 **** --- 33,37 ---- rlstdc.h f rltty.h f + rltypedefs.h f rlwinsize.h f tcap.h f *************** *** 38,41 **** --- 39,43 ---- xmalloc.h f bind.c f + compat.c f complete.c f display.c f *************** *** 86,89 **** --- 88,92 ---- doc/hsuser.texinfo f doc/readline.3 f + doc/history.3 f doc/texi2dvi f doc/texi2html f *************** *** 112,113 **** --- 115,119 ---- doc/rluserman.html f doc/readline.0 f + doc/history.0 f + doc/readline_3.ps f + doc/history_3.ps f diff -Nrc2 readline-4.1/Makefile.in readline-4.2/Makefile.in *** readline-4.1/Makefile.in Wed Dec 29 17:02:40 1999 --- readline-4.2/Makefile.in Mon Nov 27 11:57:09 2000 *************** *** 36,39 **** --- 36,40 ---- MV = mv + @SET_MAKE@ SHELL = @MAKE_SHELL@ *************** *** 66,70 **** INCLUDES = -I. -I$(srcdir) -I$(includedir) ! CCFLAGS = $(DEFS) $(LOCAL_DEFS) $(CPPFLAGS) $(INCLUDES) $(LOCAL_CFLAGS) $(CFLAGS) .c.o: --- 67,78 ---- INCLUDES = -I. -I$(srcdir) -I$(includedir) ! XCCFLAGS = $(DEFS) $(LOCAL_DEFS) $(CPPFLAGS) $(INCLUDES) ! CCFLAGS = $(XCCFLAGS) $(LOCAL_CFLAGS) $(CFLAGS) ! ! # could add -Werror here ! GCC_LINT_FLAGS = -ansi -Wall -Wshadow -Wpointer-arith -Wcast-qual \ ! -Wwrite-strings -Wstrict-prototypes \ ! -Wmissing-prototypes -Wno-implicit ! GCC_LINT_CFLAGS = $(XCCFLAGS) $(GCC_LINT_FLAGS) @CFLAGS@ @LOCAL_CFLAGS@ .c.o: *************** *** 86,95 **** $(srcdir)/history.c $(srcdir)/histsearch.c $(srcdir)/histexpand.c \ $(srcdir)/histfile.c $(srcdir)/nls.c $(srcdir)/search.c \ ! $(srcdir)/shell.c $(srcdir)/savestring.c $(srcdir)/tilde.c # The header files for this library. HSOURCES = readline.h rldefs.h chardefs.h keymaps.h history.h histlib.h \ posixstat.h posixdir.h posixjmp.h tilde.h rlconf.h rltty.h \ ! ansi_stdlib.h tcap.h rlstdc.h xmalloc.h rlprivate.h rlshell.h HISTOBJ = history.o histexpand.o histfile.o histsearch.o shell.o --- 94,105 ---- $(srcdir)/history.c $(srcdir)/histsearch.c $(srcdir)/histexpand.c \ $(srcdir)/histfile.c $(srcdir)/nls.c $(srcdir)/search.c \ ! $(srcdir)/shell.c $(srcdir)/savestring.c $(srcdir)/tilde.c \ ! $(srcdir)/compat.c # The header files for this library. HSOURCES = readline.h rldefs.h chardefs.h keymaps.h history.h histlib.h \ posixstat.h posixdir.h posixjmp.h tilde.h rlconf.h rltty.h \ ! ansi_stdlib.h tcap.h rlstdc.h xmalloc.h rlprivate.h rlshell.h \ ! rltypedefs.h HISTOBJ = history.o histexpand.o histfile.o histsearch.o shell.o *************** *** 98,102 **** rltty.o complete.o bind.o isearch.o display.o signals.o \ util.o kill.o undo.o macro.o input.o callback.o terminal.o \ ! nls.o xmalloc.o $(HISTOBJ) $(TILDEOBJ) # The texinfo files which document this library. --- 108,112 ---- rltty.o complete.o bind.o isearch.o display.o signals.o \ util.o kill.o undo.o macro.o input.o callback.o terminal.o \ ! nls.o compat.o xmalloc.o $(HISTOBJ) $(TILDEOBJ) # The texinfo files which document this library. *************** *** 112,116 **** INSTALLED_HEADERS = readline.h chardefs.h keymaps.h history.h tilde.h \ ! rlstdc.h rlconf.h ########################################################################## --- 122,126 ---- INSTALLED_HEADERS = readline.h chardefs.h keymaps.h history.h tilde.h \ ! rlstdc.h rlconf.h rltypedefs.h ########################################################################## *************** *** 135,138 **** --- 145,151 ---- $(CC) $(CCFLAGS) -o $@ ./examples/rl.c ./libreadline.a ${TERMCAP_LIB} + lint: force + $(MAKE) $(MFLAGS) CCFLAGS='$(GCC_LINT_CFLAGS)' static + Makefile makefile: config.status $(srcdir)/Makefile.in CONFIG_FILES=Makefile CONFIG_HEADERS= $(SHELL) ./config.status *************** *** 184,191 **** -$(MV) $(libdir)/libreadline.a $(libdir)/libreadline.old $(INSTALL_DATA) libreadline.a $(libdir)/libreadline.a ! -test -n "$(RANLIB)" && $(RANLIB) -t $(libdir)/libreadline.a -$(MV) $(libdir)/libhistory.a $(libdir)/libhistory.old $(INSTALL_DATA) libhistory.a $(libdir)/libhistory.a ! -test -n "$(RANLIB)" && $(RANLIB) -t $(libdir)/libhistory.a -( if test -d doc ; then \ cd doc && \ --- 197,204 ---- -$(MV) $(libdir)/libreadline.a $(libdir)/libreadline.old $(INSTALL_DATA) libreadline.a $(libdir)/libreadline.a ! -test -n "$(RANLIB)" && $(RANLIB) $(libdir)/libreadline.a -$(MV) $(libdir)/libhistory.a $(libdir)/libhistory.old $(INSTALL_DATA) libhistory.a $(libdir)/libhistory.a ! -test -n "$(RANLIB)" && $(RANLIB) $(libdir)/libhistory.a -( if test -d doc ; then \ cd doc && \ *************** *** 254,311 **** bind.o: ansi_stdlib.h posixstat.h bind.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! bind.o: readline.h keymaps.h chardefs.h tilde.h rlstdc.h bind.o: history.h callback.o: rlconf.h callback.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! callback.o: readline.h keymaps.h chardefs.h tilde.h rlstdc.h complete.o: ansi_stdlib.h posixdir.h posixstat.h complete.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! complete.o: readline.h keymaps.h chardefs.h tilde.h rlstdc.h display.o: ansi_stdlib.h posixstat.h display.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h display.o: tcap.h ! display.o: readline.h keymaps.h chardefs.h tilde.h display.o: history.h rlstdc.h ! funmap.o: readline.h keymaps.h chardefs.h tilde.h funmap.o: rlconf.h ansi_stdlib.h rlstdc.h funmap.o: ${BUILD_DIR}/config.h histexpand.o: ansi_stdlib.h ! histexpand.o: history.h histlib.h rlstdc.h histexpand.o: ${BUILD_DIR}/config.h histfile.o: ansi_stdlib.h ! histfile.o: history.h histlib.h rlstdc.h histfile.o: ${BUILD_DIR}/config.h history.o: ansi_stdlib.h ! history.o: history.h histlib.h rlstdc.h history.o: ${BUILD_DIR}/config.h histsearch.o: ansi_stdlib.h ! histsearch.o: history.h histlib.h rlstdc.h histsearch.o: ${BUILD_DIR}/config.h input.o: ansi_stdlib.h input.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! input.o: readline.h keymaps.h chardefs.h tilde.h rlstdc.h isearch.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! isearch.o: readline.h keymaps.h chardefs.h tilde.h isearch.o: ansi_stdlib.h history.h rlstdc.h keymaps.o: emacs_keymap.c vi_keymap.c ! keymaps.o: keymaps.h chardefs.h rlconf.h ansi_stdlib.h ! keymaps.o: readline.h keymaps.h chardefs.h tilde.h keymaps.o: ${BUILD_DIR}/config.h rlstdc.h kill.o: ansi_stdlib.h kill.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! kill.o: readline.h keymaps.h chardefs.h tilde.h kill.o: history.h rlstdc.h macro.o: ansi_stdlib.h macro.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! macro.o: readline.h keymaps.h chardefs.h tilde.h macro.o: history.h rlstdc.h nls.o: ansi_stdlib.h nls.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! nls.o: readline.h keymaps.h chardefs.h tilde.h nls.o: history.h rlstdc.h parens.o: rlconf.h parens.o: ${BUILD_DIR}/config.h ! parens.o: readline.h keymaps.h chardefs.h tilde.h rlstdc.h ! readline.o: readline.h keymaps.h chardefs.h tilde.h readline.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h readline.o: history.h rlstdc.h --- 267,325 ---- bind.o: ansi_stdlib.h posixstat.h bind.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! bind.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h rlstdc.h bind.o: history.h callback.o: rlconf.h callback.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! callback.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h rlstdc.h ! compat.o: rlstdc.h complete.o: ansi_stdlib.h posixdir.h posixstat.h complete.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! complete.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h rlstdc.h display.o: ansi_stdlib.h posixstat.h display.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h display.o: tcap.h ! display.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h display.o: history.h rlstdc.h ! funmap.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h funmap.o: rlconf.h ansi_stdlib.h rlstdc.h funmap.o: ${BUILD_DIR}/config.h histexpand.o: ansi_stdlib.h ! histexpand.o: history.h histlib.h rlstdc.h rltypedefs.h histexpand.o: ${BUILD_DIR}/config.h histfile.o: ansi_stdlib.h ! histfile.o: history.h histlib.h rlstdc.h rltypedefs.h histfile.o: ${BUILD_DIR}/config.h history.o: ansi_stdlib.h ! history.o: history.h histlib.h rlstdc.h rltypedefs.h history.o: ${BUILD_DIR}/config.h histsearch.o: ansi_stdlib.h ! histsearch.o: history.h histlib.h rlstdc.h rltypedefs.h histsearch.o: ${BUILD_DIR}/config.h input.o: ansi_stdlib.h input.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! input.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h rlstdc.h isearch.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! isearch.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h isearch.o: ansi_stdlib.h history.h rlstdc.h keymaps.o: emacs_keymap.c vi_keymap.c ! keymaps.o: keymaps.h rltypedefs.h chardefs.h rlconf.h ansi_stdlib.h ! keymaps.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h keymaps.o: ${BUILD_DIR}/config.h rlstdc.h kill.o: ansi_stdlib.h kill.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! kill.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h kill.o: history.h rlstdc.h macro.o: ansi_stdlib.h macro.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! macro.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h macro.o: history.h rlstdc.h nls.o: ansi_stdlib.h nls.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! nls.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h nls.o: history.h rlstdc.h parens.o: rlconf.h parens.o: ${BUILD_DIR}/config.h ! parens.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h rlstdc.h ! readline.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h readline.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h readline.o: history.h rlstdc.h *************** *** 313,328 **** rltty.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h rltty.o: rltty.h ! rltty.o: readline.h keymaps.h chardefs.h tilde.h rlstdc.h search.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! search.o: readline.h keymaps.h chardefs.h tilde.h search.o: ansi_stdlib.h history.h rlstdc.h shell.o: ${BUILD_DIR}/config.h shell.o: ansi_stdlib.h signals.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! signals.o: readline.h keymaps.h chardefs.h tilde.h signals.o: history.h rlstdc.h terminal.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h terminal.o: tcap.h ! terminal.o: readline.h keymaps.h chardefs.h tilde.h terminal.o: history.h rlstdc.h tilde.o: ansi_stdlib.h --- 327,342 ---- rltty.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h rltty.o: rltty.h ! rltty.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h rlstdc.h search.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! search.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h search.o: ansi_stdlib.h history.h rlstdc.h shell.o: ${BUILD_DIR}/config.h shell.o: ansi_stdlib.h signals.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! signals.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h signals.o: history.h rlstdc.h terminal.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h terminal.o: tcap.h ! terminal.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h terminal.o: history.h rlstdc.h tilde.o: ansi_stdlib.h *************** *** 331,341 **** undo.o: ansi_stdlib.h undo.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! undo.o: readline.h keymaps.h chardefs.h tilde.h undo.o: history.h rlstdc.h util.o: posixjmp.h ansi_stdlib.h util.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! util.o: readline.h keymaps.h chardefs.h tilde.h rlstdc.h vi_mode.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! vi_mode.o: readline.h keymaps.h chardefs.h tilde.h vi_mode.o: history.h ansi_stdlib.h rlstdc.h xmalloc.o: ${BUILD_DIR}/config.h --- 345,355 ---- undo.o: ansi_stdlib.h undo.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! undo.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h undo.o: history.h rlstdc.h util.o: posixjmp.h ansi_stdlib.h util.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! util.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h rlstdc.h vi_mode.o: rldefs.h ${BUILD_DIR}/config.h rlconf.h ! vi_mode.o: readline.h keymaps.h rltypedefs.h chardefs.h tilde.h vi_mode.o: history.h ansi_stdlib.h rlstdc.h xmalloc.o: ${BUILD_DIR}/config.h *************** *** 397,400 **** --- 411,415 ---- search.o: $(srcdir)/search.c rltty.o: $(srcdir)/rltty.c + compat.o: $(srcdir)/compat.c complete.o: $(srcdir)/complete.c bind.o: $(srcdir)/bind.c *************** *** 426,429 **** --- 441,445 ---- search.o: search.c rltty.o: rltty.c + compat.o: compat.c complete.o: complete.c bind.o: bind.c diff -Nrc2 readline-4.1/README readline-4.2/README *** readline-4.1/README Fri Mar 17 16:53:06 2000 --- readline-4.2/README Wed Apr 4 14:32:26 2001 *************** *** 2,6 **** ============ ! This is the Gnu Readline library, version 4.1. The Readline library provides a set of functions for use by applications --- 2,6 ---- ============ ! This is the Gnu Readline library, version 4.2. The Readline library provides a set of functions for use by applications *************** *** 38,41 **** --- 38,44 ---- certain Readline features. + The special make target `everything' will build the static and shared + libraries (if the target platform supports them) and the examples. + Examples ======== *************** *** 65,70 **** a `stanza' for your operating system and compiler. The script uses the value of host_os and ${CC} as determined by configure. For ! instance, FreeBSD 2.2.5 with any version of gcc is identified as ! `freebsd2.2.5-gcc*'. In the stanza for your operating system-compiler pair, you will need to --- 68,73 ---- a `stanza' for your operating system and compiler. The script uses the value of host_os and ${CC} as determined by configure. For ! instance, FreeBSD 4.2 using the ELF object file format with any ! version of gcc is identified as `freebsdelf4.2-gcc*'. In the stanza for your operating system-compiler pair, you will need to *************** *** 145,149 **** When reporting a bug, please include the following information: ! * the version number and release status of Readline (e.g., 4.0-release) * the machine and OS that it is running on * a list of the compilation flags or the contents of `config.h', if --- 148,152 ---- When reporting a bug, please include the following information: ! * the version number and release status of Readline (e.g., 4.2-release) * the machine and OS that it is running on * a list of the compilation flags or the contents of `config.h', if diff -Nrc2 readline-4.1/aclocal.m4 readline-4.2/aclocal.m4 *** readline-4.1/aclocal.m4 Tue Feb 22 11:41:01 2000 --- readline-4.2/aclocal.m4 Tue Nov 21 10:42:10 2000 *************** *** 1066,1080 **** AC_DEFUN(BASH_CHECK_GETPW_FUNCS, ! [AC_MSG_CHECKING(whether programs are able to redeclare getpw functions) ! AC_CACHE_VAL(bash_cv_can_redecl_getpw, ! [AC_TRY_COMPILE([#include #include ! extern struct passwd *getpwent(); ! extern struct passwd *getpwuid(); ! extern struct passwd *getpwnam();], ! [struct passwd *z; z = getpwent(); z = getpwuid(0); z = getpwnam("root");], ! bash_cv_can_redecl_getpw=yes,bash_cv_can_redecl_getpw=no)]) ! AC_MSG_RESULT($bash_cv_can_redecl_getpw) ! if test $bash_cv_can_redecl_getpw = no; then AC_DEFINE(HAVE_GETPW_DECLS) fi --- 1066,1082 ---- AC_DEFUN(BASH_CHECK_GETPW_FUNCS, ! [AC_MSG_CHECKING(whether getpw functions are declared in pwd.h) ! AC_CACHE_VAL(bash_cv_getpw_declared, ! [AC_EGREP_CPP(getpwuid, ! [ ! #include ! #ifdef HAVE_UNISTD_H ! # include ! #endif #include ! ], ! bash_cv_getpw_declared=yes,bash_cv_getpw_declared=no)]) ! AC_MSG_RESULT($bash_cv_getpw_declared) ! if test $bash_cv_getpw_declared = yes; then AC_DEFINE(HAVE_GETPW_DECLS) fi *************** *** 1351,1355 **** AC_DEFUN(BASH_SYS_RESTARTABLE_SYSCALLS, [AC_REQUIRE([BASH_SIGNAL_CHECK]) ! AC_CACHE_CHECK(for restartable system calls with posix sigaction, bash_cv_sys_restartable_syscalls, [AC_TRY_RUN( --- 1353,1357 ---- AC_DEFUN(BASH_SYS_RESTARTABLE_SYSCALLS, [AC_REQUIRE([BASH_SIGNAL_CHECK]) ! AC_CACHE_CHECK(whether posix sigaction restarts system calls by default, bash_cv_sys_restartable_syscalls, [AC_TRY_RUN( *************** *** 1357,1360 **** --- 1359,1365 ---- i.e. the pid of the child, which means that wait was restarted after getting the signal. */ + #ifdef HAVE_UNISTD_H + # include + #endif #include #include *************** *** 1424,1427 **** --- 1429,1463 ---- if test $bash_cv_struct_timeval = yes; then AC_DEFINE(HAVE_TIMEVAL) + fi + ]) + + AC_DEFUN(BASH_CHECK_RTSIGS, + [AC_MSG_CHECKING(for unusable real-time signals due to large values) + AC_CACHE_VAL(bash_cv_unusable_rtsigs, + [AC_TRY_RUN([ + #include + #include + + #ifndef NSIG + # define NSIG 64 + #endif + + main () + { + int n_sigs = 2 * NSIG; + #ifdef SIGRTMIN + int rtmin = SIGRTMIN; + #else + int rtmin = 0; + #endif + + exit(rtmin < n_sigs); + }], bash_cv_unusable_rtsigs=yes, bash_cv_unusable_rtsigs=no, + [AC_MSG_WARN(cannot check real-time signals if cross compiling -- defaulting to yes) + bash_cv_unusable_rtsigs=yes] + )]) + AC_MSG_RESULT($bash_cv_unusable_rtsigs) + if test $bash_cv_unusable_rtsigs = yes; then + AC_DEFINE(UNUSABLE_RT_SIGNALS) fi ]) diff -Nrc2 readline-4.1/ansi_stdlib.h readline-4.2/ansi_stdlib.h *** readline-4.1/ansi_stdlib.h Thu Aug 5 07:49:32 1999 --- readline-4.2/ansi_stdlib.h Thu Sep 7 12:07:49 2000 *************** *** 28,31 **** --- 28,34 ---- extern long int atol (); + extern double atof (); + extern double strtod (); + /* Memory allocation functions. */ extern char *malloc (); diff -Nrc2 readline-4.1/bind.c readline-4.2/bind.c *** readline-4.1/bind.c Tue Aug 24 14:19:22 1999 --- readline-4.2/bind.c Mon Mar 5 10:10:07 2001 *************** *** 69,75 **** Keymap rl_binding_keymap; ! static int _rl_read_init_file __P((char *, int)); static int glean_key_from_name __P((char *)); ! static int substring_member_of_array __P((char *, char **)); static int currently_reading_init_file; --- 69,75 ---- Keymap rl_binding_keymap; ! static int _rl_read_init_file __P((const char *, int)); static int glean_key_from_name __P((char *)); ! static int substring_member_of_array __P((char *, const char **)); static int currently_reading_init_file; *************** *** 84,94 **** /* **************************************************************** */ ! /* rl_add_defun (char *name, Function *function, int key) Add NAME to the list of named functions. Make FUNCTION be the function that gets called. If KEY is not -1, then bind it. */ int rl_add_defun (name, function, key) ! char *name; ! Function *function; int key; { --- 84,94 ---- /* **************************************************************** */ ! /* rl_add_defun (char *name, rl_command_func_t *function, int key) Add NAME to the list of named functions. Make FUNCTION be the function that gets called. If KEY is not -1, then bind it. */ int rl_add_defun (name, function, key) ! const char *name; ! rl_command_func_t *function; int key; { *************** *** 103,107 **** rl_bind_key (key, function) int key; ! Function *function; { if (key < 0) --- 103,107 ---- rl_bind_key (key, function) int key; ! rl_command_func_t *function; { if (key < 0) *************** *** 134,138 **** rl_bind_key_in_map (key, function, map) int key; ! Function *function; Keymap map; { --- 134,138 ---- rl_bind_key_in_map (key, function, map) int key; ! rl_command_func_t *function; Keymap map; { *************** *** 153,157 **** int key; { ! return (rl_bind_key (key, (Function *)NULL)); } --- 153,157 ---- int key; { ! return (rl_bind_key (key, (rl_command_func_t *)NULL)); } *************** *** 163,167 **** Keymap map; { ! return (rl_bind_key_in_map (key, (Function *)NULL, map)); } --- 163,167 ---- Keymap map; { ! return (rl_bind_key_in_map (key, (rl_command_func_t *)NULL, map)); } *************** *** 169,173 **** int rl_unbind_function_in_map (func, map) ! Function *func; Keymap map; { --- 169,173 ---- int rl_unbind_function_in_map (func, map) ! rl_command_func_t *func; Keymap map; { *************** *** 178,182 **** if (map[i].type == ISFUNC && map[i].function == func) { ! map[i].function = (Function *)NULL; rval = 1; } --- 178,182 ---- if (map[i].type == ISFUNC && map[i].function == func) { ! map[i].function = (rl_command_func_t *)NULL; rval = 1; } *************** *** 187,194 **** int rl_unbind_command_in_map (command, map) ! char *command; Keymap map; { ! Function *func; func = rl_named_function (command); --- 187,194 ---- int rl_unbind_command_in_map (command, map) ! const char *command; Keymap map; { ! rl_command_func_t *func; func = rl_named_function (command); *************** *** 203,208 **** int rl_set_key (keyseq, function, map) ! char *keyseq; ! Function *function; Keymap map; { --- 203,208 ---- int rl_set_key (keyseq, function, map) ! const char *keyseq; ! rl_command_func_t *function; Keymap map; { *************** *** 215,219 **** int rl_macro_bind (keyseq, macro, map) ! char *keyseq, *macro; Keymap map; { --- 215,219 ---- int rl_macro_bind (keyseq, macro, map) ! const char *keyseq, *macro; Keymap map; { *************** *** 240,244 **** rl_generic_bind (type, keyseq, data, map) int type; ! char *keyseq, *data; Keymap map; { --- 240,245 ---- rl_generic_bind (type, keyseq, data, map) int type; ! const char *keyseq; ! char *data; Keymap map; { *************** *** 310,314 **** int rl_translate_keyseq (seq, array, len) ! char *seq, *array; int *len; { --- 311,316 ---- int rl_translate_keyseq (seq, array, len) ! const char *seq; ! char *array; int *len; { *************** *** 514,520 **** If STRING doesn't have a matching function, then a NULL pointer is returned. */ ! Function * rl_named_function (string) ! char *string; { register int i; --- 516,522 ---- If STRING doesn't have a matching function, then a NULL pointer is returned. */ ! rl_command_func_t * rl_named_function (string) ! const char *string; { register int i; *************** *** 525,529 **** if (_rl_stricmp (funmap[i]->name, string) == 0) return (funmap[i]->function); ! return ((Function *)NULL); } --- 527,531 ---- if (_rl_stricmp (funmap[i]->name, string) == 0) return (funmap[i]->function); ! return ((rl_command_func_t *)NULL); } *************** *** 533,539 **** type of the object pointed to. One of ISFUNC (function), ISKMAP (keymap), or ISMACR (macro). */ ! Function * rl_function_of_keyseq (keyseq, map, type) ! char *keyseq; Keymap map; int *type; --- 535,541 ---- type of the object pointed to. One of ISFUNC (function), ISKMAP (keymap), or ISMACR (macro). */ ! rl_command_func_t * rl_function_of_keyseq (keyseq, map, type) ! const char *keyseq; Keymap map; int *type; *************** *** 586,590 **** } } ! return ((Function *) NULL); } --- 588,592 ---- } } ! return ((rl_command_func_t *) NULL); } *************** *** 593,597 **** /* The file we're currently reading key bindings from. */ ! static char *current_readline_init_file; static int current_readline_init_include_level; static int current_readline_init_lineno; --- 595,599 ---- /* The file we're currently reading key bindings from. */ ! static const char *current_readline_init_file; static int current_readline_init_include_level; static int current_readline_init_lineno; *************** *** 660,664 **** { int r; ! r = rl_read_init_file ((char *)NULL); rl_set_keymap_from_edit_mode (); return r; --- 662,666 ---- { int r; ! r = rl_read_init_file ((const char *)NULL); rl_set_keymap_from_edit_mode (); return r; *************** *** 674,678 **** int rl_read_init_file (filename) ! char *filename; { /* Default the filename. */ --- 676,680 ---- int rl_read_init_file (filename) ! const char *filename; { /* Default the filename. */ *************** *** 681,685 **** filename = last_readline_init_file; if (filename == 0) ! filename = get_env_value ("INPUTRC"); if (filename == 0) filename = DEFAULT_INPUTRC; --- 683,687 ---- filename = last_readline_init_file; if (filename == 0) ! filename = sh_get_env_value ("INPUTRC"); if (filename == 0) filename = DEFAULT_INPUTRC; *************** *** 699,703 **** static int _rl_read_init_file (filename, include_level) ! char *filename; int include_level; { --- 701,705 ---- static int _rl_read_init_file (filename, include_level) ! const char *filename; int include_level; { *************** *** 734,738 **** for (i = 0; line + i != end && line[i] != '\n'; i++); ! #if defined (__CYGWIN32__) /* ``Be liberal in what you accept.'' */ if (line[i] == '\n' && line[i-1] == '\r') --- 736,740 ---- for (i = 0; line + i != end && line[i] != '\n'; i++); ! #if defined (__CYGWIN__) /* ``Be liberal in what you accept.'' */ if (line[i] == '\n' && line[i-1] == '\r') *************** *** 781,788 **** /* **************************************************************** */ /* Conditionals. */ /* Calling programs set this to have their argv[0]. */ ! char *rl_readline_name = "other"; /* Stack of previous values of parsing_conditionalized_out. */ --- 783,801 ---- /* **************************************************************** */ + typedef int _rl_parser_func_t __P((char *)); + + /* Things that mean `Control'. */ + const char *_rl_possible_control_prefixes[] = { + "Control-", "C-", "CTRL-", (const char *)NULL + }; + + const char *_rl_possible_meta_prefixes[] = { + "Meta", "M-", (const char *)NULL + }; + /* Conditionals. */ /* Calling programs set this to have their argv[0]. */ ! const char *rl_readline_name = "other"; /* Stack of previous values of parsing_conditionalized_out. */ *************** *** 906,910 **** char *args; { ! char *old_init_file, *e; int old_line_number, old_include_level, r; --- 919,924 ---- char *args; { ! const char *old_init_file; ! char *e; int old_line_number, old_include_level, r; *************** *** 919,923 **** if (e) *e = '\0'; ! r = _rl_read_init_file (args, old_include_level + 1); current_readline_init_file = old_init_file; --- 933,937 ---- if (e) *e = '\0'; ! r = _rl_read_init_file ((const char *)args, old_include_level + 1); current_readline_init_file = old_init_file; *************** *** 930,935 **** /* Associate textual names with actual functions. */ static struct { ! char *name; ! Function *function; } parser_directives [] = { { "if", parser_if }, --- 944,949 ---- /* Associate textual names with actual functions. */ static struct { ! const char *name; ! _rl_parser_func_t *function; } parser_directives [] = { { "if", parser_if }, *************** *** 937,941 **** { "else", parser_else }, { "include", parser_include }, ! { (char *)0x0, (Function *)0x0 } }; --- 951,955 ---- { "else", parser_else }, { "include", parser_include }, ! { (char *)0x0, (_rl_parser_func_t *)0x0 } }; *************** *** 1181,1188 **** /* Add in control and meta bits. */ ! if (substring_member_of_array (string, possible_control_prefixes)) key = CTRL (_rl_to_upper (key)); ! if (substring_member_of_array (string, possible_meta_prefixes)) key = META (key); --- 1195,1202 ---- /* Add in control and meta bits. */ ! if (substring_member_of_array (string, _rl_possible_control_prefixes)) key = CTRL (_rl_to_upper (key)); ! if (substring_member_of_array (string, _rl_possible_meta_prefixes)) key = META (key); *************** *** 1222,1226 **** static struct { ! char *name; int *value; int flags; --- 1236,1240 ---- static struct { ! const char *name; int *value; int flags; *************** *** 1266,1270 **** int i; { ! char *name; name = boolean_varlist[i].name; --- 1280,1284 ---- int i; { ! const char *name; name = boolean_varlist[i].name; *************** *** 1281,1284 **** --- 1295,1300 ---- } + typedef int _rl_sv_func_t __P((const char *)); + /* These *must* correspond to the array indices for the appropriate string variable. (Though they're not used right now.) */ *************** *** 1293,1307 **** /* Forward declarations */ ! static int sv_bell_style __P((char *)); ! static int sv_combegin __P((char *)); ! static int sv_compquery __P((char *)); ! static int sv_editmode __P((char *)); ! static int sv_isrchterm __P((char *)); ! static int sv_keymap __P((char *)); static struct { ! char *name; int flags; ! Function *set_func; } string_varlist[] = { { "bell-style", V_STRING, sv_bell_style }, --- 1309,1323 ---- /* Forward declarations */ ! static int sv_bell_style __P((const char *)); ! static int sv_combegin __P((const char *)); ! static int sv_compquery __P((const char *)); ! static int sv_editmode __P((const char *)); ! static int sv_isrchterm __P((const char *)); ! static int sv_keymap __P((const char *)); static struct { ! const char *name; int flags; ! _rl_sv_func_t *set_func; } string_varlist[] = { { "bell-style", V_STRING, sv_bell_style }, *************** *** 1340,1344 **** int rl_variable_bind (name, value) ! char *name, *value; { register int i; --- 1356,1360 ---- int rl_variable_bind (name, value) ! const char *name, *value; { register int i; *************** *** 1368,1372 **** static int sv_editmode (value) ! char *value; { if (_rl_strnicmp (value, "vi", 2) == 0) --- 1384,1388 ---- static int sv_editmode (value) ! const char *value; { if (_rl_strnicmp (value, "vi", 2) == 0) *************** *** 1389,1393 **** static int sv_combegin (value) ! char *value; { if (value && *value) --- 1405,1409 ---- static int sv_combegin (value) ! const char *value; { if (value && *value) *************** *** 1402,1406 **** static int sv_compquery (value) ! char *value; { int nval = 100; --- 1418,1422 ---- static int sv_compquery (value) ! const char *value; { int nval = 100; *************** *** 1418,1422 **** static int sv_keymap (value) ! char *value; { Keymap kmap; --- 1434,1438 ---- static int sv_keymap (value) ! const char *value; { Keymap kmap; *************** *** 1435,1439 **** static int sv_bell_style (value) ! char *value; { if (value == 0 || *value == '\0') --- 1451,1455 ---- static int sv_bell_style (value) ! const char *value; { if (value == 0 || *value == '\0') *************** *** 1452,1456 **** static int sv_isrchterm (value) ! char *value; { int beg, end, delim; --- 1468,1472 ---- static int sv_isrchterm (value) ! const char *value; { int beg, end, delim; *************** *** 1490,1494 **** typedef struct { ! char *name; int value; } assoc_list; --- 1506,1510 ---- typedef struct { ! const char *name; int value; } assoc_list; *************** *** 1524,1528 **** /* Auxiliary functions to manage keymaps. */ static struct { ! char *name; Keymap map; } keymap_names[] = { --- 1540,1544 ---- /* Auxiliary functions to manage keymaps. */ static struct { ! const char *name; Keymap map; } keymap_names[] = { *************** *** 1542,1551 **** Keymap rl_get_keymap_by_name (name) ! char *name; { register int i; for (i = 0; keymap_names[i].name; i++) ! if (strcmp (name, keymap_names[i].name) == 0) return (keymap_names[i].map); return ((Keymap) NULL); --- 1558,1567 ---- Keymap rl_get_keymap_by_name (name) ! const char *name; { register int i; for (i = 0; keymap_names[i].name; i++) ! if (_rl_stricmp (name, keymap_names[i].name) == 0) return (keymap_names[i].map); return ((Keymap) NULL); *************** *** 1559,1563 **** for (i = 0; keymap_names[i].name; i++) if (map == keymap_names[i].map) ! return (keymap_names[i].name); return ((char *)NULL); } --- 1575,1579 ---- for (i = 0; keymap_names[i].name; i++) if (map == keymap_names[i].map) ! return ((char *)keymap_names[i].name); return ((char *)NULL); } *************** *** 1617,1621 **** { register int i; ! char **funmap_names; funmap_names = rl_funmap_names (); --- 1633,1637 ---- { register int i; ! const char **funmap_names; funmap_names = rl_funmap_names (); *************** *** 1707,1711 **** char ** rl_invoking_keyseqs_in_map (function, map) ! Function *function; Keymap map; { --- 1723,1727 ---- char ** rl_invoking_keyseqs_in_map (function, map) ! rl_command_func_t *function; Keymap map; { *************** *** 1807,1811 **** char ** rl_invoking_keyseqs (function) ! Function *function; { return (rl_invoking_keyseqs_in_map (function, _rl_keymap)); --- 1823,1827 ---- char ** rl_invoking_keyseqs (function) ! rl_command_func_t *function; { return (rl_invoking_keyseqs_in_map (function, _rl_keymap)); *************** *** 1820,1825 **** { register int i; ! char **names; ! char *name; names = rl_funmap_names (); --- 1836,1841 ---- { register int i; ! const char **names; ! const char *name; names = rl_funmap_names (); *************** *** 1829,1833 **** for (i = 0; name = names[i]; i++) { ! Function *function; char **invokers; --- 1845,1849 ---- for (i = 0; name = names[i]; i++) { ! rl_command_func_t *function; char **invokers; *************** *** 1986,1990 **** { int i; ! char *kname; for (i = 0; boolean_varlist[i].name; i++) --- 2002,2006 ---- { int i; ! const char *kname; for (i = 0; boolean_varlist[i].name; i++) *************** *** 2074,2081 **** void _rl_bind_if_unbound (keyseq, default_func) ! char *keyseq; ! Function *default_func; { ! Function *func; if (keyseq) --- 2090,2097 ---- void _rl_bind_if_unbound (keyseq, default_func) ! const char *keyseq; ! rl_command_func_t *default_func; { ! rl_command_func_t *func; if (keyseq) *************** *** 2090,2094 **** static int substring_member_of_array (string, array) ! char *string, **array; { while (*array) --- 2106,2111 ---- static int substring_member_of_array (string, array) ! char *string; ! const char **array; { while (*array) diff -Nrc2 readline-4.1/callback.c readline-4.2/callback.c *** readline-4.1/callback.c Thu Aug 5 08:17:29 1999 --- readline-4.2/callback.c Tue Dec 12 14:48:21 2000 *************** *** 53,57 **** signals handled all the time, except during calls to the user's function. */ ! VFunction *rl_linefunc; /* user callback function */ static int in_handler; /* terminal_prepped and signals set? */ --- 53,57 ---- signals handled all the time, except during calls to the user's function. */ ! rl_vcpfunc_t *rl_linefunc; /* user callback function */ static int in_handler; /* terminal_prepped and signals set? */ *************** *** 79,87 **** void rl_callback_handler_install (prompt, linefunc) ! char *prompt; ! VFunction *linefunc; { ! rl_prompt = prompt; ! rl_visible_prompt_length = rl_prompt ? rl_expand_prompt (rl_prompt) : 0; rl_linefunc = linefunc; _rl_callback_newline (); --- 79,86 ---- void rl_callback_handler_install (prompt, linefunc) ! const char *prompt; ! rl_vcpfunc_t *linefunc; { ! rl_set_prompt (prompt); rl_linefunc = linefunc; _rl_callback_newline (); *************** *** 103,124 **** eof = readline_internal_char (); ! if (rl_done) { ! line = readline_internal_teardown (eof); ! (*rl_deprep_term_function) (); #if defined (HANDLE_SIGNALS) ! rl_clear_signals (); #endif ! in_handler = 0; ! (*rl_linefunc) (line); ! /* If the user did not clear out the line, do it for him. */ ! if (rl_line_buffer[0]) ! _rl_init_line_state (); ! ! /* Redisplay the prompt if readline_handler_{install,remove} not called. */ ! if (in_handler == 0 && rl_linefunc) ! _rl_callback_newline (); } } --- 102,132 ---- eof = readline_internal_char (); ! /* We loop in case some function has pushed input back with rl_execute_next. */ ! for (;;) { ! if (rl_done) ! { ! line = readline_internal_teardown (eof); ! (*rl_deprep_term_function) (); #if defined (HANDLE_SIGNALS) ! rl_clear_signals (); #endif ! in_handler = 0; ! (*rl_linefunc) (line); ! /* If the user did not clear out the line, do it for him. */ ! if (rl_line_buffer[0]) ! _rl_init_line_state (); ! ! /* Redisplay the prompt if readline_handler_{install,remove} ! not called. */ ! if (in_handler == 0 && rl_linefunc) ! _rl_callback_newline (); ! } ! if (rl_pending_input) ! eof = readline_internal_char (); ! else ! break; } } diff -Nrc2 readline-4.1/chardefs.h readline-4.2/chardefs.h *** readline-4.1/chardefs.h Thu Aug 5 08:17:37 1999 --- readline-4.2/chardefs.h Wed Sep 13 17:20:15 2000 *************** *** 52,56 **** #define largest_char 255 /* Largest character value. */ ! #define CTRL_CHAR(c) ((c) < control_character_threshold && (c) >= 0) #define META_CHAR(c) ((c) > meta_character_threshold && (c) <= largest_char) --- 52,56 ---- #define largest_char 255 /* Largest character value. */ ! #define CTRL_CHAR(c) ((c) < control_character_threshold && (((c) & 0x80) == 0)) #define META_CHAR(c) ((c) > meta_character_threshold && (c) <= largest_char) diff -Nrc2 readline-4.1/compat.c readline-4.2/compat.c *** readline-4.1/compat.c Wed Dec 31 19:00:00 1969 --- readline-4.2/compat.c Tue Feb 6 14:15:13 2001 *************** *** 0 **** --- 1,113 ---- + /* compat.c -- backwards compatibility functions. */ + + /* Copyright (C) 2000 Free Software Foundation, Inc. + + This file is part of the GNU Readline Library, a library for + reading lines of text with interactive input and history editing. + + The GNU Readline Library 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. + + The GNU Readline Library 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. + + The GNU General Public License is often shipped with GNU software, and + is generally kept in a file called COPYING or LICENSE. If you do not + have a copy of the license, write to the Free Software Foundation, + 59 Temple Place, Suite 330, Boston, MA 02111 USA. */ + #define READLINE_LIBRARY + + #if defined (HAVE_CONFIG_H) + # include + #endif + + #include + + #include "rlstdc.h" + #include "rltypedefs.h" + + extern void rl_free_undo_list __P((void)); + extern int rl_maybe_save_line __P((void)); + extern int rl_maybe_unsave_line __P((void)); + extern int rl_maybe_replace_line __P((void)); + + extern int rl_crlf __P((void)); + extern int rl_ding __P((void)); + extern int rl_alphabetic __P((int)); + + extern char **rl_completion_matches __P((const char *, rl_compentry_func_t *)); + extern char *rl_username_completion_function __P((const char *, int)); + extern char *rl_filename_completion_function __P((const char *, int)); + + /* Provide backwards-compatible entry points for old function names. */ + + void + free_undo_list () + { + rl_free_undo_list (); + } + + int + maybe_replace_line () + { + return rl_maybe_replace_line (); + } + + int + maybe_save_line () + { + return rl_maybe_save_line (); + } + + int + maybe_unsave_line () + { + return rl_maybe_unsave_line (); + } + + int + ding () + { + return rl_ding (); + } + + int + crlf () + { + return rl_crlf (); + } + + int + alphabetic (c) + int c; + { + return rl_alphabetic (c); + } + + char ** + completion_matches (s, f) + const char *s; + rl_compentry_func_t *f; + { + return rl_completion_matches (s, f); + } + + char * + username_completion_function (s, i) + const char *s; + int i; + { + return rl_username_completion_function (s, i); + } + + char * + filename_completion_function (s, i) + const char *s; + int i; + { + return rl_filename_completion_function (s, i); + } diff -Nrc2 readline-4.1/complete.c readline-4.2/complete.c *** readline-4.1/complete.c Tue Feb 22 13:50:05 2000 --- readline-4.2/complete.c Wed Feb 14 07:47:18 2001 *************** *** 50,65 **** #include - #if !defined (HAVE_GETPW_DECLS) - extern struct passwd *getpwent (); - #endif /* USG && !HAVE_GETPW_DECLS */ - - /* ISC systems don't define getpwent() if _POSIX_SOURCE is defined. */ - #if defined (isc386) && defined (_POSIX_SOURCE) - # if defined (__STDC__) - extern struct passwd *getpwent (void); - # else - extern struct passwd *getpwent (); - # endif /* !__STDC__ */ - #endif /* isc386 && _POSIX_SOURCE */ #include "posixdir.h" --- 50,53 ---- *************** *** 80,83 **** --- 68,77 ---- #endif + /* Most systems don't declare getpwent in if _POSIX_SOURCE is + defined. */ + #if !defined (HAVE_GETPW_DECLS) || defined (_POSIX_SOURCE) + extern struct passwd *getpwent __P((void)); + #endif /* !HAVE_GETPW_DECLS || _POSIX_SOURCE */ + /* If non-zero, then this is the address of a function to call when completing a word would normally display the list of possible matches. *************** *** 87,95 **** number of strings in that array, and MAX_LENGTH is the length of the longest string in that array. */ ! VFunction *rl_completion_display_matches_hook = (VFunction *)NULL; ! ! /* Forward declarations for functions defined and used in this file. */ ! char *filename_completion_function __P((char *, int)); ! char **completion_matches __P((char *, CPFunction *)); #if defined (VISIBLE_STATS) --- 81,85 ---- number of strings in that array, and MAX_LENGTH is the length of the longest string in that array. */ ! rl_compdisp_func_t *rl_completion_display_matches_hook = (rl_compdisp_func_t *)NULL; #if defined (VISIBLE_STATS) *************** *** 101,105 **** static char *rl_quote_filename __P((char *, int, char *)); - static char *rl_strpbrk __P((char *, char *)); static char **remove_duplicate_matches __P((char **)); --- 91,94 ---- *************** *** 108,112 **** static void insert_all_matches __P((char **, int, char *)); static void display_matches __P((char **)); ! static int compute_lcd_of_matches __P((char **, int, char *)); /* **************************************************************** */ --- 97,101 ---- static void insert_all_matches __P((char **, int, char *)); static void display_matches __P((char **)); ! static int compute_lcd_of_matches __P((char **, int, const char *)); /* **************************************************************** */ *************** *** 147,151 **** completing on a directory name. The function is called with the address of a string (the current directory name) as an arg. */ ! Function *rl_directory_completion_hook = (Function *)NULL; /* Non-zero means readline completion functions perform tilde expansion. */ --- 136,142 ---- completing on a directory name. The function is called with the address of a string (the current directory name) as an arg. */ ! rl_icppfunc_t *rl_directory_completion_hook = (rl_icppfunc_t *)NULL; ! ! rl_icppfunc_t *rl_directory_rewrite_hook = (rl_icppfunc_t *)NULL; /* Non-zero means readline completion functions perform tilde expansion. */ *************** *** 153,159 **** /* Pointer to the generator function for completion_matches (). ! NULL means to use filename_completion_function (), the default filename completer. */ ! Function *rl_completion_entry_function = (Function *)NULL; /* Pointer to alternative function to create matches. --- 144,150 ---- /* Pointer to the generator function for completion_matches (). ! NULL means to use rl_filename_completion_function (), the default filename completer. */ ! rl_compentry_func_t *rl_completion_entry_function = (rl_compentry_func_t *)NULL; /* Pointer to alternative function to create matches. *************** *** 164,168 **** rl_completion_entry_function to try to match, otherwise use the array of strings returned. */ ! CPPFunction *rl_attempted_completion_function = (CPPFunction *)NULL; /* Non-zero means to suppress normal filename completion after the --- 155,159 ---- rl_completion_entry_function to try to match, otherwise use the array of strings returned. */ ! rl_completion_func_t *rl_attempted_completion_function = (rl_completion_func_t *)NULL; /* Non-zero means to suppress normal filename completion after the *************** *** 183,195 **** completer routine. The contents of this variable is what breaks words in the shell, i.e. " \t\n\"\\'`@$><=" */ ! char *rl_basic_word_break_characters = " \t\n\"\\'`@$><=;|&{("; /* List of basic quoting characters. */ ! char *rl_basic_quote_characters = "\"'"; /* The list of characters that signal a break between words for rl_complete_internal. The default list is the contents of rl_basic_word_break_characters. */ ! char *rl_completer_word_break_characters = (char *)NULL; /* List of characters which can be used to quote a substring of the line. --- 174,186 ---- completer routine. The contents of this variable is what breaks words in the shell, i.e. " \t\n\"\\'`@$><=" */ ! const char *rl_basic_word_break_characters = " \t\n\"\\'`@$><=;|&{("; /* List of basic quoting characters. */ ! const char *rl_basic_quote_characters = "\"'"; /* The list of characters that signal a break between words for rl_complete_internal. The default list is the contents of rl_basic_word_break_characters. */ ! const char *rl_completer_word_break_characters = (const char *)NULL; /* List of characters which can be used to quote a substring of the line. *************** *** 197,209 **** rl_completer_word_break_characters are treated as any other character, unless they also appear within this list. */ ! char *rl_completer_quote_characters = (char *)NULL; /* List of characters that should be quoted in filenames by the completer. */ ! char *rl_filename_quote_characters = (char *)NULL; /* List of characters that are word break characters, but should be left in TEXT when it is passed to the completion function. The shell uses this to help determine what kind of completing to do. */ ! char *rl_special_prefixes = (char *)NULL; /* If non-zero, then disallow duplicates in the matches. */ --- 188,200 ---- rl_completer_word_break_characters are treated as any other character, unless they also appear within this list. */ ! const char *rl_completer_quote_characters = (const char *)NULL; /* List of characters that should be quoted in filenames by the completer. */ ! const char *rl_filename_quote_characters = (const char *)NULL; /* List of characters that are word break characters, but should be left in TEXT when it is passed to the completion function. The shell uses this to help determine what kind of completing to do. */ ! const char *rl_special_prefixes = (const char *)NULL; /* If non-zero, then disallow duplicates in the matches. */ *************** *** 231,235 **** free()'d if they are deleted. The main intent of this function is to implement FIGNORE a la SunOS csh. */ ! Function *rl_ignore_some_completions_function = (Function *)NULL; /* Set to a function to quote a filename in an application-specific fashion. --- 222,226 ---- free()'d if they are deleted. The main intent of this function is to implement FIGNORE a la SunOS csh. */ ! rl_compignore_func_t *rl_ignore_some_completions_function = (rl_compignore_func_t *)NULL; /* Set to a function to quote a filename in an application-specific fashion. *************** *** 237,241 **** and a pointer to the quoting character to be used, which the function can reset if desired. */ ! CPFunction *rl_filename_quoting_function = rl_quote_filename; /* Function to call to remove quoting characters from a filename. Called --- 228,232 ---- and a pointer to the quoting character to be used, which the function can reset if desired. */ ! rl_quote_func_t *rl_filename_quoting_function = rl_quote_filename; /* Function to call to remove quoting characters from a filename. Called *************** *** 243,252 **** with matching names in the file system. Readline doesn't do anything with this; it's set only by applications. */ ! CPFunction *rl_filename_dequoting_function = (CPFunction *)NULL; /* Function to call to decide whether or not a word break character is quoted. If a character is quoted, it does not break words for the completer. */ ! Function *rl_char_is_quoted_p = (Function *)NULL; /* Character appended to completed words when at the end of the line. The --- 234,243 ---- with matching names in the file system. Readline doesn't do anything with this; it's set only by applications. */ ! rl_dequote_func_t *rl_filename_dequoting_function = (rl_dequote_func_t *)NULL; /* Function to call to decide whether or not a word break character is quoted. If a character is quoted, it does not break words for the completer. */ ! rl_linebuf_func_t *rl_char_is_quoted_p = (rl_linebuf_func_t *)NULL; /* Character appended to completed words when at the end of the line. The *************** *** 270,274 **** /* Complete the word at or before point. You have supplied the function that does the initial simple matching selection algorithm (see ! completion_matches ()). The default is to do filename completion. */ int rl_complete (ignore, invoking_key) --- 261,265 ---- /* Complete the word at or before point. You have supplied the function that does the initial simple matching selection algorithm (see ! rl_completion_matches ()). The default is to do filename completion. */ int rl_complete (ignore, invoking_key) *************** *** 306,330 **** /************************************/ - /* Find the first occurrence in STRING1 of any character from STRING2. - Return a pointer to the character in STRING1. */ - static char * - rl_strpbrk (string1, string2) - char *string1, *string2; - { - register char *scan; - - for (; *string1; string1++) - { - for (scan = string2; *scan; scan++) - { - if (*string1 == *scan) - { - return (string1); - } - } - } - return ((char *)NULL); - } - /* The user must press "y" or "n". Non-zero return means "y" pressed. */ static int --- 297,300 ---- *************** *** 335,339 **** --- 305,312 ---- for (;;) { + RL_SETSTATE(RL_STATE_MOREINPUT); c = rl_read_key (); + RL_UNSETSTATE(RL_STATE_MOREINPUT); + if (c == 'y' || c == 'Y' || c == ' ') return (1); *************** *** 342,346 **** if (c == ABORT_CHAR) _rl_abort_internal (); ! ding (); } } --- 315,319 ---- if (c == ABORT_CHAR) _rl_abort_internal (); ! rl_ding (); } } *************** *** 572,576 **** } ! if (rl_line_buffer[scan] == '\\') { pass_next = 1; --- 545,553 ---- } ! /* Shell-like semantics for single quotes -- don't allow backslash ! to quote anything in single quotes, especially not the closing ! quote. If you don't like this, take out the check on the value ! of quote_char. */ ! if (quote_char != '\'' && rl_line_buffer[scan] == '\\') { pass_next = 1; *************** *** 672,676 **** char *text; int start, end; ! Function *our_func; int found_quote, quote_char; { --- 649,653 ---- char *text; int start, end; ! rl_compentry_func_t *our_func; int found_quote, quote_char; { *************** *** 696,700 **** temp = (char *)NULL; ! if (found_quote && our_func == (Function *)filename_completion_function && rl_filename_dequoting_function) { --- 673,677 ---- temp = (char *)NULL; ! if (found_quote && our_func == rl_filename_completion_function && rl_filename_dequoting_function) { *************** *** 704,708 **** } ! matches = completion_matches (text, (CPFunction *)our_func); FREE (temp); return matches; --- 681,685 ---- } ! matches = rl_completion_matches (text, our_func); FREE (temp); return matches; *************** *** 776,780 **** char **match_list; int matches; ! char *text; { register int i, c1, c2, si; --- 753,757 ---- char **match_list; int matches; ! const char *text; { register int i, c1, c2, si; *************** *** 902,910 **** /* How many items of MAX length can we fit in the screen window? */ max += 2; ! limit = screenwidth / max; ! if (limit != 1 && (limit * max == screenwidth)) limit--; ! /* Avoid a possible floating exception. If max > screenwidth, limit will be 0 and a divide-by-zero fault will result. */ if (limit == 0) --- 879,887 ---- /* How many items of MAX length can we fit in the screen window? */ max += 2; ! limit = _rl_screenwidth / max; ! if (limit != 1 && (limit * max == _rl_screenwidth)) limit--; ! /* Avoid a possible floating exception. If max > _rl_screenwidth, limit will be 0 and a divide-by-zero fault will result. */ if (limit == 0) *************** *** 922,926 **** qsort (matches + 1, len, sizeof (char *), (QSFUNC *)_rl_qsort_string_compare); ! crlf (); if (_rl_print_completions_horizontally == 0) --- 899,903 ---- qsort (matches + 1, len, sizeof (char *), (QSFUNC *)_rl_qsort_string_compare); ! rl_crlf (); if (_rl_print_completions_horizontally == 0) *************** *** 944,948 **** l += count; } ! crlf (); } } --- 921,925 ---- l += count; } ! rl_crlf (); } } *************** *** 958,962 **** { if (i && (limit > 1) && (i % limit) == 0) ! crlf (); else for (k = 0; k < max - printed_len; k++) --- 935,939 ---- { if (i && (limit > 1) && (i % limit) == 0) ! rl_crlf (); else for (k = 0; k < max - printed_len; k++) *************** *** 964,968 **** } } ! crlf (); } } --- 941,945 ---- } } ! rl_crlf (); } } *************** *** 993,999 **** { temp = printable_part (matches[0]); ! crlf (); print_filename (temp, matches[0]); ! crlf (); rl_forced_update_display (); --- 970,976 ---- { temp = printable_part (matches[0]); ! rl_crlf (); print_filename (temp, matches[0]); ! rl_crlf (); rl_forced_update_display (); *************** *** 1027,1036 **** if (len >= rl_completion_query_items) { ! crlf (); fprintf (rl_outstream, "Display all %d possibilities? (y or n)", len); fflush (rl_outstream); if (get_y_or_n () == 0) { ! crlf (); rl_forced_update_display (); --- 1004,1013 ---- if (len >= rl_completion_query_items) { ! rl_crlf (); fprintf (rl_outstream, "Display all %d possibilities? (y or n)", len); fflush (rl_outstream); if (get_y_or_n () == 0) { ! rl_crlf (); rl_forced_update_display (); *************** *** 1080,1084 **** matches needs to be quoted. */ should_quote = rl_filename_quote_characters ! ? (rl_strpbrk (match, rl_filename_quote_characters) != 0) : 0; --- 1057,1061 ---- matches needs to be quoted. */ should_quote = rl_filename_quote_characters ! ? (_rl_strpbrk (match, rl_filename_quote_characters) != 0) : 0; *************** *** 1233,1241 **** { char **matches; ! Function *our_func; int start, end, delimiter, found_quote, i; char *text, *saved_line_buffer; char quote_char; /* Only the completion entry function can change these. */ rl_filename_completion_desired = 0; --- 1210,1219 ---- { char **matches; ! rl_compentry_func_t *our_func; int start, end, delimiter, found_quote, i; char *text, *saved_line_buffer; char quote_char; + RL_SETSTATE(RL_STATE_COMPLETING); /* Only the completion entry function can change these. */ rl_filename_completion_desired = 0; *************** *** 1246,1250 **** our_func = rl_completion_entry_function ? rl_completion_entry_function ! : (Function *)filename_completion_function; /* We now look backwards for the start of a filename/variable word. */ --- 1224,1228 ---- our_func = rl_completion_entry_function ? rl_completion_entry_function ! : rl_filename_completion_function; /* We now look backwards for the start of a filename/variable word. */ *************** *** 1267,1291 **** if (matches == 0) { ! ding (); FREE (saved_line_buffer); return (0); } - #if 0 - /* If we are matching filenames, our_func will have been set to - filename_completion_function */ - i = our_func == (Function *)filename_completion_function; - #else /* If we are matching filenames, the attempted completion function will have set rl_filename_completion_desired to a non-zero value. The basic ! filename_completion_function does this. */ i = rl_filename_completion_desired; - #endif if (postprocess_matches (&matches, i) == 0) { ! ding (); FREE (saved_line_buffer); completion_changed_buffer = 0; return (0); } --- 1245,1265 ---- if (matches == 0) { ! rl_ding (); FREE (saved_line_buffer); + RL_UNSETSTATE(RL_STATE_COMPLETING); return (0); } /* If we are matching filenames, the attempted completion function will have set rl_filename_completion_desired to a non-zero value. The basic ! rl_filename_completion_function does this. */ i = rl_filename_completion_desired; if (postprocess_matches (&matches, i) == 0) { ! rl_ding (); FREE (saved_line_buffer); completion_changed_buffer = 0; + RL_UNSETSTATE(RL_STATE_COMPLETING); return (0); } *************** *** 1315,1319 **** } else if (rl_editing_mode != vi_mode) ! ding (); /* There are other matches remaining. */ } else --- 1289,1293 ---- } else if (rl_editing_mode != vi_mode) ! rl_ding (); /* There are other matches remaining. */ } else *************** *** 1332,1337 **** default: fprintf (stderr, "\r\nreadline: bad value %d for what_to_do in rl_complete\n", what_to_do); ! ding (); FREE (saved_line_buffer); return 1; } --- 1306,1312 ---- default: fprintf (stderr, "\r\nreadline: bad value %d for what_to_do in rl_complete\n", what_to_do); ! rl_ding (); FREE (saved_line_buffer); + RL_UNSETSTATE(RL_STATE_COMPLETING); return 1; } *************** *** 1346,1349 **** --- 1321,1325 ---- } + RL_UNSETSTATE(RL_STATE_COMPLETING); return 0; } *************** *** 1368,1374 **** */ char ** ! completion_matches (text, entry_function) ! char *text; ! CPFunction *entry_function; { /* Number of slots in match_list. */ --- 1344,1350 ---- */ char ** ! rl_completion_matches (text, entry_function) ! const char *text; ! rl_compentry_func_t *entry_function; { /* Number of slots in match_list. */ *************** *** 1415,1420 **** character (usually `~'). */ char * ! username_completion_function (text, state) ! char *text; int state; { --- 1391,1396 ---- character (usually `~'). */ char * ! rl_username_completion_function (text, state) ! const char *text; int state; { *************** *** 1472,1477 **** completion for a command. */ char * ! filename_completion_function (text, state) ! char *text; int state; { --- 1448,1453 ---- completion for a command. */ char * ! rl_filename_completion_function (text, state) ! const char *text; int state; { *************** *** 1543,1546 **** --- 1519,1525 ---- } + if (rl_directory_rewrite_hook) + (*rl_directory_rewrite_hook) (&dirname); + if (rl_directory_completion_hook && (*rl_directory_completion_hook) (&dirname)) { *************** *** 1642,1647 **** { dirlen = strlen (users_dirname); ! temp = xmalloc (1 + dirlen + D_NAMLEN (entry)); strcpy (temp, users_dirname); } --- 1621,1629 ---- { dirlen = strlen (users_dirname); ! temp = xmalloc (2 + dirlen + D_NAMLEN (entry)); strcpy (temp, users_dirname); + /* Make sure that temp has a trailing slash here. */ + if (users_dirname[dirlen - 1] != '/') + temp[dirlen++] = '/'; } *************** *** 1668,1672 **** int count, ignore; { ! Function *our_func; int matching_filenames, found_quote; --- 1650,1654 ---- int count, ignore; { ! rl_compentry_func_t *our_func; int matching_filenames, found_quote; *************** *** 1698,1702 **** our_func = rl_completion_entry_function ? rl_completion_entry_function ! : (Function *)filename_completion_function; /* We now look backwards for the start of a filename/variable word. */ --- 1680,1684 ---- our_func = rl_completion_entry_function ? rl_completion_entry_function ! : rl_filename_completion_function; /* We now look backwards for the start of a filename/variable word. */ *************** *** 1717,1733 **** our_func, found_quote, quote_char); - #if 0 - /* If we are matching filenames, our_func will have been set to - filename_completion_function */ - matching_filenames = our_func == (Function *)filename_completion_function; - #else /* If we are matching filenames, the attempted completion function will have set rl_filename_completion_desired to a non-zero value. The basic ! filename_completion_function does this. */ matching_filenames = rl_filename_completion_desired; ! #endif if (matches == 0 || postprocess_matches (&matches, matching_filenames) == 0) { ! ding (); FREE (matches); matches = (char **)0; --- 1699,1710 ---- our_func, found_quote, quote_char); /* If we are matching filenames, the attempted completion function will have set rl_filename_completion_desired to a non-zero value. The basic ! rl_filename_completion_function does this. */ matching_filenames = rl_filename_completion_desired; ! if (matches == 0 || postprocess_matches (&matches, matching_filenames) == 0) { ! rl_ding (); FREE (matches); matches = (char **)0; *************** *** 1750,1754 **** if (matches == 0 || match_list_size == 0) { ! ding (); FREE (matches); matches = (char **)0; --- 1727,1731 ---- if (matches == 0 || match_list_size == 0) { ! rl_ding (); FREE (matches); matches = (char **)0; *************** *** 1763,1767 **** if (match_list_index == 0 && match_list_size > 1) { ! ding (); insert_match (orig_text, orig_start, MULT_MATCH, "e_char); } --- 1740,1744 ---- if (match_list_index == 0 && match_list_size > 1) { ! rl_ding (); insert_match (orig_text, orig_start, MULT_MATCH, "e_char); } diff -Nrc2 readline-4.1/config.h.in readline-4.2/config.h.in *** readline-4.1/config.h.in Fri Sep 3 11:54:26 1999 --- readline-4.2/config.h.in Wed Feb 7 13:31:08 2001 *************** *** 1,3 **** ! /* config.h.in. Generated automatically from configure.in by autoheader. */ /* Define if on MINIX. */ --- 1,3 ---- ! /* config.h.in. Maintained by hand. */ /* Define if on MINIX. */ *************** *** 125,129 **** #undef HAVE_POSIX_SIGSETJMP - /* config.h.bot */ /* modify settings or make new ones based on what autoconf tells us. */ --- 125,128 ---- diff -Nrc2 readline-4.1/configure readline-4.2/configure *** readline-4.1/configure Wed Mar 1 14:52:41 2000 --- readline-4.2/configure Mon Apr 2 15:56:02 2001 *************** *** 1,6 **** #! /bin/sh ! # From configure.in for Readline 4.1, version 2.22, from autoconf version 2.13 ! LIBVERSION=4.1 --- 1,8 ---- #! /bin/sh ! # From configure.in for Readline 4.2, version 2.26, from autoconf version 2.13 ! LIBVERSION=4.2 ! ! *************** *** 658,662 **** echo $ac_n "checking host system type""... $ac_c" 1>&6 ! echo "configure:661: checking host system type" >&5 host_alias=$host --- 660,664 ---- echo $ac_n "checking host system type""... $ac_c" 1>&6 ! echo "configure:663: checking host system type" >&5 host_alias=$host *************** *** 696,703 **** test -z "$CFLAGS" && CFLAGS=-g auto_cflags=1 # Extract the first word of "gcc", so it can be a program name with args. set dummy gcc; ac_word=$2 echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 ! echo "configure:702: checking for $ac_word" >&5 if eval "test \"`echo '$''{'ac_cv_prog_CC'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 --- 698,732 ---- test -z "$CFLAGS" && CFLAGS=-g auto_cflags=1 + echo $ac_n "checking whether ${MAKE-make} sets \${MAKE}""... $ac_c" 1>&6 + echo "configure:702: checking whether ${MAKE-make} sets \${MAKE}" >&5 + set dummy ${MAKE-make}; ac_make=`echo "$2" | sed 'y%./+-%__p_%'` + if eval "test \"`echo '$''{'ac_cv_prog_make_${ac_make}_set'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 + else + cat > conftestmake <<\EOF + all: + @echo 'ac_maketemp="${MAKE}"' + EOF + # GNU make sometimes prints "make[1]: Entering...", which would confuse us. + eval `${MAKE-make} -f conftestmake 2>/dev/null | grep temp=` + if test -n "$ac_maketemp"; then + eval ac_cv_prog_make_${ac_make}_set=yes + else + eval ac_cv_prog_make_${ac_make}_set=no + fi + rm -f conftestmake + fi + if eval "test \"`echo '$ac_cv_prog_make_'${ac_make}_set`\" = yes"; then + echo "$ac_t""yes" 1>&6 + SET_MAKE= + else + echo "$ac_t""no" 1>&6 + SET_MAKE="MAKE=${MAKE-make}" + fi + # Extract the first word of "gcc", so it can be a program name with args. set dummy gcc; ac_word=$2 echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 ! echo "configure:731: checking for $ac_word" >&5 if eval "test \"`echo '$''{'ac_cv_prog_CC'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 *************** *** 729,733 **** set dummy cc; ac_word=$2 echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 ! echo "configure:732: checking for $ac_word" >&5 if eval "test \"`echo '$''{'ac_cv_prog_CC'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 --- 758,762 ---- set dummy cc; ac_word=$2 echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 ! echo "configure:761: checking for $ac_word" >&5 if eval "test \"`echo '$''{'ac_cv_prog_CC'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 *************** *** 780,784 **** set dummy cl; ac_word=$2 echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 ! echo "configure:783: checking for $ac_word" >&5 if eval "test \"`echo '$''{'ac_cv_prog_CC'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 --- 809,813 ---- set dummy cl; ac_word=$2 echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 ! echo "configure:812: checking for $ac_word" >&5 if eval "test \"`echo '$''{'ac_cv_prog_CC'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 *************** *** 812,816 **** echo $ac_n "checking whether the C compiler ($CC $CFLAGS $LDFLAGS) works""... $ac_c" 1>&6 ! echo "configure:815: checking whether the C compiler ($CC $CFLAGS $LDFLAGS) works" >&5 ac_ext=c --- 841,845 ---- echo $ac_n "checking whether the C compiler ($CC $CFLAGS $LDFLAGS) works""... $ac_c" 1>&6 ! echo "configure:844: checking whether the C compiler ($CC $CFLAGS $LDFLAGS) works" >&5 ac_ext=c *************** *** 823,832 **** cat > conftest.$ac_ext << EOF ! #line 826 "configure" #include "confdefs.h" main(){return(0);} EOF ! if { (eval echo configure:831: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then ac_cv_prog_cc_works=yes # If we can't run a trivial program, we are probably using a cross compiler. --- 852,861 ---- cat > conftest.$ac_ext << EOF ! #line 855 "configure" #include "confdefs.h" main(){return(0);} EOF ! if { (eval echo configure:860: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then ac_cv_prog_cc_works=yes # If we can't run a trivial program, we are probably using a cross compiler. *************** *** 854,863 **** fi echo $ac_n "checking whether the C compiler ($CC $CFLAGS $LDFLAGS) is a cross-compiler""... $ac_c" 1>&6 ! echo "configure:857: checking whether the C compiler ($CC $CFLAGS $LDFLAGS) is a cross-compiler" >&5 echo "$ac_t""$ac_cv_prog_cc_cross" 1>&6 cross_compiling=$ac_cv_prog_cc_cross echo $ac_n "checking whether we are using GNU C""... $ac_c" 1>&6 ! echo "configure:862: checking whether we are using GNU C" >&5 if eval "test \"`echo '$''{'ac_cv_prog_gcc'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 --- 883,892 ---- fi echo $ac_n "checking whether the C compiler ($CC $CFLAGS $LDFLAGS) is a cross-compiler""... $ac_c" 1>&6 ! echo "configure:886: checking whether the C compiler ($CC $CFLAGS $LDFLAGS) is a cross-compiler" >&5 echo "$ac_t""$ac_cv_prog_cc_cross" 1>&6 cross_compiling=$ac_cv_prog_cc_cross echo $ac_n "checking whether we are using GNU C""... $ac_c" 1>&6 ! echo "configure:891: checking whether we are using GNU C" >&5 if eval "test \"`echo '$''{'ac_cv_prog_gcc'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 *************** *** 868,872 **** #endif EOF ! if { ac_try='${CC-cc} -E conftest.c'; { (eval echo configure:871: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; }; } | egrep yes >/dev/null 2>&1; then ac_cv_prog_gcc=yes else --- 897,901 ---- #endif EOF ! if { ac_try='${CC-cc} -E conftest.c'; { (eval echo configure:900: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; }; } | egrep yes >/dev/null 2>&1; then ac_cv_prog_gcc=yes else *************** *** 887,891 **** CFLAGS= echo $ac_n "checking whether ${CC-cc} accepts -g""... $ac_c" 1>&6 ! echo "configure:890: checking whether ${CC-cc} accepts -g" >&5 if eval "test \"`echo '$''{'ac_cv_prog_cc_g'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 --- 916,920 ---- CFLAGS= echo $ac_n "checking whether ${CC-cc} accepts -g""... $ac_c" 1>&6 ! echo "configure:919: checking whether ${CC-cc} accepts -g" >&5 if eval "test \"`echo '$''{'ac_cv_prog_cc_g'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 *************** *** 919,923 **** echo $ac_n "checking how to run the C preprocessor""... $ac_c" 1>&6 ! echo "configure:922: checking how to run the C preprocessor" >&5 # On Suns, sometimes $CPP names a directory. if test -n "$CPP" && test -d "$CPP"; then --- 948,952 ---- echo $ac_n "checking how to run the C preprocessor""... $ac_c" 1>&6 ! echo "configure:951: checking how to run the C preprocessor" >&5 # On Suns, sometimes $CPP names a directory. if test -n "$CPP" && test -d "$CPP"; then *************** *** 934,938 **** # not just through cpp. cat > conftest.$ac_ext < --- 963,967 ---- # not just through cpp. cat > conftest.$ac_ext < *************** *** 940,944 **** EOF ac_try="$ac_cpp conftest.$ac_ext >/dev/null 2>conftest.out" ! { (eval echo configure:943: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; } ac_err=`grep -v '^ *+' conftest.out | grep -v "^conftest.${ac_ext}\$"` if test -z "$ac_err"; then --- 969,973 ---- EOF ac_try="$ac_cpp conftest.$ac_ext >/dev/null 2>conftest.out" ! { (eval echo configure:972: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; } ac_err=`grep -v '^ *+' conftest.out | grep -v "^conftest.${ac_ext}\$"` if test -z "$ac_err"; then *************** *** 951,955 **** CPP="${CC-cc} -E -traditional-cpp" cat > conftest.$ac_ext < --- 980,984 ---- CPP="${CC-cc} -E -traditional-cpp" cat > conftest.$ac_ext < *************** *** 957,961 **** EOF ac_try="$ac_cpp conftest.$ac_ext >/dev/null 2>conftest.out" ! { (eval echo configure:960: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; } ac_err=`grep -v '^ *+' conftest.out | grep -v "^conftest.${ac_ext}\$"` if test -z "$ac_err"; then --- 986,990 ---- EOF ac_try="$ac_cpp conftest.$ac_ext >/dev/null 2>conftest.out" ! { (eval echo configure:989: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; } ac_err=`grep -v '^ *+' conftest.out | grep -v "^conftest.${ac_ext}\$"` if test -z "$ac_err"; then *************** *** 968,972 **** CPP="${CC-cc} -nologo -E" cat > conftest.$ac_ext < --- 997,1001 ---- CPP="${CC-cc} -nologo -E" cat > conftest.$ac_ext < *************** *** 974,978 **** EOF ac_try="$ac_cpp conftest.$ac_ext >/dev/null 2>conftest.out" ! { (eval echo configure:977: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; } ac_err=`grep -v '^ *+' conftest.out | grep -v "^conftest.${ac_ext}\$"` if test -z "$ac_err"; then --- 1003,1007 ---- EOF ac_try="$ac_cpp conftest.$ac_ext >/dev/null 2>conftest.out" ! { (eval echo configure:1006: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; } ac_err=`grep -v '^ *+' conftest.out | grep -v "^conftest.${ac_ext}\$"` if test -z "$ac_err"; then *************** *** 1000,1014 **** ac_safe=`echo "minix/config.h" | sed 'y%./+-%__p_%'` echo $ac_n "checking for minix/config.h""... $ac_c" 1>&6 ! echo "configure:1003: checking for minix/config.h" >&5 if eval "test \"`echo '$''{'ac_cv_header_$ac_safe'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < EOF ac_try="$ac_cpp conftest.$ac_ext >/dev/null 2>conftest.out" ! { (eval echo configure:1013: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; } ac_err=`grep -v '^ *+' conftest.out | grep -v "^conftest.${ac_ext}\$"` if test -z "$ac_err"; then --- 1029,1043 ---- ac_safe=`echo "minix/config.h" | sed 'y%./+-%__p_%'` echo $ac_n "checking for minix/config.h""... $ac_c" 1>&6 ! echo "configure:1032: checking for minix/config.h" >&5 if eval "test \"`echo '$''{'ac_cv_header_$ac_safe'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < EOF ac_try="$ac_cpp conftest.$ac_ext >/dev/null 2>conftest.out" ! { (eval echo configure:1042: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; } ac_err=`grep -v '^ *+' conftest.out | grep -v "^conftest.${ac_ext}\$"` if test -z "$ac_err"; then *************** *** 1053,1057 **** if test $ac_cv_prog_gcc = yes; then echo $ac_n "checking whether ${CC-cc} needs -traditional""... $ac_c" 1>&6 ! echo "configure:1056: checking whether ${CC-cc} needs -traditional" >&5 if eval "test \"`echo '$''{'ac_cv_prog_gcc_traditional'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 --- 1082,1086 ---- if test $ac_cv_prog_gcc = yes; then echo $ac_n "checking whether ${CC-cc} needs -traditional""... $ac_c" 1>&6 ! echo "configure:1085: checking whether ${CC-cc} needs -traditional" >&5 if eval "test \"`echo '$''{'ac_cv_prog_gcc_traditional'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 *************** *** 1059,1063 **** ac_pattern="Autoconf.*'x'" cat > conftest.$ac_ext < --- 1088,1092 ---- ac_pattern="Autoconf.*'x'" cat > conftest.$ac_ext < *************** *** 1077,1081 **** if test $ac_cv_prog_gcc_traditional = no; then cat > conftest.$ac_ext < --- 1106,1110 ---- if test $ac_cv_prog_gcc_traditional = no; then cat > conftest.$ac_ext < *************** *** 1110,1114 **** # ./install, which can be erroneously created by make from ./install.sh. echo $ac_n "checking for a BSD compatible install""... $ac_c" 1>&6 ! echo "configure:1113: checking for a BSD compatible install" >&5 if test -z "$INSTALL"; then if eval "test \"`echo '$''{'ac_cv_path_install'+set}'`\" = set"; then --- 1139,1143 ---- # ./install, which can be erroneously created by make from ./install.sh. echo $ac_n "checking for a BSD compatible install""... $ac_c" 1>&6 ! echo "configure:1142: checking for a BSD compatible install" >&5 if test -z "$INSTALL"; then if eval "test \"`echo '$''{'ac_cv_path_install'+set}'`\" = set"; then *************** *** 1165,1169 **** set dummy ar; ac_word=$2 echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 ! echo "configure:1168: checking for $ac_word" >&5 if eval "test \"`echo '$''{'ac_cv_prog_AR'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 --- 1194,1198 ---- set dummy ar; ac_word=$2 echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 ! echo "configure:1197: checking for $ac_word" >&5 if eval "test \"`echo '$''{'ac_cv_prog_AR'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 *************** *** 1195,1199 **** set dummy ranlib; ac_word=$2 echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 ! echo "configure:1198: checking for $ac_word" >&5 if eval "test \"`echo '$''{'ac_cv_prog_RANLIB'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 --- 1224,1228 ---- set dummy ranlib; ac_word=$2 echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 ! echo "configure:1227: checking for $ac_word" >&5 if eval "test \"`echo '$''{'ac_cv_prog_RANLIB'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 *************** *** 1227,1236 **** echo $ac_n "checking return type of signal handlers""... $ac_c" 1>&6 ! echo "configure:1230: checking return type of signal handlers" >&5 if eval "test \"`echo '$''{'ac_cv_type_signal'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < --- 1256,1265 ---- echo $ac_n "checking return type of signal handlers""... $ac_c" 1>&6 ! echo "configure:1259: checking return type of signal handlers" >&5 if eval "test \"`echo '$''{'ac_cv_type_signal'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < *************** *** 1249,1253 **** ; return 0; } EOF ! if { (eval echo configure:1252: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* ac_cv_type_signal=void --- 1278,1282 ---- ; return 0; } EOF ! if { (eval echo configure:1281: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* ac_cv_type_signal=void *************** *** 1269,1278 **** echo $ac_n "checking whether stat file-mode macros are broken""... $ac_c" 1>&6 ! echo "configure:1272: checking whether stat file-mode macros are broken" >&5 if eval "test \"`echo '$''{'ac_cv_header_stat_broken'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < --- 1298,1307 ---- echo $ac_n "checking whether stat file-mode macros are broken""... $ac_c" 1>&6 ! echo "configure:1301: checking whether stat file-mode macros are broken" >&5 if eval "test \"`echo '$''{'ac_cv_header_stat_broken'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < *************** *** 1329,1338 **** ac_safe=`echo "$ac_hdr" | sed 'y%./+-%__p_%'` echo $ac_n "checking for $ac_hdr that defines DIR""... $ac_c" 1>&6 ! echo "configure:1332: checking for $ac_hdr that defines DIR" >&5 if eval "test \"`echo '$''{'ac_cv_header_dirent_$ac_safe'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < --- 1358,1367 ---- ac_safe=`echo "$ac_hdr" | sed 'y%./+-%__p_%'` echo $ac_n "checking for $ac_hdr that defines DIR""... $ac_c" 1>&6 ! echo "configure:1361: checking for $ac_hdr that defines DIR" >&5 if eval "test \"`echo '$''{'ac_cv_header_dirent_$ac_safe'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < *************** *** 1342,1346 **** ; return 0; } EOF ! if { (eval echo configure:1345: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* eval "ac_cv_header_dirent_$ac_safe=yes" --- 1371,1375 ---- ; return 0; } EOF ! if { (eval echo configure:1374: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* eval "ac_cv_header_dirent_$ac_safe=yes" *************** *** 1367,1371 **** if test $ac_header_dirent = dirent.h; then echo $ac_n "checking for opendir in -ldir""... $ac_c" 1>&6 ! echo "configure:1370: checking for opendir in -ldir" >&5 ac_lib_var=`echo dir'_'opendir | sed 'y%./+-%__p_%'` if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then --- 1396,1400 ---- if test $ac_header_dirent = dirent.h; then echo $ac_n "checking for opendir in -ldir""... $ac_c" 1>&6 ! echo "configure:1399: checking for opendir in -ldir" >&5 ac_lib_var=`echo dir'_'opendir | sed 'y%./+-%__p_%'` if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then *************** *** 1375,1379 **** LIBS="-ldir $LIBS" cat > conftest.$ac_ext < conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* eval "ac_cv_lib_$ac_lib_var=yes" --- 1415,1419 ---- ; return 0; } EOF ! if { (eval echo configure:1418: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* eval "ac_cv_lib_$ac_lib_var=yes" *************** *** 1408,1412 **** else echo $ac_n "checking for opendir in -lx""... $ac_c" 1>&6 ! echo "configure:1411: checking for opendir in -lx" >&5 ac_lib_var=`echo x'_'opendir | sed 'y%./+-%__p_%'` if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then --- 1437,1441 ---- else echo $ac_n "checking for opendir in -lx""... $ac_c" 1>&6 ! echo "configure:1440: checking for opendir in -lx" >&5 ac_lib_var=`echo x'_'opendir | sed 'y%./+-%__p_%'` if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then *************** *** 1416,1420 **** LIBS="-lx $LIBS" cat > conftest.$ac_ext < conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* eval "ac_cv_lib_$ac_lib_var=yes" --- 1456,1460 ---- ; return 0; } EOF ! if { (eval echo configure:1459: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* eval "ac_cv_lib_$ac_lib_var=yes" *************** *** 1454,1463 **** do echo $ac_n "checking for $ac_func""... $ac_c" 1>&6 ! echo "configure:1457: checking for $ac_func" >&5 if eval "test \"`echo '$''{'ac_cv_func_$ac_func'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext <&6 ! echo "configure:1486: checking for $ac_func" >&5 if eval "test \"`echo '$''{'ac_cv_func_$ac_func'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* eval "ac_cv_func_$ac_func=yes" --- 1511,1515 ---- ; return 0; } EOF ! if { (eval echo configure:1514: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* eval "ac_cv_func_$ac_func=yes" *************** *** 1508,1512 **** echo $ac_n "checking for working strcoll""... $ac_c" 1>&6 ! echo "configure:1511: checking for working strcoll" >&5 if eval "test \"`echo '$''{'ac_cv_func_strcoll_works'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 --- 1537,1541 ---- echo $ac_n "checking for working strcoll""... $ac_c" 1>&6 ! echo "configure:1540: checking for working strcoll" >&5 if eval "test \"`echo '$''{'ac_cv_func_strcoll_works'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 *************** *** 1516,1520 **** else cat > conftest.$ac_ext < --- 1545,1549 ---- else cat > conftest.$ac_ext < *************** *** 1526,1530 **** } EOF ! if { (eval echo configure:1529: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext} && (./conftest; exit) 2>/dev/null then ac_cv_func_strcoll_works=yes --- 1555,1559 ---- } EOF ! if { (eval echo configure:1558: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext} && (./conftest; exit) 2>/dev/null then ac_cv_func_strcoll_works=yes *************** *** 1555,1569 **** ac_safe=`echo "$ac_hdr" | sed 'y%./+-%__p_%'` echo $ac_n "checking for $ac_hdr""... $ac_c" 1>&6 ! echo "configure:1558: checking for $ac_hdr" >&5 if eval "test \"`echo '$''{'ac_cv_header_$ac_safe'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < EOF ac_try="$ac_cpp conftest.$ac_ext >/dev/null 2>conftest.out" ! { (eval echo configure:1568: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; } ac_err=`grep -v '^ *+' conftest.out | grep -v "^conftest.${ac_ext}\$"` if test -z "$ac_err"; then --- 1584,1598 ---- ac_safe=`echo "$ac_hdr" | sed 'y%./+-%__p_%'` echo $ac_n "checking for $ac_hdr""... $ac_c" 1>&6 ! echo "configure:1587: checking for $ac_hdr" >&5 if eval "test \"`echo '$''{'ac_cv_header_$ac_safe'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < EOF ac_try="$ac_cpp conftest.$ac_ext >/dev/null 2>conftest.out" ! { (eval echo configure:1597: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; } ac_err=`grep -v '^ *+' conftest.out | grep -v "^conftest.${ac_ext}\$"` if test -z "$ac_err"; then *************** *** 1594,1598 **** echo $ac_n "checking for type of signal functions""... $ac_c" 1>&6 ! echo "configure:1597: checking for type of signal functions" >&5 if eval "test \"`echo '$''{'bash_cv_signal_vintage'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 --- 1623,1627 ---- echo $ac_n "checking for type of signal functions""... $ac_c" 1>&6 ! echo "configure:1626: checking for type of signal functions" >&5 if eval "test \"`echo '$''{'bash_cv_signal_vintage'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 *************** *** 1600,1604 **** cat > conftest.$ac_ext < --- 1629,1633 ---- cat > conftest.$ac_ext < *************** *** 1613,1617 **** ; return 0; } EOF ! if { (eval echo configure:1616: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* bash_cv_signal_vintage=posix --- 1642,1646 ---- ; return 0; } EOF ! if { (eval echo configure:1645: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* bash_cv_signal_vintage=posix *************** *** 1622,1626 **** cat > conftest.$ac_ext < --- 1651,1655 ---- cat > conftest.$ac_ext < *************** *** 1632,1636 **** ; return 0; } EOF ! if { (eval echo configure:1635: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* bash_cv_signal_vintage=4.2bsd --- 1661,1665 ---- ; return 0; } EOF ! if { (eval echo configure:1664: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* bash_cv_signal_vintage=4.2bsd *************** *** 1641,1645 **** cat > conftest.$ac_ext < conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* bash_cv_signal_vintage=svr3 --- 1683,1687 ---- ; return 0; } EOF ! if { (eval echo configure:1686: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* bash_cv_signal_vintage=svr3 *************** *** 1695,1699 **** echo $ac_n "checking if signal handlers must be reinstalled when invoked""... $ac_c" 1>&6 ! echo "configure:1698: checking if signal handlers must be reinstalled when invoked" >&5 if eval "test \"`echo '$''{'bash_cv_must_reinstall_sighandlers'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 --- 1724,1728 ---- echo $ac_n "checking if signal handlers must be reinstalled when invoked""... $ac_c" 1>&6 ! echo "configure:1727: checking if signal handlers must be reinstalled when invoked" >&5 if eval "test \"`echo '$''{'bash_cv_must_reinstall_sighandlers'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 *************** *** 1705,1709 **** else cat > conftest.$ac_ext < conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext} && (./conftest; exit) 2>/dev/null then bash_cv_must_reinstall_sighandlers=no --- 1781,1785 ---- EOF ! if { (eval echo configure:1784: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext} && (./conftest; exit) 2>/dev/null then bash_cv_must_reinstall_sighandlers=no *************** *** 1777,1781 **** echo $ac_n "checking for presence of POSIX-style sigsetjmp/siglongjmp""... $ac_c" 1>&6 ! echo "configure:1780: checking for presence of POSIX-style sigsetjmp/siglongjmp" >&5 if eval "test \"`echo '$''{'bash_cv_func_sigsetjmp'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 --- 1806,1810 ---- echo $ac_n "checking for presence of POSIX-style sigsetjmp/siglongjmp""... $ac_c" 1>&6 ! echo "configure:1809: checking for presence of POSIX-style sigsetjmp/siglongjmp" >&5 if eval "test \"`echo '$''{'bash_cv_func_sigsetjmp'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 *************** *** 1787,1791 **** else cat > conftest.$ac_ext < conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext} && (./conftest; exit) 2>/dev/null then bash_cv_func_sigsetjmp=present --- 1857,1861 ---- } EOF ! if { (eval echo configure:1860: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext} && (./conftest; exit) 2>/dev/null then bash_cv_func_sigsetjmp=present *************** *** 1851,1860 **** echo $ac_n "checking for lstat""... $ac_c" 1>&6 ! echo "configure:1854: checking for lstat" >&5 if eval "test \"`echo '$''{'bash_cv_func_lstat'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext <&6 ! echo "configure:1883: checking for lstat" >&5 if eval "test \"`echo '$''{'bash_cv_func_lstat'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* bash_cv_func_lstat=yes --- 1895,1899 ---- ; return 0; } EOF ! if { (eval echo configure:1898: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* bash_cv_func_lstat=yes *************** *** 1886,1920 **** fi ! echo $ac_n "checking whether programs are able to redeclare getpw functions""... $ac_c" 1>&6 ! echo "configure:1890: checking whether programs are able to redeclare getpw functions" >&5 ! if eval "test \"`echo '$''{'bash_cv_can_redecl_getpw'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < #include ! extern struct passwd *getpwent(); ! extern struct passwd *getpwuid(); ! extern struct passwd *getpwnam(); ! int main() { ! struct passwd *z; z = getpwent(); z = getpwuid(0); z = getpwnam("root"); ! ; return 0; } EOF ! if { (eval echo configure:1906: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* ! bash_cv_can_redecl_getpw=yes else - echo "configure: failed program was:" >&5 - cat conftest.$ac_ext >&5 rm -rf conftest* ! bash_cv_can_redecl_getpw=no fi rm -f conftest* fi ! echo "$ac_t""$bash_cv_can_redecl_getpw" 1>&6 ! if test $bash_cv_can_redecl_getpw = no; then cat >> confdefs.h <<\EOF #define HAVE_GETPW_DECLS 1 --- 1915,1948 ---- fi ! echo $ac_n "checking whether getpw functions are declared in pwd.h""... $ac_c" 1>&6 ! echo "configure:1919: checking whether getpw functions are declared in pwd.h" >&5 ! if eval "test \"`echo '$''{'bash_cv_getpw_declared'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < + #ifdef HAVE_UNISTD_H + # include + #endif #include ! EOF ! if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | ! egrep "getpwuid" >/dev/null 2>&1; then rm -rf conftest* ! bash_cv_getpw_declared=yes else rm -rf conftest* ! bash_cv_getpw_declared=no fi rm -f conftest* + fi ! echo "$ac_t""$bash_cv_getpw_declared" 1>&6 ! if test $bash_cv_getpw_declared = yes; then cat >> confdefs.h <<\EOF #define HAVE_GETPW_DECLS 1 *************** *** 1925,1929 **** echo $ac_n "checking whether or not strcoll and strcmp differ""... $ac_c" 1>&6 ! echo "configure:1928: checking whether or not strcoll and strcmp differ" >&5 if eval "test \"`echo '$''{'bash_cv_func_strcoll_broken'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 --- 1953,1957 ---- echo $ac_n "checking whether or not strcoll and strcmp differ""... $ac_c" 1>&6 ! echo "configure:1956: checking whether or not strcoll and strcmp differ" >&5 if eval "test \"`echo '$''{'bash_cv_func_strcoll_broken'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 *************** *** 1935,1939 **** else cat > conftest.$ac_ext < conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext} && (./conftest; exit) 2>/dev/null then bash_cv_func_strcoll_broken=yes --- 2002,2006 ---- EOF ! if { (eval echo configure:2005: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext} && (./conftest; exit) 2>/dev/null then bash_cv_func_strcoll_broken=yes *************** *** 1998,2007 **** echo $ac_n "checking whether signal handlers are of type void""... $ac_c" 1>&6 ! echo "configure:2001: checking whether signal handlers are of type void" >&5 if eval "test \"`echo '$''{'bash_cv_void_sighandler'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < --- 2026,2035 ---- echo $ac_n "checking whether signal handlers are of type void""... $ac_c" 1>&6 ! echo "configure:2029: checking whether signal handlers are of type void" >&5 if eval "test \"`echo '$''{'bash_cv_void_sighandler'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < *************** *** 2018,2022 **** ; return 0; } EOF ! if { (eval echo configure:2021: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* bash_cv_void_sighandler=yes --- 2046,2050 ---- ; return 0; } EOF ! if { (eval echo configure:2049: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* bash_cv_void_sighandler=yes *************** *** 2038,2047 **** echo $ac_n "checking for TIOCGWINSZ in sys/ioctl.h""... $ac_c" 1>&6 ! echo "configure:2041: checking for TIOCGWINSZ in sys/ioctl.h" >&5 if eval "test \"`echo '$''{'bash_cv_tiocgwinsz_in_ioctl'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < --- 2066,2075 ---- echo $ac_n "checking for TIOCGWINSZ in sys/ioctl.h""... $ac_c" 1>&6 ! echo "configure:2069: checking for TIOCGWINSZ in sys/ioctl.h" >&5 if eval "test \"`echo '$''{'bash_cv_tiocgwinsz_in_ioctl'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < *************** *** 2051,2055 **** ; return 0; } EOF ! if { (eval echo configure:2054: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* bash_cv_tiocgwinsz_in_ioctl=yes --- 2079,2083 ---- ; return 0; } EOF ! if { (eval echo configure:2082: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* bash_cv_tiocgwinsz_in_ioctl=yes *************** *** 2072,2081 **** echo $ac_n "checking for TIOCSTAT in sys/ioctl.h""... $ac_c" 1>&6 ! echo "configure:2075: checking for TIOCSTAT in sys/ioctl.h" >&5 if eval "test \"`echo '$''{'bash_cv_tiocstat_in_ioctl'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < --- 2100,2109 ---- echo $ac_n "checking for TIOCSTAT in sys/ioctl.h""... $ac_c" 1>&6 ! echo "configure:2103: checking for TIOCSTAT in sys/ioctl.h" >&5 if eval "test \"`echo '$''{'bash_cv_tiocstat_in_ioctl'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < *************** *** 2085,2089 **** ; return 0; } EOF ! if { (eval echo configure:2088: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* bash_cv_tiocstat_in_ioctl=yes --- 2113,2117 ---- ; return 0; } EOF ! if { (eval echo configure:2116: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* bash_cv_tiocstat_in_ioctl=yes *************** *** 2106,2115 **** echo $ac_n "checking for FIONREAD in sys/ioctl.h""... $ac_c" 1>&6 ! echo "configure:2109: checking for FIONREAD in sys/ioctl.h" >&5 if eval "test \"`echo '$''{'bash_cv_fionread_in_ioctl'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < --- 2134,2143 ---- echo $ac_n "checking for FIONREAD in sys/ioctl.h""... $ac_c" 1>&6 ! echo "configure:2137: checking for FIONREAD in sys/ioctl.h" >&5 if eval "test \"`echo '$''{'bash_cv_fionread_in_ioctl'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < *************** *** 2119,2123 **** ; return 0; } EOF ! if { (eval echo configure:2122: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* bash_cv_fionread_in_ioctl=yes --- 2147,2151 ---- ; return 0; } EOF ! if { (eval echo configure:2150: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* bash_cv_fionread_in_ioctl=yes *************** *** 2140,2149 **** echo $ac_n "checking for speed_t in sys/types.h""... $ac_c" 1>&6 ! echo "configure:2143: checking for speed_t in sys/types.h" >&5 if eval "test \"`echo '$''{'bash_cv_speed_t_in_sys_types'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < --- 2168,2177 ---- echo $ac_n "checking for speed_t in sys/types.h""... $ac_c" 1>&6 ! echo "configure:2171: checking for speed_t in sys/types.h" >&5 if eval "test \"`echo '$''{'bash_cv_speed_t_in_sys_types'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < *************** *** 2152,2156 **** ; return 0; } EOF ! if { (eval echo configure:2155: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* bash_cv_speed_t_in_sys_types=yes --- 2180,2184 ---- ; return 0; } EOF ! if { (eval echo configure:2183: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* bash_cv_speed_t_in_sys_types=yes *************** *** 2173,2182 **** echo $ac_n "checking for struct winsize in sys/ioctl.h and termios.h""... $ac_c" 1>&6 ! echo "configure:2176: checking for struct winsize in sys/ioctl.h and termios.h" >&5 if eval "test \"`echo '$''{'bash_cv_struct_winsize_header'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < --- 2201,2210 ---- echo $ac_n "checking for struct winsize in sys/ioctl.h and termios.h""... $ac_c" 1>&6 ! echo "configure:2204: checking for struct winsize in sys/ioctl.h and termios.h" >&5 if eval "test \"`echo '$''{'bash_cv_struct_winsize_header'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext < *************** *** 2186,2190 **** ; return 0; } EOF ! if { (eval echo configure:2189: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* bash_cv_struct_winsize_header=ioctl_h --- 2214,2218 ---- ; return 0; } EOF ! if { (eval echo configure:2217: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* bash_cv_struct_winsize_header=ioctl_h *************** *** 2194,2198 **** rm -rf conftest* cat > conftest.$ac_ext < --- 2222,2226 ---- rm -rf conftest* cat > conftest.$ac_ext < *************** *** 2202,2206 **** ; return 0; } EOF ! if { (eval echo configure:2205: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* bash_cv_struct_winsize_header=termios_h --- 2230,2234 ---- ; return 0; } EOF ! if { (eval echo configure:2233: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* bash_cv_struct_winsize_header=termios_h *************** *** 2235,2244 **** echo $ac_n "checking if struct dirent has a d_ino member""... $ac_c" 1>&6 ! echo "configure:2238: checking if struct dirent has a d_ino member" >&5 if eval "test \"`echo '$''{'bash_cv_dirent_has_dino'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext <&6 ! echo "configure:2266: checking if struct dirent has a d_ino member" >&5 if eval "test \"`echo '$''{'bash_cv_dirent_has_dino'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext <&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* bash_cv_dirent_has_dino=yes --- 2297,2301 ---- ; return 0; } EOF ! if { (eval echo configure:2300: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* bash_cv_dirent_has_dino=yes *************** *** 2291,2300 **** echo $ac_n "checking if struct dirent has a d_fileno member""... $ac_c" 1>&6 ! echo "configure:2294: checking if struct dirent has a d_fileno member" >&5 if eval "test \"`echo '$''{'bash_cv_dirent_has_d_fileno'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext <&6 ! echo "configure:2322: checking if struct dirent has a d_fileno member" >&5 if eval "test \"`echo '$''{'bash_cv_dirent_has_d_fileno'+set}'`\" = set"; then echo $ac_n "(cached) $ac_c" 1>&6 else cat > conftest.$ac_ext <&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* bash_cv_dirent_has_d_fileno=yes --- 2353,2357 ---- ; return 0; } EOF ! if { (eval echo configure:2356: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then rm -rf conftest* bash_cv_dirent_has_d_fileno=yes *************** *** 2354,2358 **** else echo $ac_n "checking which library has the termcap functions""... $ac_c" 1>&6 ! echo "configure:2357: checking which library has the termcap functions" >&5 _bash_needmsg= fi --- 2382,2386 ---- else echo $ac_n "checking which library has the termcap functions""... $ac_c" 1>&6 ! echo "configure:2385: checking which library has the termcap functions" >&5 _bash_needmsg= fi *************** *** 2361,2365 **** else echo $ac_n "checking for tgetent in -ltermcap""... $ac_c" 1>&6 ! echo "configure:2364: checking for tgetent in -ltermcap" >&5 ac_lib_var=`echo termcap'_'tgetent | sed 'y%./+-%__p_%'` if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then --- 2389,2393 ---- else echo $ac_n "checking for tgetent in -ltermcap""... $ac_c" 1>&6 ! echo "configure:2392: checking for tgetent in -ltermcap" >&5 ac_lib_var=`echo termcap'_'tgetent | sed 'y%./+-%__p_%'` if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then *************** *** 2369,2373 **** LIBS="-ltermcap $LIBS" cat > conftest.$ac_ext < conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* eval "ac_cv_lib_$ac_lib_var=yes" --- 2408,2412 ---- ; return 0; } EOF ! if { (eval echo configure:2411: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* eval "ac_cv_lib_$ac_lib_var=yes" *************** *** 2399,2403 **** echo "$ac_t""no" 1>&6 echo $ac_n "checking for tgetent in -lcurses""... $ac_c" 1>&6 ! echo "configure:2402: checking for tgetent in -lcurses" >&5 ac_lib_var=`echo curses'_'tgetent | sed 'y%./+-%__p_%'` if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then --- 2427,2431 ---- echo "$ac_t""no" 1>&6 echo $ac_n "checking for tgetent in -lcurses""... $ac_c" 1>&6 ! echo "configure:2430: checking for tgetent in -lcurses" >&5 ac_lib_var=`echo curses'_'tgetent | sed 'y%./+-%__p_%'` if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then *************** *** 2407,2411 **** LIBS="-lcurses $LIBS" cat > conftest.$ac_ext < conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* eval "ac_cv_lib_$ac_lib_var=yes" --- 2446,2450 ---- ; return 0; } EOF ! if { (eval echo configure:2449: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* eval "ac_cv_lib_$ac_lib_var=yes" *************** *** 2437,2441 **** echo "$ac_t""no" 1>&6 echo $ac_n "checking for tgetent in -lncurses""... $ac_c" 1>&6 ! echo "configure:2440: checking for tgetent in -lncurses" >&5 ac_lib_var=`echo ncurses'_'tgetent | sed 'y%./+-%__p_%'` if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then --- 2465,2469 ---- echo "$ac_t""no" 1>&6 echo $ac_n "checking for tgetent in -lncurses""... $ac_c" 1>&6 ! echo "configure:2468: checking for tgetent in -lncurses" >&5 ac_lib_var=`echo ncurses'_'tgetent | sed 'y%./+-%__p_%'` if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then *************** *** 2445,2449 **** LIBS="-lncurses $LIBS" cat > conftest.$ac_ext < conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* eval "ac_cv_lib_$ac_lib_var=yes" --- 2484,2488 ---- ; return 0; } EOF ! if { (eval echo configure:2487: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then rm -rf conftest* eval "ac_cv_lib_$ac_lib_var=yes" *************** *** 2485,2489 **** if test "X$_bash_needmsg" = "Xyes"; then echo $ac_n "checking which library has the termcap functions""... $ac_c" 1>&6 ! echo "configure:2488: checking which library has the termcap functions" >&5 fi echo "$ac_t""using $bash_cv_termcap_lib" 1>&6 --- 2513,2517 ---- if test "X$_bash_needmsg" = "Xyes"; then echo $ac_n "checking which library has the termcap functions""... $ac_c" 1>&6 ! echo "configure:2516: checking which library has the termcap functions" >&5 fi echo "$ac_t""using $bash_cv_termcap_lib" 1>&6 *************** *** 2509,2512 **** --- 2537,2541 ---- case "$host_cpu" in *cray*) LOCAL_CFLAGS=-DCRAY ;; + *s390*) LOCAL_CFLAGS=-fsigned-char ;; esac *************** *** 2522,2526 **** if test -f ${srcdir}/support/shobj-conf; then echo $ac_n "checking configuration for building shared libraries""... $ac_c" 1>&6 ! echo "configure:2525: checking configuration for building shared libraries" >&5 eval `${CONFIG_SHELL-/bin/sh} ${srcdir}/support/shobj-conf -C "${CC}" -c ${host_cpu} -o ${host_os} -v ${host_vendor}` --- 2551,2555 ---- if test -f ${srcdir}/support/shobj-conf; then echo $ac_n "checking configuration for building shared libraries""... $ac_c" 1>&6 ! echo "configure:2554: checking configuration for building shared libraries" >&5 eval `${CONFIG_SHELL-/bin/sh} ${srcdir}/support/shobj-conf -C "${CC}" -c ${host_cpu} -o ${host_os} -v ${host_vendor}` *************** *** 2706,2709 **** --- 2735,2739 ---- s%@host_vendor@%$host_vendor%g s%@host_os@%$host_os%g + s%@SET_MAKE@%$SET_MAKE%g s%@CC@%$CC%g s%@CPP@%$CPP%g diff -Nrc2 readline-4.1/configure.in readline-4.2/configure.in *** readline-4.1/configure.in Wed Mar 1 14:52:34 2000 --- readline-4.2/configure.in Mon Apr 2 15:55:12 2001 *************** *** 5,10 **** dnl dnl Process this file with autoconf to produce a configure script. ! AC_REVISION([for Readline 4.1, version 2.22, from autoconf version] AC_ACVERSION) ! LIBVERSION=4.1 AC_INIT(readline.h) --- 5,10 ---- dnl dnl Process this file with autoconf to produce a configure script. ! AC_REVISION([for Readline 4.2, version 2.26, from autoconf version] AC_ACVERSION) ! LIBVERSION=4.2 AC_INIT(readline.h) *************** *** 32,35 **** --- 32,36 ---- test -z "$CFLAGS" && CFLAGS=-g auto_cflags=1 + AC_PROG_MAKE_SET AC_PROG_CC dnl AC_AIX *************** *** 92,95 **** --- 93,97 ---- case "$host_cpu" in *cray*) LOCAL_CFLAGS=-DCRAY ;; + *s390*) LOCAL_CFLAGS=-fsigned-char ;; esac diff -Nrc2 readline-4.1/display.c readline-4.2/display.c *** readline-4.1/display.c Thu Sep 16 11:19:40 1999 --- readline-4.2/display.c Fri Feb 2 13:25:10 2001 *************** *** 60,64 **** #if defined (HACK_TERMCAP_MOTION) ! extern char *term_forward_char; #endif --- 60,64 ---- #if defined (HACK_TERMCAP_MOTION) ! extern char *_rl_term_forward_char; #endif *************** *** 104,108 **** /* Application-specific redisplay function. */ ! VFunction *rl_redisplay_function = rl_redisplay; /* Global variables declared here. */ --- 104,108 ---- /* Application-specific redisplay function. */ ! rl_voidfunc_t *rl_redisplay_function = rl_redisplay; /* Global variables declared here. */ *************** *** 143,148 **** static int line_size = 1024; static char *local_prompt, *local_prompt_prefix; ! static int visible_length, prefix_length; /* The number of invisible characters in the line currently being --- 143,151 ---- static int line_size = 1024; + /* Variables to keep track of the expanded prompt string, which may + include invisible characters. */ + static char *local_prompt, *local_prompt_prefix; ! static int prompt_visible_length, prompt_prefix_length; /* The number of invisible characters in the line currently being *************** *** 150,158 **** static int visible_wrap_offset; ! /* static so it can be shared between rl_redisplay and update_line */ static int wrap_offset; ! /* The index of the last invisible_character in the prompt string. */ ! static int last_invisible; /* The length (buffer offset) of the first line of the last (possibly --- 153,162 ---- static int visible_wrap_offset; ! /* The number of invisible characters in the prompt string. Static so it ! can be shared between rl_redisplay and update_line */ static int wrap_offset; ! /* The index of the last invisible character in the prompt string. */ ! static int prompt_last_invisible; /* The length (buffer offset) of the first line of the last (possibly *************** *** 160,167 **** static int visible_first_line_len; /* Expand the prompt string S and return the number of visible characters in *LP, if LP is not null. This is currently more-or-less a placeholder for expansion. LIP, if non-null is a place to store the ! index of the last invisible character in the returned string. */ /* Current implementation: --- 164,180 ---- static int visible_first_line_len; + /* Number of invisible characters on the first physical line of the prompt. + Only valid when the number of physical characters in the prompt exceeds + (or is equal to) _rl_screenwidth. */ + static int prompt_invis_chars_first_line; + + static int prompt_last_screen_line; + /* Expand the prompt string S and return the number of visible characters in *LP, if LP is not null. This is currently more-or-less a placeholder for expansion. LIP, if non-null is a place to store the ! index of the last invisible character in the returned string. NIFLP, ! if non-zero, is a place to store the number of invisible characters in ! the first prompt line. */ /* Current implementation: *************** *** 173,182 **** static char * ! expand_prompt (pmt, lp, lip) char *pmt; ! int *lp, *lip; { char *r, *ret, *p; ! int l, rl, last, ignoring; /* Short-circuit if we can. */ --- 186,195 ---- static char * ! expand_prompt (pmt, lp, lip, niflp) char *pmt; ! int *lp, *lip, *niflp; { char *r, *ret, *p; ! int l, rl, last, ignoring, ninvis, invfl; /* Short-circuit if we can. */ *************** *** 191,196 **** l = strlen (pmt); r = ret = xmalloc (l + 1); ! ! for (rl = ignoring = last = 0, p = pmt; p && *p; p++) { /* This code strips the invisible character string markers --- 204,211 ---- l = strlen (pmt); r = ret = xmalloc (l + 1); ! ! invfl = 0; /* invisible chars in first line of prompt */ ! ! for (rl = ignoring = last = ninvis = 0, p = pmt; p && *p; p++) { /* This code strips the invisible character string markers *************** *** 212,218 **** --- 227,240 ---- if (!ignoring) rl++; + else + ninvis++; + if (rl == _rl_screenwidth) + invfl = ninvis; } } + if (rl < _rl_screenwidth) + invfl = ninvis; + *r = '\0'; if (lp) *************** *** 220,223 **** --- 242,247 ---- if (lip) *lip = last; + if (niflp) + *niflp = invfl; return ret; } *************** *** 231,235 **** char *ret; ! ret = expand_prompt (pmt, (int *)NULL, (int *)NULL); return ret; } --- 255,259 ---- char *ret; ! ret = expand_prompt (pmt, (int *)NULL, (int *)NULL, (int *)NULL); return ret; } *************** *** 243,248 **** * local_prompt_prefix = portion before last newline of rl_display_prompt, * expanded via expand_prompt ! * visible_length = number of visible characters in local_prompt ! * prefix_length = number of visible characters in local_prompt_prefix * * This function is called once per call to readline(). It may also be --- 267,272 ---- * local_prompt_prefix = portion before last newline of rl_display_prompt, * expanded via expand_prompt ! * prompt_visible_length = number of visible characters in local_prompt ! * prompt_prefix_length = number of visible characters in local_prompt_prefix * * This function is called once per call to readline(). It may also be *************** *** 260,269 **** /* Clear out any saved values. */ ! if (local_prompt) ! free (local_prompt); ! if (local_prompt_prefix) ! free (local_prompt_prefix); local_prompt = local_prompt_prefix = (char *)0; ! last_invisible = visible_length = 0; if (prompt == 0 || *prompt == 0) --- 284,292 ---- /* Clear out any saved values. */ ! FREE (local_prompt); ! FREE (local_prompt_prefix); ! local_prompt = local_prompt_prefix = (char *)0; ! prompt_last_invisible = prompt_visible_length = 0; if (prompt == 0 || *prompt == 0) *************** *** 273,280 **** if (!p) { ! /* The prompt is only one line. */ ! local_prompt = expand_prompt (prompt, &visible_length, &last_invisible); local_prompt_prefix = (char *)0; ! return (visible_length); } else --- 296,305 ---- if (!p) { ! /* The prompt is only one logical line, though it might wrap. */ ! local_prompt = expand_prompt (prompt, &prompt_visible_length, ! &prompt_last_invisible, ! &prompt_invis_chars_first_line); local_prompt_prefix = (char *)0; ! return (prompt_visible_length); } else *************** *** 282,292 **** /* The prompt spans multiple lines. */ t = ++p; ! local_prompt = expand_prompt (p, &visible_length, &last_invisible); c = *t; *t = '\0'; /* The portion of the prompt string up to and including the final newline is now null-terminated. */ ! local_prompt_prefix = expand_prompt (prompt, &prefix_length, (int *)NULL); *t = c; ! return (prefix_length); } } --- 307,321 ---- /* The prompt spans multiple lines. */ t = ++p; ! local_prompt = expand_prompt (p, &prompt_visible_length, ! &prompt_last_invisible, ! &prompt_invis_chars_first_line); c = *t; *t = '\0'; /* The portion of the prompt string up to and including the final newline is now null-terminated. */ ! local_prompt_prefix = expand_prompt (prompt, &prompt_prefix_length, ! (int *)NULL, ! &prompt_invis_chars_first_line); *t = c; ! return (prompt_prefix_length); } } *************** *** 400,404 **** } line[out] = '\0'; ! wrap_offset = local_len - visible_length; } else --- 429,433 ---- } line[out] = '\0'; ! wrap_offset = local_len - prompt_visible_length; } else *************** *** 433,437 **** out += pmtlen; line[out] = '\0'; ! wrap_offset = 0; } --- 462,466 ---- out += pmtlen; line[out] = '\0'; ! wrap_offset = prompt_invis_chars_first_line = 0; } *************** *** 448,452 **** do { \ lpos++; \ ! if (lpos >= screenwidth) \ { \ if (newlines >= (inv_lbsize - 2)) \ --- 477,481 ---- do { \ lpos++; \ ! if (lpos >= _rl_screenwidth) \ { \ if (newlines >= (inv_lbsize - 2)) \ *************** *** 464,482 **** lpos = out - wrap_offset; ! /* XXX - what if lpos is already >= screenwidth before we start drawing the contents of the command line? */ ! while (lpos >= screenwidth) { ! /* XXX - possible fix from Darin Johnson for prompt ! string with invisible characters that is longer than the screen ! width. XXX - this doesn't work right if invisible characters have ! to be put on the second screen line -- it adds too much (the number ! of invisible chars after the screenwidth). */ ! temp = ((newlines + 1) * screenwidth) + ((newlines == 0) ? wrap_offset : 0); inv_lbreaks[++newlines] = temp; ! lpos -= screenwidth; } lb_linenum = 0; for (in = 0; in < rl_end; in++) --- 493,526 ---- lpos = out - wrap_offset; ! /* prompt_invis_chars_first_line is the number of invisible characters in ! the first physical line of the prompt. ! wrap_offset - prompt_invis_chars_first_line is the number of invis ! chars on the second line. */ ! ! /* what if lpos is already >= _rl_screenwidth before we start drawing the contents of the command line? */ ! while (lpos >= _rl_screenwidth) { ! /* fix from Darin Johnson for prompt string with ! invisible characters that is longer than the screen width. The ! prompt_invis_chars_first_line variable could be made into an array ! saying how many invisible characters there are per line, but that's ! probably too much work for the benefit gained. How many people have ! prompts that exceed two physical lines? */ ! temp = ((newlines + 1) * _rl_screenwidth) + ! ((newlines == 0) ? prompt_invis_chars_first_line : 0) + ! ((newlines == 1) ? wrap_offset : 0); inv_lbreaks[++newlines] = temp; ! lpos -= _rl_screenwidth; } + prompt_last_screen_line = newlines; + + /* Draw the rest of the line (after the prompt) into invisible_line, keeping + track of where the cursor is (c_pos), the number of the line containing + the cursor (lb_linenum), the last line number (lb_botlin and inv_botlin). + It maintains an array of line breaks for display (inv_lbreaks). + This handles expanding tabs for display and displaying meta characters. */ lb_linenum = 0; for (in = 0; in < rl_end; in++) *************** *** 504,510 **** sprintf (line + out, "\\%o", c); ! if (lpos + 4 >= screenwidth) { ! temp = screenwidth - lpos; CHECK_INV_LBREAKS (); inv_lbreaks[++newlines] = out + temp; --- 548,554 ---- sprintf (line + out, "\\%o", c); ! if (lpos + 4 >= _rl_screenwidth) { ! temp = _rl_screenwidth - lpos; CHECK_INV_LBREAKS (); inv_lbreaks[++newlines] = out + temp; *************** *** 525,529 **** else if (c == '\t') { ! register int temp, newout; #if 0 --- 569,573 ---- else if (c == '\t') { ! register int newout; #if 0 *************** *** 533,540 **** #endif temp = newout - out; ! if (lpos + temp >= screenwidth) { register int temp2; ! temp2 = screenwidth - lpos; CHECK_INV_LBREAKS (); inv_lbreaks[++newlines] = out + temp2; --- 577,584 ---- #endif temp = newout - out; ! if (lpos + temp >= _rl_screenwidth) { register int temp2; ! temp2 = _rl_screenwidth - lpos; CHECK_INV_LBREAKS (); inv_lbreaks[++newlines] = out + temp2; *************** *** 551,555 **** } #endif ! else if (c == '\n' && _rl_horizontal_scroll_mode == 0 && term_up && *term_up) { line[out++] = '\0'; /* XXX - sentinel */ --- 595,599 ---- } #endif ! else if (c == '\n' && _rl_horizontal_scroll_mode == 0 && _rl_term_up && *_rl_term_up) { line[out++] = '\0'; /* XXX - sentinel */ *************** *** 583,587 **** cursor_linenum = lb_linenum; ! /* C_POS == position in buffer where cursor should be placed. */ /* PWP: now is when things get a bit hairy. The visible and invisible --- 627,632 ---- cursor_linenum = lb_linenum; ! /* C_POS == position in buffer where cursor should be placed. ! CURSOR_LINENUM == line number where the cursor should be placed. */ /* PWP: now is when things get a bit hairy. The visible and invisible *************** *** 594,598 **** horizontally scroll it. */ ! if (_rl_horizontal_scroll_mode == 0 && term_up && *term_up) { int nleft, pos, changed_screen_line; --- 639,643 ---- horizontally scroll it. */ ! if (_rl_horizontal_scroll_mode == 0 && _rl_term_up && *_rl_term_up) { int nleft, pos, changed_screen_line; *************** *** 605,610 **** only display a screenful. We should display the last screen, not the first. */ ! if (out >= screenchars) ! out = screenchars - 1; /* The first line is at character position 0 in the buffer. The --- 650,655 ---- only display a screenful. We should display the last screen, not the first. */ ! if (out >= _rl_screenchars) ! out = _rl_screenchars - 1; /* The first line is at character position 0 in the buffer. The *************** *** 636,640 **** (_rl_last_c_pos < visible_first_line_len)) { ! nleft = screenwidth + wrap_offset - _rl_last_c_pos; if (nleft) _rl_clear_to_eol (nleft); --- 681,685 ---- (_rl_last_c_pos < visible_first_line_len)) { ! nleft = _rl_screenwidth + wrap_offset - _rl_last_c_pos; if (nleft) _rl_clear_to_eol (nleft); *************** *** 657,661 **** _rl_move_cursor_relative (0, tt); _rl_clear_to_eol ! ((linenum == _rl_vis_botlin) ? strlen (tt) : screenwidth); } } --- 702,706 ---- _rl_move_cursor_relative (0, tt); _rl_clear_to_eol ! ((linenum == _rl_vis_botlin) ? strlen (tt) : _rl_screenwidth); } } *************** *** 668,672 **** { _rl_move_vert (cursor_linenum); ! /* If we moved up to the line with the prompt using term_up, the physical cursor position on the screen stays the same, but the buffer position needs to be adjusted to account --- 713,717 ---- { _rl_move_vert (cursor_linenum); ! /* If we moved up to the line with the prompt using _rl_term_up, the physical cursor position on the screen stays the same, but the buffer position needs to be adjusted to account *************** *** 681,693 **** only need to reprint it if the cursor is before the last invisible character in the prompt string. */ ! nleft = visible_length + wrap_offset; if (cursor_linenum == 0 && wrap_offset > 0 && _rl_last_c_pos > 0 && ! _rl_last_c_pos <= last_invisible && local_prompt) { #if defined (__MSDOS__) putc ('\r', rl_outstream); #else ! if (term_cr) ! tputs (term_cr, 1, _rl_output_character_function); #endif _rl_output_some_chars (local_prompt, nleft); --- 726,738 ---- only need to reprint it if the cursor is before the last invisible character in the prompt string. */ ! nleft = prompt_visible_length + wrap_offset; if (cursor_linenum == 0 && wrap_offset > 0 && _rl_last_c_pos > 0 && ! _rl_last_c_pos <= prompt_last_invisible && local_prompt) { #if defined (__MSDOS__) putc ('\r', rl_outstream); #else ! if (_rl_term_cr) ! tputs (_rl_term_cr, 1, _rl_output_character_function); #endif _rl_output_some_chars (local_prompt, nleft); *************** *** 728,736 **** /* The number of characters that will be displayed before the cursor. */ ndisp = c_pos - wrap_offset; ! nleft = visible_length + wrap_offset; /* Where the new cursor position will be on the screen. This can be longer than SCREENWIDTH; if it is, lmargin will be adjusted. */ phys_c_pos = c_pos - (last_lmargin ? last_lmargin : wrap_offset); ! t = screenwidth / 3; /* If the number of characters had already exceeded the screenwidth, --- 773,781 ---- /* The number of characters that will be displayed before the cursor. */ ndisp = c_pos - wrap_offset; ! nleft = prompt_visible_length + wrap_offset; /* Where the new cursor position will be on the screen. This can be longer than SCREENWIDTH; if it is, lmargin will be adjusted. */ phys_c_pos = c_pos - (last_lmargin ? last_lmargin : wrap_offset); ! t = _rl_screenwidth / 3; /* If the number of characters had already exceeded the screenwidth, *************** *** 740,744 **** width, compute the starting offset so that the cursor is about two-thirds of the way across the screen. */ ! if (phys_c_pos > screenwidth - 2) { lmargin = c_pos - (2 * t); --- 785,789 ---- width, compute the starting offset so that the cursor is about two-thirds of the way across the screen. */ ! if (phys_c_pos > _rl_screenwidth - 2) { lmargin = c_pos - (2 * t); *************** *** 750,754 **** lmargin = nleft; } ! else if (ndisp < screenwidth - 2) /* XXX - was -1 */ lmargin = 0; else if (phys_c_pos < 1) --- 795,799 ---- lmargin = nleft; } ! else if (ndisp < _rl_screenwidth - 2) /* XXX - was -1 */ lmargin = 0; else if (phys_c_pos < 1) *************** *** 772,776 **** right edge of the screen. If LMARGIN is 0, we need to take the wrap offset into account. */ ! t = lmargin + M_OFFSET (lmargin, wrap_offset) + screenwidth; if (t < out) line[t - 1] = '>'; --- 817,821 ---- right edge of the screen. If LMARGIN is 0, we need to take the wrap offset into account. */ ! t = lmargin + M_OFFSET (lmargin, wrap_offset) + _rl_screenwidth; if (t < out) line[t - 1] = '>'; *************** *** 782,787 **** &invisible_line[lmargin], 0, ! screenwidth + visible_wrap_offset, ! screenwidth + (lmargin ? 0 : wrap_offset), 0); --- 827,832 ---- &invisible_line[lmargin], 0, ! _rl_screenwidth + visible_wrap_offset, ! _rl_screenwidth + (lmargin ? 0 : wrap_offset), 0); *************** *** 794,803 **** t < visible_first_line_len) { ! nleft = screenwidth - t; _rl_clear_to_eol (nleft); } visible_first_line_len = out - lmargin - M_OFFSET (lmargin, wrap_offset); ! if (visible_first_line_len > screenwidth) ! visible_first_line_len = screenwidth; _rl_move_cursor_relative (c_pos - lmargin, &invisible_line[lmargin]); --- 839,848 ---- t < visible_first_line_len) { ! nleft = _rl_screenwidth - t; _rl_clear_to_eol (nleft); } visible_first_line_len = out - lmargin - M_OFFSET (lmargin, wrap_offset); ! if (visible_first_line_len > _rl_screenwidth) ! visible_first_line_len = _rl_screenwidth; _rl_move_cursor_relative (c_pos - lmargin, &invisible_line[lmargin]); *************** *** 809,817 **** /* Swap visible and non-visible lines. */ { ! char *temp = visible_line; int *itemp = vis_lbreaks, ntemp = vis_lbsize; visible_line = invisible_line; ! invisible_line = temp; vis_lbreaks = inv_lbreaks; --- 854,862 ---- /* Swap visible and non-visible lines. */ { ! char *vtemp = visible_line; int *itemp = vis_lbreaks, ntemp = vis_lbsize; visible_line = invisible_line; ! invisible_line = vtemp; vis_lbreaks = inv_lbreaks; *************** *** 863,867 **** position of the cursor. */ temp = _rl_last_c_pos - W_OFFSET(_rl_last_v_pos, visible_wrap_offset); ! if (temp == screenwidth && _rl_term_autowrap && !_rl_horizontal_scroll_mode && _rl_last_v_pos == current_line - 1) { --- 908,912 ---- position of the cursor. */ temp = _rl_last_c_pos - W_OFFSET(_rl_last_v_pos, visible_wrap_offset); ! if (temp == _rl_screenwidth && _rl_term_autowrap && !_rl_horizontal_scroll_mode && _rl_last_v_pos == current_line - 1) { *************** *** 940,950 **** od = ofd - old; /* index of first difference in visible line */ if (current_line == 0 && !_rl_horizontal_scroll_mode && ! term_cr && lendiff > visible_length && _rl_last_c_pos > 0 && ! od > lendiff && _rl_last_c_pos < last_invisible) { #if defined (__MSDOS__) putc ('\r', rl_outstream); #else ! tputs (term_cr, 1, _rl_output_character_function); #endif _rl_output_some_chars (local_prompt, lendiff); --- 985,995 ---- od = ofd - old; /* index of first difference in visible line */ if (current_line == 0 && !_rl_horizontal_scroll_mode && ! _rl_term_cr && lendiff > prompt_visible_length && _rl_last_c_pos > 0 && ! od >= lendiff && _rl_last_c_pos <= prompt_last_invisible) { #if defined (__MSDOS__) putc ('\r', rl_outstream); #else ! tputs (_rl_term_cr, 1, _rl_output_character_function); #endif _rl_output_some_chars (local_prompt, lendiff); *************** *** 974,985 **** of lines, make sure we actually cause the new line to wrap around on auto-wrapping terminals. */ ! if (terminal_can_insert && ((2 * temp) >= lendiff || term_IC) && (!_rl_term_autowrap || !gl)) { ! /* If lendiff > visible_length and _rl_last_c_pos == 0 and _rl_horizontal_scroll_mode == 1, inserting the characters with ! term_IC or term_ic will screw up the screen because of the invisible characters. We need to just draw them. */ if (*ols && (!_rl_horizontal_scroll_mode || _rl_last_c_pos > 0 || ! lendiff <= visible_length || !current_invis_chars)) { insert_some_chars (nfd, lendiff); --- 1019,1030 ---- of lines, make sure we actually cause the new line to wrap around on auto-wrapping terminals. */ ! if (_rl_terminal_can_insert && ((2 * temp) >= lendiff || _rl_term_IC) && (!_rl_term_autowrap || !gl)) { ! /* If lendiff > prompt_visible_length and _rl_last_c_pos == 0 and _rl_horizontal_scroll_mode == 1, inserting the characters with ! _rl_term_IC or _rl_term_ic will screw up the screen because of the invisible characters. We need to just draw them. */ if (*ols && (!_rl_horizontal_scroll_mode || _rl_last_c_pos > 0 || ! lendiff <= prompt_visible_length || !current_invis_chars)) { insert_some_chars (nfd, lendiff); *************** *** 1022,1026 **** { /* If possible and inexpensive to use terminal deletion, then do so. */ ! if (term_dc && (2 * temp) >= -lendiff) { /* If all we're doing is erasing the invisible characters in the --- 1067,1071 ---- { /* If possible and inexpensive to use terminal deletion, then do so. */ ! if (_rl_term_dc && (2 * temp) >= -lendiff) { /* If all we're doing is erasing the invisible characters in the *************** *** 1107,1111 **** to use the real screenwidth. Readline's notion of screenwidth might be one less, see terminal.c. */ ! real_screenwidth = screenwidth + (_rl_term_autowrap ? 0 : 1); _rl_last_v_pos = l / real_screenwidth; /* If the prompt length is a multiple of real_screenwidth, we don't know --- 1152,1156 ---- to use the real screenwidth. Readline's notion of screenwidth might be one less, see terminal.c. */ ! real_screenwidth = _rl_screenwidth + (_rl_term_autowrap ? 0 : 1); _rl_last_v_pos = l / real_screenwidth; /* If the prompt length is a multiple of real_screenwidth, we don't know *************** *** 1152,1156 **** _rl_move_cursor_relative (new, data) int new; ! char *data; { register int i; --- 1197,1201 ---- _rl_move_cursor_relative (new, data) int new; ! const char *data; { register int i; *************** *** 1164,1173 **** i = _rl_last_c_pos - W_OFFSET(_rl_last_v_pos, visible_wrap_offset); if (new == 0 || CR_FASTER (new, _rl_last_c_pos) || ! (_rl_term_autowrap && i == screenwidth)) { #if defined (__MSDOS__) putc ('\r', rl_outstream); #else ! tputs (term_cr, 1, _rl_output_character_function); #endif /* !__MSDOS__ */ _rl_last_c_pos = 0; --- 1209,1218 ---- i = _rl_last_c_pos - W_OFFSET(_rl_last_v_pos, visible_wrap_offset); if (new == 0 || CR_FASTER (new, _rl_last_c_pos) || ! (_rl_term_autowrap && i == _rl_screenwidth)) { #if defined (__MSDOS__) putc ('\r', rl_outstream); #else ! tputs (_rl_term_cr, 1, _rl_output_character_function); #endif /* !__MSDOS__ */ _rl_last_c_pos = 0; *************** *** 1186,1192 **** data is underneath the cursor. */ #if defined (HACK_TERMCAP_MOTION) ! if (term_forward_char) for (i = _rl_last_c_pos; i < new; i++) ! tputs (term_forward_char, 1, _rl_output_character_function); else for (i = _rl_last_c_pos; i < new; i++) --- 1231,1237 ---- data is underneath the cursor. */ #if defined (HACK_TERMCAP_MOTION) ! if (_rl_term_forward_char) for (i = _rl_last_c_pos; i < new; i++) ! tputs (_rl_term_forward_char, 1, _rl_output_character_function); else for (i = _rl_last_c_pos; i < new; i++) *************** *** 1209,1213 **** register int delta, i; ! if (_rl_last_v_pos == to || to > screenheight) return; --- 1254,1258 ---- register int delta, i; ! if (_rl_last_v_pos == to || to > _rl_screenheight) return; *************** *** 1219,1223 **** putc ('\r', rl_outstream); #else ! tputs (term_cr, 1, _rl_output_character_function); #endif _rl_last_c_pos = 0; --- 1264,1268 ---- putc ('\r', rl_outstream); #else ! tputs (_rl_term_cr, 1, _rl_output_character_function); #endif _rl_last_c_pos = 0; *************** *** 1225,1231 **** else { /* delta < 0 */ ! if (term_up && *term_up) for (i = 0; i < -delta; i++) ! tputs (term_up, 1, _rl_output_character_function); } --- 1270,1276 ---- else { /* delta < 0 */ ! if (_rl_term_up && *_rl_term_up) for (i = 0; i < -delta; i++) ! tputs (_rl_term_up, 1, _rl_output_character_function); } *************** *** 1361,1369 **** saved_local_prompt = local_prompt; saved_local_prefix = local_prompt_prefix; ! saved_last_invisible = last_invisible; ! saved_visible_length = visible_length; local_prompt = local_prompt_prefix = (char *)0; ! last_invisible = visible_length = 0; } --- 1406,1414 ---- saved_local_prompt = local_prompt; saved_local_prefix = local_prompt_prefix; ! saved_last_invisible = prompt_last_invisible; ! saved_visible_length = prompt_visible_length; local_prompt = local_prompt_prefix = (char *)0; ! prompt_last_invisible = prompt_visible_length = 0; } *************** *** 1371,1383 **** rl_restore_prompt () { ! if (local_prompt) ! free (local_prompt); ! if (local_prompt_prefix) ! free (local_prompt_prefix); local_prompt = saved_local_prompt; local_prompt_prefix = saved_local_prefix; ! last_invisible = saved_last_invisible; ! visible_length = saved_visible_length; } --- 1416,1426 ---- rl_restore_prompt () { ! FREE (local_prompt); ! FREE (local_prompt_prefix); local_prompt = saved_local_prompt; local_prompt_prefix = saved_local_prefix; ! prompt_last_invisible = saved_last_invisible; ! prompt_visible_length = saved_visible_length; } *************** *** 1409,1414 **** pmt[len+1] = '\0'; local_prompt = savestring (pmt); ! last_invisible = saved_last_invisible; ! visible_length = saved_visible_length + 1; } return pmt; --- 1452,1457 ---- pmt[len+1] = '\0'; local_prompt = savestring (pmt); ! prompt_last_invisible = saved_last_invisible; ! prompt_visible_length = saved_visible_length + 1; } return pmt; *************** *** 1437,1442 **** int count; { ! if (term_clreol) ! tputs (term_clreol, 1, _rl_output_character_function); else if (count) space_to_eol (count); --- 1480,1485 ---- int count; { ! if (_rl_term_clreol) ! tputs (_rl_term_clreol, 1, _rl_output_character_function); else if (count) space_to_eol (count); *************** *** 1460,1467 **** _rl_clear_screen () { ! if (term_clrpag) ! tputs (term_clrpag, 1, _rl_output_character_function); else ! crlf (); } --- 1503,1510 ---- _rl_clear_screen () { ! if (_rl_term_clrpag) ! tputs (_rl_term_clrpag, 1, _rl_output_character_function); else ! rl_crlf (); } *************** *** 1473,1480 **** { /* If IC is defined, then we do not have to "enter" insert mode. */ ! if (term_IC) { char *buffer; ! buffer = tgoto (term_IC, 0, count); tputs (buffer, 1, _rl_output_character_function); _rl_output_some_chars (string, count); --- 1516,1523 ---- { /* If IC is defined, then we do not have to "enter" insert mode. */ ! if (_rl_term_IC) { char *buffer; ! buffer = tgoto (_rl_term_IC, 0, count); tputs (buffer, 1, _rl_output_character_function); _rl_output_some_chars (string, count); *************** *** 1485,1497 **** /* If we have to turn on insert-mode, then do so. */ ! if (term_im && *term_im) ! tputs (term_im, 1, _rl_output_character_function); /* If there is a special command for inserting characters, then use that first to open up the space. */ ! if (term_ic && *term_ic) { for (i = count; i--; ) ! tputs (term_ic, 1, _rl_output_character_function); } --- 1528,1540 ---- /* If we have to turn on insert-mode, then do so. */ ! if (_rl_term_im && *_rl_term_im) ! tputs (_rl_term_im, 1, _rl_output_character_function); /* If there is a special command for inserting characters, then use that first to open up the space. */ ! if (_rl_term_ic && *_rl_term_ic) { for (i = count; i--; ) ! tputs (_rl_term_ic, 1, _rl_output_character_function); } *************** *** 1501,1506 **** /* If there is a string to turn off insert mode, we had best use it now. */ ! if (term_ei && *term_ei) ! tputs (term_ei, 1, _rl_output_character_function); } } --- 1544,1549 ---- /* If there is a string to turn off insert mode, we had best use it now. */ ! if (_rl_term_ei && *_rl_term_ei) ! tputs (_rl_term_ei, 1, _rl_output_character_function); } } *************** *** 1511,1528 **** int count; { ! if (count > screenwidth) /* XXX */ return; ! if (term_DC && *term_DC) { char *buffer; ! buffer = tgoto (term_DC, count, count); tputs (buffer, count, _rl_output_character_function); } else { ! if (term_dc && *term_dc) while (count--) ! tputs (term_dc, 1, _rl_output_character_function); } } --- 1554,1571 ---- int count; { ! if (count > _rl_screenwidth) /* XXX */ return; ! if (_rl_term_DC && *_rl_term_DC) { char *buffer; ! buffer = tgoto (_rl_term_DC, count, count); tputs (buffer, count, _rl_output_character_function); } else { ! if (_rl_term_dc && *_rl_term_dc) while (count--) ! tputs (_rl_term_dc, 1, _rl_output_character_function); } } *************** *** 1544,1548 **** _rl_move_vert (_rl_vis_botlin); /* If we've wrapped lines, remove the final xterm line-wrap flag. */ ! if (full_lines && _rl_term_autowrap && (VIS_LLEN(_rl_vis_botlin) == screenwidth)) { char *last_line; --- 1587,1591 ---- _rl_move_vert (_rl_vis_botlin); /* If we've wrapped lines, remove the final xterm line-wrap flag. */ ! if (full_lines && _rl_term_autowrap && (VIS_LLEN(_rl_vis_botlin) == _rl_screenwidth)) { char *last_line; *************** *** 1552,1561 **** last_line = &visible_line[vis_lbreaks[_rl_vis_botlin]]; #endif ! _rl_move_cursor_relative (screenwidth - 1, last_line); _rl_clear_to_eol (0); ! putc (last_line[screenwidth - 1], rl_outstream); } _rl_vis_botlin = 0; ! crlf (); fflush (rl_outstream); rl_display_fixed++; --- 1595,1604 ---- last_line = &visible_line[vis_lbreaks[_rl_vis_botlin]]; #endif ! _rl_move_cursor_relative (_rl_screenwidth - 1, last_line); _rl_clear_to_eol (0); ! putc (last_line[_rl_screenwidth - 1], rl_outstream); } _rl_vis_botlin = 0; ! rl_crlf (); fflush (rl_outstream); rl_display_fixed++; *************** *** 1566,1575 **** cr () { ! if (term_cr) { #if defined (__MSDOS__) putc ('\r', rl_outstream); #else ! tputs (term_cr, 1, _rl_output_character_function); #endif _rl_last_c_pos = 0; --- 1609,1618 ---- cr () { ! if (_rl_term_cr) { #if defined (__MSDOS__) putc ('\r', rl_outstream); #else ! tputs (_rl_term_cr, 1, _rl_output_character_function); #endif _rl_last_c_pos = 0; *************** *** 1585,1589 **** { char *oldp, *oldl, *oldlprefix; ! int oldlen, oldlast, oldplen; /* Geez, I should make this a struct. */ --- 1628,1632 ---- { char *oldp, *oldl, *oldlprefix; ! int oldlen, oldlast, oldplen, oldninvis; /* Geez, I should make this a struct. */ *************** *** 1591,1600 **** oldl = local_prompt; oldlprefix = local_prompt_prefix; ! oldlen = visible_length; ! oldplen = prefix_length; ! oldlast = last_invisible; rl_display_prompt = t; ! local_prompt = expand_prompt (t, &visible_length, &last_invisible); local_prompt_prefix = (char *)NULL; rl_forced_update_display (); --- 1634,1646 ---- oldl = local_prompt; oldlprefix = local_prompt_prefix; ! oldlen = prompt_visible_length; ! oldplen = prompt_prefix_length; ! oldlast = prompt_last_invisible; ! oldninvis = prompt_invis_chars_first_line; rl_display_prompt = t; ! local_prompt = expand_prompt (t, &prompt_visible_length, ! &prompt_last_invisible, ! &prompt_invis_chars_first_line); local_prompt_prefix = (char *)NULL; rl_forced_update_display (); *************** *** 1603,1609 **** local_prompt = oldl; local_prompt_prefix = oldlprefix; ! visible_length = oldlen; ! prefix_length = oldplen; ! last_invisible = oldlast; } --- 1649,1656 ---- local_prompt = oldl; local_prompt_prefix = oldlprefix; ! prompt_visible_length = oldlen; ! prompt_prefix_length = oldplen; ! prompt_last_invisible = oldlast; ! prompt_invis_chars_first_line = oldninvis; } *************** *** 1616,1637 **** /* Clear the current line and put the cursor at column 0. Make sure the right thing happens if we have wrapped to a new screen line. */ ! if (term_cr) { #if defined (__MSDOS__) putc ('\r', rl_outstream); #else ! tputs (term_cr, 1, _rl_output_character_function); #endif _rl_last_c_pos = 0; #if defined (__MSDOS__) ! space_to_eol (screenwidth); putc ('\r', rl_outstream); #else ! if (term_clreol) ! tputs (term_clreol, 1, _rl_output_character_function); else { ! space_to_eol (screenwidth); ! tputs (term_cr, 1, _rl_output_character_function); } #endif --- 1663,1684 ---- /* Clear the current line and put the cursor at column 0. Make sure the right thing happens if we have wrapped to a new screen line. */ ! if (_rl_term_cr) { #if defined (__MSDOS__) putc ('\r', rl_outstream); #else ! tputs (_rl_term_cr, 1, _rl_output_character_function); #endif _rl_last_c_pos = 0; #if defined (__MSDOS__) ! space_to_eol (_rl_screenwidth); putc ('\r', rl_outstream); #else ! if (_rl_term_clreol) ! tputs (_rl_term_clreol, 1, _rl_output_character_function); else { ! space_to_eol (_rl_screenwidth); ! tputs (_rl_term_cr, 1, _rl_output_character_function); } #endif *************** *** 1640,1644 **** } else ! crlf (); /* Redraw only the last line of a multi-line prompt. */ --- 1687,1691 ---- } else ! rl_crlf (); /* Redraw only the last line of a multi-line prompt. */ *************** *** 1681,1690 **** editing buffer. */ if (rl_display_prompt == rl_prompt) ! nleft = _rl_last_c_pos - screenwidth - rl_visible_prompt_length; else ! nleft = _rl_last_c_pos - screenwidth; if (nleft > 0) ! ret = 1 + nleft / screenwidth; else ret = 0; --- 1728,1737 ---- editing buffer. */ if (rl_display_prompt == rl_prompt) ! nleft = _rl_last_c_pos - _rl_screenwidth - rl_visible_prompt_length; else ! nleft = _rl_last_c_pos - _rl_screenwidth; if (nleft > 0) ! ret = 1 + nleft / _rl_screenwidth; else ret = 0; diff -Nrc2 readline-4.1/doc/Makefile.in readline-4.2/doc/Makefile.in *** readline-4.1/doc/Makefile.in Mon Jan 24 10:28:02 2000 --- readline-4.2/doc/Makefile.in Tue Mar 6 09:05:46 2001 *************** *** 64,74 **** DVIOBJ = readline.dvi history.dvi rluserman.dvi INFOOBJ = readline.info history.info rluserman.info ! PSOBJ = readline.ps history.ps rluserman.ps HTMLOBJ = readline.html history.html rluserman.html ! TEXTOBJ = readline.0 INTERMEDIATE_OBJ = rlman.dvi hist.dvi rluserman.dvi ! CREATED_DOCS = $(DVIOBJ) $(INFOOBJ) $(PSOBJ) $(HTMLOBJ) $(TEXTOBJ) .SUFFIXES: .0 .3 .ps .txt .dvi --- 64,74 ---- DVIOBJ = readline.dvi history.dvi rluserman.dvi INFOOBJ = readline.info history.info rluserman.info ! PSOBJ = readline.ps history.ps rluserman.ps readline_3.ps history_3.ps HTMLOBJ = readline.html history.html rluserman.html ! TEXTOBJ = readline.0 history.0 INTERMEDIATE_OBJ = rlman.dvi hist.dvi rluserman.dvi ! DIST_DOCS = $(DVIOBJ) $(PSOBJ) $(HTMLOBJ) $(INFOOBJ) $(TEXTOBJ) .SUFFIXES: .0 .3 .ps .txt .dvi *************** *** 134,137 **** --- 134,147 ---- readline.0: readline.3 + readline_3.ps: readline.3 + ${RM} $@ + ${GROFF} -man < $(srcdir)/readline.3 > $@ + + history.0: history.3 + + history_3.ps: history.3 + ${RM} $@ + ${GROFF} -man < $(srcdir)/history.3 > $@ + clean: $(RM) *.aux *.cp *.fn *.ky *.log *.pg *.toc *.tp *.vr *.cps *.pgs \ *************** *** 139,143 **** distclean: clean - $(RM) $(CREATED_DOCS) $(RM) $(INTERMEDIATE_OBJ) $(RM) Makefile --- 149,152 ---- *************** *** 146,150 **** maintainer-clean: clean ! $(RM) $(CREATED_DOCS) $(RM) $(INTERMEDIATE_OBJ) $(RM) Makefile --- 155,159 ---- maintainer-clean: clean ! $(RM) $(DIST_DOCS) $(RM) $(INTERMEDIATE_OBJ) $(RM) Makefile *************** *** 174,177 **** --- 183,187 ---- else true; fi -${INSTALL_DATA} $(srcdir)/readline.3 $(man3dir)/readline.3 + -${INSTALL_DATA} $(srcdir)/history.3 $(man3dir)/history.3 uninstall: *************** *** 180,181 **** --- 190,192 ---- $(RM) $(infodir)/history.info $(RM) $(man3dir)/readline.3 + $(RM) $(man3dir)/history.3 diff -Nrc2 readline-4.1/doc/hist.texinfo readline-4.2/doc/hist.texinfo *** readline-4.1/doc/hist.texinfo Thu Aug 5 08:25:11 1999 --- readline-4.2/doc/hist.texinfo Fri Feb 2 11:37:12 2001 *************** *** 19,23 **** typed input. ! Copyright (C) 1988-1999 Free Software Foundation, Inc. Permission is granted to make and distribute verbatim copies of --- 19,23 ---- typed input. ! Copyright (C) 1988-2001 Free Software Foundation, Inc. Permission is granted to make and distribute verbatim copies of *************** *** 74,78 **** @vskip 0pt plus 1filll ! Copyright @copyright{} 1988-1999 Free Software Foundation, Inc. @end titlepage --- 74,78 ---- @vskip 0pt plus 1filll ! Copyright @copyright{} 1988-2001 Free Software Foundation, Inc. @end titlepage diff -Nrc2 readline-4.1/doc/history.0 readline-4.2/doc/history.0 *** readline-4.1/doc/history.0 Wed Dec 31 19:00:00 1969 --- readline-4.2/doc/history.0 Mon Apr 16 10:53:07 2001 *************** *** 0 **** --- 1,660 ---- + + + + HISTORY(3) HISTORY(3) + + + NNAAMMEE + history - GNU History Library + + CCOOPPYYRRIIGGHHTT + The GNU History Library is Copyright (C) 1989-2001 by the + Free Software Foundation, Inc. + + DDEESSCCRRIIPPTTIIOONN + Many programs read input from the user a line at a time. + The GNU History library is able to keep track of those + lines, associate arbitrary data with each line, and uti- + lize information from previous lines in composing new + ones. + + + HHIISSTTOORRYY EEXXPPAANNSSIIOONN + The history library supports a history expansion feature + that is identical to the history expansion in bbaasshh.. This + section describes what syntax features are available. + + History expansions introduce words from the history list + into the input stream, making it easy to repeat commands, + insert the arguments to a previous command into the cur- + rent input line, or fix errors in previous commands + quickly. + + History expansion is usually performed immediately after a + complete line is read. It takes place in two parts. The + first is to determine which line from the history list to + use during substitution. The second is to select portions + of that line for inclusion into the current one. The line + selected from the history is the _e_v_e_n_t, and the portions + of that line that are acted upon are _w_o_r_d_s. Various _m_o_d_i_- + _f_i_e_r_s are available to manipulate the selected words. The + line is broken into words in the same fashion as bbaasshh does + when reading input, so that several words that would oth- + erwise be separated are considered one word when sur- + rounded by quotes (see the description of hhiissttoorryy__ttookk-- + eenniizzee(()) below). History expansions are introduced by the + appearance of the history expansion character, which is !! + by default. Only backslash (\\) and single quotes can + quote the history expansion character. + + EEvveenntt DDeessiiggnnaattoorrss + An event designator is a reference to a command line entry + in the history list. + + !! Start a history substitution, except when followed + by a bbllaannkk, newline, = or (. + !!_n Refer to command line _n. + !!--_n Refer to the current command line minus _n. + !!!! Refer to the previous command. This is a synonym + for `!-1'. + + + + + GNU History 4.2 2001 Mar 6 1 + + + + + + HISTORY(3) HISTORY(3) + + + !!_s_t_r_i_n_g + Refer to the most recent command starting with + _s_t_r_i_n_g. + !!??_s_t_r_i_n_g[[??]] + Refer to the most recent command containing _s_t_r_i_n_g. + The trailing ?? may be omitted if _s_t_r_i_n_g is followed + immediately by a newline. + ^^_s_t_r_i_n_g_1^^_s_t_r_i_n_g_2^^ + Quick substitution. Repeat the last command, + replacing _s_t_r_i_n_g_1 with _s_t_r_i_n_g_2. Equivalent to + ``!!:s/_s_t_r_i_n_g_1/_s_t_r_i_n_g_2/'' (see MMooddiiffiieerrss below). + !!## The entire command line typed so far. + + WWoorrdd DDeessiiggnnaattoorrss + Word designators are used to select desired words from the + event. A :: separates the event specification from the + word designator. It may be omitted if the word designator + begins with a ^^, $$, **, --, or %%. Words are numbered from + the beginning of the line, with the first word being + denoted by 0 (zero). Words are inserted into the current + line separated by single spaces. + + 00 ((zzeerroo)) + The zeroth word. For the shell, this is the com- + mand word. + _n The _nth word. + ^^ The first argument. That is, word 1. + $$ The last argument. + %% The word matched by the most recent `?_s_t_r_i_n_g?' + search. + _x--_y A range of words; `-_y' abbreviates `0-_y'. + ** All of the words but the zeroth. This is a synonym + for `_1_-_$'. It is not an error to use ** if there is + just one word in the event; the empty string is + returned in that case. + xx** Abbreviates _x_-_$. + xx-- Abbreviates _x_-_$ like xx**, but omits the last word. + + If a word designator is supplied without an event specifi- + cation, the previous command is used as the event. + + MMooddiiffiieerrss + After the optional word designator, there may appear a + sequence of one or more of the following modifiers, each + preceded by a `:'. + + hh Remove a trailing file name component, leaving only + the head. + tt Remove all leading file name components, leaving + the tail. + rr Remove a trailing suffix of the form _._x_x_x, leaving + the basename. + ee Remove all but the trailing suffix. + pp Print the new command but do not execute it. + + + + GNU History 4.2 2001 Mar 6 2 + + + + + + HISTORY(3) HISTORY(3) + + + qq Quote the substituted words, escaping further sub- + stitutions. + xx Quote the substituted words as with qq, but break + into words at bbllaannkkss and newlines. + ss//_o_l_d//_n_e_w// + Substitute _n_e_w for the first occurrence of _o_l_d in + the event line. Any delimiter can be used in place + of /. The final delimiter is optional if it is the + last character of the event line. The delimiter + may be quoted in _o_l_d and _n_e_w with a single back- + slash. If & appears in _n_e_w, it is replaced by _o_l_d. + A single backslash will quote the &. If _o_l_d is + null, it is set to the last _o_l_d substituted, or, if + no previous history substitutions took place, the + last _s_t_r_i_n_g in a !!??_s_t_r_i_n_g[[??]] search. + && Repeat the previous substitution. + gg Cause changes to be applied over the entire event + line. This is used in conjunction with `::ss' (e.g., + `::ggss//_o_l_d//_n_e_w//') or `::&&'. If used with `::ss', any + delimiter can be used in place of /, and the final + delimiter is optional if it is the last character + of the event line. + + PPRROOGGRRAAMMMMIINNGG WWIITTHH HHIISSTTOORRYY FFUUNNCCTTIIOONNSS + This section describes how to use the History library in + other programs. + + IInnttrroodduuccttiioonn ttoo HHiissttoorryy + The programmer using the History library has available + functions for remembering lines on a history list, associ- + ating arbitrary data with a line, removing lines from the + list, searching through the list for a line containing an + arbitrary text string, and referencing any line in the + list directly. In addition, a history _e_x_p_a_n_s_i_o_n function + is available which provides for a consistent user inter- + face across different programs. + + The user using programs written with the History library + has the benefit of a consistent user interface with a set + of well-known commands for manipulating the text of previ- + ous lines and using that text in new commands. The basic + history manipulation commands are identical to the history + substitution provided by bbaasshh. + + If the programmer desires, he can use the Readline + library, which includes some history manipulation by + default, and has the added advantage of command line edit- + ing. + + Before declaring any functions using any functionality the + History library provides in other code, an application + writer should include the file _<_r_e_a_d_l_i_n_e_/_h_i_s_t_o_r_y_._h_> in any + file that uses the History library's features. It sup- + plies extern declarations for all of the library's public + + + + GNU History 4.2 2001 Mar 6 3 + + + + + + HISTORY(3) HISTORY(3) + + + functions and variables, and declares all of the public + data structures. + + + HHiissttoorryy SSttoorraaggee + The history list is an array of history entries. A his- + tory entry is declared as follows: + + _t_y_p_e_d_e_f _v_o_i_d _* hhiissttddaattaa__tt;; + + typedef struct _hist_entry { + char *line; + histdata_t data; + } HIST_ENTRY; + + The history list itself might therefore be declared as + + _H_I_S_T___E_N_T_R_Y _*_* tthhee__hhiissttoorryy__lliisstt;; + + The state of the History library is encapsulated into a + single structure: + + /* + * A structure used to pass around the current state of the history. + */ + typedef struct _hist_state { + HIST_ENTRY **entries; /* Pointer to the entries themselves. */ + int offset; /* The location pointer within this array. */ + int length; /* Number of elements within this array. */ + int size; /* Number of slots allocated to this array. */ + int flags; + } HISTORY_STATE; + + If the flags member includes HHSS__SSTTIIFFLLEEDD, the history has + been stifled. + + HHiissttoorryy FFuunnccttiioonnss + This section describes the calling sequence for the vari- + ous functions exported by the GNU History library. + + IInniittiiaalliizziinngg HHiissttoorryy aanndd SSttaattee MMaannaaggeemmeenntt + This section describes functions used to initialize and + manage the state of the History library when you want to + use the history functions in your program. + + _v_o_i_d uussiinngg__hhiissttoorryy (_v_o_i_d) + Begin a session in which the history functions might be + used. This initializes the interactive variables. + + _H_I_S_T_O_R_Y___S_T_A_T_E _* hhiissttoorryy__ggeett__hhiissttoorryy__ssttaattee (_v_o_i_d) + Return a structure describing the current state of the + input history. + + _v_o_i_d hhiissttoorryy__sseett__hhiissttoorryy__ssttaattee (_H_I_S_T_O_R_Y___S_T_A_T_E _*_s_t_a_t_e) + + + + GNU History 4.2 2001 Mar 6 4 + + + + + + HISTORY(3) HISTORY(3) + + + Set the state of the history list according to _s_t_a_t_e. + + + HHiissttoorryy LLiisstt MMaannaaggeemmeenntt + These functions manage individual entries on the history + list, or set parameters managing the list itself. + + _v_o_i_d aadddd__hhiissttoorryy (_c_o_n_s_t _c_h_a_r _*_s_t_r_i_n_g) + Place _s_t_r_i_n_g at the end of the history list. The associ- + ated data field (if any) is set to NNUULLLL. + + _H_I_S_T___E_N_T_R_Y _* rreemmoovvee__hhiissttoorryy (_i_n_t _w_h_i_c_h) + Remove history entry at offset _w_h_i_c_h from the history. + The removed element is returned so you can free the line, + data, and containing structure. + + _H_I_S_T___E_N_T_R_Y _* rreeppllaaccee__hhiissttoorryy__eennttrryy (_i_n_t _w_h_i_c_h_, _c_o_n_s_t _c_h_a_r + _*_l_i_n_e_, _h_i_s_t_d_a_t_a___t _d_a_t_a) + Make the history entry at offset _w_h_i_c_h have _l_i_n_e and _d_a_t_a. + This returns the old entry so you can dispose of the data. + In the case of an invalid _w_h_i_c_h, a NNUULLLL pointer is + returned. + + _v_o_i_d cclleeaarr__hhiissttoorryy (_v_o_i_d) + Clear the history list by deleting all the entries. + + _v_o_i_d ssttiiffllee__hhiissttoorryy (_i_n_t _m_a_x) + Stifle the history list, remembering only the last _m_a_x + entries. + + _i_n_t uunnssttiiffllee__hhiissttoorryy (_v_o_i_d) + Stop stifling the history. This returns the previous + amount the history was stifled. The value is positive if + the history was stifled, negative if it wasn't. + + _i_n_t hhiissttoorryy__iiss__ssttiifflleedd (_v_o_i_d) + Returns non-zero if the history is stifled, zero if it is + not. + + + IInnffoorrmmaattiioonn AAbboouutt tthhee HHiissttoorryy LLiisstt + These functions return information about the entire his- + tory list or individual list entries. + + _H_I_S_T___E_N_T_R_Y _*_* hhiissttoorryy__lliisstt (_v_o_i_d) + Return a NNUULLLL terminated array of _H_I_S_T___E_N_T_R_Y _* which is + the current input history. Element 0 of this list is the + beginning of time. If there is no history, return NNUULLLL. + + _i_n_t wwhheerree__hhiissttoorryy (_v_o_i_d) + Returns the offset of the current history element. + + _H_I_S_T___E_N_T_R_Y _* ccuurrrreenntt__hhiissttoorryy (_v_o_i_d) + Return the history entry at the current position, as + + + + GNU History 4.2 2001 Mar 6 5 + + + + + + HISTORY(3) HISTORY(3) + + + determined by wwhheerree__hhiissttoorryy(()). If there is no entry + there, return a NNUULLLL pointer. + + _H_I_S_T___E_N_T_R_Y _* hhiissttoorryy__ggeett (_i_n_t _o_f_f_s_e_t) + Return the history entry at position _o_f_f_s_e_t, starting from + hhiissttoorryy__bbaassee. If there is no entry there, or if _o_f_f_s_e_t is + greater than the history length, return a NNUULLLL pointer. + + _i_n_t hhiissttoorryy__ttoottaall__bbyytteess (_v_o_i_d) + Return the number of bytes that the primary history + entries are using. This function returns the sum of the + lengths of all the lines in the history. + + + MMoovviinngg AArroouunndd tthhee HHiissttoorryy LLiisstt + These functions allow the current index into the history + list to be set or changed. + + _i_n_t hhiissttoorryy__sseett__ppooss (_i_n_t _p_o_s) + Set the current history offset to _p_o_s, an absolute index + into the list. Returns 1 on success, 0 if _p_o_s is less + than zero or greater than the number of history entries. + + _H_I_S_T___E_N_T_R_Y _* pprreevviioouuss__hhiissttoorryy (_v_o_i_d) + Back up the current history offset to the previous history + entry, and return a pointer to that entry. If there is no + previous entry, return a NNUULLLL pointer. + + _H_I_S_T___E_N_T_R_Y _* nneexxtt__hhiissttoorryy (_v_o_i_d) + Move the current history offset forward to the next his- + tory entry, and return the a pointer to that entry. If + there is no next entry, return a NNUULLLL pointer. + + + SSeeaarrcchhiinngg tthhee HHiissttoorryy LLiisstt + These functions allow searching of the history list for + entries containing a specific string. Searching may be + performed both forward and backward from the current his- + tory position. The search may be _a_n_c_h_o_r_e_d, meaning that + the string must match at the beginning of the history + entry. + + _i_n_t hhiissttoorryy__sseeaarrcchh (_c_o_n_s_t _c_h_a_r _*_s_t_r_i_n_g_, _i_n_t _d_i_r_e_c_t_i_o_n) + Search the history for _s_t_r_i_n_g, starting at the current + history offset. If _d_i_r_e_c_t_i_o_n is less than 0, then the + search is through previous entries, otherwise through sub- + sequent entries. If _s_t_r_i_n_g is found, then the current + history index is set to that history entry, and the value + returned is the offset in the line of the entry where + _s_t_r_i_n_g was found. Otherwise, nothing is changed, and a -1 + is returned. + + _i_n_t hhiissttoorryy__sseeaarrcchh__pprreeffiixx (_c_o_n_s_t _c_h_a_r _*_s_t_r_i_n_g_, _i_n_t + _d_i_r_e_c_t_i_o_n) + + + + GNU History 4.2 2001 Mar 6 6 + + + + + + HISTORY(3) HISTORY(3) + + + Search the history for _s_t_r_i_n_g, starting at the current + history offset. The search is anchored: matching lines + must begin with _s_t_r_i_n_g. If _d_i_r_e_c_t_i_o_n is less than 0, then + the search is through previous entries, otherwise through + subsequent entries. If _s_t_r_i_n_g is found, then the current + history index is set to that entry, and the return value + is 0. Otherwise, nothing is changed, and a -1 is + returned. + + _i_n_t hhiissttoorryy__sseeaarrcchh__ppooss (_c_o_n_s_t _c_h_a_r _*_s_t_r_i_n_g_, _i_n_t _d_i_r_e_c_t_i_o_n_, + _i_n_t _p_o_s) + Search for _s_t_r_i_n_g in the history list, starting at _p_o_s, an + absolute index into the list. If _d_i_r_e_c_t_i_o_n is negative, + the search proceeds backward from _p_o_s, otherwise forward. + Returns the absolute index of the history element where + _s_t_r_i_n_g was found, or -1 otherwise. + + + MMaannaaggiinngg tthhee HHiissttoorryy FFiillee + The History library can read the history from and write it + to a file. This section documents the functions for man- + aging a history file. + + _i_n_t rreeaadd__hhiissttoorryy (_c_o_n_s_t _c_h_a_r _*_f_i_l_e_n_a_m_e) + Add the contents of _f_i_l_e_n_a_m_e to the history list, a line + at a time. If _f_i_l_e_n_a_m_e is NNUULLLL, then read from _~_/_._h_i_s_- + _t_o_r_y. Returns 0 if successful, or eerrrrnnoo if not. + + _i_n_t rreeaadd__hhiissttoorryy__rraannggee (_c_o_n_s_t _c_h_a_r _*_f_i_l_e_n_a_m_e_, _i_n_t _f_r_o_m_, + _i_n_t _t_o) + Read a range of lines from _f_i_l_e_n_a_m_e, adding them to the + history list. Start reading at line _f_r_o_m and end at _t_o. + If _f_r_o_m is zero, start at the beginning. If _t_o is less + than _f_r_o_m, then read until the end of the file. If _f_i_l_e_- + _n_a_m_e is NNUULLLL, then read from _~_/_._h_i_s_t_o_r_y. Returns 0 if + successful, or eerrrrnnoo if not. + + _i_n_t wwrriittee__hhiissttoorryy (_c_o_n_s_t _c_h_a_r _*_f_i_l_e_n_a_m_e) + Write the current history to _f_i_l_e_n_a_m_e, overwriting _f_i_l_e_- + _n_a_m_e if necessary. If _f_i_l_e_n_a_m_e is NNUULLLL, then write the + history list to _~_/_._h_i_s_t_o_r_y. Returns 0 on success, or + eerrrrnnoo on a read or write error. + + + _i_n_t aappppeenndd__hhiissttoorryy (_i_n_t _n_e_l_e_m_e_n_t_s_, _c_o_n_s_t _c_h_a_r _*_f_i_l_e_n_a_m_e) + Append the last _n_e_l_e_m_e_n_t_s of the history list to _f_i_l_e_n_a_m_e. + If _f_i_l_e_n_a_m_e is NNUULLLL, then append to _~_/_._h_i_s_t_o_r_y. Returns 0 + on success, or eerrrrnnoo on a read or write error. + + _i_n_t hhiissttoorryy__ttrruunnccaattee__ffiillee (_c_o_n_s_t _c_h_a_r _*_f_i_l_e_n_a_m_e_, _i_n_t + _n_l_i_n_e_s) + Truncate the history file _f_i_l_e_n_a_m_e, leaving only the last + _n_l_i_n_e_s lines. If _f_i_l_e_n_a_m_e is NNUULLLL, then _~_/_._h_i_s_t_o_r_y is + truncated. Returns 0 on success, or eerrrrnnoo on failure. + + + + GNU History 4.2 2001 Mar 6 7 + + + + + + HISTORY(3) HISTORY(3) + + + HHiissttoorryy EExxppaannssiioonn + These functions implement history expansion. + + _i_n_t hhiissttoorryy__eexxppaanndd (_c_h_a_r _*_s_t_r_i_n_g_, _c_h_a_r _*_*_o_u_t_p_u_t) + Expand _s_t_r_i_n_g, placing the result into _o_u_t_p_u_t, a pointer + to a string. Returns: + 0 If no expansions took place (or, if the only + change in the text was the removal of escape + characters preceding the history expansion + character); + 1 if expansions did take place; + -1 if there was an error in expansion; + 2 if the returned line should be displayed, + but not executed, as with the ::pp modifier. + If an error ocurred in expansion, then _o_u_t_p_u_t contains a + descriptive error message. + + _c_h_a_r _* ggeett__hhiissttoorryy__eevveenntt (_c_o_n_s_t _c_h_a_r _*_s_t_r_i_n_g_, _i_n_t _*_c_i_n_d_e_x_, + _i_n_t _q_c_h_a_r) + Returns the text of the history event beginning at _s_t_r_i_n_g + + _*_c_i_n_d_e_x. _*_c_i_n_d_e_x is modified to point to after the + event specifier. At function entry, _c_i_n_d_e_x points to the + index into _s_t_r_i_n_g where the history event specification + begins. _q_c_h_a_r is a character that is allowed to end the + event specification in addition to the ``normal'' termi- + nating characters. + + _c_h_a_r _*_* hhiissttoorryy__ttookkeenniizzee (_c_o_n_s_t _c_h_a_r _*_s_t_r_i_n_g) + Return an array of tokens parsed out of _s_t_r_i_n_g, much as + the shell might. The tokens are split on the characters + in the hhiissttoorryy__wwoorrdd__ddeelliimmiitteerrss variable, and shell quoting + conventions are obeyed. + + _c_h_a_r _* hhiissttoorryy__aarrgg__eexxttrraacctt (_i_n_t _f_i_r_s_t_, _i_n_t _l_a_s_t_, _c_o_n_s_t + _c_h_a_r _*_s_t_r_i_n_g) + Extract a string segment consisting of the _f_i_r_s_t through + _l_a_s_t arguments present in _s_t_r_i_n_g. Arguments are split + using hhiissttoorryy__ttookkeenniizzee(()). + + + HHiissttoorryy VVaarriiaabblleess + This section describes the externally-visible variables + exported by the GNU History Library. + + _i_n_t hhiissttoorryy__bbaassee + The logical offset of the first entry in the history list. + + _i_n_t hhiissttoorryy__lleennggtthh + The number of entries currently stored in the history + list. + + _i_n_t hhiissttoorryy__mmaaxx__eennttrriieess + The maximum number of history entries. This must be + changed using ssttiiffllee__hhiissttoorryy(()). + + + + GNU History 4.2 2001 Mar 6 8 + + + + + + HISTORY(3) HISTORY(3) + + + _c_h_a_r hhiissttoorryy__eexxppaannssiioonn__cchhaarr + The character that introduces a history event. The + default is !!. Setting this to 0 inhibits history expan- + sion. + + _c_h_a_r hhiissttoorryy__ssuubbsstt__cchhaarr + The character that invokes word substitution if found at + the start of a line. The default is ^^. + + _c_h_a_r hhiissttoorryy__ccoommmmeenntt__cchhaarr + During tokenization, if this character is seen as the + first character of a word, then it and all subsequent + characters up to a newline are ignored, suppressing his- + tory expansion for the remainder of the line. This is + disabled by default. + + _c_h_a_r _* hhiissttoorryy__wwoorrdd__ddeelliimmiitteerrss + The characters that separate tokens for hhiissttoorryy__ttookk-- + eenniizzee(()). The default value is "" \\tt\\nn(())<<>>;;&&||"". + + _c_h_a_r _* hhiissttoorryy__nnoo__eexxppaanndd__cchhaarrss + The list of characters which inhibit history expansion if + found immediately following hhiissttoorryy__eexxppaannssiioonn__cchhaarr. The + default is space, tab, newline, \\rr, and ==. + + _c_h_a_r _* hhiissttoorryy__sseeaarrcchh__ddeelliimmiitteerr__cchhaarrss + The list of additional characters which can delimit a his- + tory search string, in addition to space, tab, _: and _? in + the case of a substring search. The default is empty. + + _i_n_t hhiissttoorryy__qquuootteess__iinnhhiibbiitt__eexxppaannssiioonn + If non-zero, single-quoted words are not scanned for the + history expansion character. The default value is 0. + + _r_l___l_i_n_e_b_u_f___f_u_n_c___t _* hhiissttoorryy__iinnhhiibbiitt__eexxppaannssiioonn__ffuunnccttiioonn + This should be set to the address of a function that takes + two arguments: a cchhaarr ** (_s_t_r_i_n_g) and an iinntt index into + that string (_i). It should return a non-zero value if the + history expansion starting at _s_t_r_i_n_g_[_i_] should not be per- + formed; zero if the expansion should be done. It is + intended for use by applications like bbaasshh that use the + history expansion character for additional purposes. By + default, this variable is set to NNUULLLL. + + FFIILLEESS + _~_/_._h_i_s_t_o_r_y + Default filename for reading and writing saved his- + tory + + SSEEEE AALLSSOO + _T_h_e _G_n_u _R_e_a_d_l_i_n_e _L_i_b_r_a_r_y, Brian Fox and Chet Ramey + _T_h_e _G_n_u _H_i_s_t_o_r_y _L_i_b_r_a_r_y, Brian Fox and Chet Ramey + _b_a_s_h(1) + + + + + GNU History 4.2 2001 Mar 6 9 + + + + + + HISTORY(3) HISTORY(3) + + + _r_e_a_d_l_i_n_e(3) + + AAUUTTHHOORRSS + Brian Fox, Free Software Foundation + bfox@gnu.org + + Chet Ramey, Case Western Reserve University + chet@ins.CWRU.Edu + + BBUUGG RREEPPOORRTTSS + If you find a bug in the hhiissttoorryy library, you should + report it. But first, you should make sure that it really + is a bug, and that it appears in the latest version of the + hhiissttoorryy library that you have. + + Once you have determined that a bug actually exists, mail + a bug report to _b_u_g_-_r_e_a_d_l_i_n_e@_g_n_u_._o_r_g. If you have a fix, + you are welcome to mail that as well! Suggestions and + `philosophical' bug reports may be mailed to _b_u_g_-_r_e_a_d_- + _l_i_n_e@_g_n_u_._o_r_g or posted to the Usenet newsgroup + ggnnuu..bbaasshh..bbuugg. + + Comments and bug reports concerning this manual page + should be directed to _c_h_e_t_@_i_n_s_._C_W_R_U_._E_d_u. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + GNU History 4.2 2001 Mar 6 10 + + diff -Nrc2 readline-4.1/doc/history.3 readline-4.2/doc/history.3 *** readline-4.1/doc/history.3 Wed Dec 31 19:00:00 1969 --- readline-4.2/doc/history.3 Mon Mar 12 05:38:09 2001 *************** *** 0 **** --- 1,639 ---- + .\" + .\" MAN PAGE COMMENTS to + .\" + .\" Chet Ramey + .\" Information Network Services + .\" Case Western Reserve University + .\" chet@ins.CWRU.Edu + .\" + .\" Last Change: Tue Mar 6 12:50:54 EST 2001 + .\" + .TH HISTORY 3 "2001 Mar 6" "GNU History 4.2" + .\" + .\" File Name macro. This used to be `.PN', for Path Name, + .\" but Sun doesn't seem to like that very much. + .\" + .de FN + \fI\|\\$1\|\fP + .. + .ds lp \fR\|(\fP + .ds rp \fR\|)\fP + .\" FnN return-value fun-name N arguments + .de Fn1 + \fI\\$1\fP \fB\\$2\fP \\*(lp\fI\\$3\fP\\*(rp + .br + .. + .de Fn2 + .if t \fI\\$1\fP \fB\\$2\fP \\*(lp\fI\\$3,\|\\$4\fP\\*(rp + .if n \fI\\$1\fP \fB\\$2\fP \\*(lp\fI\\$3, \\$4\fP\\*(rp + .br + .. + .de Fn3 + .if t \fI\\$1\fP \fB\\$2\fP \\*(lp\fI\\$3,\|\\$4,\|\\$5\fP\|\\*(rp + .if n \fI\\$1\fP \fB\\$2\fP \\*(lp\fI\\$3, \\$4, \\$5\fP\\*(rp + .br + .. + .de Vb + \fI\\$1\fP \fB\\$2\fP + .br + .. + .SH NAME + history \- GNU History Library + .SH COPYRIGHT + .if t The GNU History Library is Copyright \(co 1989-2001 by the Free Software Foundation, Inc. + .if n The GNU History Library is Copyright (C) 1989-2001 by the Free Software Foundation, Inc. + .SH DESCRIPTION + Many programs read input from the user a line at a time. The GNU + History library is able to keep track of those lines, associate arbitrary + data with each line, and utilize information from previous lines in + composing new ones. + .PP + .SH "HISTORY EXPANSION" + .PP + The history library supports a history expansion feature that + is identical to the history expansion in + .BR bash. + This section describes what syntax features are available. + .PP + History expansions introduce words from the history list into + the input stream, making it easy to repeat commands, insert the + arguments to a previous command into the current input line, or + fix errors in previous commands quickly. + .PP + History expansion is usually performed immediately after a complete line + is read. + It takes place in two parts. + The first is to determine which line from the history list + to use during substitution. + The second is to select portions of that line for inclusion into + the current one. + The line selected from the history is the \fIevent\fP, + and the portions of that line that are acted upon are \fIwords\fP. + Various \fImodifiers\fP are available to manipulate the selected words. + The line is broken into words in the same fashion as \fBbash\fP + does when reading input, + so that several words that would otherwise be separated + are considered one word when surrounded by quotes (see the + description of \fBhistory_tokenize()\fP below). + History expansions are introduced by the appearance of the + history expansion character, which is \^\fB!\fP\^ by default. + Only backslash (\^\fB\e\fP\^) and single quotes can quote + the history expansion character. + .SS Event Designators + .PP + An event designator is a reference to a command line entry in the + history list. + .PP + .PD 0 + .TP + .B ! + Start a history substitution, except when followed by a + .BR blank , + newline, = or (. + .TP + .B !\fIn\fR + Refer to command line + .IR n . + .TP + .B !\-\fIn\fR + Refer to the current command line minus + .IR n . + .TP + .B !! + Refer to the previous command. This is a synonym for `!\-1'. + .TP + .B !\fIstring\fR + Refer to the most recent command starting with + .IR string . + .TP + .B !?\fIstring\fR\fB[?]\fR + Refer to the most recent command containing + .IR string . + The trailing \fB?\fP may be omitted if + .I string + is followed immediately by a newline. + .TP + .B \d\s+2^\s-2\u\fIstring1\fP\d\s+2^\s-2\u\fIstring2\fP\d\s+2^\s-2\u + Quick substitution. Repeat the last command, replacing + .I string1 + with + .IR string2 . + Equivalent to + ``!!:s/\fIstring1\fP/\fIstring2\fP/'' + (see \fBModifiers\fP below). + .TP + .B !# + The entire command line typed so far. + .PD + .SS Word Designators + .PP + Word designators are used to select desired words from the event. + A + .B : + separates the event specification from the word designator. + It may be omitted if the word designator begins with a + .BR ^ , + .BR $ , + .BR * , + .BR \- , + or + .BR % . + Words are numbered from the beginning of the line, + with the first word being denoted by 0 (zero). + Words are inserted into the current line separated by single spaces. + .PP + .PD 0 + .TP + .B 0 (zero) + The zeroth word. For the shell, this is the command + word. + .TP + .I n + The \fIn\fRth word. + .TP + .B ^ + The first argument. That is, word 1. + .TP + .B $ + The last argument. + .TP + .B % + The word matched by the most recent `?\fIstring\fR?' search. + .TP + .I x\fB\-\fPy + A range of words; `\-\fIy\fR' abbreviates `0\-\fIy\fR'. + .TP + .B * + All of the words but the zeroth. This is a synonym + for `\fI1\-$\fP'. It is not an error to use + .B * + if there is just one + word in the event; the empty string is returned in that case. + .TP + .B x* + Abbreviates \fIx\-$\fP. + .TP + .B x\- + Abbreviates \fIx\-$\fP like \fBx*\fP, but omits the last word. + .PD + .PP + If a word designator is supplied without an event specification, the + previous command is used as the event. + .SS Modifiers + .PP + After the optional word designator, there may appear a sequence of + one or more of the following modifiers, each preceded by a `:'. + .PP + .PD 0 + .PP + .TP + .B h + Remove a trailing file name component, leaving only the head. + .TP + .B t + Remove all leading file name components, leaving the tail. + .TP + .B r + Remove a trailing suffix of the form \fI.xxx\fP, leaving the + basename. + .TP + .B e + Remove all but the trailing suffix. + .TP + .B p + Print the new command but do not execute it. + .TP + .B q + Quote the substituted words, escaping further substitutions. + .TP + .B x + Quote the substituted words as with + .BR q , + but break into words at + .B blanks + and newlines. + .TP + .B s/\fIold\fP/\fInew\fP/ + Substitute + .I new + for the first occurrence of + .I old + in the event line. Any delimiter can be used in place of /. The + final delimiter is optional if it is the last character of the + event line. The delimiter may be quoted in + .I old + and + .I new + with a single backslash. If & appears in + .IR new , + it is replaced by + .IR old . + A single backslash will quote the &. If + .I old + is null, it is set to the last + .I old + substituted, or, if no previous history substitutions took place, + the last + .I string + in a + .B !?\fIstring\fR\fB[?]\fR + search. + .TP + .B & + Repeat the previous substitution. + .TP + .B g + Cause changes to be applied over the entire event line. This is + used in conjunction with `\fB:s\fP' (e.g., `\fB:gs/\fIold\fP/\fInew\fP/\fR') + or `\fB:&\fP'. If used with + `\fB:s\fP', any delimiter can be used + in place of /, and the final delimiter is optional + if it is the last character of the event line. + .PD + .SH "PROGRAMMING WITH HISTORY FUNCTIONS" + This section describes how to use the History library in other programs. + .SS Introduction to History + .PP + The programmer using the History library has available functions + for remembering lines on a history list, associating arbitrary data + with a line, removing lines from the list, searching through the list + for a line containing an arbitrary text string, and referencing any line + in the list directly. In addition, a history \fIexpansion\fP function + is available which provides for a consistent user interface across + different programs. + .PP + The user using programs written with the History library has the + benefit of a consistent user interface with a set of well-known + commands for manipulating the text of previous lines and using that text + in new commands. The basic history manipulation commands are + identical to + the history substitution provided by \fBbash\fP. + .PP + If the programmer desires, he can use the Readline library, which + includes some history manipulation by default, and has the added + advantage of command line editing. + .PP + Before declaring any functions using any functionality the History + library provides in other code, an application writer should include + the file + .FN + in any file that uses the + History library's features. It supplies extern declarations for all + of the library's public functions and variables, and declares all of + the public data structures. + + .SS History Storage + .PP + The history list is an array of history entries. A history entry is + declared as follows: + .PP + .Vb "typedef void *" histdata_t; + .PP + .nf + typedef struct _hist_entry { + char *line; + histdata_t data; + } HIST_ENTRY; + .fi + .PP + The history list itself might therefore be declared as + .PP + .Vb "HIST_ENTRY **" the_history_list; + .PP + The state of the History library is encapsulated into a single structure: + .PP + .nf + /* + * A structure used to pass around the current state of the history. + */ + typedef struct _hist_state { + HIST_ENTRY **entries; /* Pointer to the entries themselves. */ + int offset; /* The location pointer within this array. */ + int length; /* Number of elements within this array. */ + int size; /* Number of slots allocated to this array. */ + int flags; + } HISTORY_STATE; + .fi + .PP + If the flags member includes \fBHS_STIFLED\fP, the history has been + stifled. + .SH "History Functions" + .PP + This section describes the calling sequence for the various functions + exported by the GNU History library. + .SS Initializing History and State Management + This section describes functions used to initialize and manage + the state of the History library when you want to use the history + functions in your program. + + .Fn1 void using_history void + Begin a session in which the history functions might be used. This + initializes the interactive variables. + + .Fn1 "HISTORY_STATE *" history_get_history_state void + Return a structure describing the current state of the input history. + + .Fn1 void history_set_history_state "HISTORY_STATE *state" + Set the state of the history list according to \fIstate\fP. + + .SS History List Management + + These functions manage individual entries on the history list, or set + parameters managing the list itself. + + .Fn1 void add_history "const char *string" + Place \fIstring\fP at the end of the history list. The associated data + field (if any) is set to \fBNULL\fP. + + .Fn1 "HIST_ENTRY *" remove_history "int which" + Remove history entry at offset \fIwhich\fP from the history. The + removed element is returned so you can free the line, data, + and containing structure. + + .Fn3 "HIST_ENTRY *" replace_history_entry "int which" "const char *line" "histdata_t data" + Make the history entry at offset \fIwhich\fP have \fIline\fP and \fIdata\fP. + This returns the old entry so you can dispose of the data. In the case + of an invalid \fIwhich\fP, a \fBNULL\fP pointer is returned. + + .Fn1 void clear_history "void" + Clear the history list by deleting all the entries. + + .Fn1 void stifle_history "int max" + Stifle the history list, remembering only the last \fImax\fP entries. + + .Fn1 int unstifle_history "void" + Stop stifling the history. This returns the previous amount the + history was stifled. The value is positive if the history was + stifled, negative if it wasn't. + + .Fn1 int history_is_stifled "void" + Returns non-zero if the history is stifled, zero if it is not. + + .SS Information About the History List + + These functions return information about the entire history list or + individual list entries. + + .Fn1 "HIST_ENTRY **" history_list "void" + Return a \fBNULL\fP terminated array of \fIHIST_ENTRY *\fP which is the + current input history. Element 0 of this list is the beginning of time. + If there is no history, return \fBNULL\fP. + + .Fn1 int where_history "void" + Returns the offset of the current history element. + + .Fn1 "HIST_ENTRY *" current_history "void" + Return the history entry at the current position, as determined by + \fBwhere_history()\fP. If there is no entry there, return a \fBNULL\fP + pointer. + + .Fn1 "HIST_ENTRY *" history_get "int offset" + Return the history entry at position \fIoffset\fP, starting from + \fBhistory_base\fP. + If there is no entry there, or if \fIoffset\fP + is greater than the history length, return a \fBNULL\fP pointer. + + .Fn1 int history_total_bytes "void" + Return the number of bytes that the primary history entries are using. + This function returns the sum of the lengths of all the lines in the + history. + + .SS Moving Around the History List + + These functions allow the current index into the history list to be + set or changed. + + .Fn1 int history_set_pos "int pos" + Set the current history offset to \fIpos\fP, an absolute index + into the list. + Returns 1 on success, 0 if \fIpos\fP is less than zero or greater + than the number of history entries. + + .Fn1 "HIST_ENTRY *" previous_history "void" + Back up the current history offset to the previous history entry, and + return a pointer to that entry. If there is no previous entry, return + a \fBNULL\fP pointer. + + .Fn1 "HIST_ENTRY *" next_history "void" + Move the current history offset forward to the next history entry, and + return the a pointer to that entry. If there is no next entry, return + a \fBNULL\fP pointer. + + .SS Searching the History List + + These functions allow searching of the history list for entries containing + a specific string. Searching may be performed both forward and backward + from the current history position. The search may be \fIanchored\fP, + meaning that the string must match at the beginning of the history entry. + + .Fn2 int history_search "const char *string" "int direction" + Search the history for \fIstring\fP, starting at the current history offset. + If \fIdirection\fP is less than 0, then the search is through + previous entries, otherwise through subsequent entries. + If \fIstring\fP is found, then + the current history index is set to that history entry, and the value + returned is the offset in the line of the entry where + \fIstring\fP was found. Otherwise, nothing is changed, and a -1 is + returned. + + .Fn2 int history_search_prefix "const char *string" "int direction" + Search the history for \fIstring\fP, starting at the current history + offset. The search is anchored: matching lines must begin with + \fIstring\fP. If \fIdirection\fP is less than 0, then the search is + through previous entries, otherwise through subsequent entries. + If \fIstring\fP is found, then the + current history index is set to that entry, and the return value is 0. + Otherwise, nothing is changed, and a -1 is returned. + + .Fn3 int history_search_pos "const char *string" "int direction" "int pos" + Search for \fIstring\fP in the history list, starting at \fIpos\fP, an + absolute index into the list. If \fIdirection\fP is negative, the search + proceeds backward from \fIpos\fP, otherwise forward. Returns the absolute + index of the history element where \fIstring\fP was found, or -1 otherwise. + + .SS Managing the History File + The History library can read the history from and write it to a file. + This section documents the functions for managing a history file. + + .Fn1 int read_history "const char *filename" + Add the contents of \fIfilename\fP to the history list, a line at a time. + If \fIfilename\fP is \fBNULL\fP, then read from \fI~/.history\fP. + Returns 0 if successful, or \fBerrno\fP if not. + + .Fn3 int read_history_range "const char *filename" "int from" "int to" + Read a range of lines from \fIfilename\fP, adding them to the history list. + Start reading at line \fIfrom\fP and end at \fIto\fP. + If \fIfrom\fP is zero, start at the beginning. If \fIto\fP is less than + \fIfrom\fP, then read until the end of the file. If \fIfilename\fP is + \fBNULL\fP, then read from \fI~/.history\fP. Returns 0 if successful, + or \fBerrno\fP if not. + + .Fn1 int write_history "const char *filename" + Write the current history to \fIfilename\fP, overwriting \fIfilename\fP + if necessary. + If \fIfilename\fP is \fBNULL\fP, then write the history list to \fI~/.history\fP. + Returns 0 on success, or \fBerrno\fP on a read or write error. + + + .Fn2 int append_history "int nelements" "const char *filename" + Append the last \fInelements\fP of the history list to \fIfilename\fP. + If \fIfilename\fP is \fBNULL\fP, then append to \fI~/.history\fP. + Returns 0 on success, or \fBerrno\fP on a read or write error. + + .Fn2 int history_truncate_file "const char *filename" "int nlines" + Truncate the history file \fIfilename\fP, leaving only the last + \fInlines\fP lines. + If \fIfilename\fP is \fBNULL\fP, then \fI~/.history\fP is truncated. + Returns 0 on success, or \fBerrno\fP on failure. + + .SS History Expansion + + These functions implement history expansion. + + .Fn2 int history_expand "char *string" "char **output" + Expand \fIstring\fP, placing the result into \fIoutput\fP, a pointer + to a string. Returns: + .RS + .PD 0 + .TP + 0 + If no expansions took place (or, if the only change in + the text was the removal of escape characters preceding the history expansion + character); + .TP + 1 + if expansions did take place; + .TP + -1 + if there was an error in expansion; + .TP + 2 + if the returned line should be displayed, but not executed, + as with the \fB:p\fP modifier. + .PD + .RE + If an error ocurred in expansion, then \fIoutput\fP contains a descriptive + error message. + + .Fn3 "char *" get_history_event "const char *string" "int *cindex" "int qchar" + Returns the text of the history event beginning at \fIstring\fP + + \fI*cindex\fP. \fI*cindex\fP is modified to point to after the event + specifier. At function entry, \fIcindex\fP points to the index into + \fIstring\fP where the history event specification begins. \fIqchar\fP + is a character that is allowed to end the event specification in addition + to the ``normal'' terminating characters. + + .Fn1 "char **" history_tokenize "const char *string" + Return an array of tokens parsed out of \fIstring\fP, much as the + shell might. + The tokens are split on the characters in the + \fBhistory_word_delimiters\fP variable, + and shell quoting conventions are obeyed. + + .Fn3 "char *" history_arg_extract "int first" "int last" "const char *string" + Extract a string segment consisting of the \fIfirst\fP through \fIlast\fP + arguments present in \fIstring\fP. Arguments are split using + \fBhistory_tokenize()\fP. + + .SS History Variables + + This section describes the externally-visible variables exported by + the GNU History Library. + + .Vb int history_base + The logical offset of the first entry in the history list. + + .Vb int history_length + The number of entries currently stored in the history list. + + .Vb int history_max_entries + The maximum number of history entries. This must be changed using + \fBstifle_history()\fP. + + .Vb char history_expansion_char + The character that introduces a history event. The default is \fB!\fP. + Setting this to 0 inhibits history expansion. + + .Vb char history_subst_char + The character that invokes word substitution if found at the start of + a line. The default is \fB^\fP. + + .Vb char history_comment_char + During tokenization, if this character is seen as the first character + of a word, then it and all subsequent characters up to a newline are + ignored, suppressing history expansion for the remainder of the line. + This is disabled by default. + + .Vb "char *" history_word_delimiters + The characters that separate tokens for \fBhistory_tokenize()\fP. + The default value is \fB"\ \et\en()<>;&|"\fP. + + .Vb "char *" history_no_expand_chars + The list of characters which inhibit history expansion if found immediately + following \fBhistory_expansion_char\fP. The default is space, tab, newline, + \fB\er\fP, and \fB=\fP. + + .Vb "char *" history_search_delimiter_chars + The list of additional characters which can delimit a history search + string, in addition to space, tab, \fI:\fP and \fI?\fP in the case of + a substring search. The default is empty. + + .Vb int history_quotes_inhibit_expansion + If non-zero, single-quoted words are not scanned for the history expansion + character. The default value is 0. + + .Vb "rl_linebuf_func_t *" history_inhibit_expansion_function + This should be set to the address of a function that takes two arguments: + a \fBchar *\fP (\fIstring\fP) + and an \fBint\fP index into that string (\fIi\fP). + It should return a non-zero value if the history expansion starting at + \fIstring[i]\fP should not be performed; zero if the expansion should + be done. + It is intended for use by applications like \fBbash\fP that use the history + expansion character for additional purposes. + By default, this variable is set to \fBNULL\fP. + .SH FILES + .PD 0 + .TP + .FN ~/.history + Default filename for reading and writing saved history + .PD + .SH "SEE ALSO" + .PD 0 + .TP + \fIThe Gnu Readline Library\fP, Brian Fox and Chet Ramey + .TP + \fIThe Gnu History Library\fP, Brian Fox and Chet Ramey + .TP + \fIbash\fP(1) + .TP + \fIreadline\fP(3) + .PD + .SH AUTHORS + Brian Fox, Free Software Foundation + .br + bfox@gnu.org + .PP + Chet Ramey, Case Western Reserve University + .br + chet@ins.CWRU.Edu + .SH BUG REPORTS + If you find a bug in the + .B history + library, you should report it. But first, you should + make sure that it really is a bug, and that it appears in the latest + version of the + .B history + library that you have. + .PP + Once you have determined that a bug actually exists, mail a + bug report to \fIbug\-readline\fP@\fIgnu.org\fP. + If you have a fix, you are welcome to mail that + as well! Suggestions and `philosophical' bug reports may be mailed + to \fPbug-readline\fP@\fIgnu.org\fP or posted to the Usenet + newsgroup + .BR gnu.bash.bug . + .PP + Comments and bug reports concerning + this manual page should be directed to + .IR chet@ins.CWRU.Edu . Binary files readline-4.1/doc/history.dvi and readline-4.2/doc/history.dvi differ diff -Nrc2 readline-4.1/doc/history.html readline-4.2/doc/history.html *** readline-4.1/doc/history.html Wed Jan 19 12:18:01 2000 --- readline-4.2/doc/history.html Mon Apr 16 11:05:46 2001 *************** *** 2,6 **** GNU History Library --- 2,6 ---- GNU History Library *************** *** 8,13 ****

GNU History Library

!

Edition 4.1, for History Library Version 4.1.

!

January 2000

Brian Fox, Free Software Foundation
Chet Ramey, Case Western Reserve University
--- 8,13 ----

GNU History Library

!

Edition 4.2, for History Library Version 4.2.

!

Apr 2001

Brian Fox, Free Software Foundation
Chet Ramey, Case Western Reserve University
*************** *** 80,84 ****

! Copyright (C) 1988-1999 Free Software Foundation, Inc.

--- 80,84 ----

! Copyright (C) 1988-2001 Free Software Foundation, Inc.

*************** *** 360,367 ****

! Many programs read input from the user a line at a time. The GNU History ! library is able to keep track of those lines, associate arbitrary data with ! each line, and utilize information from previous lines in composing new ! ones.

--- 360,367 ----

! Many programs read input from the user a line at a time. The GNU ! History library is able to keep track of those lines, associate arbitrary ! data with each line, and utilize information from previous lines in ! composing new ones.

*************** *** 410,416 ****
  typedef struct _hist_entry {
    char *line;
!   char *data;
  } HIST_ENTRY;
  
--- 410,418 ----
+ typedef void *histdata_t;
+ 
  typedef struct _hist_entry {
    char *line;
!   histdata_t data;
  } HIST_ENTRY;
  
*************** *** 431,440 ****
! /* A structure used to pass the current state of the history stuff around. */
  typedef struct _hist_state {
!   HIST_ENTRY **entries;         /* Pointer to the entries themselves. */
!   int offset;                   /* The location pointer within this array. */
!   int length;                   /* Number of elements within this array. */
!   int size;                     /* Number of slots allocated to this array. */
    int flags;
  } HISTORY_STATE;
--- 433,444 ----
  
  
! /*
!  * A structure used to pass around the current state of the history.
!  */
  typedef struct _hist_state {
!   HIST_ENTRY **entries; /* Pointer to the entries themselves. */
!   int offset;           /* The location pointer within this array. */
!   int length;           /* Number of elements within this array. */
!   int size;             /* Number of slots allocated to this array. */
    int flags;
  } HISTORY_STATE;
***************
*** 452,456 ****
  

This section describes the calling sequence for the various functions ! present in GNU History.

--- 456,460 ----

This section describes the calling sequence for the various functions ! exported by the GNU History library.

*************** *** 486,490 ****

!
Function: void using_history ()
Begin a session in which the history functions might be used. This --- 490,494 ----

!
Function: void using_history (void)
Begin a session in which the history functions might be used. This *************** *** 495,499 ****

!
Function: HISTORY_STATE * history_get_history_state ()
Return a structure describing the current state of the input history. --- 499,503 ----

!
Function: HISTORY_STATE * history_get_history_state (void)
Return a structure describing the current state of the input history. *************** *** 520,524 ****

!
Function: void add_history (char *string)
Place string at the end of the history list. The associated data --- 524,528 ----

!
Function: void add_history (const char *string)
Place string at the end of the history list. The associated data *************** *** 539,543 ****

!
Function: HIST_ENTRY * replace_history_entry (int which, char *line, char *data)
Make the history entry at offset which have line and data. --- 543,547 ----

!
Function: HIST_ENTRY * replace_history_entry (int which, const char *line, histdata_t data)
Make the history entry at offset which have line and data. *************** *** 549,553 ****

!
Function: void clear_history ()
Clear the history list by deleting all the entries. --- 553,557 ----

!
Function: void clear_history (void)
Clear the history list by deleting all the entries. *************** *** 565,569 ****

!
Function: int unstifle_history ()
Stop stifling the history. This returns the previous amount the --- 569,573 ----

!
Function: int unstifle_history (void)
Stop stifling the history. This returns the previous amount the *************** *** 575,579 ****

!
Function: int history_is_stifled ()
Returns non-zero if the history is stifled, zero if it is not. --- 579,583 ----

!
Function: int history_is_stifled (void)
Returns non-zero if the history is stifled, zero if it is not. *************** *** 592,598 ****

!
Function: HIST_ENTRY ** history_list ()
! Return a NULL terminated array of HIST_ENTRY which is the current input history. Element 0 of this list is the beginning of time. If there is no history, return NULL. --- 596,602 ----

!
Function: HIST_ENTRY ** history_list (void)
! Return a NULL terminated array of HIST_ENTRY * which is the current input history. Element 0 of this list is the beginning of time. If there is no history, return NULL. *************** *** 602,606 ****

!
Function: int where_history ()
Returns the offset of the current history element. --- 606,610 ----

!
Function: int where_history (void)
Returns the offset of the current history element. *************** *** 610,617 ****

!
Function: HIST_ENTRY * current_history ()
Return the history entry at the current position, as determined by ! where_history (). If there is no entry there, return a NULL pointer.
--- 614,621 ----

!
Function: HIST_ENTRY * current_history (void)
Return the history entry at the current position, as determined by ! where_history(). If there is no entry there, return a NULL pointer.
*************** *** 623,627 ****
Return the history entry at position offset, starting from ! history_base. If there is no entry there, or if offset is greater than the history length, return a NULL pointer.
--- 627,632 ----
Return the history entry at position offset, starting from ! history_base (see section History Variables). ! If there is no entry there, or if offset is greater than the history length, return a NULL pointer.
*************** *** 630,634 ****

!
Function: int history_total_bytes ()
Return the number of bytes that the primary history entries are using. --- 635,639 ----

!
Function: int history_total_bytes (void)
Return the number of bytes that the primary history entries are using. *************** *** 651,656 ****
Function: int history_set_pos (int pos)
! Set the position in the history list to pos, an absolute index into the list.
--- 656,663 ----
Function: int history_set_pos (int pos)
! Set the current history offset to pos, an absolute index into the list. + Returns 1 on success, 0 if pos is less than zero or greater + than the number of history entries.
*************** *** 658,662 ****

!
Function: HIST_ENTRY * previous_history ()
Back up the current history offset to the previous history entry, and --- 665,669 ----

!
Function: HIST_ENTRY * previous_history (void)
Back up the current history offset to the previous history entry, and *************** *** 668,672 ****

!
Function: HIST_ENTRY * next_history ()
Move the current history offset forward to the next history entry, and --- 675,679 ----

!
Function: HIST_ENTRY * next_history (void)
Move the current history offset forward to the next history entry, and *************** *** 693,701 ****

!
Function: int history_search (char *string, int direction)
! Search the history for string, starting at the current history ! offset. If direction < 0, then the search is through previous entries, ! else through subsequent. If string is found, then the current history index is set to that history entry, and the value returned is the offset in the line of the entry where --- 700,709 ----

!
Function: int history_search (const char *string, int direction)
! Search the history for string, starting at the current history offset. ! If direction is less than 0, then the search is through ! previous entries, otherwise through subsequent entries. ! If string is found, then the current history index is set to that history entry, and the value returned is the offset in the line of the entry where *************** *** 707,716 ****

!
Function: int history_search_prefix (char *string, int direction)
Search the history for string, starting at the current history offset. The search is anchored: matching lines must begin with ! string. If direction < 0, then the search is through previous ! entries, else through subsequent. If string is found, then the current history index is set to that entry, and the return value is 0. Otherwise, nothing is changed, and a -1 is returned. --- 715,725 ----

!
Function: int history_search_prefix (const char *string, int direction)
Search the history for string, starting at the current history offset. The search is anchored: matching lines must begin with ! string. If direction is less than 0, then the search is ! through previous entries, otherwise through subsequent entries. ! If string is found, then the current history index is set to that entry, and the return value is 0. Otherwise, nothing is changed, and a -1 is returned. *************** *** 720,724 ****

!
Function: int history_search_pos (char *string, int direction, int pos)
Search for string in the history list, starting at pos, an --- 729,733 ----

!
Function: int history_search_pos (const char *string, int direction, int pos)
Search for string in the history list, starting at pos, an *************** *** 740,748 ****

!
Function: int read_history (char *filename)
! Add the contents of filename to the history list, a line at a ! time. If filename is NULL, then read from ! `~/.history'. Returns 0 if successful, or errno if not.
--- 749,757 ----

!
Function: int read_history (const char *filename)
! Add the contents of filename to the history list, a line at a time. ! If filename is NULL, then read from `~/.history'. ! Returns 0 if successful, or errno if not.
*************** *** 750,758 ****

!
Function: int read_history_range (char *filename, int from, int to)
Read a range of lines from filename, adding them to the history list. ! Start reading at line from and end at to. If ! from is zero, start at the beginning. If to is less than from, then read until the end of the file. If filename is NULL, then read from `~/.history'. Returns 0 if successful, --- 759,767 ----

!
Function: int read_history_range (const char *filename, int from, int to)
Read a range of lines from filename, adding them to the history list. ! Start reading at line from and end at to. ! If from is zero, start at the beginning. If to is less than from, then read until the end of the file. If filename is NULL, then read from `~/.history'. Returns 0 if successful, *************** *** 763,772 ****

!
Function: int write_history (char *filename)
Write the current history to filename, overwriting filename ! if necessary. If filename is ! NULL, then write the history list to `~/.history'. Values ! returned are as in read_history ().
--- 772,782 ----

!
Function: int write_history (const char *filename)
Write the current history to filename, overwriting filename ! if necessary. ! If filename is NULL, then write the history list to ! `~/.history'. ! Returns 0 on success, or errno on a read or write error.
*************** *** 774,780 ****

!
Function: int append_history (int nelements, char *filename)
Append the last nelements of the history list to filename.
--- 784,792 ----

!
Function: int append_history (int nelements, const char *filename)
Append the last nelements of the history list to filename. + If filename is NULL, then append to `~/.history'. + Returns 0 on success, or errno on a read or write error.
*************** *** 782,789 ****

!
Function: int history_truncate_file (char *filename, int nlines)
Truncate the history file filename, leaving only the last nlines lines.
--- 794,803 ----

!
Function: int history_truncate_file (const char *filename, int nlines)
Truncate the history file filename, leaving only the last nlines lines. + If filename is NULL, then `~/.history' is truncated. + Returns 0 on success, or errno on failure.
*************** *** 794,798 ****

! These functions implement csh-like history expansion.

--- 808,812 ----

! These functions implement history expansion.

*************** *** 808,812 ****
If no expansions took place (or, if the only change in ! the text was the de-slashifying of the history expansion character);
1 --- 822,826 ----
If no expansions took place (or, if the only change in ! the text was the removal of escape characters preceding the history expansion character);
1 *************** *** 830,844 ****

!
Function: char * history_arg_extract (int first, int last, char *string)
- Extract a string segment consisting of the first through last - arguments present in string. Arguments are broken up as in Bash. -
- -

-

-

-
Function: char * get_history_event (char *string, int *cindex, int qchar) -
Returns the text of the history event beginning at string + *cindex. *cindex is modified to point to after the event --- 844,849 ----

!
Function: char * get_history_event (const char *string, int *cindex, int qchar)
Returns the text of the history event beginning at string + *cindex. *cindex is modified to point to after the event *************** *** 852,861 ****

!
Function: char ** history_tokenize (char *string) !
Return an array of tokens parsed out of string, much as the ! shell might. The tokens are split on white space and on the ! characters ()<>;&|$, and shell quoting conventions are ! obeyed.
--- 857,876 ----

!
Function: char ** history_tokenize (const char *string) !
Return an array of tokens parsed out of string, much as the ! shell might. The tokens are split on the characters in the ! history_word_delimiters variable, ! and shell quoting conventions are obeyed. !
! !

!

!

!
Function: char * history_arg_extract (int first, int last, const char *string) !
! Extract a string segment consisting of the first through last ! arguments present in string. Arguments are split using ! history_tokenize.
*************** *** 866,870 ****

! This section describes the externally visible variables exported by the GNU History Library. --- 881,885 ----

! This section describes the externally-visible variables exported by the GNU History Library. *************** *** 888,895 ****

!
Variable: int max_input_history
The maximum number of history entries. This must be changed using ! stifle_history ().
--- 903,910 ----

!
Variable: int history_max_entries
The maximum number of history entries. This must be changed using ! stifle_history().
*************** *** 899,903 ****
Variable: char history_expansion_char
! The character that starts a history event. The default is `!'.
--- 914,919 ----
Variable: char history_expansion_char
! The character that introduces a history event. The default is `!'. ! Setting this to 0 inhibits history expansion.
*************** *** 925,933 ****

!
Variable: char * history_no_expand_chars
The list of characters which inhibit history expansion if found immediately ! following history_expansion_char. The default is whitespace and ! `='.
--- 941,958 ----

!
Variable: char * history_word_delimiters
+ The characters that separate tokens for \fBhistory_tokenize()\fP. + The default value is " \t\n()<>;&|". +
+ +

+

+

+
Variable: char * history_no_expand_chars +
The list of characters which inhibit history expansion if found immediately ! following history_expansion_char. The default is space, tab, newline, ! carriage return, and `='.
*************** *** 936,942 ****
Variable: char * history_search_delimiter_chars !
The list of additional characters which can delimit a history search ! string, in addition to whitespace, `:' and `?' in the case of a substring search. The default is empty.
--- 961,967 ----
Variable: char * history_search_delimiter_chars !
The list of additional characters which can delimit a history search ! string, in addition to space, TAB, `:' and `?' in the case of a substring search. The default is empty.
*************** *** 946,950 ****
Variable: int history_quotes_inhibit_expansion !
If non-zero, single-quoted words are not scanned for the history expansion character. The default value is 0. --- 971,975 ----
Variable: int history_quotes_inhibit_expansion !
If non-zero, single-quoted words are not scanned for the history expansion character. The default value is 0. *************** *** 954,961 ****

!
Variable: Function * history_inhibit_expansion_function !
This should be set to the address of a function that takes two arguments: ! a char * (string) and an integer index into that string (i). It should return a non-zero value if the history expansion starting at string[i] should not be performed; zero if the expansion should --- 979,987 ----

!
Variable: rl_linebuf_func_t * history_inhibit_expansion_function !
This should be set to the address of a function that takes two arguments: ! a char * (string) ! and an int index into that string (i). It should return a non-zero value if the history expansion starting at string[i] should not be performed; zero if the expansion should *************** *** 963,967 **** It is intended for use by applications like Bash that use the history expansion character for additional purposes. ! By default, this variable is set to NULL.
--- 989,993 ---- It is intended for use by applications like Bash that use the history expansion character for additional purposes. ! By default, this variable is set to NULL.
*************** *** 977,981 ****
! main ()
  {
    char line[1024], *t;
--- 1003,1012 ----
  
  
! #include <stdio.h>
! #include <readline/history.h>
! 
! main (argc, argv)
!      int argc;
!      char **argv;
  {
    char line[1024], *t;
***************
*** 1099,1104 ****
  h
  -
- m
- -
  n
  -
--- 1130,1133 ----
***************
*** 1125,1133 ****
  

g

!
  • get_history_event
  • h

    !
  • history_arg_extract
  • history_base
  • history_comment_char --- 1154,1162 ----

    g

    !
  • get_history_event
  • h

    !
  • history_arg_extract
  • history_base
  • history_comment_char *************** *** 1136,1147 ****
  • history_get
  • history_get_history_state !
  • history_inhibit_expansion_function
  • history_is_stifled
  • history_length
  • history_list !
  • history_no_expand_chars !
  • history_quotes_inhibit_expansion
  • history_search !
  • history_search_delimiter_chars
  • history_search_pos
  • history_search_prefix --- 1165,1177 ----
  • history_get
  • history_get_history_state !
  • history_inhibit_expansion_function
  • history_is_stifled
  • history_length
  • history_list !
  • history_max_entries !
  • history_no_expand_chars !
  • history_quotes_inhibit_expansion
  • history_search !
  • history_search_delimiter_chars
  • history_search_pos
  • history_search_prefix *************** *** 1149,1159 ****
  • history_set_pos
  • history_subst_char !
  • history_tokenize
  • history_total_bytes
  • history_truncate_file !
  • !

    m

    ! !
  • max_input_history
  • n

    --- 1179,1186 ----
  • history_set_pos
  • history_subst_char !
  • history_tokenize
  • history_total_bytes
  • history_truncate_file !
  • history_word_delimiters
  • n

    *************** *** 1189,1193 ****


    ! This document was generated on 19 January 2000 using the texi2html translator version 1.52.

    --- 1216,1220 ----


    ! This document was generated on 16 April 2001 using the texi2html translator version 1.52.

    diff -Nrc2 readline-4.1/doc/history.info readline-4.2/doc/history.info *** readline-4.1/doc/history.info Wed Jan 19 12:17:44 2000 --- readline-4.2/doc/history.info Mon Apr 16 11:05:39 2001 *************** *** 1,4 **** ! This is Info file history.info, produced by Makeinfo version 1.68 from ! the input file /usr/homes/chet/src/bash/readline-src/doc/hist.texinfo. INFO-DIR-SECTION Libraries --- 1,4 ---- ! This is history.info, produced by makeinfo version 4.0 from ! /usr/homes/chet/src/bash/readline-src/doc/hist.texinfo. INFO-DIR-SECTION Libraries *************** *** 11,15 **** previously typed input. ! Copyright (C) 1988-1999 Free Software Foundation, Inc. Permission is granted to make and distribute verbatim copies of this --- 11,15 ---- previously typed input. ! Copyright (C) 1988-2001 Free Software Foundation, Inc. Permission is granted to make and distribute verbatim copies of this *************** *** 54,58 **** interactively, from a user's standpoint. It should be considered a user's guide. For information on using the GNU History Library in your ! own programs, *note Programming with GNU History::.. * Menu: --- 54,58 ---- interactively, from a user's standpoint. It should be considered a user's guide. For information on using the GNU History Library in your ! own programs, *note Programming with GNU History::. * Menu: *************** *** 239,243 **** the GNU History Library. It should be considered a technical guide. For information on the interactive use of GNU History, *note Using ! History Interactively::.. * Menu: --- 239,243 ---- the GNU History Library. It should be considered a technical guide. For information on the interactive use of GNU History, *note Using ! History Interactively::. * Menu: *************** *** 294,300 **** declared as follows: typedef struct _hist_entry { char *line; ! char *data; } HIST_ENTRY; --- 294,302 ---- declared as follows: + typedef void *histdata_t; + typedef struct _hist_entry { char *line; ! histdata_t data; } HIST_ENTRY; *************** *** 306,315 **** structure: ! /* A structure used to pass the current state of the history stuff around. */ typedef struct _hist_state { ! HIST_ENTRY **entries; /* Pointer to the entries themselves. */ ! int offset; /* The location pointer within this array. */ ! int length; /* Number of elements within this array. */ ! int size; /* Number of slots allocated to this array. */ int flags; } HISTORY_STATE; --- 308,319 ---- structure: ! /* ! * A structure used to pass around the current state of the history. ! */ typedef struct _hist_state { ! HIST_ENTRY **entries; /* Pointer to the entries themselves. */ ! int offset; /* The location pointer within this array. */ ! int length; /* Number of elements within this array. */ ! int size; /* Number of slots allocated to this array. */ int flags; } HISTORY_STATE; *************** *** 325,329 **** This section describes the calling sequence for the various functions ! present in GNU History. * Menu: --- 329,333 ---- This section describes the calling sequence for the various functions ! exported by the GNU History library. * Menu: *************** *** 355,363 **** in your program. ! - Function: void using_history () Begin a session in which the history functions might be used. This initializes the interactive variables. ! - Function: HISTORY_STATE * history_get_history_state () Return a structure describing the current state of the input history. --- 359,367 ---- in your program. ! - Function: void using_history (void) Begin a session in which the history functions might be used. This initializes the interactive variables. ! - Function: HISTORY_STATE * history_get_history_state (void) Return a structure describing the current state of the input history. *************** *** 375,379 **** parameters managing the list itself. ! - Function: void add_history (char *string) Place STRING at the end of the history list. The associated data field (if any) is set to `NULL'. --- 379,383 ---- parameters managing the list itself. ! - Function: void add_history (const char *string) Place STRING at the end of the history list. The associated data field (if any) is set to `NULL'. *************** *** 384,394 **** containing structure. ! - Function: HIST_ENTRY * replace_history_entry (int which, char *line, ! char *data) Make the history entry at offset WHICH have LINE and DATA. This returns the old entry so you can dispose of the data. In the case of an invalid WHICH, a `NULL' pointer is returned. ! - Function: void clear_history () Clear the history list by deleting all the entries. --- 388,398 ---- containing structure. ! - Function: HIST_ENTRY * replace_history_entry (int which, const char ! *line, histdata_t data) Make the history entry at offset WHICH have LINE and DATA. This returns the old entry so you can dispose of the data. In the case of an invalid WHICH, a `NULL' pointer is returned. ! - Function: void clear_history (void) Clear the history list by deleting all the entries. *************** *** 396,405 **** Stifle the history list, remembering only the last MAX entries. ! - Function: int unstifle_history () Stop stifling the history. This returns the previous amount the history was stifled. The value is positive if the history was stifled, negative if it wasn't. ! - Function: int history_is_stifled () Returns non-zero if the history is stifled, zero if it is not. --- 400,409 ---- Stifle the history list, remembering only the last MAX entries. ! - Function: int unstifle_history (void) Stop stifling the history. This returns the previous amount the history was stifled. The value is positive if the history was stifled, negative if it wasn't. ! - Function: int history_is_stifled (void) Returns non-zero if the history is stifled, zero if it is not. *************** *** 413,435 **** individual list entries. ! - Function: HIST_ENTRY ** history_list () ! Return a `NULL' terminated array of `HIST_ENTRY' which is the current input history. Element 0 of this list is the beginning of time. If there is no history, return `NULL'. ! - Function: int where_history () Returns the offset of the current history element. ! - Function: HIST_ENTRY * current_history () Return the history entry at the current position, as determined by ! `where_history ()'. If there is no entry there, return a `NULL' pointer. - Function: HIST_ENTRY * history_get (int offset) Return the history entry at position OFFSET, starting from ! `history_base'. If there is no entry there, or if OFFSET is ! greater than the history length, return a `NULL' pointer. ! - Function: int history_total_bytes () Return the number of bytes that the primary history entries are using. This function returns the sum of the lengths of all the --- 417,440 ---- individual list entries. ! - Function: HIST_ENTRY ** history_list (void) ! Return a `NULL' terminated array of `HIST_ENTRY *' which is the current input history. Element 0 of this list is the beginning of time. If there is no history, return `NULL'. ! - Function: int where_history (void) Returns the offset of the current history element. ! - Function: HIST_ENTRY * current_history (void) Return the history entry at the current position, as determined by ! `where_history()'. If there is no entry there, return a `NULL' pointer. - Function: HIST_ENTRY * history_get (int offset) Return the history entry at position OFFSET, starting from ! `history_base' (*note History Variables::). If there is no entry ! there, or if OFFSET is greater than the history length, return a ! `NULL' pointer. ! - Function: int history_total_bytes (void) Return the number of bytes that the primary history entries are using. This function returns the sum of the lengths of all the *************** *** 446,458 **** - Function: int history_set_pos (int pos) ! Set the position in the history list to POS, an absolute index ! into the list. ! - Function: HIST_ENTRY * previous_history () Back up the current history offset to the previous history entry, and return a pointer to that entry. If there is no previous entry, return a `NULL' pointer. ! - Function: HIST_ENTRY * next_history () Move the current history offset forward to the next history entry, and return the a pointer to that entry. If there is no next --- 451,464 ---- - Function: int history_set_pos (int pos) ! Set the current history offset to POS, an absolute index into the ! list. Returns 1 on success, 0 if POS is less than zero or greater ! than the number of history entries. ! - Function: HIST_ENTRY * previous_history (void) Back up the current history offset to the previous history entry, and return a pointer to that entry. If there is no previous entry, return a `NULL' pointer. ! - Function: HIST_ENTRY * next_history (void) Move the current history offset forward to the next history entry, and return the a pointer to that entry. If there is no next *************** *** 471,492 **** history entry. ! - Function: int history_search (char *string, int direction) Search the history for STRING, starting at the current history ! offset. If DIRECTION < 0, then the search is through previous ! entries, else through subsequent. If STRING is found, then the ! current history index is set to that history entry, and the value ! returned is the offset in the line of the entry where STRING was ! found. Otherwise, nothing is changed, and a -1 is returned. ! - Function: int history_search_prefix (char *string, int direction) Search the history for STRING, starting at the current history offset. The search is anchored: matching lines must begin with ! STRING. If DIRECTION < 0, then the search is through previous ! entries, else through subsequent. If STRING is found, then the ! current history index is set to that entry, and the return value ! is 0. Otherwise, nothing is changed, and a -1 is returned. ! - Function: int history_search_pos (char *string, int direction, int ! pos) Search for STRING in the history list, starting at POS, an absolute index into the list. If DIRECTION is negative, the search --- 477,501 ---- history entry. ! - Function: int history_search (const char *string, int direction) Search the history for STRING, starting at the current history ! offset. If DIRECTION is less than 0, then the search is through ! previous entries, otherwise through subsequent entries. If STRING ! is found, then the current history index is set to that history ! entry, and the value returned is the offset in the line of the ! entry where STRING was found. Otherwise, nothing is changed, and ! a -1 is returned. ! - Function: int history_search_prefix (const char *string, int ! direction) Search the history for STRING, starting at the current history offset. The search is anchored: matching lines must begin with ! STRING. If DIRECTION is less than 0, then the search is through ! previous entries, otherwise through subsequent entries. If STRING ! is found, then the current history index is set to that entry, and ! the return value is 0. Otherwise, nothing is changed, and a -1 is ! returned. ! - Function: int history_search_pos (const char *string, int direction, ! int pos) Search for STRING in the history list, starting at POS, an absolute index into the list. If DIRECTION is negative, the search *************** *** 504,513 **** This section documents the functions for managing a history file. ! - Function: int read_history (char *filename) ! Add the contents of FILENAME to the history list, a line at a ! time. If FILENAME is `NULL', then read from `~/.history'. ! Returns 0 if successful, or errno if not. ! - Function: int read_history_range (char *filename, int from, int to) Read a range of lines from FILENAME, adding them to the history list. Start reading at line FROM and end at TO. If FROM is zero, --- 513,523 ---- This section documents the functions for managing a history file. ! - Function: int read_history (const char *filename) ! Add the contents of FILENAME to the history list, a line at a time. ! If FILENAME is `NULL', then read from `~/.history'. Returns 0 if ! successful, or `errno' if not. ! - Function: int read_history_range (const char *filename, int from, ! int to) Read a range of lines from FILENAME, adding them to the history list. Start reading at line FROM and end at TO. If FROM is zero, *************** *** 516,530 **** `~/.history'. Returns 0 if successful, or `errno' if not. ! - Function: int write_history (char *filename) Write the current history to FILENAME, overwriting FILENAME if necessary. If FILENAME is `NULL', then write the history list to ! `~/.history'. Values returned are as in `read_history ()'. ! - Function: int append_history (int nelements, char *filename) ! Append the last NELEMENTS of the history list to FILENAME. ! - Function: int history_truncate_file (char *filename, int nlines) Truncate the history file FILENAME, leaving only the last NLINES ! lines.  --- 526,545 ---- `~/.history'. Returns 0 if successful, or `errno' if not. ! - Function: int write_history (const char *filename) Write the current history to FILENAME, overwriting FILENAME if necessary. If FILENAME is `NULL', then write the history list to ! `~/.history'. Returns 0 on success, or `errno' on a read or write ! error. ! - Function: int append_history (int nelements, const char *filename) ! Append the last NELEMENTS of the history list to FILENAME. If ! FILENAME is `NULL', then append to `~/.history'. Returns 0 on ! success, or `errno' on a read or write error. ! - Function: int history_truncate_file (const char *filename, int ! nlines) Truncate the history file FILENAME, leaving only the last NLINES ! lines. If FILENAME is `NULL', then `~/.history' is truncated. ! Returns 0 on success, or `errno' on failure.  *************** *** 534,546 **** ----------------- ! These functions implement `csh'-like history expansion. - Function: int history_expand (char *string, char **output) Expand STRING, placing the result into OUTPUT, a pointer to a ! string (*note History Interaction::.). Returns: `0' If no expansions took place (or, if the only change in the ! text was the de-slashifying of the history expansion ! character); `1' --- 549,561 ---- ----------------- ! These functions implement history expansion. - Function: int history_expand (char *string, char **output) Expand STRING, placing the result into OUTPUT, a pointer to a ! string (*note History Interaction::). Returns: `0' If no expansions took place (or, if the only change in the ! text was the removal of escape characters preceding the ! history expansion character); `1' *************** *** 552,567 **** `2' if the returned line should be displayed, but not executed, ! as with the `:p' modifier (*note Modifiers::.). If an error ocurred in expansion, then OUTPUT contains a descriptive error message. ! - Function: char * history_arg_extract (int first, int last, char ! *string) ! Extract a string segment consisting of the FIRST through LAST ! arguments present in STRING. Arguments are broken up as in Bash. ! ! - Function: char * get_history_event (char *string, int *cindex, int ! qchar) Returns the text of the history event beginning at STRING + *CINDEX. *CINDEX is modified to point to after the event --- 567,577 ---- `2' if the returned line should be displayed, but not executed, ! as with the `:p' modifier (*note Modifiers::). If an error ocurred in expansion, then OUTPUT contains a descriptive error message. ! - Function: char * get_history_event (const char *string, int *cindex, ! int qchar) Returns the text of the history event beginning at STRING + *CINDEX. *CINDEX is modified to point to after the event *************** *** 571,578 **** addition to the "normal" terminating characters. ! - Function: char ** history_tokenize (char *string) Return an array of tokens parsed out of STRING, much as the shell ! might. The tokens are split on white space and on the characters ! `()<>;&|$', and shell quoting conventions are obeyed.  --- 581,595 ---- addition to the "normal" terminating characters. ! - Function: char ** history_tokenize (const char *string) Return an array of tokens parsed out of STRING, much as the shell ! might. The tokens are split on the characters in the ! HISTORY_WORD_DELIMITERS variable, and shell quoting conventions ! are obeyed. ! ! - Function: char * history_arg_extract (int first, int last, const ! char *string) ! Extract a string segment consisting of the FIRST through LAST ! arguments present in STRING. Arguments are split using ! `history_tokenize'.  *************** *** 582,586 **** ================= ! This section describes the externally visible variables exported by the GNU History Library. --- 599,603 ---- ================= ! This section describes the externally-visible variables exported by the GNU History Library. *************** *** 591,600 **** The number of entries currently stored in the history list. ! - Variable: int max_input_history The maximum number of history entries. This must be changed using ! `stifle_history ()'. - Variable: char history_expansion_char ! The character that starts a history event. The default is `!'. - Variable: char history_subst_char --- 608,618 ---- The number of entries currently stored in the history list. ! - Variable: int history_max_entries The maximum number of history entries. This must be changed using ! `stifle_history()'. - Variable: char history_expansion_char ! The character that introduces a history event. The default is `!'. ! Setting this to 0 inhibits history expansion. - Variable: char history_subst_char *************** *** 608,619 **** remainder of the line. This is disabled by default. - Variable: char * history_no_expand_chars The list of characters which inhibit history expansion if found immediately following HISTORY_EXPANSION_CHAR. The default is ! whitespace and `='. - Variable: char * history_search_delimiter_chars The list of additional characters which can delimit a history ! search string, in addition to whitespace, `:' and `?' in the case of a substring search. The default is empty. --- 626,641 ---- remainder of the line. This is disabled by default. + - Variable: char * history_word_delimiters + The characters that separate tokens for \fBhistory_tokenize()\fP. + The default value is `" \t\n()<>;&|"'. + - Variable: char * history_no_expand_chars The list of characters which inhibit history expansion if found immediately following HISTORY_EXPANSION_CHAR. The default is ! space, tab, newline, carriage return, and `='. - Variable: char * history_search_delimiter_chars The list of additional characters which can delimit a history ! search string, in addition to space, TAB, `:' and `?' in the case of a substring search. The default is empty. *************** *** 622,633 **** expansion character. The default value is 0. ! - Variable: Function * history_inhibit_expansion_function This should be set to the address of a function that takes two ! arguments: a `char *' (STRING) and an integer index into that ! string (I). It should return a non-zero value if the history ! expansion starting at STRING[I] should not be performed; zero if ! the expansion should be done. It is intended for use by ! applications like Bash that use the history expansion character ! for additional purposes. By default, this variable is set to NULL.  --- 644,655 ---- expansion character. The default value is 0. ! - Variable: rl_linebuf_func_t * history_inhibit_expansion_function This should be set to the address of a function that takes two ! arguments: a `char *' (STRING) and an `int' index into that string ! (I). It should return a non-zero value if the history expansion ! starting at STRING[I] should not be performed; zero if the ! expansion should be done. It is intended for use by applications ! like Bash that use the history expansion character for additional ! purposes. By default, this variable is set to `NULL'.  *************** *** 640,644 **** Library. ! main () { char line[1024], *t; --- 662,671 ---- Library. ! #include ! #include ! ! main (argc, argv) ! int argc; ! char **argv; { char line[1024], *t; *************** *** 759,762 **** --- 786,790 ---- * history_length: History Variables. * history_list: Information About the History List. + * history_max_entries: History Variables. * history_no_expand_chars: History Variables. * history_quotes_inhibit_expansion: History Variables. *************** *** 771,775 **** * history_total_bytes: Information About the History List. * history_truncate_file: Managing the History File. ! * max_input_history: History Variables. * next_history: Moving Around the History List. * previous_history: Moving Around the History List. --- 799,803 ---- * history_total_bytes: Information About the History List. * history_truncate_file: Managing the History File. ! * history_word_delimiters: History Variables. * next_history: Moving Around the History List. * previous_history: Moving Around the History List. *************** *** 787,811 ****  Tag Table: ! Node: Top1162 ! Node: Using History Interactively1742 ! Node: History Interaction2250 ! Node: Event Designators3669 ! Node: Word Designators4596 ! Node: Modifiers6225 ! Node: Programming with GNU History7363 ! Node: Introduction to History8089 ! Node: History Storage9774 ! Node: History Functions10867 ! Node: Initializing History and State Management11838 ! Node: History List Management12630 ! Node: Information About the History List14151 ! Node: Moving Around the History List15457 ! Node: Searching the History List16342 ! Node: Managing the History File18174 ! Node: History Expansion19680 ! Node: History Variables21519 ! Node: History Programming Example23837 ! Node: Concept Index26441 ! Node: Function and Variable Index26927  End Tag Table --- 815,839 ----  Tag Table: ! Node: Top1136 ! Node: Using History Interactively1716 ! Node: History Interaction2223 ! Node: Event Designators3642 ! Node: Word Designators4569 ! Node: Modifiers6198 ! Node: Programming with GNU History7336 ! Node: Introduction to History8061 ! Node: History Storage9746 ! Node: History Functions10857 ! Node: Initializing History and State Management11841 ! Node: History List Management12641 ! Node: Information About the History List14191 ! Node: Moving Around the History List15547 ! Node: Searching the History List16536 ! Node: Managing the History File18454 ! Node: History Expansion20260 ! Node: History Variables22155 ! Node: History Programming Example24725 ! Node: Concept Index27447 ! Node: Function and Variable Index27933  End Tag Table diff -Nrc2 readline-4.1/doc/history.ps readline-4.2/doc/history.ps *** readline-4.1/doc/history.ps Wed Jan 19 12:18:06 2000 --- readline-4.2/doc/history.ps Mon Apr 16 11:05:46 2001 *************** *** 1,4 **** %!PS-Adobe-2.0 ! %%Creator: dvips(k) 5.82 Copyright 1998 Radical Eye Software %%Title: history.dvi %%Pages: 20 --- 1,4 ---- %!PS-Adobe-2.0 ! %%Creator: dvips(k) 5.86 Copyright 1999 Radical Eye Software %%Title: history.dvi %%Pages: 20 *************** *** 9,13 **** %DVIPSCommandLine: dvips -D 300 -t letter -o history.ps history.dvi %DVIPSParameters: dpi=300, compressed ! %DVIPSSource: TeX output 2000.01.19:1217 %%BeginProcSet: texc.pro %! --- 9,13 ---- %DVIPSCommandLine: dvips -D 300 -t letter -o history.ps history.dvi %DVIPSParameters: dpi=300, compressed ! %DVIPSSource: TeX output 2001.04.16:1105 %%BeginProcSet: texc.pro %! *************** *** 21,27 **** exch round exch]setmatrix}N/@landscape{/isls true N}B/@manualfeed{ statusdict/manualfeed true put}B/@copies{/#copies X}B/FMat[1 0 0 -1 0 0] ! N/FBB[0 0 0 0]N/nn 0 N/IE 0 N/ctr 0 N/df-tail{/nn 8 dict N nn begin /FontType 3 N/FontMatrix fntrx N/FontBBox FBB N string/base X array ! /BitMaps X/BuildChar{CharBuilder}N/Encoding IE N end A{/foo setfont}2 array copy cvx N load 0 nn put/ctr 0 N[}B/sf 0 N/df{/sf 1 N/fntrx FMat N df-tail}B/dfs{div/sf X/fntrx[sf 0 0 sf neg 0 0]N df-tail}B/E{pop nn A --- 21,27 ---- exch round exch]setmatrix}N/@landscape{/isls true N}B/@manualfeed{ statusdict/manualfeed true put}B/@copies{/#copies X}B/FMat[1 0 0 -1 0 0] ! N/FBB[0 0 0 0]N/nn 0 N/IEn 0 N/ctr 0 N/df-tail{/nn 8 dict N nn begin /FontType 3 N/FontMatrix fntrx N/FontBBox FBB N string/base X array ! /BitMaps X/BuildChar{CharBuilder}N/Encoding IEn N end A{/foo setfont}2 array copy cvx N load 0 nn put/ctr 0 N[}B/sf 0 N/df{/sf 1 N/fntrx FMat N df-tail}B/dfs{div/sf X/fntrx[sf 0 0 sf neg 0 0]N df-tail}B/E{pop nn A *************** *** 51,55 **** SI restore userdict/eop-hook known{eop-hook}if showpage}N/@start{ userdict/start-hook known{start-hook}if pop/VResolution X/Resolution X ! 1000 div/DVImag X/IE 256 array N 2 string 0 1 255{IE S A 360 add 36 4 index cvrs cvn put}for pop 65781.76 div/vsize X 65781.76 div/hsize X}N /p{show}N/RMat[1 0 0 -1 0 0]N/BDot 260 string N/Rx 0 N/Ry 0 N/V{}B/RV/v{ --- 51,55 ---- SI restore userdict/eop-hook known{eop-hook}if showpage}N/@start{ userdict/start-hook known{start-hook}if pop/VResolution X/Resolution X ! 1000 div/DVImag X/IEn 256 array N 2 string 0 1 255{IEn S A 360 add 36 4 index cvrs cvn put}for pop 65781.76 div/vsize X 65781.76 div/hsize X}N /p{show}N/RMat[1 0 0 -1 0 0]N/BDot 260 string N/Rx 0 N/Ry 0 N/V{}B/RV/v{ *************** *** 108,113 **** 70B5FCA210107F8F14>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fd cmsl9 9 1 ! /Fd 1 47 df<1270A212F0126004047D830B>46 D E %EndDVIPSBitmapFont %DVIPSBitmapFont: Fe cmr9 9 24 --- 108,113 ---- 70B5FCA210107F8F14>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fd cmti9 9 1 ! /Fd 1 47 df<1230127812F0126005047C830C>46 D E %EndDVIPSBitmapFont %DVIPSBitmapFont: Fe cmr9 9 24 *************** *** 195,208 **** 00E0EA7E03B5FCA214167E9519>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fh cmtt10 12 24 ! /Fh 24 119 df<13E0A538F0E1E0EAFCE7387EEFC0381FFF00EA07FCEA01F0EA07FCEA1F FF387EEFC038FCE7E0EAF0E13800E000A513157D991A>42 D<1338137CA2136C13EEA313 C6A2EA01C7A438038380A4380701C0A213FFA24813E0EA0E00A4481370387F01FC38FF83 FE387F01FC171E7F9D1A>65 D69 D<387FFFFCB5FC7E380E001CA51400A2EB03 ! 80A3EA0FFFA3EA0E03A390C7FCA8EA7FE012FF127F161E7F9D1A>I<38FF83FEA3381C00 ! 70AA381FFFF0A3381C0070AB38FF83FEA3171E7F9D1A>72 DI<38FE03FE12FFA2381D8070A213C0121CA213E0A213601370A213 ! 301338A21318131CA2130C130EA21306A213071303A238FF81F0A21380171E7F9D1A>78 DII E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fh cmtt10 12 27 ! /Fh 27 119 df<13E0A538F0E1E0EAFCE7387EEFC0381FFF00EA07FCEA01F0EA07FCEA1F FF387EEFC038FCE7E0EAF0E13800E000A513157D991A>42 D<1338137CA2136C13EEA313 C6A2EA01C7A438038380A4380701C0A213FFA24813E0EA0E00A4481370387F01FC38FF83 FE387F01FC171E7F9D1A>65 D69 D<38FF83FEA3381C0070AA381FFFF0A3381C ! 0070AB38FF83FEA3171E7F9D1A>72 D ! I<38FE03FE12FFA2381D8070A213C0121CA213E0A213601370A213301338A21318131CA2 ! 130C130EA21306A213071303A238FF81F0A21380171E7F9D1A>78 DI95 D97 D99 ! DI<12FEA3120EA6133EEBFF80000F ! 13C013C1EB80E01300120EAC38FFE3FE13E713E3171E7F9D1A>104 ! DI< ! EAFE3EEBFF80B512C0EA0FC1EB80E01300120EAC38FFE3FE13E713E317157F941A>110 ! DI<387F81F838FF8FFC38 ! 7F9FFE3803FE1EEBF80CEBE000A25B5BAAEA7FFFB5FC7E17157F941A>114 D<487E1203A6387FFFE0B5FCA238038000AA1470A43801C1E013FF6C1380EB3F00141C7F 9B1A>116 D<38FE0FE0A3EA0E00AD1301EA0F033807FFFE7EEA00FC17157F941A>I<387F --- 214,232 ---- D<387FFFC0B512E0A26C13C013047D7E1A>95 D97 D<12FEA3120EA6133EEBFF80000F13E0EBC1F0EB8070EB0038120E14 ! 1CA7000F13381478EB80F0EBC1E0EBFFC0000E138038063E00161E7F9D1A>IIIII<12FEA3120EA6133EEBFF80000F13C013C1EB80E01300120EAC38FFE3 ! FE13E713E3171E7F9D1A>104 DI108 ! D ! 110 DI<387F81F838FF8F ! FC387F9FFE3803FE1EEBF80CEBE000A25B5BAAEA7FFFB5FC7E17157F941A>114 D<487E1203A6387FFFE0B5FCA238038000AA1470A43801C1E013FF6C1380EB3F00141C7F 9B1A>116 D<38FE0FE0A3EA0E00AD1301EA0F033807FFFE7EEA00FC17157F941A>I<387F *************** *** 326,330 **** D<1438EB01F8EB00781438A21470A614E013FCEA0382EA0601121CEA3C00383801C01278 12F0A438E00380A412F0EA700738380F00381C37803807C7E015207D9F19>I<13F8EA07 ! 0EEA0E07121C383803801278127012F0A2B5FC00F0C7FC5AA46C5AEA7002EA3004EA1C18 EA07E011147D9314>II<140EEB3E11EBE1A33801C1C238 --- 330,334 ---- D<1438EB01F8EB00781438A21470A614E013FCEA0382EA0601121CEA3C00383801C01278 12F0A438E00380A412F0EA700738380F00381C37803807C7E015207D9F19>I<13F8EA07 ! 0EEA0E07381C038012381278127012F0B5FC00F0C7FCA25AA46C5AEA7002EA3004EA1C18 EA07E011147D9314>II<140EEB3E11EBE1A33801C1C238 *************** *** 357,362 **** 191D809318>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fk cmbx12 17.28 36 ! /Fk 36 122 df49 DI E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fk cmcsc10 10.95 3 ! /Fk 3 118 df103 ! D<38FC01FC381E007014201217EA1380A2EA11C0EA10E0A213701338A2131C130E1307A2 ! EB03A0EB01E0A213001460123800FE132016177E961C>110 D<38FF81FC381C00701420 ! B0000C1340120E6C138038018300EA007C16177E961C>117 D E ! %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fl cmbx12 17.28 36 ! /Fl 36 122 df49 DI E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fl cmsy10 10.95 1 ! /Fl 1 14 df<14FF010713E090381F00F80178131E01E01307D80180EB018048C812C000 ! 061560481530A248151848150CA2481506A4481503A900601506A46C150CA26C15186C15 ! 30A26C15606C15C06C6CEB0180D800E0EB07000178131E011F13F8903807FFE0010090C7 ! FC282B7EA02D>13 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fm cmbx12 14.4 45 ! /Fm 45 122 df<123C127FEAFF80A213C0A3127F123E1200A2EA0180A3EA0300A2120612 0E5A5A12100A157B8813>44 D<121C127FA2EAFF80A3EA7F00A2121C09097B8813>46 D<130E131E137EEA07FE12FFA212F81200B3ABB512FEA317277BA622>49 --- 456,467 ---- 1EEA787CEA3FF0EA0FC0262E7E9F2B>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fm cmsy10 10.95 1 ! /Fm 1 14 df<14FE903807FFC090381F01F0903878003C01E0130ED80180130348C7EA01 ! 800006EC00C0481560A2481530481518A248150CA4481506A90060150CA46C1518A26C15 ! 306C1560A26C15C06CEC01806C6CEB0300D800E0130E0178133C90381F01F0903807FFC0 ! D900FEC7FC272B7DA02E>13 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fn cmbx12 14.4 44 ! /Fn 44 122 df<123C127FEAFF80A213C0A3127F123E1200A2EA0180A3EA0300A2120612 0E5A5A12100A157B8813>44 D<121C127FA2EAFF80A3EA7F00A2121C09097B8813>46 D<130E131E137EEA07FE12FFA212F81200B3ABB512FEA317277BA622>49 *************** *** 482,554 **** B45B90387FF007011FB5129F0107EBFE0F9039007FF0032D297CA835>III77 ! DI80 ! D82 D<9038FF80600003EBF0E0000F13F8381F80FD383F ! 001F003E1307481303A200FC1301A214007EA26C140013C0EA7FFCEBFFE06C13F86C13FE ! 80000714806C14C0C6FC010F13E0EB007FEC1FF0140F140700E01303A46C14E0A26C1307 ! 6C14C0B4EB0F80EBE03F39E3FFFE0000E15B38C01FF01C297CA825>I85 DII<3803FF80000F13F0381F01FC383F80 ! FE147F801580EA1F00C7FCA4EB3FFF3801FC3FEA0FE0EA1F80EA3F00127E5AA4145F007E ! 13DF393F839FFC381FFE0F3803FC031E1B7E9A21>97 DIIII< ! EB07F8EB3FFCEB7E3E3801FC7FEA03F813F01207143E1400A7B512C0A33807F000B3A338 ! 7FFF80A3182A7EA915>I<9038FF80F00003EBE3F8390FC1FE1C391F007C7C48137E003E ! EB3E10007EEB3F00A6003E133E003F137E6C137C380FC1F8380BFFE00018138090C8FC12 ! 38A2123C383FFFF814FF6C14C06C14E06C14F0121F383C0007007CEB01F8481300A4007C ! EB01F0A2003FEB07E0390FC01F806CB5120038007FF01E287E9A22>II<1207EA0F80EA1FC0EA3FE0A3EA1FC0EA0F80EA0700C7FCA7EAFFE0A3120F ! B3A3EAFFFEA30F2B7EAA12>I108 ! D<26FFC07FEB1FC0903AC1FFC07FF0903AC307E0C1F8D80FC49038F101FC9039C803F200 ! 01D801FE7F01D05BA201E05BB03CFFFE3FFF8FFFE0A3331B7D9A38>I<38FFC07E9038C1 ! FF809038C30FC0D80FC413E0EBC80701D813F013D0A213E0B039FFFE3FFFA3201B7D9A25 ! >II<38FFE1FE9038EFFF809038FE0FE0390FF803F09038F001F801E013FC ! 140015FEA2157FA8157E15FEA215FC140101F013F89038F807F09038FC0FE09038EFFF80 ! 9038E1FC0001E0C7FCA9EAFFFEA320277E9A25>I<38FFC1F0EBC7FCEBC63E380FCC7F13 ! D813D0A2EBF03EEBE000B0B5FCA3181B7F9A1B>114 D<3803FE30380FFFF0EA3E03EA78 ! 00127000F01370A27E00FE1300EAFFE06CB4FC14C06C13E06C13F0000713F8C6FCEB07FC ! 130000E0137C143C7E14387E6C137038FF01E038E7FFC000C11300161B7E9A1B>I<13E0 ! A41201A31203A21207120F381FFFE0B5FCA2380FE000AD1470A73807F0E0000313C03801 ! FF8038007F0014267FA51A>I<39FFE07FF0A3000F1307B2140FA2000713173903F067FF ! 3801FFC738007F87201B7D9A25>I<39FFFC03FFA3390FF000F0000714E07F0003EB01C0 ! A2EBFC0300011480EBFE070000140013FFEB7F0EA2149EEB3F9C14FC6D5AA26D5AA36D5A ! A26D5AA2201B7F9A23>I<3BFFFC7FFC1FFCA33B0FE00FE001C02607F007EB0380A201F8 ! EBF00700031600EC0FF801FC5C0001150EEC1FFC2600FE1C5B15FE9039FF387E3C017F14 ! 38EC787F6D486C5A16F0ECE01F011F5CA26D486C5AA2EC800701075CA22E1B7F9A31>I< ! 39FFFC1FFEA33907F003803803F8079038FC0F003801FE1E00005BEB7F3814F86D5A6D5A ! 130F806D7E130F497EEB3CFEEB38FFEB787F9038F03F803901E01FC0D803C013E0EB800F ! 39FFF03FFFA3201B7F9A23>I<39FFFC03FFA3390FF000F0000714E07F0003EB01C0A2EB ! FC0300011480EBFE070000140013FFEB7F0EA2149EEB3F9C14FC6D5AA26D5AA36D5AA26D ! 5AA25CA21307003890C7FCEA7C0FEAFE0E131E131C5BEA74F0EA3FE0EA0F8020277F9A23 ! >I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fn cmtt10 10.95 75 ! /Fn 75 127 df<127012F8B012701200A5127012F8A31270051C779B18>33 DI --- 493,561 ---- B45B90387FF007011FB5129F0107EBFE0F9039007FF0032D297CA835>III78 D80 D82 D<9038FF80600003EBF0E0 ! 000F13F8381F80FD383F001F003E1307481303A200FC1301A214007EA26C140013C0EA7F ! FCEBFFE06C13F86C13FE80000714806C14C0C6FC010F13E0EB007FEC1FF0140F140700E0 ! 1303A46C14E0A26C13076C14C0B4EB0F80EBE03F39E3FFFE0000E15B38C01FF01C297CA8 ! 25>I85 ! DII<3803FF80000F13F0381F01FC383F80FE147F801580EA1F00C7FCA4EB3FFF3801 ! FC3FEA0FE0EA1F80EA3F00127E5AA4145F007E13DF393F839FFC381FFE0F3803FC031E1B ! 7E9A21>97 DIIIII<9038FF80F000 ! 03EBE3F8390FC1FE1C391F007C7C48137E003EEB3E10007EEB3F00A6003E133E003F137E ! 6C137C380FC1F8380BFFE00018138090C8FC1238A2123C383FFFF814FF6C14C06C14E06C ! 14F0121F383C0007007CEB01F8481300A4007CEB01F0A2003FEB07E0390FC01F806CB512 ! 0038007FF01E287E9A22>II<1207EA0F80EA1FC0EA3FE0 ! A3EA1FC0EA0F80EA0700C7FCA7EAFFE0A3120FB3A3EAFFFEA30F2B7EAA12>I108 D<26FFC07FEB1FC0903AC1FFC07FF0903AC307E0 ! C1F8D80FC49038F101FC9039C803F20001D801FE7F01D05BA201E05BB03CFFFE3FFF8FFF ! E0A3331B7D9A38>I<38FFC07E9038C1FF809038C30FC0D80FC413E0EBC80701D813F013 ! D0A213E0B039FFFE3FFFA3201B7D9A25>II<38FFE1FE9038EFFF809038FE ! 0FE0390FF803F09038F001F801E013FC140015FEA2157FA8157E15FEA215FC140101F013 ! F89038F807F09038FC0FE09038EFFF809038E1FC0001E0C7FCA9EAFFFEA320277E9A25> ! I<38FFC1F0EBC7FCEBC63E380FCC7F13D813D0A2EBF03EEBE000B0B5FCA3181B7F9A1B> ! 114 D<3803FE30380FFFF0EA3E03EA7800127000F01370A27E00FE1300EAFFE06CB4FC14 ! C06C13E06C13F0000713F8C6FCEB07FC130000E0137C143C7E14387E6C137038FF01E038 ! E7FFC000C11300161B7E9A1B>I<13E0A41201A31203A21207120F381FFFE0B5FCA2380F ! E000AD1470A73807F0E0000313C03801FF8038007F0014267FA51A>I<39FFE07FF0A300 ! 0F1307B2140FA2000713173903F067FF3801FFC738007F87201B7D9A25>I<39FFFC03FF ! A3390FF000F0000714E07F0003EB01C0A2EBFC0300011480EBFE070000140013FFEB7F0E ! A2149EEB3F9C14FC6D5AA26D5AA36D5AA26D5AA2201B7F9A23>I<3BFFFC7FFC1FFCA33B ! 0FE00FE001C02607F007EB0380A201F8EBF00700031600EC0FF801FC5C0001150EEC1FFC ! 2600FE1C5B15FE9039FF387E3C017F1438EC787F6D486C5A16F0ECE01F011F5CA26D486C ! 5AA2EC800701075CA22E1B7F9A31>I<39FFFC1FFEA33907F003803803F8079038FC0F00 ! 3801FE1E00005BEB7F3814F86D5A6D5A130F806D7E130F497EEB3CFEEB38FFEB787F9038 ! F03F803901E01FC0D803C013E0EB800F39FFF03FFFA3201B7F9A23>I<39FFFC03FFA339 ! 0FF000F0000714E07F0003EB01C0A2EBFC0300011480EBFE070000140013FFEB7F0EA214 ! 9EEB3F9C14FC6D5AA26D5AA36D5AA26D5AA25CA21307003890C7FCEA7C0FEAFE0E131E13 ! 1C5BEA74F0EA3FE0EA0F8020277F9A23>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fo cmtt10 10.95 76 ! /Fo 76 127 df<127012F8B012701200A5127012F8A31270051C779B18>33 DI *************** *** 590,595 **** D68 DII<387F07F038FF 8FF8387F07F0381C01C0A9EA1FFFA3EA1C01AA387F07F038FF8FF8387F07F0151C7F9B18 >72 DI68 DII<387F07F038FF 8FF8387F07F0381C01C0A9EA1FFFA3EA1C01AA387F07F038FF8FF8387F07F0151C7F9B18 >72 DIII108 D<38F9C1C038FFF7F013FF383E3E ! 38EA3C3CA2EA3838AB38FE3E3EEB7E7EEB3E3E1714809318>IIII<3801F380EA07FBEA1FFFEA3E1FEA380FEA7007A2EAE003A6EA7007A2 ! EA380FEA3C1FEA1FFFEA0FFBEA03E3EA0003A7EB1FF0EB3FF8EB1FF0151E7E9318>I<38 ! FF0FC0EB3FE0EB7FF0EA07F0EBE060EBC0005BA290C7FCA9EAFFFC7F5B14147E9318>I< ! EA07F7EA3FFF5AEA780FEAE007A3007CC7FCEA7FE0EA1FFCEA03FEEA001F38600780EAE0 ! 03A212F038F80F00B5FC13FCEAE7F011147D9318>I<487E1203A4387FFFC0B5FCA23803 ! 8000A9144014E0A33801C1C013FF6C1380EB3E0013197F9818>I<387E07E0EAFE0FEA7E ! 07EA0E00AC1301EA0F033807FFFC6C13FE3801FCFC1714809318>I<387F8FF000FF13F8 ! 007F13F0381C01C0380E0380A338070700A3138FEA038EA3EA01DCA3EA00F8A213701514 ! 7F9318>I<38FF07F8138F1307383800E0A4381C01C0137113F9A213D9EA1DDD000D1380 ! A3138DEA0F8FA23807070015147F9318>I<387F8FF0139F138F380F0700EA078EEA039E ! EA01DC13F81200137013F07FEA01DCEA039E138EEA0707000E1380387F8FF000FF13F800 ! 7F13F015147F9318>I<387F8FF000FF13F8007F13F0380E01C0EB0380A21207EB0700A2 ! EA0387A2138EEA01CEA213CC120013DC1378A31370A313F05B1279EA7BC0EA7F806CC7FC ! 121E151E7F9318>I<383FFFF05AA2387001E0EB03C0EB078038000F00131E5B13F8485A ! EA03C0485A380F0070121E5A5AB512F0A314147F9318>II<126012 ! F0B3B012600424769F18>I<127CB4FC13C01203C67EAB7FEB7FC0EB3FE0A2EB7FC0EBF0 ! 005BABEA03C012FF90C7FC127C13247E9F18>II E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fo cmr10 10.95 75 ! /Fo 75 123 df<90381F83E09038F06E303901C07878380380F8903800F03048EB7000A7 B612803907007000B2383FE3FF1D20809F1B>11 D<133FEBE0C0EA01C0380381E0EA0701 A290C7FCA6B512E0EA0700B2383FC3FC1620809F19>III<127E12FE127E120EA5EB3FF0A3EB0780EB0F00131E5B5B5BEA0FF87F139C130EEA ! 0E0F7FEB038014C0387FC7F812FF127F151C7F9B18>107 DI<38F9C1C038FFF7F013FF383E3E38EA3C3CA2EA3838AB38FE3E3EEB7E ! 7EEB3E3E1714809318>IIII<3801F380EA07FB ! EA1FFFEA3E1FEA380FEA7007A2EAE003A6EA7007A2EA380FEA3C1FEA1FFFEA0FFBEA03E3 ! EA0003A7EB1FF0EB3FF8EB1FF0151E7E9318>I<38FF0FC0EB3FE0EB7FF0EA07F0EBE060 ! EBC0005BA290C7FCA9EAFFFC7F5B14147E9318>II<487E1203A4387FFFC0B5FCA238038000A9144014E0A33801C1C013FF6C ! 1380EB3E0013197F9818>I<387E07E0EAFE0FEA7E07EA0E00AC1301EA0F033807FFFC6C ! 13FE3801FCFC1714809318>I<387F8FF000FF13F8007F13F0381C01C0380E0380A33807 ! 0700A3138FEA038EA3EA01DCA3EA00F8A2137015147F9318>I<38FF07F8138F13073838 ! 00E0A4381C01C0137113F9A213D9EA1DDD000D1380A3138DEA0F8FA23807070015147F93 ! 18>I<387F8FF0139F138F380F0700EA078EEA039EEA01DC13F81200137013F07FEA01DC ! EA039E138EEA0707000E1380387F8FF000FF13F8007F13F015147F9318>I<387F8FF000 ! FF13F8007F13F0380E01C0EB0380A21207EB0700A2EA0387A2138EEA01CEA213CC120013 ! DC1378A31370A313F05B1279EA7BC0EA7F806CC7FC121E151E7F9318>I<383FFFF05AA2 ! 387001E0EB03C0EB078038000F00131E5B13F8485AEA03C0485A380F0070121E5A5AB512 ! F0A314147F9318>II<126012F0B3B012600424769F18>I<127CB4FC ! 13C01203C67EAB7FEB7FC0EB3FE0A2EB7FC0EBF0005BABEA03C012FF90C7FC127C13247E ! 9F18>II ! E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fp cmr10 10.95 74 ! /Fp 74 123 df<90381F83E09038F06E303901C07878380380F8903800F03048EB7000A7 B612803907007000B2383FE3FF1D20809F1B>11 D<133FEBE0C0EA01C0380381E0EA0701 A290C7FCA6B512E0EA0700B2383FC3FC1620809F19>II<127012F8A3127005057C840D>I48 D<13801203120F12F31203B3A6EA07C0EAFFFE0F1E7C9D17>III<127012F8A3127005057C840D>I48 D<13801203120F12F31203B3A6EA07C0EA7FFE0F1E7C9D17>IIII<90380FE01090 ! 38381C309038E002703803C00139078000F048C71270121E15305A1510127C127800F814 ! 00A7EC3FFEEC01F000781300127C123CA27EA27E6C7E3903C001703900E002309038380C ! 1090380FF0001F217E9F24>I<39FFF07FF8390F000780AD90B5FCEB0007AF39FFF07FF8 ! 1D1F7E9E22>II<3807FFC038003E00131EB3A3 ! 122012F8A3EAF01CEA403CEA6038EA1070EA0FC012207F9E17>I76 DIIIIII<3803F040 ! 380C0CC0EA1803EA3001EA6000A212E01440A36C13007E127CEA7F80EA3FF86CB4FC0007 ! 1380C613C0EB1FE013031301EB00F014707EA46C136014E06C13C038F8018038C60300EA ! 81FC14217E9F19>I<007FB512E038780F010060EB006000401420A200C0143000801410 ! A400001400B3497E3803FFFC1C1F7E9E21>I<39FFF00FF8390F0003E0EC0080B3A46CEB ! 01001380120314026C6C5A6C6C5AEB3830EB0FC01D207E9E22>I<39FFF003FE391F8000 ! F86CC7126015206C6C1340A36C6C1380A2EBE00100011400A23800F002A213F8EB7804A2 ! 6D5AA36D5AA2131F6D5AA2EB07C0A36D5AA36DC7FC1F207F9E22>I<3BFFF07FF81FF03B ! 1F000FC007C06C903907800180170015C001805C00071502EC09E013C000035DEC19F014 ! 10D801E05CA2EC2078D800F05CA2EC403C01785CA2EC801E017C1460013C144090383D00 ! 0F133F6D5CA2011E1307010E91C7FCA2010C7F010413022C207F9E2F>I<12FFA212C0B3 ! B3A512FFA2082D7CA10D>91 DI<12FFA21203B3B3A512FFA2082D80A10D>I<12081210 ! 1220A21240A21280A312B812FCA2127C1238060E7D9F0D>96 DI<121C12FC121CAA137CEA1D87381E0180EB00C0001C13E01470A21478A6 ! 147014F014E0001E13C0381A018038198700EA107C15207E9F19>IIII<13 ! 7CEA01C6EA030F1207EA0E061300A7EAFFF0EA0E00B2EA7FE01020809F0E>I<14E03803 ! E330EA0E3CEA1C1C38380E00EA780FA5EA380E6C5AEA1E38EA33E00020C7FCA21230A2EA ! 3FFE381FFF8014C0383001E038600070481330A4006013606C13C0381C03803803FC0014 ! 1F7F9417>I<121C12FC121CAA137C1386EA1D03001E1380A2121CAE38FF8FF014207E9F ! 19>I<1238127CA31238C7FCA6121C12FC121CB1EAFF80091F7F9E0C>I<13E0EA01F0A3EA ! 00E01300A61370EA07F012001370B3A31260EAF06013C0EA6180EA3F000C28829E0E>I< ! 121C12FC121CAAEB1FE0EB0780EB060013045B5B5B136013E0EA1DF0EA1E70EA1C38133C ! 131C7F130F7F148014C038FF9FF014207E9F18>I<121C12FC121CB3ABEAFF8009207F9F ! 0C>I<391C3E03E039FCC30C30391D039038391E01E01CA2001C13C0AE3AFF8FF8FF8021 ! 147E9326>IIII<3801 ! F04038070CC0EA0E02EA1C03EA38011278127012F0A6127012781238EA1C03EA0C05EA07 ! 09EA01F1EA0001A8EB0FF8151D7F9318>III<1202A31206A2120E ! A2123EEAFFF8EA0E00AB1304A5EA07081203EA01F00E1C7F9B12>I<381C0380EAFC1FEA ! 1C03AE1307120CEA061B3803E3F014147E9319>I<38FF83F8383E00E0001C13C06C1380 ! A338070100A21383EA0382A2EA01C4A213E4EA00E8A21370A3132015147F9318>I<39FF ! 9FE1FC393C078070391C030060EC8020000E1440A214C0D80704138014E0A23903886100 ! 1471A23801D032143A143E3800E01CA2EB6018EB40081E147F9321>I<38FF87F8381E03 ! C0380E0180EB0300EA0702EA0384EA01C813D8EA00F01370137813F8139CEA010E1202EA ! 060738040380000C13C0003C13E038FE07FC16147F9318>I<38FF83F8383E00E0001C13 ! C06C1380A338070100A21383EA0382A2EA01C4A213E4EA00E8A21370A31320A25BA3EAF0 ! 80A200F1C7FC1262123C151D7F9318>I ! I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fp cmbx12 20.736 13 ! /Fp 13 122 dfII<90380FE02090 ! 387818609038E004E03803800238070001481300001E1460A25A1520127C127800F81400 ! A7EC7FFCEC03E000781301127C123CA27EA27E7E380380023900E0046090387818209038 ! 0FE0001E217D9F24>I<39FFF07FF8390F000780AD90B5FCEB0007AF39FFF07FF81D1F7E ! 9E22>II76 DIIIIII<38 ! 03F040380C0CC0EA1803EA3001EA6000A212E01440A36C13007E127CEA7F80EA3FF86CB4 ! FC00071380C613C0EB1FE013031301EB00F014707EA46C136014E06C13C038F8018038C6 ! 0300EA81FC14217E9F19>I<007FB512E038780F010060EB006000401420A200C0143000 ! 801410A400001400B3497E3803FFFC1C1F7E9E21>I<39FFF00FF8390F0003E0EC0080B3 ! A46CEB01001380120314026C6C5A6C6C5AEB3830EB0FC01D207E9E22>I<39FFF003FE39 ! 1F8000F86CC7126015206C6C1340A36C6C1380A2EBE00100011400A23800F002A213F8EB ! 7804A26D5AA36D5AA2131F6D5AA2EB07C0A36D5AA36DC7FC1F207F9E22>I<3BFFF07FF8 ! 1FF03B1F000FC007C06C903907800180170015C001805C00071502EC09E013C000035DEC ! 19F01410D801E05CA2EC2078D800F05CA2EC403C01785CA2EC801E017C1460013C144090 ! 383D000F133F6D5CA2011E1307010E91C7FCA2010C7F010413022C207F9E2F>I<12FFA2 ! 12C0B3B3A512FFA2082D7CA10D>91 DI<12FFA21203B3B3A512FFA2082D80A10D>I<12 ! 0812101220A21240A21280A312B812FCA2127C1238060E7D9F0D>96 ! DI<121C12FC121CAA137CEA1D87381E0180EB00 ! C0001C13E01470A21478A6147014F014E0001E13C0381A018038198700EA107C15207E9F ! 19>IIII<137CEA01C6EA030F1207EA0E061300A7EAFFF0EA0E00B2EA7FE010 ! 20809F0E>I<14E03803E330EA0E3CEA1C1C38380E00EA780FA5EA380E6C5AEA1E38EA33 ! E00020C7FCA21230A2EA3FFE381FFF8014C0383001E038600070481330A4006013606C13 ! C0381C03803803FC00141F7F9417>I<121C12FC121CAA137C1386EA1D03001E1380A212 ! 1CAE38FF8FF014207E9F19>I<1238127CA31238C7FCA6121C12FC121CB1EAFF80091F7F ! 9E0C>I<13E0EA01F0A3EA00E01300A61370EA07F012001370B3A31260EAF06013C0EA61 ! 80EA3F000C28829E0E>I<121C12FC121CAAEB1FE0EB0780EB060013045B5B5B136013E0 ! EA1DF0EA1E70EA1C38133C131C7F130F7F148014C038FF9FF014207E9F18>I<121C12FC ! 121CB3ABEAFF8009207F9F0C>I<391C3E03E039FCC30C30391D019018001EEBE01CA200 ! 1C13C0AE3AFF8FF8FF8021147E9326>IIII<3801F04038070CC0EA0E02EA1C03EA38011278127012F0A61270 ! 12781238EA1C03EA0C05EA0709EA01F1EA0001A8EB0FF8151D7F9318>III<1202A31206A2120EA2123EEAFFF8EA0E00AB1304A5EA07081203EA01F00E1C7F ! 9B12>I<381C0380EAFC1FEA1C03AE1307120CEA061B3803E3F014147E9319>I<38FF83F8 ! 383E00E0001C13C06C1380A338070100A21383EA0382A2EA01C4A213E4EA00E8A21370A3 ! 132015147F9318>I<39FF9FE1FC393C078070391C030060EC8020000E1440A214C0D807 ! 04138014E0A239038861001471A23801D032143A143E3800E01CA2EB6018EB40081E147F ! 9321>I<38FF87F8381E03C0380E0180EB0300EA0702EA0384EA01C813D8EA00F0137013 ! 7813F8139CEA010E1202EA060738040380000C13C0003C13E038FE07FC16147F9318>I< ! 38FF83F8383E00E0001C13C06C1380A338070100A21383EA0382A2EA01C4A213E4EA00E8 ! A21370A31320A25BA3EAF080A200F1C7FC1262123C151D7F9318>II E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fq cmbx12 20.736 13 ! /Fq 13 122 df)d ! Fo(in)j(an)o(y)f(\014le)75 1513 y(that)d(uses)h(the)h(History)e (library's)i(features.)18 b(It)12 b(supplies)i(extern)e(declarations)h ! (for)e(all)i(of)f(the)g(library's)75 1568 y(public)17 b(functions)f(and)g(v)m(ariables,)g(and)f(declares)h(all)g(of)f(the)h ! (public)h(data)d(structures.)75 1686 y Fm(2.2)33 b(History)22 ! b(Storage)137 1778 y Fo(The)16 b(history)f(list)h(is)g(an)f(arra)o(y)f (of)g(history)i(en)o(tries.)k(A)15 b(history)g(en)o(try)g(is)h ! (declared)g(as)f(follo)o(ws:)195 1839 y Fn(typedef)23 ! b(struct)g(_hist_entry)f({)243 1891 y(char)h(*line;)243 ! 1943 y(char)g(*data;)195 1995 y(})h(HIST_ENTRY;)137 2058 ! y Fo(The)16 b(history)f(list)h(itself)g(migh)o(t)f(therefore)g(b)q(e)h ! (declared)g(as)195 2119 y Fn(HIST_ENTRY)22 b(**the_history_list;)137 ! 2183 y Fo(The)16 b(state)e(of)h(the)g(History)g(library)h(is)g ! (encapsulated)g(in)o(to)f(a)g(single)i(structure:)195 ! 2243 y Fn(/*)24 b(A)f(structure)g(used)g(to)h(pass)f(the)h(current)f ! (state)g(of)g(the)h(history)f(stuff)g(around.)g(*/)p ! 2033 2253 21 42 v 195 2295 a(typedef)g(struct)g(_hist_state)f({)243 ! 2347 y(HIST_ENTRY)g(**entries;)214 b(/*)23 b(Pointer)g(to)h(the)f ! (entries)g(themselves.)f(*/)243 2399 y(int)h(offset;)453 ! b(/*)23 b(The)h(location)e(pointer)h(within)g(this)h(array.)f(*/)p ! 2033 2409 V 243 2451 a(int)g(length;)453 b(/*)23 b(Number)g(of)h ! (elements)f(within)g(this)g(array.)g(*/)p 1985 2461 V ! 243 2503 a(int)g(size;)501 b(/*)23 b(Number)g(of)h(slots)f(allocated)g ! (to)g(this)h(array.)f(*/)p 2057 2513 V 243 2555 a(int)g(flags;)195 ! 2606 y(})h(HISTORY_STATE;)137 2670 y Fo(If)16 b(the)f(\015ags)g(mem)o ! (b)q(er)g(includes)j Fn(HS_STIFLED)p Fo(,)13 b(the)i(history)h(has)f(b) ! q(een)h(sti\015ed.)p eop %%Page: 6 8 ! 6 7 bop 75 -58 a Fo(6)1347 b(GNU)15 b(History)g(Library)75 ! 183 y Fm(2.3)33 b(History)22 b(F)-6 b(unctions)137 278 ! y Fo(This)21 b(section)g(describ)q(es)h(the)f(calling)h(sequence)g(for) ! e(the)g(v)m(arious)h(functions)g(presen)o(t)g(in)g(GNU)75 ! 333 y(History)l(.)75 441 y Fi(2.3.1)30 b(Initializing)20 ! b(History)h(and)f(State)g(Managemen)n(t)137 536 y Fo(This)e(section)g ! (describ)q(es)h(functions)f(used)g(to)e(initialize)21 ! b(and)c(manage)g(the)g(state)g(of)g(the)g(History)75 ! 591 y(library)f(when)g(y)o(ou)f(w)o(an)o(t)f(to)g(use)i(the)f(history)g ! (functions)h(in)g(y)o(our)f(program.)1650 679 y(F)l(unction)-1749 ! b Fh(void)20 b Fg(using)p 333 679 18 3 v 20 w(history)j ! Ff(\(\))195 734 y Fo(Begin)18 b(a)f(session)h(in)g(whic)o(h)g(the)g ! (history)f(functions)h(migh)o(t)f(b)q(e)h(used.)27 b(This)18 ! b(initializes)195 788 y(the)d(in)o(teractiv)o(e)h(v)m(ariables.)1650 ! 877 y(F)l(unction)-1749 b Fh(HISTORY_STATE)21 b(*)e Fg(history)p ! 657 877 V 21 w(get)p 755 877 V 21 w(history)p 951 877 ! V 21 w(state)j Ff(\(\))195 931 y Fo(Return)16 b(a)f(structure)g ! (describing)i(the)e(curren)o(t)g(state)f(of)h(the)g(input)i(history)l ! (.)1650 1019 y(F)l(unction)-1749 b Fh(void)20 b Fg(history)p ! 377 1019 V 20 w(set)p 468 1019 V 21 w(history)p 664 1019 ! V 21 w(state)j Ff(\()p Fn(HISTORY_STATE)13 b(*state)p ! Ff(\))195 1074 y Fo(Set)i(the)h(state)e(of)h(the)g(history)g(list)h ! (according)g(to)e Fj(state)p Fo(.)75 1182 y Fi(2.3.2)30 ! b(History)20 b(List)h(Managemen)n(t)137 1277 y Fo(These)11 b(functions)h(manage)e(individual)k(en)o(tries)d(on)g(the)g(history)f ! (list,)i(or)f(set)f(parameters)g(managing)75 1332 y(the)15 ! b(list)h(itself.)1650 1420 y(F)l(unction)-1749 b Fh(void)20 ! b Fg(add)p 294 1420 V 20 w(history)j Ff(\()p Fn(char)14 ! b(*string)p Ff(\))195 1475 y Fo(Place)i Fj(string)j Fo(at)c(the)g(end)i ! (of)d(the)i(history)f(list.)22 b(The)15 b(asso)q(ciated)h(data)f ! (\014eld)h(\(if)g(an)o(y\))e(is)195 1530 y(set)h(to)g ! Fn(NULL)p Fo(.)1650 1618 y(F)l(unction)-1749 b Fh(HIST_ENTRY)21 ! b(*)e Fg(remo)n(v)n(e)p 584 1618 V 20 w(history)k Ff(\()p ! Fn(int)14 b(which)p Ff(\))195 1673 y Fo(Remo)o(v)o(e)g(history)g(en)o ! (try)f(at)h(o\013set)f Fj(whic)o(h)h Fo(from)g(the)g(history)l(.)19 ! b(The)14 b(remo)o(v)o(ed)g(elemen)o(t)g(is)195 1727 y(returned)i(so)e ! (y)o(ou)h(can)h(free)f(the)g(line,)i(data,)d(and)h(con)o(taining)h ! (structure.)1650 1816 y(F)l(unction)-1749 b Fh(HIST_ENTRY)21 ! b(*)e Fg(replace)p 580 1816 V 22 w(history)p 777 1816 ! V 20 w(en)n(try)24 b Ff(\()p Fn(int)14 b(which,)g(char)283 ! 1870 y(*line,)g(char)g(*data)p Ff(\))195 1925 y Fo(Mak)o(e)f(the)h ! (history)f(en)o(try)g(at)g(o\013set)g Fj(whic)o(h)h Fo(ha)o(v)o(e)g ! Fj(line)k Fo(and)13 b Fj(data)p Fo(.)19 b(This)14 b(returns)g(the)f ! (old)195 1980 y(en)o(try)k(so)g(y)o(ou)g(can)g(disp)q(ose)i(of)d(the)i ! (data.)25 b(In)18 b(the)f(case)h(of)f(an)g(in)o(v)m(alid)i ! Fj(whic)o(h)p Fo(,)g(a)e Fn(NULL)195 2035 y Fo(p)q(oin)o(ter)f(is)f ! (returned.)1650 2123 y(F)l(unction)-1749 b Fh(void)20 ! b Fg(clear)p 320 2123 V 21 w(history)j Ff(\(\))195 2178 ! y Fo(Clear)15 b(the)h(history)f(list)h(b)o(y)f(deleting)i(all)f(the)f ! (en)o(tries.)1650 2266 y(F)l(unction)-1749 b Fh(void)20 ! b Fg(sti\015e)p 320 2266 V 21 w(history)j Ff(\()p Fn(int)14 ! b(max)p Ff(\))195 2321 y Fo(Sti\015e)i(the)f(history)h(list,)f(remem)o ! (b)q(ering)h(only)g(the)f(last)g Fj(max)j Fo(en)o(tries.)1650 ! 2409 y(F)l(unction)-1749 b Fh(int)20 b Fg(unsti\015e)p ! 358 2409 V 21 w(history)i Ff(\(\))195 2463 y Fo(Stop)e(sti\015ing)i ! (the)f(history)l(.)36 b(This)21 b(returns)g(the)f(previous)i(amoun)o(t) ! e(the)g(history)h(w)o(as)195 2518 y(sti\015ed.)g(The)15 ! b(v)m(alue)i(is)e(p)q(ositiv)o(e)i(if)e(the)g(history)h(w)o(as)e ! (sti\015ed,)i(negativ)o(e)f(if)h(it)f(w)o(asn't.)1650 ! 2606 y(F)l(unction)-1749 b Fh(int)20 b Fg(history)p 351 ! 2606 V 20 w(is)p 409 2606 V 21 w(sti\015ed)k Ff(\(\))195 ! 2661 y Fo(Returns)16 b(non-zero)f(if)h(the)f(history)g(is)h(sti\015ed,) ! g(zero)f(if)g(it)h(is)g(not.)p eop %%Page: 7 9 ! 7 8 bop 75 -58 a Fo(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (History)889 b(7)75 183 y Fi(2.3.3)30 b(Information)19 ! b(Ab)r(out)i(the)f(History)h(List)137 279 y Fo(These)13 ! b(functions)h(return)f(information)g(ab)q(out)f(the)h(en)o(tire)h ! (history)e(list)i(or)e(individual)k(list)e(en)o(tries.)1650 ! 371 y(F)l(unction)-1749 b Fh(HIST_ENTRY)21 b(**)e Fg(history)p ! 605 371 18 3 v 21 w(list)24 b Ff(\(\))195 426 y Fo(Return)f(a)g ! Fn(NULL)f Fo(terminated)g(arra)o(y)g(of)g Fn(HIST_ENTRY)f ! Fo(whic)o(h)j(is)f(the)f(curren)o(t)h(input)195 481 y(history)l(.)j ! (Elemen)o(t)18 b(0)e(of)h(this)h(list)g(is)f(the)h(b)q(eginning)h(of)e ! (time.)26 b(If)17 b(there)g(is)h(no)f(history)l(,)195 ! 535 y(return)e Fn(NULL)p Fo(.)1650 627 y(F)l(unction)-1749 ! b Fh(int)20 b Fg(where)p 325 627 V 20 w(history)j Ff(\(\))195 ! 682 y Fo(Returns)16 b(the)f(o\013set)f(of)h(the)g(curren)o(t)g(history) ! g(elemen)o(t.)1650 773 y(F)l(unction)-1749 b Fh(HIST_ENTRY)21 ! b(*)e Fg(curren)n(t)p 587 773 V 21 w(history)k Ff(\(\))195 ! 828 y Fo(Return)g(the)f(history)g(en)o(try)g(at)f(the)h(curren)o(t)g(p) ! q(osition,)j(as)c(determined)j(b)o(y)e Fn(where_)195 ! 883 y(history)14 b(\(\))p Fo(.)20 b(If)15 b(there)g(is)h(no)f(en)o(try) ! g(there,)g(return)g(a)g Fn(NULL)g Fo(p)q(oin)o(ter.)1650 ! 975 y(F)l(unction)-1749 b Fh(HIST_ENTRY)21 b(*)e Fg(history)p ! 579 975 V 21 w(get)j Ff(\()p Fn(int)15 b(offset)p Ff(\))195 ! 1029 y Fo(Return)21 b(the)g(history)g(en)o(try)f(at)g(p)q(osition)i ! Fj(o\013set)p Fo(,)e(starting)g(from)g Fn(history_base)p ! Fo(.)35 b(If)195 1084 y(there)16 b(is)h(no)g(en)o(try)f(there,)g(or)g ! (if)g Fj(o\013set)h Fo(is)g(greater)e(than)h(the)h(history)f(length,)h ! (return)f(a)195 1139 y Fn(NULL)f Fo(p)q(oin)o(ter.)1650 ! 1231 y(F)l(unction)-1749 b Fh(int)20 b Fg(history)p 351 ! 1231 V 20 w(total)p 487 1231 V 22 w(b)n(ytes)j Ff(\(\))195 ! 1285 y Fo(Return)c(the)f(n)o(um)o(b)q(er)g(of)g(b)o(ytes)g(that)f(the)h ! (primary)h(history)f(en)o(tries)g(are)g(using.)29 b(This)195 ! 1340 y(function)16 b(returns)f(the)g(sum)h(of)e(the)i(lengths)f(of)g ! (all)h(the)g(lines)g(in)g(the)g(history)l(.)75 1452 y Fi(2.3.4)30 b(Mo)n(ving)21 b(Around)f(the)h(History)g(List)137 ! 1548 y Fo(These)16 b(functions)g(allo)o(w)f(the)g(curren)o(t)h(index)g (in)o(to)f(the)h(history)f(list)h(to)e(b)q(e)i(set)f(or)g(c)o(hanged.) ! 1650 1640 y(F)l(unction)-1749 b Fh(int)20 b Fg(history)p ! 351 1640 V 20 w(set)p 442 1640 V 21 w(p)r(os)h Ff(\()p ! Fn(int)15 b(pos)p Ff(\))195 1694 y Fo(Set)g(the)h(p)q(osition)g(in)g ! (the)f(history)g(list)h(to)f Fj(p)q(os)p Fo(,)g(an)g(absolute)g(index)i ! (in)o(to)e(the)g(list.)1650 1786 y(F)l(unction)-1749 ! b Fh(HIST_ENTRY)21 b(*)e Fg(previous)p 615 1786 V 20 ! w(history)k Ff(\(\))195 1841 y Fo(Bac)o(k)17 b(up)h(the)f(curren)o(t)g ! (history)g(o\013set)f(to)h(the)g(previous)h(history)f(en)o(try)l(,)g ! (and)g(return)g(a)195 1896 y(p)q(oin)o(ter)f(to)e(that)h(en)o(try)l(.)k ! (If)d(there)f(is)h(no)f(previous)h(en)o(try)l(,)f(return)g(a)g ! Fn(NULL)f Fo(p)q(oin)o(ter.)1650 1987 y(F)l(unction)-1749 ! b Fh(HIST_ENTRY)21 b(*)e Fg(next)p 514 1987 V 21 w(history)k ! Ff(\(\))195 2042 y Fo(Mo)o(v)o(e)17 b(the)h(curren)o(t)g(history)f ! (o\013set)g(forw)o(ard)g(to)g(the)h(next)g(history)g(en)o(try)l(,)g ! (and)g(return)195 2097 y(the)d(a)g(p)q(oin)o(ter)h(to)e(that)h(en)o ! (try)l(.)20 b(If)15 b(there)g(is)h(no)f(next)g(en)o(try)l(,)g(return)g ! (a)g Fn(NULL)g Fo(p)q(oin)o(ter.)75 2208 y Fi(2.3.5)30 ! b(Searc)n(hing)21 b(the)f(History)h(List)137 2304 y Fo(These)14 ! b(functions)g(allo)o(w)g(searc)o(hing)g(of)e(the)i(history)f(list)h ! (for)f(en)o(tries)h(con)o(taining)g(a)f(sp)q(eci\014c)i(string.)75 ! 2359 y(Searc)o(hing)f(ma)o(y)g(b)q(e)g(p)q(erformed)g(b)q(oth)g(forw)o ! (ard)e(and)i(bac)o(kw)o(ard)f(from)g(the)h(curren)o(t)g(history)f(p)q ! (osition.)75 2414 y(The)j(searc)o(h)f(ma)o(y)g(b)q(e)i ! Fj(anc)o(hored)p Fo(,)e(meaning)h(that)f(the)h(string)g(m)o(ust)f(matc) ! o(h)g(at)g(the)h(b)q(eginning)i(of)d(the)75 2469 y(history)g(en)o(try)l ! (.)1650 2560 y(F)l(unction)-1749 b Fh(int)20 b Fg(history)p ! 351 2560 V 20 w(searc)n(h)j Ff(\()p Fn(char)14 b(*string,)g(int)h ! (direction)p Ff(\))195 2615 y Fo(Searc)o(h)g(the)h(history)f(for)f ! Fj(string)p Fo(,)h(starting)f(at)h(the)g(curren)o(t)g(history)g ! (o\013set.)k(If)d Fj(direction)195 2670 y Fn(<)j Fo(0,)g(then)g(the)h ! (searc)o(h)e(is)i(through)e(previous)i(en)o(tries,)g(else)g(through)f ! (subsequen)o(t.)32 b(If)p eop %%Page: 8 10 ! 8 9 bop 75 -58 a Fo(8)1347 b(GNU)15 b(History)g(Library)195 ! 183 y Fj(string)k Fo(is)d(found,)f(then)h(the)f(curren)o(t)g(history)g ! (index)i(is)f(set)f(to)f(that)h(history)g(en)o(try)l(,)g(and)195 ! 238 y(the)g(v)m(alue)h(returned)f(is)g(the)g(o\013set)f(in)h(the)g ! (line)h(of)e(the)h(en)o(try)g(where)g Fj(string)j Fo(w)o(as)c(found.) ! 195 293 y(Otherwise,)i(nothing)f(is)h(c)o(hanged,)f(and)h(a)e(-1)h(is)h ! (returned.)1650 396 y(F)l(unction)-1749 b Fh(int)20 b ! Fg(history)p 351 396 18 3 v 20 w(searc)n(h)p 527 396 ! V 21 w(pre\014x)i Ff(\()p Fn(char)15 b(*string,)f(int)g(direction)p ! Ff(\))195 451 y Fo(Searc)o(h)i(the)f(history)g(for)g ! Fj(string)p Fo(,)g(starting)g(at)g(the)g(curren)o(t)h(history)f ! (o\013set.)k(The)d(searc)o(h)195 506 y(is)h(anc)o(hored:)23 ! b(matc)o(hing)17 b(lines)h(m)o(ust)e(b)q(egin)i(with)f ! Fj(string)p Fo(.)25 b(If)17 b Fj(direction)h Fn(<)e Fo(0,)h(then)g(the) ! 195 560 y(searc)o(h)f(is)g(through)f(previous)i(en)o(tries,)f(else)g ! (through)g(subsequen)o(t.)22 b(If)16 b Fj(string)k Fo(is)c(found,)195 ! 615 y(then)i(the)g(curren)o(t)g(history)g(index)h(is)g(set)e(to)h(that) ! f(en)o(try)l(,)h(and)g(the)g(return)g(v)m(alue)h(is)g(0.)195 ! 670 y(Otherwise,)d(nothing)f(is)h(c)o(hanged,)f(and)h(a)e(-1)h(is)h ! (returned.)1650 773 y(F)l(unction)-1749 b Fh(int)20 b ! Fg(history)p 351 773 V 20 w(searc)n(h)p 527 773 V 21 ! w(p)r(os)h Ff(\()p Fn(char)15 b(*string,)f(int)g(direction,)g(int)283 ! 828 y(pos)p Ff(\))195 883 y Fo(Searc)o(h)h(for)g Fj(string)k ! Fo(in)d(the)f(history)g(list,)g(starting)g(at)f Fj(p)q(os)p ! Fo(,)h(an)g(absolute)g(index)i(in)o(to)e(the)195 937 ! y(list.)21 b(If)15 b Fj(direction)h Fo(is)g(negativ)o(e,)f(the)g(searc) ! o(h)g(pro)q(ceeds)g(bac)o(kw)o(ard)g(from)f Fj(p)q(os)p ! Fo(,)h(otherwise)195 992 y(forw)o(ard.)27 b(Returns)18 ! b(the)g(absolute)g(index)h(of)f(the)g(history)f(elemen)o(t)i(where)f ! Fj(string)k Fo(w)o(as)195 1047 y(found,)15 b(or)g(-1)g(otherwise.)75 ! 1170 y Fi(2.3.6)30 b(Managing)20 b(the)g(History)h(File)137 ! 1272 y Fo(The)16 b(History)g(library)h(can)e(read)h(the)g(history)g ! (from)f(and)h(write)g(it)g(to)f(a)h(\014le.)22 b(This)17 ! b(section)f(do)q(cu-)75 1327 y(men)o(ts)f(the)g(functions)h(for)f ! (managing)g(a)g(history)g(\014le.)1650 1430 y(F)l(unction)-1749 ! b Fh(int)20 b Fg(read)p 286 1430 V 20 w(history)i Ff(\()p ! Fn(char)15 b(*filename)p Ff(\))195 1485 y Fo(Add)h(the)f(con)o(ten)o ! (ts)f(of)h Fj(\014lename)j Fo(to)d(the)g(history)g(list,)g(a)g(line)h ! (at)f(a)f(time.)21 b(If)15 b Fj(\014lename)j Fo(is)195 ! 1539 y Fn(NULL)p Fo(,)c(then)i(read)f(from)f(`)p Fn(~/.history)p ! Fo('.)k(Returns)e(0)f(if)g(successful,)i(or)d(errno)h(if)h(not.)1650 ! 1643 y(F)l(unction)-1749 b Fh(int)20 b Fg(read)p 286 ! 1643 V 20 w(history)p 481 1643 V 20 w(range)i Ff(\()p ! Fn(char)15 b(*filename,)e(int)i(from,)g(int)f(to)p Ff(\))195 ! 1697 y Fo(Read)21 b(a)f(range)g(of)g(lines)i(from)e Fj(\014lename)p ! Fo(,)i(adding)f(them)g(to)f(the)g(history)h(list.)36 ! b(Start)195 1752 y(reading)15 b(at)e(line)j Fj(from)e ! Fo(and)g(end)h(at)e Fj(to)p Fo(.)19 b(If)c Fj(from)e ! Fo(is)i(zero,)f(start)f(at)g(the)h(b)q(eginning.)22 b(If)15 ! b Fj(to)195 1807 y Fo(is)i(less)g(than)f Fj(from)p Fo(,)g(then)h(read)f ! (un)o(til)i(the)e(end)h(of)f(the)h(\014le.)24 b(If)17 ! b Fj(\014lename)j Fo(is)d Fn(NULL)p Fo(,)f(then)195 1862 ! y(read)f(from)g(`)p Fn(~/.history)p Fo('.)i(Returns)f(0)f(if)h ! (successful,)g(or)e Fn(errno)h Fo(if)h(not.)1650 1965 ! y(F)l(unction)-1749 b Fh(int)20 b Fg(write)p 304 1965 ! V 22 w(history)i Ff(\()p Fn(char)15 b(*filename)p Ff(\))195 ! 2020 y Fo(W)l(rite)23 b(the)f(curren)o(t)g(history)h(to)f ! Fj(\014lename)p Fo(,)j(o)o(v)o(erwriting)d Fj(\014lename)k ! Fo(if)d(necessary)l(.)42 b(If)195 2074 y Fj(\014lename)20 ! b Fo(is)d Fn(NULL)p Fo(,)f(then)g(write)h(the)f(history)h(list)g(to)f ! (`)p Fn(~/.history)p Fo('.)21 b(V)l(alues)d(returned)195 ! 2129 y(are)d(as)g(in)h Fn(read_history)d(\(\))p Fo(.)1650 ! 2232 y(F)l(unction)-1749 b Fh(int)20 b Fg(app)r(end)p ! 360 2232 V 19 w(history)j Ff(\()p Fn(int)14 b(nelements,)g(char)h ! (*filename)p Ff(\))195 2287 y Fo(App)q(end)i(the)e(last)g ! Fj(nelemen)o(ts)j Fo(of)d(the)g(history)g(list)h(to)f ! Fj(\014lename)p Fo(.)1650 2390 y(F)l(unction)-1749 b ! Fh(int)20 b Fg(history)p 351 2390 V 20 w(truncate)p 582 ! 2390 V 21 w(\014le)k Ff(\()p Fn(char)14 b(*filename,)g(int)h(nlines)p ! Ff(\))195 2445 y Fo(T)l(runcate)g(the)h(history)f(\014le)h ! Fj(\014lename)p Fo(,)g(lea)o(ving)g(only)g(the)f(last)g ! Fj(nlines)k Fo(lines.)75 2568 y Fi(2.3.7)30 b(History)20 ! b(Expansion)137 2670 y Fo(These)c(functions)g(implemen)o(t)g ! Fn(csh)p Fo(-lik)o(e)g(history)g(expansion.)p eop %%Page: 9 11 ! 9 10 bop 75 -58 a Fo(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (History)889 b(9)1650 183 y(F)l(unction)-1749 b Fh(int)20 ! b Fg(history)p 351 183 18 3 v 20 w(expand)j Ff(\()p Fn(char)14 ! b(*string,)g(char)h(**output)p Ff(\))195 238 y Fo(Expand)k ! Fj(string)p Fo(,)g(placing)h(the)e(result)h(in)o(to)g ! Fj(output)p Fo(,)g(a)f(p)q(oin)o(ter)h(to)f(a)g(string)h(\(see)f(Sec-) ! 195 293 y(tion)d(1.1)g([History)f(In)o(teraction],)h(page)g(1\).)k ! (Returns:)195 370 y Fn(0)216 b Fo(If)16 b(no)g(expansions)h(to)q(ok)e ! (place)i(\(or,)d(if)j(the)f(only)g(c)o(hange)g(in)h(the)e(text)h(w)o ! (as)435 425 y(the)f(de-slashifying)j(of)c(the)i(history)f(expansion)h ! (c)o(haracter\);)195 502 y Fn(1)216 b Fo(if)16 b(expansions)g(did)g ! (tak)o(e)e(place;)195 580 y Fn(-1)192 b Fo(if)16 b(there)f(w)o(as)f(an) ! h(error)g(in)h(expansion;)195 657 y Fn(2)216 b Fo(if)16 ! b(the)g(returned)f(line)j(should)e(b)q(e)g(displa)o(y)o(ed,)h(but)e ! (not)g(executed,)i(as)e(with)435 712 y(the)g Fn(:p)g ! Fo(mo)q(di\014er)h(\(see)f(Section)i(1.1.3)c([Mo)q(di\014ers],)i(page)g ! (2\).)195 789 y(If)g(an)g(error)f(o)q(curred)i(in)g(expansion,)f(then)h ! Fj(output)f Fo(con)o(tains)g(a)g(descriptiv)o(e)i(error)d(mes-)195 ! 844 y(sage.)1650 932 y(F)l(unction)-1749 b Fh(char)20 ! b(*)f Fg(history)p 422 932 V 21 w(arg)p 524 932 V 19 ! w(extract)24 b Ff(\()p Fn(int)14 b(first,)h(int)g(last,)f(char)283 ! 987 y(*string)p Ff(\))195 1042 y Fo(Extract)g(a)g(string)g(segmen)o(t)g ! (consisting)i(of)e(the)g Fj(\014rst)i Fo(through)e Fj(last)h ! Fo(argumen)o(ts)f(presen)o(t)195 1097 y(in)i Fj(string)p ! Fo(.)k(Argumen)o(ts)15 b(are)f(brok)o(en)i(up)f(as)g(in)h(Bash.)1650 ! 1185 y(F)l(unction)-1749 b Fh(char)20 b(*)f Fg(get)p ! 324 1185 V 21 w(history)p 520 1185 V 20 w(ev)n(en)n(t)25 ! b Ff(\()p Fn(char)14 b(*string,)g(int)h(*cindex,)f(int)283 ! 1240 y(qchar)p Ff(\))195 1295 y Fo(Returns)h(the)g(text)f(of)g(the)h ! (history)g(ev)o(en)o(t)f(b)q(eginning)j(at)d Fj(string)k ! Fn(+)d Fj(*cindex)p Fo(.)20 b Fj(*cindex)f Fo(is)195 ! 1350 y(mo)q(di\014ed)e(to)e(p)q(oin)o(t)h(to)f(after)g(the)h(ev)o(en)o ! (t)f(sp)q(eci\014er.)23 b(A)o(t)16 b(function)g(en)o(try)l(,)f ! Fj(cindex)21 b Fo(p)q(oin)o(ts)195 1404 y(to)16 b(the)h(index)h(in)o ! (to)e Fj(string)21 b Fo(where)c(the)g(history)f(ev)o(en)o(t)h(sp)q ! (eci\014cation)h(b)q(egins.)26 b Fj(qc)o(har)19 b Fo(is)195 ! 1459 y(a)h(c)o(haracter)g(that)g(is)h(allo)o(w)o(ed)f(to)g(end)h(the)g ! (ev)o(en)o(t)f(sp)q(eci\014cation)i(in)g(addition)f(to)f(the)195 ! 1514 y(\\normal")15 b(terminating)g(c)o(haracters.)1650 ! 1602 y(F)l(unction)-1749 b Fh(char)20 b(**)f Fg(history)p ! 448 1602 V 21 w(tok)n(enize)25 b Ff(\()p Fn(char)14 b(*string)p ! Ff(\))195 1657 y Fo(Return)j(an)g(arra)o(y)f(of)g(tok)o(ens)g(parsed)h ! (out)g(of)f Fj(string)p Fo(,)h(m)o(uc)o(h)g(as)f(the)h(shell)h(migh)o ! (t.)25 b(The)195 1712 y(tok)o(ens)d(are)g(split)i(on)f(white)g(space)g ! (and)f(on)h(the)g(c)o(haracters)f Fn(\(\)<>;&|$)p Fo(,)h(and)f(shell) ! 195 1767 y(quoting)15 b(con)o(v)o(en)o(tions)h(are)e(ob)q(ey)o(ed.)75 ! 1892 y Fm(2.4)33 b(History)22 b(V)-6 b(ariables)137 1987 ! y Fo(This)23 b(section)f(describ)q(es)h(the)f(externally)h(visible)h(v) ! m(ariables)f(exp)q(orted)f(b)o(y)g(the)g(GNU)f(History)75 ! 2042 y(Library)l(.)1661 2130 y(V)l(ariable)-1749 b Fh(int)20 ! b Fg(history)p 351 2130 V 20 w(base)195 2185 y Fo(The)15 b(logical)i(o\013set)d(of)h(the)g(\014rst)g(en)o(try)g(in)h(the)f ! (history)g(list.)1661 2274 y(V)l(ariable)-1749 b Fh(int)20 ! b Fg(history)p 351 2274 V 20 w(length)195 2329 y Fo(The)15 b(n)o(um)o(b)q(er)h(of)f(en)o(tries)g(curren)o(tly)h(stored)f(in)h(the) ! f(history)g(list.)1661 2417 y(V)l(ariable)-1749 b Fh(int)20 ! b Fg(max)p 283 2417 V 19 w(input)p 435 2417 V 21 w(history)195 ! 2472 y Fo(The)14 b(maxim)o(um)f(n)o(um)o(b)q(er)h(of)e(history)i(en)o ! (tries.)19 b(This)14 b(m)o(ust)f(b)q(e)h(c)o(hanged)g(using)g ! Fn(stifle_)195 2527 y(history)g(\(\))p Fo(.)1661 2615 ! y(V)l(ariable)-1749 b Fh(char)20 b Fg(history)p 377 2615 ! V 20 w(expansion)p 644 2615 V 21 w(c)n(har)195 2670 y ! Fo(The)15 b(c)o(haracter)g(that)f(starts)g(a)h(history)g(ev)o(en)o(t.) ! 20 b(The)15 b(default)h(is)g(`)p Fn(!)p Fo('.)p eop ! %%Page: 10 12 ! 10 11 bop 75 -58 a Fo(10)1324 b(GNU)15 b(History)g(Library)1661 ! 183 y(V)l(ariable)-1749 b Fh(char)20 b Fg(history)p 377 ! 183 18 3 v 20 w(subst)p 529 183 V 20 w(c)n(har)195 238 ! y Fo(The)13 b(c)o(haracter)e(that)h(in)o(v)o(ok)o(es)g(w)o(ord)g ! (substitution)h(if)g(found)g(at)e(the)i(start)e(of)h(a)g(line.)21 ! b(The)195 293 y(default)16 b(is)f(`)p Fn(^)p Fo('.)1661 ! 388 y(V)l(ariable)-1749 b Fh(char)20 b Fg(history)p 377 ! 388 V 20 w(commen)n(t)p 627 388 V 19 w(c)n(har)195 443 ! y Fo(During)e(tok)o(enization,)h(if)f(this)h(c)o(haracter)e(is)i(seen)f ! (as)g(the)g(\014rst)g(c)o(haracter)f(of)g(a)h(w)o(ord,)195 ! 498 y(then)e(it)g(and)g(all)h(subsequen)o(t)g(c)o(haracters)e(up)h(to)g ! (a)f(newline)j(are)e(ignored,)g(suppressing)195 553 y(history)f ! (expansion)h(for)f(the)g(remainder)h(of)f(the)g(line.)22 ! b(This)15 b(is)h(disabled)h(b)o(y)e(default.)1661 648 ! y(V)l(ariable)-1749 b Fh(char)20 b(*)f Fg(history)p 422 ! 648 V 21 w(no)p 504 648 V 20 w(expand)p 704 648 V 20 ! w(c)n(hars)195 703 y Fo(The)j(list)h(of)f(c)o(haracters)f(whic)o(h)i ! (inhibit)h(history)e(expansion)h(if)g(found)f(immediately)195 ! 758 y(follo)o(wing)16 b Fj(history)p 528 758 14 2 v 16 ! w(expansion)p 739 758 V 18 w(c)o(har)p Fo(.)j(The)d(default)f(is)h ! (whitespace)g(and)g(`)p Fn(=)p Fo('.)1661 853 y(V)l(ariable)-1749 ! b Fh(char)20 b(*)f Fg(history)p 422 853 18 3 v 21 w(searc)n(h)p ! 599 853 V 20 w(delimiter)p 843 853 V 23 w(c)n(hars)195 ! 908 y Fo(The)f(list)h(of)e(additional)i(c)o(haracters)e(whic)o(h)i(can) ! f(delimit)h(a)f(history)g(searc)o(h)f(string,)h(in)195 ! 963 y(addition)c(to)d(whitespace,)j(`)p Fn(:)p Fo(')d(and)i(`)p ! Fn(?)p Fo(')f(in)h(the)f(case)h(of)f(a)g(substring)h(searc)o(h.)19 ! b(The)12 b(default)195 1018 y(is)k(empt)o(y)l(.)1661 ! 1113 y(V)l(ariable)-1749 b Fh(int)20 b Fg(history)p 351 ! 1113 V 20 w(quotes)p 533 1113 V 21 w(inhibit)p 717 1113 ! V 23 w(expansion)195 1168 y Fo(If)13 b(non-zero,)f(single-quoted)i(w)o ! (ords)e(are)g(not)g(scanned)h(for)f(the)g(history)h(expansion)g(c)o ! (har-)195 1223 y(acter.)19 b(The)d(default)g(v)m(alue)g(is)g(0.)1661 ! 1318 y(V)l(ariable)-1749 b Fh(Function)20 b(*)g Fg(history)p ! 527 1318 V 20 w(inhibit)p 710 1318 V 23 w(expansion)p ! 980 1318 V 21 w(function)195 1373 y Fo(This)12 b(should)g(b)q(e)g(set)f ! (to)f(the)i(address)f(of)g(a)g(function)h(that)e(tak)o(es)h(t)o(w)o(o)f ! (argumen)o(ts:)17 b(a)11 b Fn(char)195 1428 y(*)j Fo(\()p ! Fj(string)t Fo(\))f(and)i(an)f(in)o(teger)g(index)h(in)o(to)f(that)g ! (string)g(\()p Fj(i)r Fo(\).)20 b(It)14 b(should)h(return)f(a)g ! (non-zero)195 1482 y(v)m(alue)g(if)e(the)h(history)f(expansion)h ! (starting)f(at)g Fj(string[i])i Fo(should)f(not)f(b)q(e)h(p)q ! (erformed;)g(zero)195 1537 y(if)g(the)h(expansion)f(should)h(b)q(e)g ! (done.)20 b(It)13 b(is)g(in)o(tended)i(for)d(use)h(b)o(y)g ! (applications)i(lik)o(e)f(Bash)195 1592 y(that)j(use)h(the)g(history)f ! (expansion)i(c)o(haracter)e(for)g(additional)i(purp)q(oses.)28 ! b(By)18 b(default,)195 1647 y(this)e(v)m(ariable)g(is)g(set)f(to)f ! (NULL.)75 1780 y Fm(2.5)33 b(History)22 b(Programming)h(Example)137 ! 1878 y Fo(The)16 b(follo)o(wing)g(program)e(demonstrates)g(simple)j ! (use)e(of)g(the)g(GNU)g(History)g(Library)l(.)195 1944 ! y Fn(main)23 b(\(\))195 1995 y({)243 2047 y(char)g(line[1024],)f(*t;) ! 243 2099 y(int)h(len,)g(done)h(=)g(0;)243 2203 y(line[0])f(=)g(0;)243 ! 2307 y(using_history)f(\(\);)243 2359 y(while)h(\(!done\))290 ! 2411 y({)338 2462 y(printf)g(\("history$)g("\);)338 2514 ! y(fflush)g(\(stdout\);)338 2566 y(t)h(=)g(fgets)f(\(line,)g(sizeof)g ! (\(line\))g(-)h(1,)f(stdin\);)338 2618 y(if)h(\(t)f(&&)h(*t\))386 ! 2670 y({)p eop %%Page: 11 13 ! 11 12 bop 75 -58 a Fo(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (History)867 b(11)434 183 y Fn(len)23 b(=)h(strlen)f(\(t\);)434 ! 235 y(if)g(\(t[len)g(-)h(1])g(==)f('\\n'\))481 287 y(t[len)h(-)f(1])h ! (=)g('\\0';)386 339 y(})338 443 y(if)g(\(!t\))386 495 ! y(strcpy)f(\(line,)g("quit"\);)338 598 y(if)h(\(line[0]\))386 ! 650 y({)434 702 y(char)f(*expansion;)434 754 y(int)g(result;)434 ! 858 y(result)g(=)g(history_expand)f(\(line,)h(&expansion\);)434 ! 910 y(if)g(\(result\))481 962 y(fprintf)g(\(stderr,)g("\045s\\n",)g ! (expansion\);)434 1065 y(if)g(\(result)g(<)h(0)g(||)f(result)g(==)h ! (2\))481 1117 y({)529 1169 y(free)f(\(expansion\);)529 ! 1221 y(continue;)481 1273 y(})434 1377 y(add_history)f(\(expansion\);) ! 434 1429 y(strncpy)h(\(line,)g(expansion,)f(sizeof)h(\(line\))g(-)h ! (1\);)434 1480 y(free)f(\(expansion\);)386 1532 y(})338 ! 1636 y(if)h(\(strcmp)f(\(line,)g("quit"\))g(==)g(0\))386 ! 1688 y(done)g(=)h(1;)338 1740 y(else)f(if)h(\(strcmp)f(\(line,)g ! ("save"\))g(==)h(0\))386 1792 y(write_history)e(\("history_file"\);)338 ! 1844 y(else)h(if)h(\(strcmp)f(\(line,)g("read"\))g(==)h(0\))386 ! 1896 y(read_history)e(\("history_file"\);)338 1947 y(else)h(if)h ! (\(strcmp)f(\(line,)g("list"\))g(==)h(0\))386 1999 y({)434 ! 2051 y(register)e(HIST_ENTRY)h(**the_list;)434 2103 y(register)f(int)i ! (i;)434 2207 y(the_list)e(=)i(history_list)e(\(\);)434 ! 2259 y(if)h(\(the_list\))481 2311 y(for)h(\(i)f(=)h(0;)g(the_list[i];)e ! (i++\))529 2363 y(printf)h(\("\045d:)g(\045s\\n",)g(i)h(+)g ! (history_base,)e(the_list[i]->line\);)386 2414 y(})338 ! 2466 y(else)h(if)h(\(strncmp)f(\(line,)g("delete",)g(6\))g(==)h(0\))386 ! 2518 y({)434 2570 y(int)f(which;)434 2622 y(if)g(\(\(sscanf)g(\(line)g ! (+)h(6,)f("\045d",)h(&which\)\))e(==)i(1\))p eop %%Page: 12 14 ! 12 13 bop 75 -58 a Fo(12)1324 b(GNU)15 b(History)g(Library)481 ! 183 y Fn({)529 235 y(HIST_ENTRY)23 b(*entry)g(=)g(remove_history)f ! (\(which\);)529 287 y(if)i(\(!entry\))577 339 y(fprintf)f(\(stderr,)f ! ("No)i(such)f(entry)g(\045d\\n",)g(which\);)529 391 y(else)577 ! 443 y({)625 495 y(free)g(\(entry->line\);)625 546 y(free)g(\(entry\);) ! 577 598 y(})481 650 y(})434 702 y(else)481 754 y({)529 ! 806 y(fprintf)g(\(stderr,)g("non-numeric)f(arg)h(given)h(to)f ! (`delete'\\n"\);)481 858 y(})386 910 y(})290 962 y(})195 ! 1013 y(})p eop %%Page: 13 15 ! 13 14 bop 75 -58 a Fo(App)q(endix)17 b(A:)e(Concept)g(Index)1196 ! b(13)75 183 y Fk(App)r(endix)25 b(A)41 b(Concept)27 b(Index)75 ! 359 y Fm(A)75 417 y Fe(anc)o(hored)14 b(searc)o(h)s Fd(.)7 ! b(.)f(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)16 ! b Fe(7)75 517 y Fm(E)75 575 y Fe(ev)o(en)o(t)d(designators)c ! Fd(.)g(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)21 ! b Fe(1)1012 359 y Fm(H)1012 417 y Fe(history)15 b(ev)o(en)o(ts)s ! Fd(.)7 b(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)16 b Fe(1)1012 467 y(history)f(expansion)6 b Fd(.)j(.)d(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)19 b Fe(1)1012 517 y(History)14 ! b(Searc)o(hing)5 b Fd(.)j(.)e(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)18 b Fe(7)p eop %%Page: 14 16 ! 14 15 bop 75 -58 a Fo(14)1324 b(GNU)15 b(History)g(Library)p eop %%Page: 15 17 ! 15 16 bop 75 -58 a Fo(App)q(endix)17 b(B:)e(F)l(unction)h(and)g(V)l ! (ariable)g(Index)919 b(15)75 183 y Fk(App)r(endix)25 b(B)41 b(F)-7 b(unction)26 b(and)h(V)-7 b(ariable)26 ! b(Index)75 359 y Fm(A)75 417 y Fc(add)p 137 417 12 2 ! v 13 w(history)6 b Fd(.)s(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)h(.)18 b Fe(6)75 467 y Fc(append)p ! 197 467 V 12 w(history)8 b Fd(.)e(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)23 b Fe(8)75 567 y Fm(C)75 625 y Fc(clear)p ! 177 625 V 12 w(history)s Fd(.)t(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)16 b Fe(6)75 675 y Fc(current)p ! 217 675 V 11 w(history)7 b Fd(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)22 b Fe(7)75 774 y Fm(G)75 832 y Fc(get)p ! 137 832 V 13 w(history)p 290 832 V 11 w(event)8 b Fd(.)e(.)g(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)g(.)22 b Fe(9)75 932 y Fm(H)75 ! 990 y Fc(history)p 217 990 V 11 w(arg)p 288 990 V 13 ! w(extract)7 b Fd(.)t(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)20 ! b Fe(9)75 1040 y Fc(history)p 217 1040 V 11 w(base)f ! Fd(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)19 ! b Fe(9)75 1090 y Fc(history_co)o(mm)o(ent)o(_c)o(har)g ! Fd(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)23 b Fe(10)75 1139 y Fc(history)p ! 217 1139 V 11 w(expand)9 b Fd(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)23 b Fe(9)75 1189 y Fc(history)p 217 ! 1189 V 11 w(expansion)p 408 1189 V 11 w(char)17 b Fd(.)6 ! b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)18 b Fe(9)75 1239 y Fc(history)p 217 ! 1239 V 11 w(get)6 b Fd(.)f(.)h(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)h(.)18 b Fe(7)75 1289 y Fc(history)p ! 217 1289 V 11 w(get)p 288 1289 V 13 w(history)p 441 1289 ! V 12 w(state)9 b Fd(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)23 b Fe(6)75 1339 y Fc(history_in)o(hi)o ! (bit)o(_e)o(xpa)o(nsi)o(on)o(_fu)o(nc)o(tio)o(n)c Fd(.)6 ! b(.)g(.)g(.)g(.)g(.)g(.)22 b Fe(10)75 1389 y Fc(history)p ! 217 1389 V 11 w(is)p 268 1389 V 14 w(stifled)8 b Fd(.)s(.)f(.)f(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)21 b Fe(6)75 1438 y Fc(history)p ! 217 1438 V 11 w(length)15 b Fd(.)6 b(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)17 b Fe(9)75 1488 y Fc(history)p 217 ! 1488 V 11 w(list)5 b Fd(.)g(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)17 b Fe(7)75 1538 y Fc(history_no)o(_e)o(xpa)o(nd)o ! (_ch)o(ars)e Fd(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)19 b Fe(10)75 1588 y Fc(history_qu)o(ot)o ! (es_)o(in)o(hib)o(it_)o(ex)o(pan)o(si)o(on)13 b Fd(.)6 ! b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)16 b Fe(10)75 1638 ! y Fc(history)p 217 1638 V 11 w(search)9 b Fd(.)d(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)23 b Fe(7)75 1687 y Fc(history_se)o(ar)o ! (ch_)o(de)o(lim)o(ite)o(r_)o(cha)o(rs)15 b Fd(.)6 b(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)18 b Fe(10)75 1737 y Fc(history)p ! 217 1737 V 11 w(search)p 348 1737 V 12 w(pos)8 b Fd(.)d(.)i(.)f(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)21 b Fe(8)75 1787 y Fc(history)p ! 217 1787 V 11 w(search)p 348 1787 V 12 w(prefix)5 b Fd(.)t(.)h(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)g(.)g(.)17 b Fe(8)75 1837 y Fc(history)p 217 1837 ! V 11 w(set)p 288 1837 V 13 w(history)p 441 1837 V 12 ! w(state)9 b Fd(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)23 b Fe(6)75 1887 y Fc(history)p ! 217 1887 V 11 w(set)p 288 1887 V 13 w(pos)t Fd(.)5 b(.)h(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)16 b Fe(7)1012 359 ! y Fc(history_sub)o(st)o(_ch)o(ar)d Fd(.)6 b(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! 17 b Fe(10)1012 409 y Fc(history)p 1154 409 V 12 w(tokenize)8 ! b Fd(.)s(.)e(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)21 ! b Fe(9)1012 459 y Fc(history)p 1154 459 V 12 w(total)p ! 1266 459 V 12 w(bytes)7 b Fd(.)t(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)20 ! b Fe(7)1012 509 y Fc(history)p 1154 509 V 12 w(truncate)p ! 1326 509 V 11 w(file)5 b Fd(.)t(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)18 ! b Fe(8)1012 612 y Fm(M)1012 670 y Fc(max)p 1074 670 V ! 13 w(input)p 1187 670 V 13 w(history)13 b Fd(.)6 b(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)16 b Fe(9)1012 773 y Fm(N)1012 831 ! y Fc(next)p 1094 831 V 13 w(history)5 b Fd(.)s(.)h(.)g(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)18 b Fe(7)1012 ! 934 y Fm(P)1012 992 y Fc(previous)p 1174 992 V 11 w(history)8 ! b Fd(.)t(.)e(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)21 ! b Fe(7)1012 1096 y Fm(R)1012 1154 y Fc(read)p 1094 1154 ! V 13 w(history)5 b Fd(.)s(.)h(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)18 b Fe(8)1012 1204 y Fc(read)p 1094 ! 1204 V 13 w(history)p 1247 1204 V 11 w(range)8 b Fd(.)d(.)h(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)h(.)f(.)21 b Fe(8)1012 1253 y Fc(remove)p ! 1134 1253 V 12 w(history)8 b Fd(.)e(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)24 b Fe(6)1012 1303 y Fc(replace)p 1154 ! 1303 V 12 w(history)p 1306 1303 V 11 w(entry)5 b Fd(.)t(.)h(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)18 b Fe(6)1012 1406 y Fm(S)1012 1464 y Fc(stifle)p ! 1134 1464 V 12 w(history)8 b Fd(.)e(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)24 b Fe(6)1012 1568 y Fm(U)1012 1626 ! y Fc(unstifle)p 1174 1626 V 11 w(history)8 b Fd(.)t(.)e(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)21 b Fe(6)1012 1676 y Fc(using)p ! 1114 1676 V 13 w(history)s Fd(.)s(.)6 b(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)17 b Fe(6)1012 1779 y Fm(W)1012 ! 1837 y Fc(where)p 1114 1837 V 13 w(history)s Fd(.)s(.)6 ! b(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)17 ! b Fe(7)1012 1887 y Fc(write)p 1114 1887 V 13 w(history)s ! Fd(.)s(.)6 b(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)17 b Fe(8)p eop %%Page: 16 18 ! 16 17 bop 75 -58 a Fo(16)1324 b(GNU)15 b(History)g(Library)p eop %%Page: -1 19 ! -1 18 bop 1862 -58 a Fo(i)75 183 y Fk(T)-7 b(able)27 ! b(of)f(Con)n(ten)n(ts)75 354 y Fm(1)67 b(Using)22 b(History)h(In)n (teractiv)n(ely)9 b Fb(.)k(.)d(.)h(.)f(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)h(.)31 b Fm(1)224 423 y Fo(1.1)45 b(History)15 b(Expansion)5 b Fa(.)j(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) ! f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)19 b Fo(1)374 478 y(1.1.1)44 b(Ev)o(en)o(t)14 b(Designators)e Fa(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.) ! f(.)h(.)f(.)h(.)26 b Fo(1)374 532 y(1.1.2)44 b(W)l(ord)15 b(Designators)5 b Fa(.)h(.)i(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h ! (.)19 b Fo(2)374 587 y(1.1.3)44 b(Mo)q(di\014ers)t Fa(.)8 b(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) ! f(.)h(.)f(.)19 b Fo(2)75 708 y Fm(2)67 b(Programming)23 b(with)g(GNU)f(History)16 b Fb(.)10 b(.)g(.)g(.)h(.)f(.)g(.)g(.)h(.)f ! (.)g(.)38 b Fm(5)224 777 y Fo(2.1)45 b(In)o(tro)q(duction)16 b(to)f(History)10 b Fa(.)d(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) ! f(.)h(.)f(.)h(.)24 b Fo(5)224 832 y(2.2)45 b(History)15 b(Storage)c Fa(.)d(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) ! g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)26 b Fo(5)224 886 y(2.3)45 b(History)15 b(F)l(unctions)d Fa(.)c(.)f(.)h(.)f(.)h(.)f(.)h (.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)26 ! b Fo(6)374 941 y(2.3.1)44 b(Initializing)18 b(History)d(and)h(State)e (Managemen)o(t)g Fa(.)7 b(.)h(.)g(.)f(.)h(.)f(.)29 b ! Fo(6)374 996 y(2.3.2)44 b(History)15 b(List)h(Managemen)o(t)d Fa(.)7 b(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)29 b Fo(6)374 1051 y(2.3.3)44 b(Information)15 b(Ab)q(out)g(the)h(History)f(List)c Fa(.)d(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)26 ! b Fo(7)374 1106 y(2.3.4)44 b(Mo)o(ving)15 b(Around)g(the)g(History)g (List)c Fa(.)d(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)25 b Fo(7)374 1160 y(2.3.5)44 b(Searc)o(hing)16 b(the)f(History)g(List)7 b Fa(.)h(.)g(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)22 ! b Fo(7)374 1215 y(2.3.6)44 b(Managing)15 b(the)g(History)g(File)6 b Fa(.)i(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) ! f(.)h(.)f(.)h(.)f(.)h(.)20 b Fo(8)374 1270 y(2.3.7)44 b(History)15 b(Expansion)9 b Fa(.)f(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)24 b Fo(8)224 1325 y(2.4)45 b(History)15 b(V)l(ariables)6 ! b Fa(.)j(.)e(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.) ! f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h ! (.)f(.)h(.)f(.)h(.)f(.)21 b Fo(9)224 1380 y(2.5)45 b(History)15 b(Programming)f(Example)7 b Fa(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)22 ! b Fo(10)75 1501 y Fm(App)r(endix)i(A)67 b(Concept)22 b(Index)17 b Fb(.)10 b(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)h(.)f(.)g(.)38 b Fm(13)75 1636 y(App)r(endix)24 b(B)67 b(F)-6 b(unction)25 b(and)e(V)-6 b(ariable)24 b(Index)16 ! b Fb(.)10 b(.)g(.)g(.)38 b Fm(15)p eop %%Page: -2 20 ! -2 19 bop 75 -58 a Fo(ii)1346 b(GNU)15 b(History)g(Library)p eop %%Trailer --- 820,1655 ---- %%EndSetup %%Page: 1 1 ! 1 0 bop 75 659 a Fq(GNU)33 b(History)f(Library)p 75 709 ! 1800 17 v 960 757 a Fp(Edition)16 b(4.2,)e(for)h Fo(History)f(Library)g ! Fp(V)l(ersion)i(4.2.)1692 811 y(Apr)f(2001)75 2467 y ! Fn(Brian)23 b(F)-6 b(o)n(x,)23 b(F)-6 b(ree)23 b(Soft)n(w)n(are)f(F)-6 ! b(oundation)75 2534 y(Chet)22 b(Ramey)-6 b(,)23 b(Case)e(W)-6 ! b(estern)23 b(Reserv)n(e)f(Univ)n(ersit)n(y)p 75 2570 ! 1800 9 v eop %%Page: 2 2 ! 2 1 bop 75 217 a Fp(This)21 b(do)q(cumen)o(t)g(describ)q(es)h(the)f (GNU)f(History)g(library)l(,)j(a)d(programming)g(to)q(ol)g(that)g(pro)o ! (vides)h(a)75 271 y(consisten)o(t)15 b(user)h(in)o(terface)f(for)g (recalling)i(lines)f(of)f(previously)i(t)o(yp)q(ed)e(input.)75 ! 339 y(Published)i(b)o(y)f(the)f(F)l(ree)g(Soft)o(w)o(are)f(F)l ! (oundation)75 394 y(59)h(T)l(emple)h(Place,)f(Suite)i(330,)75 ! 448 y(Boston,)d(MA)h(02111)f(USA)75 516 y(P)o(ermission)j(is)f(gran)o (ted)g(to)f(mak)o(e)h(and)g(distribute)i(v)o(erbatim)d(copies)i(of)f ! (this)h(man)o(ual)f(pro)o(vided)h(the)75 570 y(cop)o(yrigh)o(t)e (notice)h(and)f(this)h(p)q(ermission)g(notice)g(are)f(preserv)o(ed)h ! (on)f(all)h(copies.)75 638 y(P)o(ermission)c(is)h(gran)o(ted)e(to)g (cop)o(y)h(and)g(distribute)h(mo)q(di\014ed)g(v)o(ersions)f(of)f(this)h ! (man)o(ual)g(under)h(the)f(con-)75 692 y(ditions)k(for)e(v)o(erbatim)h (cop)o(ying,)g(pro)o(vided)h(that)e(the)h(en)o(tire)h(resulting)g ! (deriv)o(ed)g(w)o(ork)e(is)h(distributed)75 747 y(under)h(the)f(terms)g (of)g(a)f(p)q(ermission)j(notice)f(iden)o(tical)h(to)e(this)g(one.)75 ! 814 y(P)o(ermission)i(is)g(gran)o(ted)f(to)g(cop)o(y)h(and)f (distribute)i(translations)f(of)f(this)h(man)o(ual)g(in)o(to)f(another) ! g(lan-)75 869 y(guage,)e(under)h(the)f(ab)q(o)o(v)o(e)g(conditions)i (for)d(mo)q(di\014ed)j(v)o(ersions,)e(except)h(that)f(this)h(p)q ! (ermission)g(notice)75 924 y(ma)o(y)f(b)q(e)i(stated)f(in)h(a)f (translation)g(appro)o(v)o(ed)g(b)o(y)g(the)g(F)l(ree)h(Soft)o(w)o(are) d(F)l(oundation.)75 2661 y(Cop)o(yrigh)o(t)301 2660 y(c)289 ! 2661 y Fm(\015)h Fp(1988-2001)f(F)l(ree)i(Soft)o(w)o(are)f(F)l (oundation,)h(Inc.)p eop %%Page: 1 3 ! 1 2 bop 75 -58 a Fp(Chapter)15 b(1:)k(Using)d(History)f(In)o(teractiv)o ! (ely)1007 b(1)75 149 y Fl(1)41 b(Using)26 b(History)h(In)n(teractiv)n ! (ely)137 289 y Fp(This)17 b(c)o(hapter)g(describ)q(es)h(ho)o(w)e(to)g ! (use)h(the)g Fk(gnu)f Fp(History)g(Library)h(in)o(teractiv)o(ely)l(,)h ! (from)e(a)g(user's)75 344 y(standp)q(oin)o(t.)38 b(It)21 ! b(should)h(b)q(e)g(considered)g(a)f(user's)g(guide.)38 ! b(F)l(or)21 b(information)g(on)g(using)h(the)f Fk(gnu)75 ! 398 y Fp(History)c(Library)h(in)h(y)o(our)e(o)o(wn)g(programs,)f(see)i ! (Chapter)f(2)h([Programming)e(with)i(GNU)f(History],)75 ! 453 y(page)e(5.)75 600 y Fn(1.1)33 b(History)22 b(Expansion)137 ! 704 y Fp(The)c(History)g(library)h(pro)o(vides)f(a)f(history)h (expansion)h(feature)e(that)h(is)g(similar)h(to)e(the)h(history)75 ! 759 y(expansion)12 b(pro)o(vided)g(b)o(y)f Fo(csh)p Fp(.)18 b(This)11 b(section)h(describ)q(es)g(the)g(syn)o(tax)e(used)h(to)g ! (manipulate)h(the)f(history)75 814 y(information.)137 ! 888 y(History)k(expansions)h(in)o(tro)q(duce)h(w)o(ords)d(from)g(the)i (history)f(list)h(in)o(to)f(the)h(input)g(stream,)e(making)75 ! 943 y(it)h(easy)g(to)g(rep)q(eat)g(commands,)g(insert)h(the)f(argumen)o (ts)f(to)h(a)g(previous)h(command)f(in)o(to)g(the)g(curren)o(t)75 ! 998 y(input)h(line,)h(or)d(\014x)i(errors)e(in)i(previous)g(commands)f ! (quic)o(kly)l(.)137 1072 y(History)j(expansion)i(tak)o(es)d(place)i(in) h(t)o(w)o(o)d(parts.)28 b(The)19 b(\014rst)f(is)g(to)g(determine)i ! (whic)o(h)f(line)h(from)75 1127 y(the)h(history)f(list)i(should)g(b)q (e)f(used)g(during)h(substitution.)37 b(The)21 b(second)g(is)g(to)f ! (select)i(p)q(ortions)e(of)75 1182 y(that)15 b(line)i(for)d(inclusion)k (in)o(to)d(the)h(curren)o(t)f(one.)20 b(The)c(line)g(selected)h(from)e ! (the)g(history)g(is)h(called)h(the)75 1237 y Fj(ev)o(en)o(t)p ! Fp(,)c(and)h(the)g(p)q(ortions)g(of)f(that)g(line)i(that)e(are)g(acted) ! h(up)q(on)g(are)f(called)j Fj(w)o(ords)p Fp(.)i(V)l(arious)c ! Fj(mo)q(di\014ers)75 1292 y Fp(are)i(a)o(v)m(ailable)i(to)e(manipulate) i(the)e(selected)i(w)o(ords.)23 b(The)17 b(line)h(is)f(brok)o(en)f(in)o ! (to)h(w)o(ords)e(in)j(the)e(same)75 1346 y(fashion)c(that)e(Bash)i(do)q (es,)g(so)f(that)g(sev)o(eral)g(w)o(ords)g(surrounded)h(b)o(y)f(quotes) ! h(are)f(considered)h(one)g(w)o(ord.)75 1401 y(History)18 b(expansions)h(are)g(in)o(tro)q(duced)g(b)o(y)f(the)h(app)q(earance)g ! (of)f(the)g(history)h(expansion)g(c)o(haracter,)75 1456 ! y(whic)o(h)d(is)g(`)p Fo(!)p Fp(')e(b)o(y)h(default.)75 ! 1583 y Fi(1.1.1)30 b(Ev)n(en)n(t)21 b(Designators)137 ! 1687 y Fp(An)16 b(ev)o(en)o(t)f(designator)g(is)g(a)g(reference)h(to)f (a)g(command)g(line)i(en)o(try)d(in)i(the)g(history)f(list.)75 ! 1777 y Fo(!)216 b Fp(Start)16 b(a)g(history)h(substitution,)g(except)h (when)f(follo)o(w)o(ed)g(b)o(y)f(a)h(space,)g(tab,)f(the)h(end)g(of)315 ! 1832 y(the)e(line,)i(`)p Fo(=)p Fp(')d(or)h(`)p Fo(\()p ! Fp('.)75 1919 y Fo(!)p Fj(n)191 b Fp(Refer)15 b(to)f(command)h(line)i ! Fj(n)p Fp(.)75 2006 y Fo(!-)p Fj(n)167 b Fp(Refer)15 ! b(to)f(the)i(command)f Fj(n)g Fp(lines)i(bac)o(k.)75 ! 2094 y Fo(!!)192 b Fp(Refer)15 b(to)f(the)i(previous)f(command.)20 ! b(This)c(is)g(a)f(synon)o(ym)g(for)f(`)p Fo(!-1)p Fp('.)75 ! 2181 y Fo(!)p Fj(string)102 b Fp(Refer)15 b(to)f(the)i(most)e(recen)o ! (t)h(command)g(starting)g(with)g Fj(string)p Fp(.)75 ! 2268 y Fo(!?)p Fj(string)t Fo([?])315 2323 y Fp(Refer)h(to)g(the)h (most)f(recen)o(t)h(command)g(con)o(taining)g Fj(string)p ! Fp(.)25 b(The)17 b(trailing)g(`)p Fo(?)p Fp(')f(ma)o(y)g(b)q(e)315 ! 2377 y(omitted)f(if)h(the)f Fj(string)k Fp(is)d(follo)o(w)o(ed)f ! (immediately)i(b)o(y)e(a)g(newline.)75 2464 y Fo(^)p ! Fj(string1)t Fo(^)p Fj(string2)t Fo(^)315 2519 y Fp(Quic)o(k)i ! (Substitution.)23 b(Rep)q(eat)16 b(the)g(last)f(command,)h(replacing)h ! Fj(string1)i Fp(with)e Fj(string2)p Fp(.)315 2574 y(Equiv)m(alen)o(t)g ! (to)d Fo(!!:s/)p Fj(string1)t Fo(/)p Fj(string2)t Fo(/)p ! Fp(.)75 2661 y Fo(!#)192 b Fp(The)15 b(en)o(tire)h(command)f(line)i(t)o (yp)q(ed)f(so)e(far.)p eop %%Page: 2 4 ! 2 3 bop 75 -58 a Fp(2)1347 b(GNU)15 b(History)g(Library)75 ! 149 y Fi(1.1.2)30 b(W)-5 b(ord)20 b(Designators)137 247 ! y Fp(W)l(ord)d(designators)g(are)g(used)h(to)f(select)h(desired)h(w)o ! (ords)d(from)h(the)g(ev)o(en)o(t.)26 b(A)18 b(`)p Fo(:)p ! Fp(')e(separates)h(the)75 302 y(ev)o(en)o(t)j(sp)q(eci\014cation)h (from)e(the)h(w)o(ord)f(designator.)34 b(It)20 b(ma)o(y)f(b)q(e)h ! (omitted)g(if)g(the)g(w)o(ord)f(designator)75 357 y(b)q(egins)f(with)g ! (a)e(`)p Fo(^)p Fp(',)h(`)p Fo($)p Fp(',)f(`)p Fo(*)p ! Fp(',)g(`)p Fo(-)p Fp(',)g(or)h(`)p Fo(\045)p Fp('.)24 b(W)l(ords)17 b(are)g(n)o(um)o(b)q(ered)g(from)g(the)g(b)q(eginning)i ! (of)e(the)g(line,)75 411 y(with)j(the)g(\014rst)f(w)o(ord)h(b)q(eing)h (denoted)f(b)o(y)g(0)f(\(zero\).)33 b(W)l(ords)20 b(are)f(inserted)i ! (in)o(to)f(the)g(curren)o(t)f(line)75 466 y(separated)c(b)o(y)g(single) ! i(spaces.)137 535 y(F)l(or)e(example,)75 616 y Fo(!!)192 ! b Fp(designates)18 b(the)g(preceding)i(command.)28 b(When)18 b(y)o(ou)g(t)o(yp)q(e)g(this,)h(the)f(preceding)h(com-)315 ! 671 y(mand)c(is)h(rep)q(eated)g(in)g(toto.)75 752 y Fo(!!:$)144 ! b Fp(designates)12 b(the)f(last)g(argumen)o(t)f(of)h(the)g(preceding)i (command.)19 b(This)11 b(ma)o(y)g(b)q(e)h(shortened)315 ! 807 y(to)j Fo(!$)p Fp(.)75 887 y Fo(!fi:2)120 b Fp(designates)15 b(the)g(second)g(argumen)o(t)f(of)g(the)h(most)f(recen)o(t)g(command)h ! (starting)f(with)h(the)315 942 y(letters)g Fo(fi)p Fp(.)137 ! 1024 y(Here)h(are)f(the)g(w)o(ord)f(designators:)75 1105 ! y Fo(0)h(\(zero\))57 b Fp(The)15 b Fo(0)p Fp(th)g(w)o(ord.)20 b(F)l(or)14 b(man)o(y)h(applications,)h(this)g(is)g(the)f(command)g(w)o ! (ord.)75 1186 y Fj(n)215 b Fp(The)15 b Fj(n)p Fp(th)h(w)o(ord.)75 ! 1267 y Fo(^)216 b Fp(The)15 b(\014rst)g(argumen)o(t;)f(that)h(is,)g(w)o ! (ord)g(1.)75 1348 y Fo($)216 b Fp(The)15 b(last)h(argumen)o(t.)75 ! 1429 y Fo(\045)216 b Fp(The)15 b(w)o(ord)g(matc)o(hed)g(b)o(y)g(the)g ! (most)g(recen)o(t)g(`)p Fo(?)p Fj(string)t Fo(?)p Fp(')f(searc)o(h.)75 ! 1510 y Fj(x)p Fo(-)p Fj(y)168 b Fp(A)15 b(range)g(of)g(w)o(ords;)f(`)p ! Fo(-)p Fj(y)t Fp(')g(abbreviates)i(`)p Fo(0-)p Fj(y)t ! Fp('.)75 1591 y Fo(*)216 b Fp(All)15 b(of)f(the)f(w)o(ords,)g(except)i ! (the)f Fo(0)p Fp(th.)19 b(This)14 b(is)h(a)e(synon)o(ym)h(for)f(`)p ! Fo(1-$)p Fp('.)18 b(It)c(is)g(not)g(an)g(error)315 1645 ! y(to)g(use)h(`)p Fo(*)p Fp(')f(if)i(there)e(is)i(just)e(one)h(w)o(ord)f (in)i(the)f(ev)o(en)o(t;)f(the)h(empt)o(y)g(string)g(is)g(returned)g ! (in)315 1700 y(that)f(case.)75 1781 y Fj(x)s Fo(*)189 ! b Fp(Abbreviates)16 b(`)p Fj(x)p Fo(-$)p Fp(')75 1862 ! y Fj(x)p Fo(-)192 b Fp(Abbreviates)16 b(`)p Fj(x)p Fo(-$)p ! Fp(')e(lik)o(e)i(`)p Fj(x)s Fo(*)p Fp(',)e(but)i(omits)f(the)g(last)g ! (w)o(ord.)137 1943 y(If)i(a)g(w)o(ord)f(designator)h(is)h(supplied)h (without)e(an)g(ev)o(en)o(t)f(sp)q(eci\014cation,)j(the)e(previous)h ! (command)75 1998 y(is)e(used)f(as)g(the)h(ev)o(en)o(t.)75 ! 2113 y Fi(1.1.3)30 b(Mo)r(di\014ers)137 2210 y Fp(After)10 b(the)h(optional)g(w)o(ord)e(designator,)i(y)o(ou)f(can)h(add)f(a)g (sequence)i(of)e(one)g(or)g(more)g(of)g(the)g(follo)o(wing)75 ! 2265 y(mo)q(di\014ers,)16 b(eac)o(h)f(preceded)i(b)o(y)e(a)g(`)p ! Fo(:)p Fp('.)75 2346 y Fo(h)216 b Fp(Remo)o(v)o(e)14 ! b(a)h(trailing)h(pathname)f(comp)q(onen)o(t,)g(lea)o(ving)h(only)g(the) ! f(head.)75 2427 y Fo(t)216 b Fp(Remo)o(v)o(e)14 b(all)i(leading)h (pathname)e(comp)q(onen)o(ts,)g(lea)o(ving)h(the)f(tail.)75 ! 2508 y Fo(r)216 b Fp(Remo)o(v)o(e)14 b(a)h(trailing)h(su\016x)f(of)g ! (the)g(form)g(`)p Fo(.)p Fj(su\016x)s Fp(',)f(lea)o(ving)i(the)f ! (basename.)75 2589 y Fo(e)216 b Fp(Remo)o(v)o(e)14 b(all)i(but)g(the)f ! (trailing)h(su\016x.)75 2670 y Fo(p)216 b Fp(Prin)o(t)15 b(the)g(new)h(command)f(but)g(do)g(not)g(execute)h(it.)p eop %%Page: 3 5 ! 3 4 bop 75 -58 a Fp(Chapter)15 b(1:)k(Using)d(History)f(In)o(teractiv)o ! (ely)1007 b(3)75 149 y Fo(s/)p Fj(old)r Fo(/)p Fj(new)t ! Fo(/)315 204 y Fp(Substitute)17 b Fj(new)j Fp(for)c(the)h(\014rst)e(o)q ! (ccurrence)j(of)e Fj(old)i Fp(in)f(the)g(ev)o(en)o(t)f(line.)25 ! b(An)o(y)16 b(delimiter)315 259 y(ma)o(y)c(b)q(e)h(used)g(in)g(place)g ! (of)f(`)p Fo(/)p Fp('.)18 b(The)13 b(delimiter)h(ma)o(y)e(b)q(e)h ! (quoted)f(in)i Fj(old)g Fp(and)f Fj(new)k Fp(with)12 ! b(a)315 314 y(single)j(bac)o(kslash.)20 b(If)15 b(`)p ! Fo(&)p Fp(')e(app)q(ears)h(in)h Fj(new)p Fp(,)f(it)g(is)h(replaced)g(b) ! o(y)f Fj(old)p Fp(.)20 b(A)14 b(single)i(bac)o(kslash)315 ! 369 y(will)j(quote)e(the)h(`)p Fo(&)p Fp('.)25 b(The)17 b(\014nal)i(delimiter)g(is)f(optional)g(if)f(it)h(is)g(the)f(last)g(c)o ! (haracter)g(on)315 423 y(the)e(input)h(line.)75 503 y ! Fo(&)216 b Fp(Rep)q(eat)15 b(the)g(previous)h(substitution.)75 ! 583 y Fo(g)216 b Fp(Cause)19 b(c)o(hanges)h(to)e(b)q(e)i(applied)h(o)o (v)o(er)e(the)g(en)o(tire)h(ev)o(en)o(t)f(line.)34 b(Used)20 ! b(in)g(conjunction)315 638 y(with)c(`)p Fo(s)p Fp(',)d(as)i(in)h ! Fo(gs/)p Fj(old)r Fo(/)p Fj(new)t Fo(/)p Fp(,)f(or)g(with)g(`)p ! Fo(&)p Fp('.)p eop %%Page: 4 6 ! 4 5 bop 75 -58 a Fp(4)1347 b(GNU)15 b(History)g(Library)p eop %%Page: 5 7 ! 5 6 bop 75 -58 a Fp(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (History)889 b(5)75 149 y Fl(2)41 b(Programming)28 b(with)e(GNU)i ! (History)137 269 y Fp(This)17 b(c)o(hapter)f(describ)q(es)i(ho)o(w)e ! (to)f(in)o(terface)i(programs)e(that)g(y)o(ou)h(write)g(with)h(the)f ! Fk(gnu)g Fp(History)75 324 y(Library)l(.)24 b(It)17 b(should)g(b)q(e)g (considered)h(a)e(tec)o(hnical)i(guide.)25 b(F)l(or)15 b(information)i(on)f(the)h(in)o(teractiv)o(e)g(use)75 ! 379 y(of)e Fk(gnu)g Fp(History)l(,)g(see)g(Chapter)g(1)g([Using)g ! (History)g(In)o(teractiv)o(ely],)h(page)f(1.)75 509 y ! Fn(2.1)33 b(In)n(tro)r(duction)24 b(to)e(History)137 ! 607 y Fp(Man)o(y)11 b(programs)f(read)h(input)i(from)d(the)i(user)f(a)g ! (line)i(at)e(a)g(time.)19 b(The)12 b Fk(gnu)f Fp(History)g(library)h ! (is)g(able)75 661 y(to)i(k)o(eep)g(trac)o(k)g(of)g(those)g(lines,)i ! (asso)q(ciate)e(arbitrary)g(data)g(with)g(eac)o(h)h(line,)h(and)e ! (utilize)j(information)75 716 y(from)d(previous)i(lines)h(in)f(comp)q ! (osing)g(new)f(ones.)137 784 y(The)f(programmer)f(using)h(the)g ! (History)g(library)g(has)g(a)o(v)m(ailable)h(functions)g(for)e(remem)o ! (b)q(ering)h(lines)75 839 y(on)c(a)g(history)h(list,)g(asso)q(ciating)g ! (arbitrary)f(data)f(with)i(a)f(line,)j(remo)o(ving)d(lines)i(from)d ! (the)i(list,)h(searc)o(hing)75 894 y(through)17 b(the)h(list)g(for)f(a) ! h(line)h(con)o(taining)f(an)g(arbitrary)f(text)g(string,)h(and)g ! (referencing)h(an)o(y)e(line)i(in)75 949 y(the)c(list)i(directly)l(.)22 ! b(In)16 b(addition,)g(a)f(history)g Fj(expansion)h Fp(function)h(is)e (a)o(v)m(ailable)i(whic)o(h)g(pro)o(vides)f(for)e(a)75 ! 1003 y(consisten)o(t)h(user)h(in)o(terface)f(across)g(di\013eren)o(t)g ! (programs.)137 1072 y(The)f(user)h(using)f(programs)f(written)h(with)g (the)g(History)g(library)h(has)f(the)g(b)q(ene\014t)h(of)e(a)h ! (consisten)o(t)75 1126 y(user)20 b(in)o(terface)f(with)h(a)f(set)h(of)f (w)o(ell-kno)o(wn)h(commands)g(for)e(manipulating)k(the)d(text)g(of)g ! (previous)75 1181 y(lines)c(and)f(using)h(that)e(text)g(in)i(new)f (commands.)19 b(The)14 b(basic)h(history)e(manipulation)j(commands)d ! (are)75 1236 y(similar)j(to)f(the)g(history)g(substitution)h(pro)o ! (vided)g(b)o(y)g Fo(csh)p Fp(.)137 1304 y(If)f(the)g(programmer)f ! (desires,)h(he)g(can)g(use)g(the)g(Readline)h(library)l(,)g(whic)o(h)f ! (includes)j(some)c(history)75 1359 y(manipulation)j(b)o(y)e(default,)g (and)h(has)f(the)g(added)h(adv)m(an)o(tage)f(of)f(command)h(line)i ! (editing.)137 1427 y(Before)i(declaring)i(an)o(y)d(functions)i(using)g (an)o(y)f(functionalit)o(y)h(the)f(History)g(library)h(pro)o(vides)f ! (in)75 1482 y(other)14 b(co)q(de,)h(an)f(application)i(writer)e(should) ! i(include)g(the)f(\014le)g Fo()d ! Fp(in)j(an)o(y)f(\014le)75 1537 y(that)d(uses)h(the)h(History)e (library's)i(features.)18 b(It)12 b(supplies)i(extern)e(declarations)h ! (for)e(all)i(of)f(the)g(library's)75 1591 y(public)17 b(functions)f(and)g(v)m(ariables,)g(and)f(declares)h(all)g(of)f(the)h ! (public)h(data)d(structures.)75 1722 y Fn(2.2)33 b(History)22 ! b(Storage)137 1819 y Fp(The)16 b(history)f(list)h(is)g(an)f(arra)o(y)f (of)g(history)i(en)o(tries.)k(A)15 b(history)g(en)o(try)g(is)h ! (declared)g(as)f(follo)o(ws:)195 1885 y Fo(typedef)23 ! b(void)g(*histdata_t;)195 1988 y(typedef)g(struct)g(_hist_entry)f({)243 ! 2040 y(char)h(*line;)243 2092 y(histdata_t)f(data;)195 ! 2144 y(})i(HIST_ENTRY;)137 2212 y Fp(The)16 b(history)f(list)h(itself)g ! (migh)o(t)f(therefore)g(b)q(e)h(declared)g(as)195 2277 ! y Fo(HIST_ENTRY)22 b(**the_history_list;)137 2345 y Fp(The)16 ! b(state)e(of)h(the)g(History)g(library)h(is)g(encapsulated)g(in)o(to)f ! (a)g(single)i(structure:)195 2411 y Fo(/*)219 2462 y(*)24 ! b(A)f(structure)g(used)g(to)h(pass)f(around)g(the)h(current)f(state)g ! (of)g(the)h(history.)219 2514 y(*/)195 2566 y(typedef)f(struct)g ! (_hist_state)f({)243 2618 y(HIST_ENTRY)g(**entries;)h(/*)g(Pointer)g ! (to)h(the)f(entries)g(themselves.)g(*/)243 2670 y(int)g(offset;)262 ! b(/*)23 b(The)h(location)f(pointer)f(within)h(this)h(array.)f(*/)p ! eop %%Page: 6 8 ! 6 7 bop 75 -58 a Fp(6)1347 b(GNU)15 b(History)g(Library)243 ! 149 y Fo(int)23 b(length;)262 b(/*)23 b(Number)g(of)h(elements)f ! (within)g(this)g(array.)g(*/)243 201 y(int)g(size;)310 ! b(/*)23 b(Number)g(of)h(slots)f(allocated)g(to)g(this)h(array.)f(*/)243 ! 253 y(int)g(flags;)195 305 y(})h(HISTORY_STATE;)137 372 ! y Fp(If)16 b(the)f(\015ags)g(mem)o(b)q(er)g(includes)j ! Fo(HS_STIFLED)p Fp(,)13 b(the)i(history)h(has)f(b)q(een)h(sti\015ed.)75 ! 498 y Fn(2.3)33 b(History)22 b(F)-6 b(unctions)137 593 ! y Fp(This)13 b(section)g(describ)q(es)h(the)e(calling)i(sequence)g(for) ! e(the)g(v)m(arious)h(functions)g(exp)q(orted)f(b)o(y)h(the)f ! Fk(gnu)75 648 y Fp(History)j(library)l(.)75 758 y Fi(2.3.1)30 ! b(Initializing)20 b(History)h(and)f(State)g(Managemen)n(t)137 ! 853 y Fp(This)e(section)g(describ)q(es)h(functions)f(used)g(to)e ! (initialize)21 b(and)c(manage)g(the)g(state)g(of)g(the)g(History)75 ! 908 y(library)f(when)g(y)o(ou)f(w)o(an)o(t)f(to)g(use)i(the)f(history)g ! (functions)h(in)g(y)o(our)f(program.)1762 1021 y(F)l(unction)-1861 ! b Fh(void)20 b Fg(using)p 333 1021 18 3 v 20 w(history)j ! Ff(\()p Fo(void)p Ff(\))195 1075 y Fp(Begin)e(a)f(session)g(in)h(whic)o ! (h)g(the)f(history)g(functions)g(migh)o(t)g(b)q(e)h(used.)34 ! b(This)21 b(initializes)i(the)195 1130 y(in)o(teractiv)o(e)16 ! b(v)m(ariables.)1762 1243 y(F)l(unction)-1861 b Fh(HISTORY_STATE)21 ! b(*)e Fg(history)p 657 1243 V 21 w(get)p 755 1243 V 21 ! w(history)p 951 1243 V 21 w(state)j Ff(\()p Fo(void)p ! Ff(\))195 1298 y Fp(Return)15 b(a)g(structure)g(describing)i(the)e ! (curren)o(t)g(state)f(of)h(the)g(input)i(history)l(.)1762 ! 1411 y(F)l(unction)-1861 b Fh(void)20 b Fg(history)p ! 377 1411 V 20 w(set)p 468 1411 V 21 w(history)p 664 1411 ! V 21 w(state)j Ff(\()p Fo(HISTORY_STATE)13 b(*state)p ! Ff(\))195 1466 y Fp(Set)i(the)h(state)e(of)h(the)g(history)g(list)h ! (according)g(to)e Fj(state)p Fp(.)75 1575 y Fi(2.3.2)30 ! b(History)20 b(List)h(Managemen)n(t)137 1671 y Fp(These)11 b(functions)h(manage)e(individual)k(en)o(tries)d(on)g(the)g(history)f ! (list,)i(or)f(set)f(parameters)g(managing)75 1725 y(the)15 ! b(list)h(itself.)1762 1838 y(F)l(unction)-1861 b Fh(void)20 ! b Fg(add)p 294 1838 V 20 w(history)j Ff(\()p Fo(const)14 ! b(char)g(*string)p Ff(\))195 1893 y Fp(Place)i Fj(string)i ! Fp(at)d(the)g(end)h(of)e(the)h(history)g(list.)21 b(The)15 ! b(asso)q(ciated)g(data)g(\014eld)h(\(if)f(an)o(y\))f(is)i(set)f(to)195 ! 1948 y Fo(NULL)p Fp(.)1762 2061 y(F)l(unction)-1861 b ! Fh(HIST_ENTRY)21 b(*)e Fg(remo)n(v)n(e)p 584 2061 V 20 ! w(history)k Ff(\()p Fo(int)14 b(which)p Ff(\))195 2115 ! y Fp(Remo)o(v)o(e)22 b(history)g(en)o(try)h(at)f(o\013set)g ! Fj(whic)o(h)h Fp(from)f(the)h(history)l(.)43 b(The)23 ! b(remo)o(v)o(ed)f(elemen)o(t)h(is)195 2170 y(returned)16 ! b(so)e(y)o(ou)h(can)h(free)f(the)g(line,)i(data,)d(and)h(con)o(taining) ! h(structure.)1762 2283 y(F)l(unction)-1861 b Fh(HIST_ENTRY)21 ! b(*)e Fg(replace)p 580 2283 V 22 w(history)p 777 2283 ! V 20 w(en)n(try)24 b Ff(\()p Fo(int)14 b(which,)g(const)h(char)283 ! 2338 y(*line,)f(histdata_t)g(data)p Ff(\))195 2393 y ! Fp(Mak)o(e)f(the)h(history)g(en)o(try)f(at)g(o\013set)g ! Fj(whic)o(h)i Fp(ha)o(v)o(e)e Fj(line)18 b Fp(and)c Fj(data)p ! Fp(.)19 b(This)14 b(returns)g(the)g(old)g(en)o(try)195 ! 2448 y(so)19 b(y)o(ou)f(can)i(disp)q(ose)g(of)e(the)i(data.)30 ! b(In)20 b(the)f(case)g(of)g(an)g(in)o(v)m(alid)i Fj(whic)o(h)p ! Fp(,)g(a)d Fo(NULL)h Fp(p)q(oin)o(ter)g(is)195 2502 y(returned.)1762 ! 2615 y(F)l(unction)-1861 b Fh(void)20 b Fg(clear)p 320 ! 2615 V 21 w(history)j Ff(\()p Fo(void)p Ff(\))195 2670 ! y Fp(Clear)15 b(the)h(history)f(list)h(b)o(y)f(deleting)i(all)f(the)f ! (en)o(tries.)p eop %%Page: 7 9 ! 7 8 bop 75 -58 a Fp(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (History)889 b(7)1762 149 y(F)l(unction)-1861 b Fh(void)20 ! b Fg(sti\015e)p 320 149 18 3 v 21 w(history)j Ff(\()p ! Fo(int)14 b(max)p Ff(\))195 204 y Fp(Sti\015e)i(the)f(history)h(list,)f ! (remem)o(b)q(ering)h(only)g(the)f(last)g Fj(max)j Fp(en)o(tries.)1762 ! 307 y(F)l(unction)-1861 b Fh(int)20 b Fg(unsti\015e)p ! 358 307 V 21 w(history)i Ff(\()p Fo(void)p Ff(\))195 ! 361 y Fp(Stop)c(sti\015ing)i(the)e(history)l(.)29 b(This)19 ! b(returns)f(the)h(previous)g(amoun)o(t)e(the)i(history)f(w)o(as)f ! (sti\015ed.)195 416 y(The)e(v)m(alue)i(is)f(p)q(ositiv)o(e)g(if)f(the)h ! (history)f(w)o(as)f(sti\015ed,)i(negativ)o(e)f(if)h(it)f(w)o(asn't.) ! 1762 518 y(F)l(unction)-1861 b Fh(int)20 b Fg(history)p ! 351 518 V 20 w(is)p 409 518 V 21 w(sti\015ed)k Ff(\()p ! Fo(void)p Ff(\))195 573 y Fp(Returns)15 b(non-zero)g(if)h(the)f ! (history)g(is)h(sti\015ed,)g(zero)f(if)g(it)h(is)g(not.)75 ! 676 y Fi(2.3.3)30 b(Information)19 b(Ab)r(out)i(the)f(History)h(List) ! 137 770 y Fp(These)13 b(functions)h(return)f(information)g(ab)q(out)f ! (the)h(en)o(tire)h(history)e(list)i(or)e(individual)k(list)e(en)o ! (tries.)1762 872 y(F)l(unction)-1861 b Fh(HIST_ENTRY)21 ! b(**)e Fg(history)p 605 872 V 21 w(list)24 b Ff(\()p ! Fo(void)p Ff(\))195 927 y Fp(Return)15 b(a)g Fo(NULL)f ! Fp(terminated)i(arra)o(y)e(of)h Fo(HIST_ENTRY)f(*)h Fp(whic)o(h)h(is)f ! (the)h(curren)o(t)f(input)h(history)l(.)195 982 y(Elemen)o(t)g(0)f(of)f ! (this)i(list)g(is)g(the)f(b)q(eginning)i(of)e(time.)20 ! b(If)c(there)f(is)h(no)f(history)l(,)g(return)g Fo(NULL)p ! Fp(.)1762 1084 y(F)l(unction)-1861 b Fh(int)20 b Fg(where)p ! 325 1084 V 20 w(history)j Ff(\()p Fo(void)p Ff(\))195 ! 1139 y Fp(Returns)15 b(the)g(o\013set)f(of)h(the)g(curren)o(t)g ! (history)g(elemen)o(t.)1762 1241 y(F)l(unction)-1861 ! b Fh(HIST_ENTRY)21 b(*)e Fg(curren)n(t)p 587 1241 V 21 ! w(history)k Ff(\()p Fo(void)p Ff(\))195 1296 y Fp(Return)12 ! b(the)h(history)f(en)o(try)g(at)g(the)g(curren)o(t)h(p)q(osition,)g(as) ! f(determined)i(b)o(y)e Fo(where_history\(\))p Fp(.)195 ! 1350 y(If)j(there)h(is)f(no)h(en)o(try)e(there,)h(return)g(a)g ! Fo(NULL)g Fp(p)q(oin)o(ter.)1762 1453 y(F)l(unction)-1861 ! b Fh(HIST_ENTRY)21 b(*)e Fg(history)p 579 1453 V 21 w(get)j ! Ff(\()p Fo(int)15 b(offset)p Ff(\))195 1508 y Fp(Return)20 ! b(the)h(history)g(en)o(try)f(at)h(p)q(osition)g Fj(o\013set)p ! Fp(,)g(starting)f(from)g Fo(history_base)f Fp(\(see)i(Sec-)195 ! 1562 y(tion)15 b(2.4)f([History)g(V)l(ariables],)h(page)g(10\).)j(If)d ! (there)g(is)g(no)g(en)o(try)f(there,)h(or)f(if)h Fj(o\013set)g ! Fp(is)g(greater)195 1617 y(than)g(the)g(history)g(length,)h(return)f(a) ! g Fo(NULL)g Fp(p)q(oin)o(ter.)1762 1719 y(F)l(unction)-1861 ! b Fh(int)20 b Fg(history)p 351 1719 V 20 w(total)p 487 ! 1719 V 22 w(b)n(ytes)j Ff(\()p Fo(void)p Ff(\))195 1774 ! y Fp(Return)13 b(the)h(n)o(um)o(b)q(er)g(of)g(b)o(ytes)f(that)g(the)h ! (primary)g(history)g(en)o(tries)g(are)g(using.)20 b(This)14 ! b(function)195 1829 y(returns)h(the)g(sum)h(of)e(the)i(lengths)f(of)g ! (all)h(the)g(lines)g(in)g(the)g(history)l(.)75 1932 y Fi(2.3.4)30 b(Mo)n(ving)21 b(Around)f(the)h(History)g(List)137 ! 2026 y Fp(These)16 b(functions)g(allo)o(w)f(the)g(curren)o(t)h(index)g (in)o(to)f(the)h(history)f(list)h(to)e(b)q(e)i(set)f(or)g(c)o(hanged.) ! 1762 2128 y(F)l(unction)-1861 b Fh(int)20 b Fg(history)p ! 351 2128 V 20 w(set)p 442 2128 V 21 w(p)r(os)h Ff(\()p ! Fo(int)15 b(pos)p Ff(\))195 2183 y Fp(Set)j(the)h(curren)o(t)f(history) ! g(o\013set)g(to)f Fj(p)q(os)p Fp(,)i(an)f(absolute)h(index)h(in)o(to)e ! (the)g(list.)30 b(Returns)18 b(1)g(on)195 2237 y(success,)d(0)g(if)h ! Fj(p)q(os)h Fp(is)f(less)g(than)f(zero)g(or)g(greater)f(than)h(the)g(n) ! o(um)o(b)q(er)h(of)e(history)i(en)o(tries.)1762 2340 ! y(F)l(unction)-1861 b Fh(HIST_ENTRY)21 b(*)e Fg(previous)p ! 615 2340 V 20 w(history)k Ff(\()p Fo(void)p Ff(\))195 ! 2394 y Fp(Bac)o(k)14 b(up)h(the)g(curren)o(t)f(history)g(o\013set)g(to) ! f(the)i(previous)g(history)f(en)o(try)l(,)g(and)h(return)f(a)g(p)q(oin) ! o(ter)195 2449 y(to)h(that)f(en)o(try)l(.)20 b(If)15 ! b(there)g(is)h(no)f(previous)h(en)o(try)l(,)f(return)g(a)g ! Fo(NULL)g Fp(p)q(oin)o(ter.)1762 2552 y(F)l(unction)-1861 ! b Fh(HIST_ENTRY)21 b(*)e Fg(next)p 514 2552 V 21 w(history)k ! Ff(\()p Fo(void)p Ff(\))195 2606 y Fp(Mo)o(v)o(e)17 b(the)h(curren)o(t) ! f(history)h(o\013set)f(forw)o(ard)f(to)h(the)h(next)g(history)g(en)o ! (try)l(,)g(and)g(return)f(the)h(a)195 2661 y(p)q(oin)o(ter)e(to)e(that) ! h(en)o(try)l(.)k(If)d(there)f(is)h(no)f(next)g(en)o(try)l(,)g(return)g ! (a)g Fo(NULL)g Fp(p)q(oin)o(ter.)p eop %%Page: 8 10 ! 8 9 bop 75 -58 a Fp(8)1347 b(GNU)15 b(History)g(Library)75 ! 149 y Fi(2.3.5)30 b(Searc)n(hing)21 b(the)f(History)h(List)137 ! 245 y Fp(These)14 b(functions)g(allo)o(w)g(searc)o(hing)g(of)e(the)i ! (history)f(list)h(for)f(en)o(tries)h(con)o(taining)g(a)f(sp)q(eci\014c) ! i(string.)75 300 y(Searc)o(hing)f(ma)o(y)g(b)q(e)g(p)q(erformed)g(b)q ! (oth)g(forw)o(ard)e(and)i(bac)o(kw)o(ard)f(from)g(the)h(curren)o(t)g ! (history)f(p)q(osition.)75 355 y(The)j(searc)o(h)f(ma)o(y)g(b)q(e)i ! Fj(anc)o(hored)p Fp(,)e(meaning)h(that)f(the)h(string)g(m)o(ust)f(matc) ! o(h)g(at)g(the)h(b)q(eginning)i(of)d(the)75 410 y(history)g(en)o(try)l ! (.)1762 524 y(F)l(unction)-1861 b Fh(int)20 b Fg(history)p ! 351 524 18 3 v 20 w(searc)n(h)j Ff(\()p Fo(const)14 b(char)h(*string,)f ! (int)h(direction)p Ff(\))195 578 y Fp(Searc)o(h)g(the)f(history)g(for)g ! Fj(string)p Fp(,)g(starting)g(at)g(the)h(curren)o(t)f(history)g ! (o\013set.)19 b(If)c Fj(direction)g Fp(is)g(less)195 ! 633 y(than)20 b(0,)g(then)h(the)f(searc)o(h)f(is)i(through)f(previous)g ! (en)o(tries,)i(otherwise)e(through)f(subsequen)o(t)195 ! 688 y(en)o(tries.)h(If)c Fj(string)j Fp(is)d(found,)f(then)g(the)h ! (curren)o(t)f(history)g(index)h(is)g(set)f(to)g(that)f(history)h(en)o ! (try)l(,)195 743 y(and)i(the)g(v)m(alue)h(returned)f(is)g(the)g ! (o\013set)e(in)j(the)f(line)h(of)e(the)h(en)o(try)g(where)g ! Fj(string)j Fp(w)o(as)c(found.)195 798 y(Otherwise,)g(nothing)f(is)h(c) ! o(hanged,)f(and)h(a)e(-1)h(is)h(returned.)1762 912 y(F)l(unction)-1861 ! b Fh(int)20 b Fg(history)p 351 912 V 20 w(searc)n(h)p ! 527 912 V 21 w(pre\014x)i Ff(\()p Fo(const)14 b(char)h(*string,)f(int)h ! (direction)p Ff(\))195 966 y Fp(Searc)o(h)20 b(the)h(history)f(for)g ! Fj(string)p Fp(,)h(starting)e(at)h(the)g(curren)o(t)h(history)f ! (o\013set.)34 b(The)20 b(searc)o(h)g(is)195 1021 y(anc)o(hored:)g(matc) ! o(hing)14 b(lines)j(m)o(ust)d(b)q(egin)i(with)f Fj(string)p ! Fp(.)20 b(If)15 b Fj(direction)h Fp(is)f(less)g(than)g(0,)f(then)h(the) ! 195 1076 y(searc)o(h)g(is)i(through)e(previous)h(en)o(tries,)g ! (otherwise)g(through)f(subsequen)o(t)h(en)o(tries.)22 ! b(If)16 b Fj(string)j Fp(is)195 1131 y(found,)e(then)g(the)f(curren)o ! (t)h(history)f(index)i(is)f(set)f(to)g(that)g(en)o(try)l(,)g(and)h(the) ! f(return)h(v)m(alue)h(is)f(0.)195 1186 y(Otherwise,)f(nothing)f(is)h(c) ! o(hanged,)f(and)h(a)e(-1)h(is)h(returned.)1762 1300 y(F)l(unction)-1861 ! b Fh(int)20 b Fg(history)p 351 1300 V 20 w(searc)n(h)p ! 527 1300 V 21 w(p)r(os)h Ff(\()p Fo(const)14 b(char)h(*string,)f(int)h ! (direction,)f(int)283 1355 y(pos)p Ff(\))195 1409 y Fp(Searc)o(h)j(for) ! g Fj(string)k Fp(in)d(the)f(history)g(list,)h(starting)e(at)h ! Fj(p)q(os)p Fp(,)g(an)g(absolute)h(index)g(in)o(to)f(the)h(list.)195 ! 1464 y(If)g Fj(direction)i Fp(is)e(negativ)o(e,)h(the)f(searc)o(h)g ! (pro)q(ceeds)g(bac)o(kw)o(ard)g(from)f Fj(p)q(os)p Fp(,)h(otherwise)h ! (forw)o(ard.)195 1519 y(Returns)j(the)g(absolute)g(index)h(of)f(the)g ! (history)g(elemen)o(t)h(where)f Fj(string)k Fp(w)o(as)21 ! b(found,)j(or)d(-1)195 1574 y(otherwise.)75 1684 y Fi(2.3.6)30 ! b(Managing)20 b(the)g(History)h(File)137 1780 y Fp(The)16 ! b(History)g(library)h(can)e(read)h(the)g(history)g(from)f(and)h(write)g ! (it)g(to)f(a)h(\014le.)22 b(This)17 b(section)f(do)q(cu-)75 ! 1835 y(men)o(ts)f(the)g(functions)h(for)f(managing)g(a)g(history)g ! (\014le.)1762 1949 y(F)l(unction)-1861 b Fh(int)20 b ! Fg(read)p 286 1949 V 20 w(history)i Ff(\()p Fo(const)15 ! b(char)f(*filename)p Ff(\))195 2003 y Fp(Add)h(the)g(con)o(ten)o(ts)f ! (of)h Fj(\014lename)j Fp(to)c(the)h(history)g(list,)g(a)g(line)h(at)f ! (a)f(time.)20 b(If)15 b Fj(\014lename)k Fp(is)c Fo(NULL)p ! Fp(,)195 2058 y(then)h(read)f(from)f(`)p Fo(~/.history)p ! Fp('.)k(Returns)d(0)f(if)i(successful,)g(or)f Fo(errno)f ! Fp(if)i(not.)1762 2172 y(F)l(unction)-1861 b Fh(int)20 ! b Fg(read)p 286 2172 V 20 w(history)p 481 2172 V 20 w(range)i ! Ff(\()p Fo(const)14 b(char)h(*filename,)f(int)h(from,)f(int)h(to)p ! Ff(\))195 2227 y Fp(Read)f(a)f(range)h(of)f(lines)j(from)d ! Fj(\014lename)p Fp(,)i(adding)g(them)f(to)f(the)h(history)g(list.)20 ! b(Start)13 b(reading)i(at)195 2282 y(line)g Fj(from)d ! Fp(and)h(end)h(at)f Fj(to)p Fp(.)18 b(If)c Fj(from)e ! Fp(is)i(zero,)f(start)f(at)g(the)h(b)q(eginning.)22 b(If)13 ! b Fj(to)i Fp(is)e(less)h(than)f Fj(from)p Fp(,)195 2337 ! y(then)i(read)g(un)o(til)i(the)e(end)g(of)g(the)g(\014le.)21 ! b(If)15 b Fj(\014lename)k Fp(is)d Fo(NULL)p Fp(,)e(then)h(read)g(from)f ! (`)p Fo(~/.history)p Fp('.)195 2392 y(Returns)h(0)g(if)g(successful,)h ! (or)f Fo(errno)g Fp(if)g(not.)1762 2506 y(F)l(unction)-1861 ! b Fh(int)20 b Fg(write)p 304 2506 V 22 w(history)i Ff(\()p ! Fo(const)15 b(char)f(*filename)p Ff(\))195 2560 y Fp(W)l(rite)k(the)f ! (curren)o(t)g(history)h(to)f Fj(\014lename)p Fp(,)h(o)o(v)o(erwriting)f ! Fj(\014lename)k Fp(if)d(necessary)l(.)27 b(If)18 b Fj(\014lename)195 ! 2615 y Fp(is)f Fo(NULL)p Fp(,)e(then)h(write)h(the)f(history)g(list)h ! (to)e(`)p Fo(~/.history)p Fp('.)21 b(Returns)16 b(0)f(on)h(success,)h ! (or)f Fo(errno)195 2670 y Fp(on)f(a)g(read)g(or)g(write)g(error.)p ! eop %%Page: 9 11 ! 9 10 bop 75 -58 a Fp(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (History)889 b(9)1762 149 y(F)l(unction)-1861 b Fh(int)20 ! b Fg(app)r(end)p 360 149 18 3 v 19 w(history)j Ff(\()p ! Fo(int)14 b(nelements,)g(const)h(char)f(*filename)p Ff(\))195 ! 204 y Fp(App)q(end)19 b(the)e(last)g Fj(nelemen)o(ts)k ! Fp(of)16 b(the)i(history)f(list)h(to)f Fj(\014lename)p ! Fp(.)27 b(If)18 b Fj(\014lename)j Fp(is)d Fo(NULL)p Fp(,)f(then)195 ! 259 y(app)q(end)f(to)f(`)p Fo(~/.history)p Fp('.)j(Returns)c(0)h(on)g ! (success,)h(or)e Fo(errno)h Fp(on)g(a)g(read)g(or)g(write)g(error.)1762 ! 404 y(F)l(unction)-1861 b Fh(int)20 b Fg(history)p 351 ! 404 V 20 w(truncate)p 582 404 V 21 w(\014le)k Ff(\()p ! Fo(const)14 b(char)h(*filename,)e(int)i(nlines)p Ff(\))195 ! 459 y Fp(T)l(runcate)k(the)h(history)f(\014le)h Fj(\014lename)p ! Fp(,)h(lea)o(ving)f(only)g(the)f(last)g Fj(nlines)k Fp(lines.)34 ! b(If)20 b Fj(\014lename)i Fp(is)195 513 y Fo(NULL)p Fp(,)14 ! b(then)i(`)p Fo(~/.history)p Fp(')d(is)j(truncated.)j(Returns)c(0)g(on) ! g(success,)h(or)e Fo(errno)h Fp(on)g(failure.)75 644 ! y Fi(2.3.7)30 b(History)20 b(Expansion)137 750 y Fp(These)c(functions)g ! (implemen)o(t)g(history)f(expansion.)1762 895 y(F)l(unction)-1861 ! b Fh(int)20 b Fg(history)p 351 895 V 20 w(expand)j Ff(\()p ! Fo(char)14 b(*string,)g(char)h(**output)p Ff(\))195 949 ! y Fp(Expand)j Fj(string)p Fp(,)f(placing)h(the)g(result)f(in)o(to)g ! Fj(output)p Fp(,)h(a)e(p)q(oin)o(ter)i(to)f(a)g(string)g(\(see)g ! (Section)h(1.1)195 1004 y([History)d(In)o(teraction],)f(page)h(1\).)20 ! b(Returns:)195 1098 y Fo(0)216 b Fp(If)19 b(no)g(expansions)g(to)q(ok)f ! (place)i(\(or,)e(if)i(the)e(only)i(c)o(hange)e(in)i(the)f(text)f(w)o ! (as)g(the)435 1152 y(remo)o(v)m(al)d(of)g(escap)q(e)h(c)o(haracters)e ! (preceding)i(the)f(history)g(expansion)h(c)o(haracter\);)195 ! 1241 y Fo(1)216 b Fp(if)16 b(expansions)g(did)g(tak)o(e)e(place;)195 ! 1330 y Fo(-1)192 b Fp(if)16 b(there)f(w)o(as)f(an)h(error)g(in)h ! (expansion;)195 1419 y Fo(2)216 b Fp(if)14 b(the)g(returned)g(line)i ! (should)f(b)q(e)f(displa)o(y)o(ed,)h(but)f(not)f(executed,)i(as)e(with) ! h(the)g Fo(:p)435 1474 y Fp(mo)q(di\014er)i(\(see)f(Section)h(1.1.3)e ! ([Mo)q(di\014ers],)h(page)g(2\).)195 1568 y(If)g(an)h(error)e(o)q ! (curred)i(in)g(expansion,)f(then)h Fj(output)g Fp(con)o(tains)f(a)g ! (descriptiv)o(e)i(error)d(message.)1762 1713 y(F)l(unction)-1861 ! b Fh(char)20 b(*)f Fg(get)p 324 1713 V 21 w(history)p ! 520 1713 V 20 w(ev)n(en)n(t)25 b Ff(\()p Fo(const)14 ! b(char)h(*string,)f(int)g(*cindex,)g(int)283 1767 y(qchar)p ! Ff(\))195 1822 y Fp(Returns)22 b(the)h(text)f(of)h(the)f(history)h(ev)o ! (en)o(t)g(b)q(eginning)h(at)f Fj(string)j Fo(+)d Fj(*cindex)p ! Fp(.)43 b Fj(*cindex)27 b Fp(is)195 1877 y(mo)q(di\014ed)16 ! b(to)e(p)q(oin)o(t)h(to)f(after)g(the)h(ev)o(en)o(t)f(sp)q(eci\014er.) ! 22 b(A)o(t)14 b(function)h(en)o(try)l(,)g Fj(cindex)k ! Fp(p)q(oin)o(ts)c(to)f(the)195 1932 y(index)19 b(in)o(to)f ! Fj(string)k Fp(where)c(the)g(history)g(ev)o(en)o(t)g(sp)q ! (eci\014cation)h(b)q(egins.)30 b Fj(qc)o(har)21 b Fp(is)d(a)g(c)o ! (haracter)195 1987 y(that)13 b(is)h(allo)o(w)o(ed)g(to)e(end)i(the)g ! (ev)o(en)o(t)f(sp)q(eci\014cation)j(in)e(addition)g(to)f(the)h ! (\\normal")f(terminating)195 2041 y(c)o(haracters.)1762 ! 2186 y(F)l(unction)-1861 b Fh(char)20 b(**)f Fg(history)p ! 448 2186 V 21 w(tok)n(enize)25 b Ff(\()p Fo(const)14 ! b(char)h(*string)p Ff(\))195 2241 y Fp(Return)g(an)g(arra)o(y)g(of)g ! (tok)o(ens)g(parsed)g(out)g(of)g Fj(string)p Fp(,)g(m)o(uc)o(h)h(as)f ! (the)g(shell)i(migh)o(t.)k(The)15 b(tok)o(ens)195 2296 ! y(are)h(split)h(on)e(the)h(c)o(haracters)g(in)g(the)g ! Fj(history)p 1007 2296 14 2 v 17 w(w)o(ord)p 1122 2296 ! V 15 w(delimiters)k Fp(v)m(ariable,)d(and)f(shell)i(quoting)195 ! 2351 y(con)o(v)o(en)o(tions)d(are)g(ob)q(ey)o(ed.)1762 ! 2496 y(F)l(unction)-1861 b Fh(char)20 b(*)f Fg(history)p ! 422 2496 18 3 v 21 w(arg)p 524 2496 V 19 w(extract)24 ! b Ff(\()p Fo(int)14 b(first,)h(int)g(last,)f(const)g(char)283 ! 2550 y(*string)p Ff(\))195 2605 y Fp(Extract)19 b(a)h(string)g(segmen)o ! (t)g(consisting)h(of)f(the)g Fj(\014rst)h Fp(through)f ! Fj(last)h Fp(argumen)o(ts)e(presen)o(t)h(in)195 2660 ! y Fj(string)p Fp(.)g(Argumen)o(ts)15 b(are)f(split)j(using)f ! Fo(history_tokenize)p Fp(.)p eop ! %%Page: 10 12 ! 10 11 bop 75 -58 a Fp(10)1324 b(GNU)15 b(History)g(Library)75 ! 149 y Fn(2.4)33 b(History)22 b(V)-6 b(ariables)137 251 ! y Fp(This)18 b(section)f(describ)q(es)i(the)e(externally-visible)k(v)m ! (ariables)d(exp)q(orted)f(b)o(y)g(the)g Fk(gnu)g Fp(History)g(Li-)75 ! 306 y(brary)l(.)1773 438 y(V)l(ariable)-1861 b Fh(int)20 ! b Fg(history)p 351 438 18 3 v 20 w(base)195 493 y Fp(The)15 b(logical)i(o\013set)d(of)h(the)g(\014rst)g(en)o(try)g(in)h(the)f ! (history)g(list.)1773 625 y(V)l(ariable)-1861 b Fh(int)20 ! b Fg(history)p 351 625 V 20 w(length)195 680 y Fp(The)15 b(n)o(um)o(b)q(er)h(of)f(en)o(tries)g(curren)o(tly)h(stored)f(in)h(the) ! f(history)g(list.)1773 812 y(V)l(ariable)-1861 b Fh(int)20 ! b Fg(history)p 351 812 V 20 w(max)p 478 812 V 20 w(en)n(tries)195 ! 867 y Fp(The)j(maxim)o(um)g(n)o(um)o(b)q(er)g(of)g(history)g(en)o ! (tries.)43 b(This)24 b(m)o(ust)e(b)q(e)i(c)o(hanged)f(using)h ! Fo(stifle_)195 922 y(history\(\))p Fp(.)1773 1054 y(V)l(ariable)-1861 ! b Fh(char)20 b Fg(history)p 377 1054 V 20 w(expansion)p ! 644 1054 V 21 w(c)n(har)195 1109 y Fp(The)e(c)o(haracter)f(that)g(in)o ! (tro)q(duces)h(a)f(history)h(ev)o(en)o(t.)27 b(The)18 ! b(default)g(is)g(`)p Fo(!)p Fp('.)26 b(Setting)18 b(this)g(to)f(0)195 ! 1164 y(inhibits)g(history)f(expansion.)1773 1296 y(V)l(ariable)-1861 ! b Fh(char)20 b Fg(history)p 377 1296 V 20 w(subst)p 529 ! 1296 V 20 w(c)n(har)195 1351 y Fp(The)h(c)o(haracter)e(that)h(in)o(v)o ! (ok)o(es)g(w)o(ord)g(substitution)h(if)g(found)f(at)g(the)h(start)e(of) ! h(a)g(line.)37 b(The)195 1406 y(default)16 b(is)f(`)p ! Fo(^)p Fp('.)1773 1538 y(V)l(ariable)-1861 b Fh(char)20 ! b Fg(history)p 377 1538 V 20 w(commen)n(t)p 627 1538 ! V 19 w(c)n(har)195 1593 y Fp(During)f(tok)o(enization,)h(if)f(this)h(c) ! o(haracter)e(is)h(seen)h(as)e(the)h(\014rst)g(c)o(haracter)f(of)g(a)h ! (w)o(ord,)g(then)195 1648 y(it)j(and)g(all)g(subsequen)o(t)h(c)o ! (haracters)d(up)j(to)e(a)g(newline)i(are)f(ignored,)h(suppressing)g ! (history)195 1702 y(expansion)16 b(for)f(the)g(remainder)h(of)f(the)g ! (line.)21 b(This)16 b(is)g(disabled)h(b)o(y)e(default.)1773 ! 1835 y(V)l(ariable)-1861 b Fh(char)20 b(*)f Fg(history)p ! 422 1835 V 21 w(w)n(ord)p 567 1835 V 20 w(delimiters)195 ! 1889 y Fp(The)e(c)o(haracters)g(that)f(separate)h(tok)o(ens)g(for)f ! Fo(\\)p Fp(fBhistory)p 1217 1889 14 2 v 17 w(tok)o(enize\(\))p ! Fo(\\)p Fp(fP)l(.)g(The)i(default)g(v)m(alue)195 1944 ! y(is)e Fo(")f(\\t\\n\(\)<>;&|")p Fp(.)1773 2077 y(V)l(ariable)-1861 ! b Fh(char)20 b(*)f Fg(history)p 422 2077 18 3 v 21 w(no)p ! 504 2077 V 20 w(expand)p 704 2077 V 20 w(c)n(hars)195 ! 2131 y Fp(The)c(list)h(of)e(c)o(haracters)g(whic)o(h)i(inhibit)h ! (history)e(expansion)h(if)f(found)h(immediately)g(follo)o(wing)195 ! 2186 y Fj(history)p 336 2186 14 2 v 16 w(expansion)p ! 547 2186 V 18 w(c)o(har)p Fp(.)j(The)d(default)f(is)h(space,)f(tab,)g ! (newline,)h(carriage)f(return,)g(and)h(`)p Fo(=)p Fp('.)1773 ! 2318 y(V)l(ariable)-1861 b Fh(char)20 b(*)f Fg(history)p ! 422 2318 18 3 v 21 w(searc)n(h)p 599 2318 V 20 w(delimiter)p ! 843 2318 V 23 w(c)n(hars)195 2373 y Fp(The)13 b(list)h(of)f(additional) ! h(c)o(haracters)e(whic)o(h)i(can)g(delimit)g(a)f(history)g(searc)o(h)g ! (string,)g(in)h(addition)195 2428 y(to)h(space,)g(T)l(AB,)g(`)p ! Fo(:)p Fp(')f(and)h(`)p Fo(?)p Fp(')g(in)h(the)f(case)g(of)g(a)g ! (substring)g(searc)o(h.)20 b(The)c(default)f(is)h(empt)o(y)l(.)1773 ! 2560 y(V)l(ariable)-1861 b Fh(int)20 b Fg(history)p 351 ! 2560 V 20 w(quotes)p 533 2560 V 21 w(inhibit)p 717 2560 ! V 23 w(expansion)195 2615 y Fp(If)15 b(non-zero,)f(single-quoted)j(w)o ! (ords)c(are)i(not)f(scanned)h(for)f(the)h(history)g(expansion)g(c)o ! (haracter.)195 2670 y(The)g(default)h(v)m(alue)h(is)e(0.)p ! eop %%Page: 11 13 ! 11 12 bop 75 -58 a Fp(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (History)867 b(11)1773 149 y(V)l(ariable)-1861 b Fh(rl_linebuf_func_t) ! 22 b(*)d Fg(history)p 762 149 18 3 v 21 w(inhibit)p 946 ! 149 V 23 w(expansion)p 1216 149 V 20 w(function)195 204 ! y Fp(This)e(should)h(b)q(e)f(set)g(to)f(the)g(address)h(of)f(a)h ! (function)g(that)f(tak)o(es)g(t)o(w)o(o)f(argumen)o(ts:)22 ! b(a)17 b Fo(char)d(*)195 259 y Fp(\()p Fj(string)t Fp(\))e(and)i(an)f ! Fo(int)g Fp(index)i(in)o(to)e(that)f(string)i(\()p Fj(i)r ! Fp(\).)19 b(It)14 b(should)g(return)f(a)g(non-zero)h(v)m(alue)g(if)g ! (the)195 314 y(history)h(expansion)g(starting)f(at)g ! Fj(string[i])i Fp(should)g(not)e(b)q(e)h(p)q(erformed;)g(zero)f(if)h ! (the)g(expansion)195 369 y(should)i(b)q(e)g(done.)22 ! b(It)16 b(is)h(in)o(tended)g(for)e(use)i(b)o(y)f(applications)h(lik)o ! (e)g(Bash)f(that)g(use)g(the)g(history)195 423 y(expansion)g(c)o ! (haracter)f(for)f(additional)j(purp)q(oses.)j(By)c(default,)f(this)h(v) ! m(ariable)g(is)g(set)f(to)f Fo(NULL)p Fp(.)75 543 y Fn(2.5)33 ! b(History)22 b(Programming)h(Example)137 637 y Fp(The)16 ! b(follo)o(wing)g(program)e(demonstrates)g(simple)j(use)e(of)g(the)g ! Fk(gnu)g Fp(History)g(Library)l(.)195 698 y Fo(#include)23 ! b()195 750 y(#include)g()195 ! 854 y(main)g(\(argc,)g(argv\))314 906 y(int)h(argc;)314 ! 958 y(char)g(**argv;)195 1010 y({)243 1061 y(char)f(line[1024],)f(*t;) ! 243 1113 y(int)h(len,)g(done)h(=)g(0;)243 1217 y(line[0])f(=)g(0;)243 ! 1321 y(using_history)f(\(\);)243 1373 y(while)h(\(!done\))290 ! 1425 y({)338 1477 y(printf)g(\("history$)g("\);)338 1528 ! y(fflush)g(\(stdout\);)338 1580 y(t)h(=)g(fgets)f(\(line,)g(sizeof)g ! (\(line\))g(-)h(1,)f(stdin\);)338 1632 y(if)h(\(t)f(&&)h(*t\))386 ! 1684 y({)434 1736 y(len)f(=)h(strlen)f(\(t\);)434 1788 ! y(if)g(\(t[len)g(-)h(1])g(==)f('\\n'\))481 1840 y(t[len)h(-)f(1])h(=)g ! ('\\0';)386 1892 y(})338 1995 y(if)g(\(!t\))386 2047 ! y(strcpy)f(\(line,)g("quit"\);)338 2151 y(if)h(\(line[0]\))386 ! 2203 y({)434 2255 y(char)f(*expansion;)434 2307 y(int)g(result;)434 ! 2411 y(result)g(=)g(history_expand)f(\(line,)h(&expansion\);)434 ! 2462 y(if)g(\(result\))481 2514 y(fprintf)g(\(stderr,)g("\045s\\n",)g ! (expansion\);)434 2618 y(if)g(\(result)g(<)h(0)g(||)f(result)g(==)h ! (2\))481 2670 y({)p eop %%Page: 12 14 ! 12 13 bop 75 -58 a Fp(12)1324 b(GNU)15 b(History)g(Library)529 ! 149 y Fo(free)23 b(\(expansion\);)529 201 y(continue;)481 ! 253 y(})434 357 y(add_history)f(\(expansion\);)434 409 ! y(strncpy)h(\(line,)g(expansion,)f(sizeof)h(\(line\))g(-)h(1\);)434 ! 461 y(free)f(\(expansion\);)386 513 y(})338 616 y(if)h(\(strcmp)f ! (\(line,)g("quit"\))g(==)g(0\))386 668 y(done)g(=)h(1;)338 ! 720 y(else)f(if)h(\(strcmp)f(\(line,)g("save"\))g(==)h(0\))386 ! 772 y(write_history)e(\("history_file"\);)338 824 y(else)h(if)h ! (\(strcmp)f(\(line,)g("read"\))g(==)h(0\))386 876 y(read_history)e ! (\("history_file"\);)338 928 y(else)h(if)h(\(strcmp)f(\(line,)g ! ("list"\))g(==)h(0\))386 980 y({)434 1032 y(register)e(HIST_ENTRY)h ! (**the_list;)434 1083 y(register)f(int)i(i;)434 1187 ! y(the_list)e(=)i(history_list)e(\(\);)434 1239 y(if)h(\(the_list\))481 ! 1291 y(for)h(\(i)f(=)h(0;)g(the_list[i];)e(i++\))529 ! 1343 y(printf)h(\("\045d:)g(\045s\\n",)g(i)h(+)g(history_base,)e ! (the_list[i]->line\);)386 1395 y(})338 1447 y(else)h(if)h(\(strncmp)f ! (\(line,)g("delete",)g(6\))g(==)h(0\))386 1499 y({)434 ! 1550 y(int)f(which;)434 1602 y(if)g(\(\(sscanf)g(\(line)g(+)h(6,)f ! ("\045d",)h(&which\)\))e(==)i(1\))481 1654 y({)529 1706 ! y(HIST_ENTRY)f(*entry)g(=)g(remove_history)f(\(which\);)529 ! 1758 y(if)i(\(!entry\))577 1810 y(fprintf)f(\(stderr,)f("No)i(such)f ! (entry)g(\045d\\n",)g(which\);)529 1862 y(else)577 1914 ! y({)625 1966 y(free)g(\(entry->line\);)625 2017 y(free)g(\(entry\);)577 ! 2069 y(})481 2121 y(})434 2173 y(else)481 2225 y({)529 ! 2277 y(fprintf)g(\(stderr,)g("non-numeric)f(arg)h(given)h(to)f ! (`delete'\\n"\);)481 2329 y(})386 2381 y(})290 2433 y(})195 ! 2484 y(})p eop %%Page: 13 15 ! 13 14 bop 75 -58 a Fp(App)q(endix)17 b(A:)e(Concept)g(Index)1196 ! b(13)75 149 y Fl(App)r(endix)25 b(A)41 b(Concept)27 b(Index)75 ! 321 y Fn(A)75 383 y Fe(anc)o(hored)14 b(searc)o(h)s Fd(.)8 ! b(.)e(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)16 ! b Fe(8)75 507 y Fn(E)75 568 y Fe(ev)o(en)o(t)d(designators)g ! Fd(.)6 b(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)23 b ! Fe(1)1012 321 y Fn(H)1012 431 y Fe(history)15 b(ev)o(en)o(ts)d ! Fd(.)6 b(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)24 ! b Fe(1)1012 500 y(history)15 b(expansion)8 b Fd(.)g(.)e(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)21 b Fe(1)1012 568 y(History)14 b(Searc)o(hing)6 ! b Fd(.)j(.)d(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)19 b ! Fe(8)p eop %%Page: 14 16 ! 14 15 bop 75 -58 a Fp(14)1324 b(GNU)15 b(History)g(Library)p eop %%Page: 15 17 ! 15 16 bop 75 -58 a Fp(App)q(endix)17 b(B:)e(F)l(unction)h(and)g(V)l ! (ariable)g(Index)919 b(15)75 149 y Fl(App)r(endix)25 b(B)41 b(F)-7 b(unction)26 b(and)h(V)-7 b(ariable)26 ! b(Index)75 321 y Fn(A)75 382 y Fc(add_histor)o(y)8 b ! Fd(.)e(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)23 ! b Fe(6)75 428 y Fc(append_his)o(to)o(ry)8 b Fd(.)s(.)f(.)f(.)g(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)21 b Fe(9)75 557 y Fn(C)75 618 ! y Fc(clear_hist)o(or)o(y)6 b Fd(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)22 b Fe(6)75 664 y Fc(current_hi)o(st)o(ory)7 ! b Fd(.)s(.)f(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)20 b ! Fe(7)75 793 y Fn(G)75 854 y Fc(get_histor)o(y_)o(eve)o(nt)5 ! b Fd(.)t(.)h(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)19 b Fe(9)75 ! 984 y Fn(H)75 1044 y Fc(history_ar)o(g_)o(ext)o(ra)o(ct)5 ! b Fd(.)s(.)h(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)18 b Fe(9)75 1090 y Fc(history_ba)o(se) ! 6 b Fd(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)22 ! b Fe(10)75 1136 y Fc(history_co)o(mm)o(ent)o(_c)o(har)s ! Fd(.)s(.)6 b(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)16 b Fe(10)75 1182 y Fc(history_ex)o(pa)o(nd)8 ! b Fd(.)s(.)f(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)21 ! b Fe(9)75 1227 y Fc(history_ex)o(pa)o(nsi)o(on)o(_ch)o(ar)8 ! b Fd(.)e(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)24 b Fe(10)75 1273 y Fc(history_ge)o(t)8 ! b Fd(.)e(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)23 ! b Fe(7)75 1319 y Fc(history_ge)o(t_)o(his)o(to)o(ry_)o(sta)o(te)6 ! b Fd(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)22 b Fe(6)75 1364 y Fc(history_in)o(hi)o(bit)o(_e)o(xpa)o(nsi)o(on) ! o(_fu)o(nc)o(tio)o(n)9 b Fd(.)d(.)g(.)g(.)g(.)g(.)h(.)24 ! b Fe(11)75 1410 y Fc(history_is)o(_s)o(tif)o(le)o(d)6 ! b Fd(.)s(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)18 b Fe(7)75 1456 ! y Fc(history_le)o(ng)o(th)8 b Fd(.)s(.)e(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)21 b Fe(10)75 1501 y Fc(history_li)o(st)6 b Fd(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)23 b Fe(7)75 ! 1547 y Fc(history_ma)o(x_)o(ent)o(ri)o(es)t Fd(.)s(.)6 ! b(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)g(.)h(.)f(.)17 b Fe(10)75 1593 y Fc(history_no)o(_e)o(xpa)o(nd)o ! (_ch)o(ars)7 b Fd(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)h(.)23 b Fe(10)75 1638 y Fc(history_qu)o(ot)o(es_)o ! (in)o(hib)o(it_)o(ex)o(pan)o(si)o(on)t Fd(.)s(.)6 b(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)17 b Fe(10)75 1684 y Fc(history_se)o(ar)o(ch)8 ! b Fd(.)s(.)f(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)21 ! b Fe(8)75 1730 y Fc(history_se)o(ar)o(ch_)o(de)o(lim)o(ite)o(r_)o(cha)o ! (rs)5 b Fd(.)s(.)h(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)18 ! b Fe(10)75 1776 y Fc(history_se)o(ar)o(ch_)o(po)o(s)6 ! b Fd(.)s(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)18 b Fe(8)75 1821 ! y Fc(history_se)o(ar)o(ch_)o(pr)o(efi)o(x)s Fd(.)t(.)6 ! b(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)16 b Fe(8)75 1867 y Fc(history_se)o(t_)o(his)o(to)o(ry_) ! o(sta)o(te)6 b Fd(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)22 b Fe(6)75 1913 y Fc(history_se)o(t_)o(pos)7 ! b Fd(.)s(.)f(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)20 b ! Fe(7)1012 321 y Fc(history_sub)o(st)o(_ch)o(ar)t Fd(.)t(.)6 ! b(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)g(.)19 b Fe(10)1012 368 y Fc(history_tok)o(en)o(ize) ! 6 b Fd(.)t(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)20 b Fe(9)1012 ! 414 y Fc(history_tot)o(al)o(_by)o(te)o(s)5 b Fd(.)s(.)h(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)18 b Fe(7)1012 460 y Fc(history_tru)o(nc)o(ate)o(_f)o(ile)s ! Fd(.)s(.)6 b(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)17 b Fe(9)1012 507 y Fc(history_wor)o(d_)o(del) ! o(im)o(ite)o(rs)7 b Fd(.)f(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)24 b Fe(10)1012 640 y Fn(N)1012 ! 702 y Fc(next_histor)o(y)7 b Fd(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)g(.)h(.)f(.)23 b Fe(7)1012 836 y Fn(P)1012 898 y ! Fc(previous_hi)o(st)o(ory)6 b Fd(.)t(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f ! (.)20 b Fe(7)1012 1031 y Fn(R)1012 1094 y Fc(read_histor)o(y)7 ! b Fd(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)23 ! b Fe(8)1012 1140 y Fc(read_histor)o(y_)o(ran)o(ge)5 b ! Fd(.)s(.)h(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)19 b Fe(8)1012 1186 ! y Fc(remove_hist)o(or)o(y)9 b Fd(.)s(.)d(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)22 b Fe(6)1012 1233 y Fc(replace_his)o(to)o(ry_)o(en)o(try)s ! Fd(.)s(.)6 b(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)17 b Fe(6)1012 1366 y Fn(S)1012 ! 1429 y Fc(stifle_hist)o(or)o(y)9 b Fd(.)s(.)d(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)22 b Fe(7)1012 1562 y Fn(U)1012 1624 ! y Fc(unstifle_hi)o(st)o(ory)6 b Fd(.)t(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)20 b Fe(7)1012 1671 y Fc(using_histo)o(ry)6 b Fd(.)g(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)22 b Fe(6)1012 1804 ! y Fn(W)1012 1866 y Fc(where_histo)o(ry)6 b Fd(.)g(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)h(.)22 b Fe(7)1012 1913 y Fc(write_histo)o(ry)6 ! b Fd(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)22 b Fe(8)p eop %%Page: 16 18 ! 16 17 bop 75 -58 a Fp(16)1324 b(GNU)15 b(History)g(Library)p eop %%Page: -1 19 ! -1 18 bop 1862 -58 a Fp(i)75 149 y Fl(T)-7 b(able)27 ! b(of)f(Con)n(ten)n(ts)75 320 y Fn(1)67 b(Using)22 b(History)h(In)n (teractiv)n(ely)9 b Fb(.)k(.)d(.)h(.)f(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)h(.)31 b Fn(1)224 389 y Fp(1.1)45 b(History)15 b(Expansion)5 b Fa(.)j(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) ! f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)19 b Fp(1)374 444 y(1.1.1)44 b(Ev)o(en)o(t)14 b(Designators)e Fa(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.) ! f(.)h(.)f(.)h(.)26 b Fp(1)374 499 y(1.1.2)44 b(W)l(ord)15 b(Designators)5 b Fa(.)h(.)i(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h ! (.)19 b Fp(2)374 553 y(1.1.3)44 b(Mo)q(di\014ers)t Fa(.)8 b(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) ! f(.)h(.)f(.)19 b Fp(2)75 675 y Fn(2)67 b(Programming)23 b(with)g(GNU)f(History)16 b Fb(.)10 b(.)g(.)g(.)h(.)f(.)g(.)g(.)h(.)f ! (.)g(.)38 b Fn(5)224 743 y Fp(2.1)45 b(In)o(tro)q(duction)16 b(to)f(History)10 b Fa(.)d(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) ! f(.)h(.)f(.)h(.)24 b Fp(5)224 798 y(2.2)45 b(History)15 b(Storage)c Fa(.)d(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) ! g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)26 b Fp(5)224 853 y(2.3)45 b(History)15 b(F)l(unctions)d Fa(.)c(.)f(.)h(.)f(.)h(.)f(.)h (.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)26 ! b Fp(6)374 907 y(2.3.1)44 b(Initializing)18 b(History)d(and)h(State)e (Managemen)o(t)g Fa(.)7 b(.)h(.)g(.)f(.)h(.)f(.)29 b ! Fp(6)374 962 y(2.3.2)44 b(History)15 b(List)h(Managemen)o(t)d Fa(.)7 b(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)29 b Fp(6)374 1017 y(2.3.3)44 b(Information)15 b(Ab)q(out)g(the)h(History)f(List)c Fa(.)d(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)26 ! b Fp(7)374 1072 y(2.3.4)44 b(Mo)o(ving)15 b(Around)g(the)g(History)g (List)c Fa(.)d(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)25 b Fp(7)374 1127 y(2.3.5)44 b(Searc)o(hing)16 b(the)f(History)g(List)7 b Fa(.)h(.)g(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)22 ! b Fp(8)374 1181 y(2.3.6)44 b(Managing)15 b(the)g(History)g(File)6 b Fa(.)i(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) ! f(.)h(.)f(.)h(.)f(.)h(.)20 b Fp(8)374 1236 y(2.3.7)44 b(History)15 b(Expansion)9 b Fa(.)f(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)24 b Fp(9)224 1291 y(2.4)45 b(History)15 b(V)l(ariables)6 ! b Fa(.)i(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) ! f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)f(.)21 b Fp(10)224 1346 y(2.5)45 b(History)15 b(Programming)f(Example)7 b Fa(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)22 ! b Fp(11)75 1467 y Fn(App)r(endix)i(A)67 b(Concept)22 b(Index)17 b Fb(.)10 b(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)h(.)f(.)g(.)38 b Fn(13)75 1602 y(App)r(endix)24 b(B)67 b(F)-6 b(unction)25 b(and)e(V)-6 b(ariable)24 b(Index)16 ! b Fb(.)10 b(.)g(.)g(.)38 b Fn(15)p eop %%Page: -2 20 ! -2 19 bop 75 -58 a Fp(ii)1346 b(GNU)15 b(History)g(Library)p eop %%Trailer diff -Nrc2 readline-4.1/doc/history_3.ps readline-4.2/doc/history_3.ps *** readline-4.1/doc/history_3.ps Wed Dec 31 19:00:00 1969 --- readline-4.2/doc/history_3.ps Mon Apr 16 10:53:07 2001 *************** *** 0 **** --- 1,798 ---- + %!PS-Adobe-3.0 + %%Creator: groff version 1.16.1 + %%CreationDate: Mon Apr 16 10:53:07 2001 + %%DocumentNeededResources: font Times-Roman + %%+ font Times-Bold + %%+ font Times-Italic + %%DocumentSuppliedResources: procset grops 1.16 1 + %%Pages: 7 + %%PageOrder: Ascend + %%Orientation: Portrait + %%EndComments + %%BeginProlog + %%BeginResource: procset grops 1.16 1 + /setpacking where{ + pop + currentpacking + true setpacking + }if + /grops 120 dict dup begin + /SC 32 def + /A/show load def + /B{0 SC 3 -1 roll widthshow}bind def + /C{0 exch ashow}bind def + /D{0 exch 0 SC 5 2 roll awidthshow}bind def + /E{0 rmoveto show}bind def + /F{0 rmoveto 0 SC 3 -1 roll widthshow}bind def + /G{0 rmoveto 0 exch ashow}bind def + /H{0 rmoveto 0 exch 0 SC 5 2 roll awidthshow}bind def + /I{0 exch rmoveto show}bind def + /J{0 exch rmoveto 0 SC 3 -1 roll widthshow}bind def + /K{0 exch rmoveto 0 exch ashow}bind def + /L{0 exch rmoveto 0 exch 0 SC 5 2 roll awidthshow}bind def + /M{rmoveto show}bind def + /N{rmoveto 0 SC 3 -1 roll widthshow}bind def + /O{rmoveto 0 exch ashow}bind def + /P{rmoveto 0 exch 0 SC 5 2 roll awidthshow}bind def + /Q{moveto show}bind def + /R{moveto 0 SC 3 -1 roll widthshow}bind def + /S{moveto 0 exch ashow}bind def + /T{moveto 0 exch 0 SC 5 2 roll awidthshow}bind def + /SF{ + findfont exch + [exch dup 0 exch 0 exch neg 0 0]makefont + dup setfont + [exch/setfont cvx]cvx bind def + }bind def + /MF{ + findfont + [5 2 roll + 0 3 1 roll + neg 0 0]makefont + dup setfont + [exch/setfont cvx]cvx bind def + }bind def + /level0 0 def + /RES 0 def + /PL 0 def + /LS 0 def + /MANUAL{ + statusdict begin/manualfeed true store end + }bind def + /PLG{ + gsave newpath clippath pathbbox grestore + exch pop add exch pop + }bind def + /BP{ + /level0 save def + 1 setlinecap + 1 setlinejoin + 72 RES div dup scale + LS{ + 90 rotate + }{ + 0 PL translate + }ifelse + 1 -1 scale + }bind def + /EP{ + level0 restore + showpage + }bind def + /DA{ + newpath arcn stroke + }bind def + /SN{ + transform + .25 sub exch .25 sub exch + round .25 add exch round .25 add exch + itransform + }bind def + /DL{ + SN + moveto + SN + lineto stroke + }bind def + /DC{ + newpath 0 360 arc closepath + }bind def + /TM matrix def + /DE{ + TM currentmatrix pop + translate scale newpath 0 0 .5 0 360 arc closepath + TM setmatrix + }bind def + /RC/rcurveto load def + /RL/rlineto load def + /ST/stroke load def + /MT/moveto load def + /CL/closepath load def + /FL{ + currentgray exch setgray fill setgray + }bind def + /BL/fill load def + /LW/setlinewidth load def + /RE{ + findfont + dup maxlength 1 index/FontName known not{1 add}if dict begin + { + 1 index/FID ne{def}{pop pop}ifelse + }forall + /Encoding exch def + dup/FontName exch def + currentdict end definefont pop + }bind def + /DEFS 0 def + /EBEGIN{ + moveto + DEFS begin + }bind def + /EEND/end load def + /CNT 0 def + /level1 0 def + /PBEGIN{ + /level1 save def + translate + div 3 1 roll div exch scale + neg exch neg exch translate + 0 setgray + 0 setlinecap + 1 setlinewidth + 0 setlinejoin + 10 setmiterlimit + []0 setdash + /setstrokeadjust where{ + pop + false setstrokeadjust + }if + /setoverprint where{ + pop + false setoverprint + }if + newpath + /CNT countdictstack def + userdict begin + /showpage{}def + }bind def + /PEND{ + clear + countdictstack CNT sub{end}repeat + level1 restore + }bind def + end def + /setpacking where{ + pop + setpacking + }if + %%EndResource + %%IncludeResource: font Times-Roman + %%IncludeResource: font Times-Bold + %%IncludeResource: font Times-Italic + grops begin/DEFS 1 dict def DEFS begin/u{.001 mul}bind def end/RES 72 + def/PL 792 def/LS false def/ENC0[/asciicircum/asciitilde/Scaron/Zcaron + /scaron/zcaron/Ydieresis/trademark/quotesingle/.notdef/.notdef/.notdef + /.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef + /.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef + /.notdef/.notdef/space/exclam/quotedbl/numbersign/dollar/percent + /ampersand/quoteright/parenleft/parenright/asterisk/plus/comma/hyphen + /period/slash/zero/one/two/three/four/five/six/seven/eight/nine/colon + /semicolon/less/equal/greater/question/at/A/B/C/D/E/F/G/H/I/J/K/L/M/N/O + /P/Q/R/S/T/U/V/W/X/Y/Z/bracketleft/backslash/bracketright/circumflex + /underscore/quoteleft/a/b/c/d/e/f/g/h/i/j/k/l/m/n/o/p/q/r/s/t/u/v/w/x/y + /z/braceleft/bar/braceright/tilde/.notdef/quotesinglbase/guillemotleft + /guillemotright/bullet/florin/fraction/perthousand/dagger/daggerdbl + /endash/emdash/ff/fi/fl/ffi/ffl/dotlessi/dotlessj/grave/hungarumlaut + /dotaccent/breve/caron/ring/ogonek/quotedblleft/quotedblright/oe/lslash + /quotedblbase/OE/Lslash/.notdef/exclamdown/cent/sterling/currency/yen + /brokenbar/section/dieresis/copyright/ordfeminine/guilsinglleft + /logicalnot/minus/registered/macron/degree/plusminus/twosuperior + /threesuperior/acute/mu/paragraph/periodcentered/cedilla/onesuperior + /ordmasculine/guilsinglright/onequarter/onehalf/threequarters + /questiondown/Agrave/Aacute/Acircumflex/Atilde/Adieresis/Aring/AE + /Ccedilla/Egrave/Eacute/Ecircumflex/Edieresis/Igrave/Iacute/Icircumflex + /Idieresis/Eth/Ntilde/Ograve/Oacute/Ocircumflex/Otilde/Odieresis + /multiply/Oslash/Ugrave/Uacute/Ucircumflex/Udieresis/Yacute/Thorn + /germandbls/agrave/aacute/acircumflex/atilde/adieresis/aring/ae/ccedilla + /egrave/eacute/ecircumflex/edieresis/igrave/iacute/icircumflex/idieresis + /eth/ntilde/ograve/oacute/ocircumflex/otilde/odieresis/divide/oslash + /ugrave/uacute/ucircumflex/udieresis/yacute/thorn/ydieresis]def + /Times-Italic@0 ENC0/Times-Italic RE/Times-Bold@0 ENC0/Times-Bold RE + /Times-Roman@0 ENC0/Times-Roman RE + %%EndProlog + %%Page: 1 1 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF(HIST)72 48 Q(OR)-.18 E 357.18(Y\(3\) HIST)-.65 F + (OR)-.18 E(Y\(3\))-.65 E/F1 10.95/Times-Bold@0 SF -.219(NA)72 84 S(ME) + .219 E F0(history \255 GNU History Library)108 96 Q F1(COPYRIGHT)72 + 112.8 Q F0(The GNU History Library is Cop)108 124.8 Q + (yright \251 1989-2001 by the Free Softw)-.1 E(are F)-.1 E + (oundation, Inc.)-.15 E F1(DESCRIPTION)72 141.6 Q F0(Man)108 153.6 Q + 2.81(yp)-.15 G .31(rograms read input from the user a line at a time.) + -2.81 F .309(The GNU History library is able to k)5.309 F .309 + (eep track of)-.1 F .024(those lines, associate arbitrary data with eac\ + h line, and utilize information from pre)108 165.6 R .024 + (vious lines in composing)-.25 F(ne)108 177.6 Q 2.5(wo)-.25 G(nes.)-2.5 + E F1(HIST)72 199.2 Q(OR)-.197 E 2.738(YE)-.383 G(XP)-2.738 E(ANSION)-.81 + E F0 .823(The history library supports a history e)108 211.2 R .822 + (xpansion feature that is identical to the history e)-.15 F .822 + (xpansion in)-.15 F/F2 10/Times-Bold@0 SF(bash.)3.322 E F0 + (This section describes what syntax features are a)108 223.2 Q -.25(va) + -.2 G(ilable.).25 E 1.305(History e)108 240 R 1.305 + (xpansions introduce w)-.15 F 1.306(ords from the history list into the\ + input stream, making it easy to repeat)-.1 F .21 + (commands, insert the ar)108 252 R .21(guments to a pre)-.18 F .209 + (vious command into the current input line, or \214x errors in pre)-.25 + F(vious)-.25 E(commands quickly)108 264 Q(.)-.65 E 1.296(History e)108 + 280.8 R 1.297(xpansion is usually performed immediately after a complet\ + e line is read.)-.15 F 1.297(It tak)6.297 F 1.297(es place in tw)-.1 F + (o)-.1 E 2.855(parts. The)108 292.8 R .354(\214rst is to determine whic\ + h line from the history list to use during substitution.)2.855 F .354 + (The second is to)5.354 F .116 + (select portions of that line for inclusion into the current one.)108 + 304.8 R .117(The line selected from the history is the)5.116 F/F3 10 + /Times-Italic@0 SF -.15(ev)2.617 G(ent).15 E F0(,)A .846 + (and the portions of that line that are acted upon are)108 316.8 R F3 + (wor)3.346 E(ds)-.37 E F0 5.846(.V)C(arious)-6.956 E F3(modi\214er)3.346 + E(s)-.1 E F0 .846(are a)3.346 F -.25(va)-.2 G .845(ilable to manipulate) + .25 F .304(the selected w)108 328.8 R 2.804(ords. The)-.1 F .304 + (line is brok)2.804 F .304(en into w)-.1 F .304(ords in the same f)-.1 F + .304(ashion as)-.1 F F2(bash)2.804 E F0 .305 + (does when reading input, so)2.804 F .539(that se)108 340.8 R -.15(ve) + -.25 G .539(ral w).15 F .539(ords that w)-.1 F .539 + (ould otherwise be separated are considered one w)-.1 F .538 + (ord when surrounded by quotes)-.1 F .307(\(see the description of)108 + 352.8 R F2(history_tok)2.807 E(enize\(\))-.1 E F0(belo)2.807 E 2.807 + (w\). History)-.25 F -.15(ex)2.807 G .307 + (pansions are introduced by the appearance of).15 F .52(the history e) + 108 364.8 R .52(xpansion character)-.15 F 3.02(,w)-.4 G .52(hich is) + -3.02 F F2(!)3.853 E F0 .52(by def)3.853 F 3.02(ault. Only)-.1 F .52 + (backslash \()3.02 F F2(\\).833 E F0 3.02(\)a).833 G .52 + (nd single quotes can quote the)-3.02 F(history e)108 376.8 Q + (xpansion character)-.15 E(.)-.55 E F2(Ev)87 393.6 Q(ent Designators)-.1 + E F0(An e)108 405.6 Q -.15(ve)-.25 G(nt designator is a reference to a \ + command line entry in the history list.).15 E F2(!)108 422.4 Q F0 + (Start a history substitution, e)32.67 E(xcept when follo)-.15 E + (wed by a)-.25 E F2(blank)2.5 E F0 2.5(,n)C -.25(ew)-2.5 G + (line, = or \(.).25 E F2(!)108 434.4 Q F3(n)A F0(Refer to command line) + 27.67 E F3(n)2.5 E F0(.).24 E F2<21ad>108 446.4 Q F3(n)A F0 + (Refer to the current command line minus)21.97 E F3(n)2.5 E F0(.).24 E + F2(!!)108 458.4 Q F0(Refer to the pre)29.34 E(vious command.)-.25 E + (This is a synon)5 E(ym for `!\2551'.)-.15 E F2(!)108 470.4 Q F3(string) + A F0(Refer to the most recent command starting with)9.33 E F3(string)2.5 + E F0(.).22 E F2(!?)108 482.4 Q F3(string)A F2([?])A F0 1.057 + (Refer to the most recent command containing)144 494.4 R F3(string)3.557 + E F0 6.057(.T).22 G 1.057(he trailing)-6.057 F F2(?)3.557 E F0 1.057 + (may be omitted if)3.557 F F3(string)3.557 E F0(is)3.557 E(follo)144 + 506.4 Q(wed immediately by a ne)-.25 E(wline.)-.25 E/F4 12/Times-Bold@0 + SF(^)108 523.4 Q F3(string1)-5 I F4(^)5 I F3(string2)-5 I F4(^)5 I F0 + 2.66(Quick substitution.)144 530.4 R 2.66 + (Repeat the last command, replacing)7.66 F F3(string1)5.16 E F0(with) + 5.16 E F3(string2)5.16 E F0 7.66(.E).02 G(qui)-7.66 E -.25(va)-.25 G + 2.66(lent to).25 F -.74(``)144 542.4 S(!!:s/).74 E F3(string1)A F0(/)A + F3(string2)A F0(/')A 2.5('\()-.74 G(see)-2.5 E F2(Modi\214ers)2.5 E F0 + (belo)2.5 E(w\).)-.25 E F2(!#)108 554.4 Q F0 + (The entire command line typed so f)27.67 E(ar)-.1 E(.)-.55 E F2 -.75 + (Wo)87 571.2 S(rd Designators).75 E F0 -.8(Wo)108 583.2 S 1.313 + (rd designators are used to select desired w).8 F 1.314(ords from the e) + -.1 F -.15(ve)-.25 G 3.814(nt. A).15 F F2(:)3.814 E F0 1.314 + (separates the e)3.814 F -.15(ve)-.25 G 1.314(nt speci\214cation).15 F + .53(from the w)108 595.2 R .529(ord designator)-.1 F 5.529(.I)-.55 G + 3.029(tm)-5.529 G .529(ay be omitted if the w)-3.029 F .529 + (ord designator be)-.1 F .529(gins with a)-.15 F F2(^)3.029 E F0(,)A F2 + ($)3.029 E F0(,)A F2(*)3.029 E F0(,)A F23.029 E F0 3.029(,o)C(r) + -3.029 E F2(%)3.029 E F0 5.529(.W)C(ords)-6.329 E 1.3 + (are numbered from the be)108 607.2 R 1.3 + (ginning of the line, with the \214rst w)-.15 F 1.301 + (ord being denoted by 0 \(zero\).)-.1 F -.8(Wo)6.301 G 1.301(rds are).8 + F(inserted into the current line separated by single spaces.)108 619.2 Q + F2 2.5(0\()108 636 S(zer)-2.5 E(o\))-.18 E F0(The zeroth w)144 648 Q 2.5 + (ord. F)-.1 F(or the shell, this is the command w)-.15 E(ord.)-.1 E F3 + (n)108 660 Q F0(The)31 E F3(n)2.5 E F0(th w)A(ord.)-.1 E F2(^)108 672 Q + F0(The \214rst ar)32.67 E 2.5(gument. That)-.18 F(is, w)2.5 E(ord 1.)-.1 + E F2($)108 684 Q F0(The last ar)31 E(gument.)-.18 E F2(%)108 696 Q F0 + (The w)26 E(ord matched by the most recent `?)-.1 E F3(string)A F0 + (?' search.)A F3(x)108 708 Q F2A F3(y)A F0 2.5(Ar)21.42 G(ange of w) + -2.5 E(ords; `\255)-.1 E F3(y)A F0 2.5('a)C(bbre)-2.5 E(viates `0\255) + -.25 E F3(y)A F0('.)A(GNU History 4.2)72 768 Q(2001 Mar 6)141.51 E(1) + 205.67 E EP + %%Page: 2 2 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF(HIST)72 48 Q(OR)-.18 E 357.18(Y\(3\) HIST)-.65 F + (OR)-.18 E(Y\(3\))-.65 E/F1 10/Times-Bold@0 SF(*)108 84 Q F0 .316 + (All of the w)31 F .316(ords b)-.1 F .316(ut the zeroth.)-.2 F .315 + (This is a synon)5.315 F .315(ym for `)-.15 F/F2 10/Times-Italic@0 SF + (1\255$)A F0 2.815('. It)B .315(is not an error to use)2.815 F F1(*) + 2.815 E F0 .315(if there is)2.815 F(just one w)144 96 Q(ord in the e)-.1 + E -.15(ve)-.25 G(nt; the empty string is returned in that case.).15 E F1 + (x*)108 108 Q F0(Abbre)26 E(viates)-.25 E F2(x\255$)2.5 E F0(.)A F1 + <78ad>108 120 Q F0(Abbre)25.3 E(viates)-.25 E F2(x\255$)2.5 E F0(lik)2.5 + E(e)-.1 E F1(x*)2.5 E F0 2.5(,b)C(ut omits the last w)-2.7 E(ord.)-.1 E + (If a w)108 136.8 Q(ord designator is supplied without an e)-.1 E -.15 + (ve)-.25 G(nt speci\214cation, the pre).15 E + (vious command is used as the e)-.25 E -.15(ve)-.25 G(nt.).15 E F1 + (Modi\214ers)87 153.6 Q F0 .183(After the optional w)108 165.6 R .183 + (ord designator)-.1 F 2.683(,t)-.4 G .184 + (here may appear a sequence of one or more of the follo)-2.683 F .184 + (wing modi\214ers,)-.25 F(each preceded by a `:'.)108 177.6 Q F1(h)108 + 194.4 Q F0(Remo)30.44 E .3 -.15(ve a t)-.15 H + (railing \214le name component, lea).15 E(ving only the head.)-.2 E F1 + (t)108 206.4 Q F0(Remo)32.67 E .3 -.15(ve a)-.15 H + (ll leading \214le name components, lea).15 E(ving the tail.)-.2 E F1(r) + 108 218.4 Q F0(Remo)31.56 E .3 -.15(ve a t)-.15 H(railing suf).15 E + (\214x of the form)-.25 E F2(.xxx)2.5 E F0 2.5(,l)C(ea)-2.5 E + (ving the basename.)-.2 E F1(e)108 230.4 Q F0(Remo)31.56 E .3 -.15(ve a) + -.15 H(ll b).15 E(ut the trailing suf)-.2 E(\214x.)-.25 E F1(p)108 242.4 + Q F0(Print the ne)30.44 E 2.5(wc)-.25 G(ommand b)-2.5 E(ut do not e)-.2 + E -.15(xe)-.15 G(cute it.).15 E F1(q)108 254.4 Q F0 + (Quote the substituted w)30.44 E(ords, escaping further substitutions.) + -.1 E F1(x)108 266.4 Q F0(Quote the substituted w)31 E(ords as with)-.1 + E F1(q)2.5 E F0 2.5(,b)C(ut break into w)-2.7 E(ords at)-.1 E F1(blanks) + 2.5 E F0(and ne)2.5 E(wlines.)-.25 E F1(s/)108 278.4 Q F2(old)A F1(/)A + F2(ne)A(w)-.15 E F1(/)A F0(Substitute)144 290.4 Q F2(ne)2.814 E(w)-.15 E + F0 .314(for the \214rst occurrence of)2.814 F F2(old)2.814 E F0 .314 + (in the e)2.814 F -.15(ve)-.25 G .314(nt line.).15 F(An)5.314 E 2.814 + (yd)-.15 G .314(elimiter can be used in place)-2.814 F .616(of /.)144 + 302.4 R .617 + (The \214nal delimiter is optional if it is the last character of the e) + 5.616 F -.15(ve)-.25 G .617(nt line.).15 F .617(The delimiter may)5.617 + F .75(be quoted in)144 314.4 R F2(old)3.25 E F0(and)3.25 E F2(ne)3.25 E + (w)-.15 E F0 .75(with a single backslash.)3.25 F .749(If & appears in) + 5.75 F F2(ne)3.249 E(w)-.15 E F0 3.249(,i).31 G 3.249(ti)-3.249 G 3.249 + (sr)-3.249 G .749(eplaced by)-3.249 F F2(old)3.249 E F0 5.749(.A).77 G + .369(single backslash will quote the &.)144 326.4 R(If)5.369 E F2(old) + 2.869 E F0 .37(is null, it is set to the last)2.869 F F2(old)2.87 E F0 + .37(substituted, or)2.87 F 2.87(,i)-.4 G 2.87(fn)-2.87 G 2.87(op)-2.87 G + (re)-2.87 E(vi-)-.25 E(ous history substitutions took place, the last) + 144 338.4 Q F2(string)2.5 E F0(in a)2.5 E F1(!?)2.5 E F2(string)A F1 + ([?])A F0(search.)5 E F1(&)108 350.4 Q F0(Repeat the pre)27.67 E + (vious substitution.)-.25 E F1(g)108 362.4 Q F0 .398 + (Cause changes to be applied o)31 F -.15(ve)-.15 G 2.898(rt).15 G .398 + (he entire e)-2.898 F -.15(ve)-.25 G .398(nt line.).15 F .397 + (This is used in conjunction with `)5.398 F F1(:s)A F0 2.897('\()C + (e.g.,)-2.897 E(`)144 374.4 Q F1(:gs/)A F2(old)A F1(/)A F2(ne)A(w)-.15 E + F1(/)A F0 1.218('\) or `)B F1(:&)A F0 3.718('. If)B 1.218(used with `) + 3.718 F F1(:s)A F0 1.218(', an)B 3.718(yd)-.15 G 1.219 + (elimiter can be used in place of /, and the \214nal)-3.718 F + (delimiter is optional if it is the last character of the e)144 386.4 Q + -.15(ve)-.25 G(nt line.).15 E/F3 10.95/Times-Bold@0 SF(PR)72 403.2 Q + (OGRAMMING WITH HIST)-.329 E(OR)-.197 E 2.738(YF)-.383 G(UNCTIONS)-2.738 + E F0(This section describes ho)108 415.2 Q 2.5(wt)-.25 G 2.5(ou)-2.5 G + (se the History library in other programs.)-2.5 E F1(Intr)87 432 Q + (oduction to History)-.18 E F0 .797 + (The programmer using the History library has a)108 444 R -.25(va)-.2 G + .796(ilable functions for remembering lines on a history list,).25 F + .307(associating arbitrary data with a line, remo)108 456 R .308 + (ving lines from the list, searching through the list for a line con-) + -.15 F .303(taining an arbitrary te)108 468 R .303 + (xt string, and referencing an)-.15 F 2.803(yl)-.15 G .303 + (ine in the list directly)-2.803 F 5.303(.I)-.65 G 2.803(na)-5.303 G + .303(ddition, a history)-2.803 F F2 -.2(ex)2.802 G(pansion).2 E F0 + (function is a)108 480 Q -.25(va)-.2 G(ilable which pro).25 E + (vides for a consistent user interf)-.15 E(ace across dif)-.1 E + (ferent programs.)-.25 E .059(The user using programs written with the \ + History library has the bene\214t of a consistent user interf)108 496.8 + R .059(ace with a)-.1 F .918(set of well-kno)108 508.8 R .917 + (wn commands for manipulating the te)-.25 F .917(xt of pre)-.15 F .917 + (vious lines and using that te)-.25 F .917(xt in ne)-.15 F 3.417(wc)-.25 + G(om-)-3.417 E 4.183(mands. The)108 520.8 R 1.684(basic history manipul\ + ation commands are identical to the history substitution pro)4.183 F + 1.684(vided by)-.15 F F1(bash)108 532.8 Q F0(.)A .904 + (If the programmer desires, he can use the Readline library)108 549.6 R + 3.403(,w)-.65 G .903(hich includes some history manipulation by)-3.403 F + (def)108 561.6 Q(ault, and has the added adv)-.1 E + (antage of command line editing.)-.25 E .39(Before declaring an)108 + 578.4 R 2.89(yf)-.15 G .39(unctions using an)-2.89 F 2.89(yf)-.15 G .39 + (unctionality the History library pro)-2.89 F .39 + (vides in other code, an appli-)-.15 F .067 + (cation writer should include the \214le)108 590.4 R F2()-.55 E F0 .067(in an)4.233 F 2.566<798c>-.15 + G .066(le that uses the History library')-2.566 F 2.566(sf)-.55 G + (eatures.)-2.566 E .538(It supplies e)108 602.4 R .538 + (xtern declarations for all of the library')-.15 F 3.038(sp)-.55 G .538 + (ublic functions and v)-3.038 F .539(ariables, and declares all of the) + -.25 F(public data structures.)108 614.4 Q F1(History Storage)87 643.2 Q + F0(The history list is an array of history entries.)108 655.2 Q 2.5(Ah)5 + G(istory entry is declared as follo)-2.5 E(ws:)-.25 E F2(typedef void *) + 108 672 Q F1(histdata_t;)2.5 E F0(typedef struct _hist_entry {)108 688.8 + Q(char *line;)113 700.8 Q(histdata_t data;)113 712.8 Q 2.5(}H)108 724.8 + S(IST_ENTR)-2.5 E -.92(Y;)-.65 G(GNU History 4.2)72 768 Q(2001 Mar 6) + 141.51 E(2)205.67 E EP + %%Page: 3 3 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF(HIST)72 48 Q(OR)-.18 E 357.18(Y\(3\) HIST)-.65 F + (OR)-.18 E(Y\(3\))-.65 E + (The history list itself might therefore be declared as)108 84 Q/F1 10 + /Times-Italic@0 SF(HIST_ENTR)108 100.8 Q 2.5(Y*)-.18 G(*)-2.5 E/F2 10 + /Times-Bold@0 SF(the_history_list;)2.5 E F0(The state of the History li\ + brary is encapsulated into a single structure:)108 117.6 Q(/*)108 134.4 + Q 2.5(*As)110.5 146.4 S + (tructure used to pass around the current state of the history)-2.5 E(.) + -.65 E(*/)110.5 158.4 Q(typedef struct _hist_state {)108 170.4 Q + (HIST_ENTR)113 182.4 Q 2.5(Y*)-.65 G + (*entries; /* Pointer to the entries themselv)-2.5 E(es. */)-.15 E + (int of)113 194.4 Q 25(fset; /*)-.25 F + (The location pointer within this array)2.5 E 2.5(.*)-.65 G(/)-2.5 E + (int length;)113 206.4 Q(/* Number of elements within this array)27.5 E + 2.5(.*)-.65 G(/)-2.5 E(int size;)113 218.4 Q + (/* Number of slots allocated to this array)32.5 E 2.5(.*)-.65 G(/)-2.5 + E(int \215ags;)113 230.4 Q 2.5(}H)108 242.4 S(IST)-2.5 E(OR)-.18 E(Y_ST) + -.65 E -1.11(AT)-.93 G(E;)1.11 E(If the \215ags member includes)108 + 259.2 Q F2(HS_STIFLED)2.5 E F0 2.5(,t)C(he history has been sti\215ed.) + -2.5 E/F3 10.95/Times-Bold@0 SF(History Functions)72 276 Q F0 + (This section describes the calling sequence for the v)108 288 Q + (arious functions e)-.25 E(xported by the GNU History library)-.15 E(.) + -.65 E F2(Initializing History and State Management)87 304.8 Q F0 1.274 + (This section describes functions used to initialize and manage the sta\ + te of the History library when you)108 316.8 R -.1(wa)108 328.8 S + (nt to use the history functions in your program.).1 E F1(void)108 352.8 + Q F2(using_history)2.5 E F0(\()4.166 E F1(void)A F0(\))1.666 E(Be)108 + 364.8 Q(gin a session in which the history functions might be used.)-.15 + E(This initializes the interacti)5 E .3 -.15(ve v)-.25 H(ariables.)-.1 E + F1(HIST)108 388.8 Q(OR)-.18 E(Y_ST)-.18 E -.37(AT)-.5 G 2.5(E*).37 G F2 + (history_get_history_state)A F0(\()4.166 E F1(void)A F0(\))1.666 E + (Return a structure describing the current state of the input history) + 108 400.8 Q(.)-.65 E F1(void)108 424.8 Q F2(history_set_history_state) + 2.5 E F0(\()4.166 E F1(HIST)A(OR)-.18 E(Y_ST)-.18 E -.37(AT)-.5 G 2.5 + (E*).37 G(state)-2.5 E F0(\))1.666 E + (Set the state of the history list according to)108 436.8 Q F1(state)2.5 + E F0(.)A F2(History List Management)87 465.6 Q F0 + (These functions manage indi)108 477.6 Q(vidual entries on the history \ + list, or set parameters managing the list itself.)-.25 E F1(void)108 + 501.6 Q F2(add_history)2.5 E F0(\()4.166 E F1(const c)A(har *string)-.15 + E F0(\))1.666 E(Place)108 513.6 Q F1(string)2.5 E F0 + (at the end of the history list.)2.5 E + (The associated data \214eld \(if an)5 E(y\) is set to)-.15 E F2(NULL) + 2.5 E F0(.)A F1(HIST_ENTR)108 537.6 Q 2.5(Y*)-.18 G F2 -.18(re)C(mo).18 + E -.1(ve)-.1 G(_history).1 E F0(\()4.166 E F1(int whic)A(h)-.15 E F0(\)) + 1.666 E(Remo)108 549.6 Q .352 -.15(ve h)-.15 H .052(istory entry at of) + .15 F(fset)-.25 E F1(whic)2.553 E(h)-.15 E F0 .053(from the history) + 2.553 F 5.053(.T)-.65 G .053(he remo)-5.053 F -.15(ve)-.15 G 2.553(de) + .15 G .053(lement is returned so you can free the)-2.553 F + (line, data, and containing structure.)108 561.6 Q F1(HIST_ENTR)108 + 585.6 Q 2.5(Y*)-.18 G F2 -.18(re)C(place_history_entry).18 E F0(\()4.166 + E F1(int whic)A -.834(h, const)-.15 F -.15(ch)2.5 G(ar *line).15 E 1.666 + (,h)-.1 G(istdata_t data)-1.666 E F0(\))3.332 E(Mak)108 597.6 Q 2.868 + (et)-.1 G .368(he history entry at of)-2.868 F(fset)-.25 E F1(whic)2.868 + E(h)-.15 E F0(ha)2.868 E -.15(ve)-.2 G F1(line)3.018 E F0(and)2.868 E F1 + (data)2.868 E F0 5.367(.T)C .367 + (his returns the old entry so you can dispose of)-5.367 F(the data.)108 + 609.6 Q(In the case of an in)5 E -.25(va)-.4 G(lid).25 E F1(whic)2.5 E + (h)-.15 E F0 2.5(,a)C F2(NULL)A F0(pointer is returned.)2.5 E F1(void) + 108 633.6 Q F2(clear_history)2.5 E F0(\()4.166 E F1(void)A F0(\))1.666 E + (Clear the history list by deleting all the entries.)108 645.6 Q F1 + (void)108 669.6 Q F2(sti\215e_history)2.5 E F0(\()4.166 E F1(int max)A + F0(\))1.666 E(Sti\215e the history list, remembering only the last)108 + 681.6 Q F1(max)2.5 E F0(entries.)2.5 E F1(int)108 705.6 Q F2 + (unsti\215e_history)2.5 E F0(\()4.166 E F1(void)A F0(\))1.666 E .655 + (Stop sti\215ing the history)108 717.6 R 5.656(.T)-.65 G .656 + (his returns the pre)-5.656 F .656(vious amount the history w)-.25 F + .656(as sti\215ed.)-.1 F .656(The v)5.656 F .656(alue is positi)-.25 F + .956 -.15(ve i)-.25 H(f).15 E(the history w)108 729.6 Q + (as sti\215ed, ne)-.1 E -.05(ga)-.15 G(ti).05 E .3 -.15(ve i)-.25 H 2.5 + (fi).15 G 2.5(tw)-2.5 G(asn')-2.6 E(t.)-.18 E(GNU History 4.2)72 768 Q + (2001 Mar 6)141.51 E(3)205.67 E EP + %%Page: 4 4 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF(HIST)72 48 Q(OR)-.18 E 357.18(Y\(3\) HIST)-.65 F + (OR)-.18 E(Y\(3\))-.65 E/F1 10/Times-Italic@0 SF(int)108 84 Q/F2 10 + /Times-Bold@0 SF(history_is_sti\215ed)2.5 E F0(\()4.166 E F1(void)A F0 + (\))1.666 E + (Returns non-zero if the history is sti\215ed, zero if it is not.)108 96 + Q F2(Inf)87 124.8 Q(ormation About the History List)-.25 E F0(These fun\ + ctions return information about the entire history list or indi)108 + 136.8 Q(vidual list entries.)-.25 E F1(HIST_ENTR)108 160.8 Q 2.5(Y*)-.18 + G(*)-2.5 E F2(history_list)2.5 E F0(\()4.166 E F1(void)A F0(\))1.666 E + .708(Return a)108 172.8 R F2(NULL)3.208 E F0 .708(terminated array of) + 3.208 F F1(HIST_ENTR)3.208 E 3.208(Y*)-.18 G F0 .708 + (which is the current input history)B 5.707(.E)-.65 G .707 + (lement 0 of this)-5.707 F(list is the be)108 184.8 Q(ginning of time.) + -.15 E(If there is no history)5 E 2.5(,r)-.65 G(eturn)-2.5 E F2(NULL)2.5 + E F0(.)A F1(int)108 208.8 Q F2(wher)2.5 E(e_history)-.18 E F0(\()4.166 E + F1(void)A F0(\))1.666 E(Returns the of)108 220.8 Q + (fset of the current history element.)-.25 E F1(HIST_ENTR)108 244.8 Q + 2.5(Y*)-.18 G F2(curr)A(ent_history)-.18 E F0(\()4.166 E F1(void)A F0 + (\))1.666 E 1.373 + (Return the history entry at the current position, as determined by)108 + 256.8 R F2(wher)3.873 E(e_history\(\))-.18 E F0 6.373(.I)C 3.873(ft) + -6.373 G 1.374(here is no entry)-3.873 F(there, return a)108 268.8 Q F2 + (NULL)2.5 E F0(pointer)2.5 E(.)-.55 E F1(HIST_ENTR)108 292.8 Q 2.5(Y*) + -.18 G F2(history_get)A F0(\()4.166 E F1(int of)A(fset)-.18 E F0(\)) + 1.666 E .288(Return the history entry at position)108 304.8 R F1(of) + 2.787 E(fset)-.18 E F0 2.787(,s)C .287(tarting from)-2.787 F F2 + (history_base)2.787 E F0 5.287(.I)C 2.787(ft)-5.287 G .287 + (here is no entry there, or if)-2.787 F F1(of)2.787 E(fset)-.18 E F0 + (is greater than the history length, return a)108 316.8 Q F2(NULL)2.5 E + F0(pointer)2.5 E(.)-.55 E F1(int)108 340.8 Q F2(history_total_bytes)2.5 + E F0(\()4.166 E F1(void)A F0(\))1.666 E .391 + (Return the number of bytes that the primary history entries are using.) + 108 352.8 R .392(This function returns the sum of the)5.392 F + (lengths of all the lines in the history)108 364.8 Q(.)-.65 E F2(Mo)87 + 393.6 Q(ving Ar)-.1 E(ound the History List)-.18 E F0 + (These functions allo)108 405.6 Q 2.5(wt)-.25 G(he current inde)-2.5 E + 2.5(xi)-.15 G(nto the history list to be set or changed.)-2.5 E F1(int) + 108 429.6 Q F2(history_set_pos)2.5 E F0(\()4.166 E F1(int pos)A F0(\)) + 1.666 E .79(Set the current history of)108 441.6 R .79(fset to)-.25 F F1 + (pos)3.29 E F0 3.29(,a)C 3.29(na)-3.29 G .79(bsolute inde)-3.29 F 3.29 + (xi)-.15 G .79(nto the list.)-3.29 F .79(Returns 1 on success, 0 if)5.79 + F F1(pos)3.29 E F0 .79(is less)3.29 F + (than zero or greater than the number of history entries.)108 453.6 Q F1 + (HIST_ENTR)108 477.6 Q 2.5(Y*)-.18 G F2(pr)A -.15(ev)-.18 G + (ious_history).15 E F0(\()4.166 E F1(void)A F0(\))1.666 E .207 + (Back up the current history of)108 489.6 R .207(fset to the pre)-.25 F + .207(vious history entry)-.25 F 2.708(,a)-.65 G .208 + (nd return a pointer to that entry)-2.708 F 5.208(.I)-.65 G 2.708(ft) + -5.208 G .208(here is)-2.708 F(no pre)108 501.6 Q(vious entry)-.25 E 2.5 + (,r)-.65 G(eturn a)-2.5 E F2(NULL)2.5 E F0(pointer)2.5 E(.)-.55 E F1 + (HIST_ENTR)108 525.6 Q 2.5(Y*)-.18 G F2(next_history)A F0(\()4.166 E F1 + (void)A F0(\))1.666 E(Mo)108 537.6 Q 1.047 -.15(ve t)-.15 H .747 + (he current history of).15 F .747(fset forw)-.25 F .746(ard to the ne) + -.1 F .746(xt history entry)-.15 F 3.246(,a)-.65 G .746 + (nd return the a pointer to that entry)-3.246 F 5.746(.I)-.65 G(f)-5.746 + E(there is no ne)108 549.6 Q(xt entry)-.15 E 2.5(,r)-.65 G(eturn a)-2.5 + E F2(NULL)2.5 E F0(pointer)2.5 E(.)-.55 E F2(Sear)87 578.4 Q + (ching the History List)-.18 E F0 .005(These functions allo)108 590.4 R + 2.505(ws)-.25 G .006(earching of the history list for entries containin\ + g a speci\214c string.)-2.505 F .006(Searching may be)5.006 F 1.452 + (performed both forw)108 602.4 R 1.452(ard and backw)-.1 F 1.451 + (ard from the current history position.)-.1 F 1.451(The search may be) + 6.451 F F1(anc)3.951 E(hor)-.15 E(ed)-.37 E F0(,)A + (meaning that the string must match at the be)108 614.4 Q + (ginning of the history entry)-.15 E(.)-.65 E F1(int)108 638.4 Q F2 + (history_sear)2.5 E(ch)-.18 E F0(\()4.166 E F1(const c)A(har *string) + -.15 E 1.666(,i)-.1 G(nt dir)-1.666 E(ection)-.37 E F0(\))1.666 E .155 + (Search the history for)108 650.4 R F1(string)2.655 E F0 2.656(,s)C .156 + (tarting at the current history of)-2.656 F 2.656(fset. If)-.25 F F1 + (dir)2.656 E(ection)-.37 E F0 .156(is less than 0, then the search)2.656 + F .802(is through pre)108 662.4 R .802 + (vious entries, otherwise through subsequent entries.)-.25 F(If)5.801 E + F1(string)3.301 E F0 .801(is found, then the current his-)3.301 F .064 + (tory inde)108 674.4 R 2.564(xi)-.15 G 2.564(ss)-2.564 G .064 + (et to that history entry)-2.564 F 2.564(,a)-.65 G .064(nd the v)-2.564 + F .064(alue returned is the of)-.25 F .064 + (fset in the line of the entry where)-.25 F F1(string)2.565 E F0 -.1(wa) + 108 686.4 S 2.5(sf).1 G 2.5(ound. Otherwise,)-2.5 F + (nothing is changed, and a -1 is returned.)2.5 E F1(int)108 710.4 Q F2 + (history_sear)2.5 E(ch_pr)-.18 E(e\214x)-.18 E F0(\()4.166 E F1(const c) + A(har *string)-.15 E 1.666(,i)-.1 G(nt dir)-1.666 E(ection)-.37 E F0(\)) + 1.666 E .684(Search the history for)108 722.4 R F1(string)3.183 E F0 + 3.183(,s)C .683(tarting at the current history of)-3.183 F 3.183 + (fset. The)-.25 F .683(search is anchored: matching lines)3.183 F + (GNU History 4.2)72 768 Q(2001 Mar 6)141.51 E(4)205.67 E EP + %%Page: 5 5 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF(HIST)72 48 Q(OR)-.18 E 357.18(Y\(3\) HIST)-.65 F + (OR)-.18 E(Y\(3\))-.65 E 1.063(must be)108 84 R 1.063(gin with)-.15 F/F1 + 10/Times-Italic@0 SF(string)3.563 E F0 6.063(.I)C(f)-6.063 E F1(dir) + 3.563 E(ection)-.37 E F0 1.064 + (is less than 0, then the search is through pre)3.563 F 1.064 + (vious entries, otherwise)-.25 F 1.115(through subsequent entries.)108 + 96 R(If)6.115 E F1(string)3.615 E F0 1.115 + (is found, then the current history inde)3.615 F 3.614(xi)-.15 G 3.614 + (ss)-3.614 G 1.114(et to that entry)-3.614 F 3.614(,a)-.65 G 1.114 + (nd the)-3.614 F(return v)108 108 Q(alue is 0.)-.25 E + (Otherwise, nothing is changed, and a -1 is returned.)5 E F1(int)108 132 + Q/F2 10/Times-Bold@0 SF(history_sear)2.5 E(ch_pos)-.18 E F0(\()4.166 E + F1(const c)A(har *string)-.15 E 1.666(,i)-.1 G(nt dir)-1.666 E -.834 + (ection, int)-.37 F(pos)2.5 E F0(\))3.332 E .603(Search for)108 144 R F1 + (string)3.103 E F0 .603(in the history list, starting at)3.103 F F1(pos) + 3.104 E F0 3.104(,a)C 3.104(na)-3.104 G .604(bsolute inde)-3.104 F 3.104 + (xi)-.15 G .604(nto the list.)-3.104 F(If)5.604 E F1(dir)3.104 E(ection) + -.37 E F0 .604(is ne)3.104 F -.05(ga)-.15 G(ti).05 E -.15(ve)-.25 G(,) + .15 E .608(the search proceeds backw)108 156 R .608(ard from)-.1 F F1 + (pos)3.108 E F0 3.108(,o)C .608(therwise forw)-3.108 F 3.108 + (ard. Returns)-.1 F .608(the absolute inde)3.108 F 3.108(xo)-.15 G 3.108 + (ft)-3.108 G .608(he history ele-)-3.108 F(ment where)108 168 Q F1 + (string)2.5 E F0 -.1(wa)2.5 G 2.5(sf).1 G(ound, or -1 otherwise.)-2.5 E + F2(Managing the History File)87 196.8 Q F0 .035(The History library can\ + read the history from and write it to a \214le.)108 208.8 R .036 + (This section documents the functions for)5.035 F + (managing a history \214le.)108 220.8 Q F1(int)108 244.8 Q F2 -.18(re) + 2.5 G(ad_history).18 E F0(\()4.166 E F1(const c)A(har *\214lename)-.15 E + F0(\))1.666 E .151(Add the contents of)108 256.8 R F1(\214lename)2.651 E + F0 .151(to the history list, a line at a time.)2.651 F(If)5.15 E F1 + (\214lename)2.65 E F0(is)2.65 E F2(NULL)2.65 E F0 2.65(,t)C .15 + (hen read from)-2.65 F F1(~/.his-)2.65 E(tory)108 268.8 Q F0 5(.R)C + (eturns 0 if successful, or)-5 E F2(err)2.5 E(no)-.15 E F0(if not.)2.5 E + F1(int)108 292.8 Q F2 -.18(re)2.5 G(ad_history_range).18 E F0(\()4.166 E + F1(const c)A(har *\214lename)-.15 E 1.666(,i)-.1 G(nt fr)-1.666 E -.834 + (om, int)-.45 F(to)2.5 E F0(\))3.332 E .052(Read a range of lines from) + 108 304.8 R F1(\214lename)2.553 E F0 2.553(,a)C .053 + (dding them to the history list.)-2.553 F .053(Start reading at line) + 5.053 F F1(fr)2.553 E(om)-.45 E F0 .053(and end at)2.553 F F1(to)2.553 E + F0(.)A(If)108 316.8 Q F1(fr)2.889 E(om)-.45 E F0 .389 + (is zero, start at the be)2.889 F 2.889(ginning. If)-.15 F F1(to)2.889 E + F0 .389(is less than)2.889 F F1(fr)2.889 E(om)-.45 E F0 2.889(,t)C .388 + (hen read until the end of the \214le.)-2.889 F(If)5.388 E F1 + (\214lename)2.888 E F0(is)108 328.8 Q F2(NULL)2.5 E F0 2.5(,t)C + (hen read from)-2.5 E F1(~/.history)2.5 E F0 5(.R)C + (eturns 0 if successful, or)-5 E F2(err)2.5 E(no)-.15 E F0(if not.)2.5 E + F1(int)108 352.8 Q F2(write_history)2.5 E F0(\()4.166 E F1(const c)A + (har *\214lename)-.15 E F0(\))1.666 E .961(Write the current history to) + 108 364.8 R F1(\214lename)3.461 E F0 3.461(,o)C -.15(ve)-3.611 G + (rwriting).15 E F1(\214lename)3.461 E F0 .961(if necessary)3.461 F 5.961 + (.I)-.65 G(f)-5.961 E F1(\214lename)3.462 E F0(is)3.462 E F2(NULL)3.462 + E F0 3.462(,t)C .962(hen write)-3.462 F(the history list to)108 376.8 Q + F1(~/.history)2.5 E F0 5(.R)C(eturns 0 on success, or)-5 E F2(err)2.5 E + (no)-.15 E F0(on a read or write error)2.5 E(.)-.55 E F1(int)108 412.8 Q + F2(append_history)2.5 E F0(\()4.166 E F1(int nelements,)A(const c)1.666 + E(har *\214lename)-.15 E F0(\))1.666 E .839(Append the last)108 424.8 R + F1(nelements)3.339 E F0 .839(of the history list to)3.339 F F1 + (\214lename)3.339 E F0 5.839(.I)C(f)-5.839 E F1(\214lename)3.339 E F0 + (is)3.339 E F2(NULL)3.339 E F0 3.339(,t)C .838(hen append to)-3.339 F F1 + (~/.history)3.338 E F0(.)A(Returns 0 on success, or)108 436.8 Q F2(err) + 2.5 E(no)-.15 E F0(on a read or write error)2.5 E(.)-.55 E F1(int)108 + 460.8 Q F2(history_truncate_\214le)2.5 E F0(\()4.166 E F1(const c)A + (har *\214lename)-.15 E 1.666(,i)-.1 G(nt nlines)-1.666 E F0(\))1.666 E + -.35(Tr)108 472.8 S .38(uncate the history \214le).35 F F1(\214lename) + 2.88 E F0 2.88(,l)C(ea)-2.88 E .38(ving only the last)-.2 F F1(nlines) + 2.881 E F0 2.881(lines. If)2.881 F F1(\214lename)2.881 E F0(is)2.881 E + F2(NULL)2.881 E F0 2.881(,t)C(hen)-2.881 E F1(~/.history)2.881 E F0(is) + 2.881 E 2.5(truncated. Returns)108 484.8 R 2.5(0o)2.5 G 2.5(ns)-2.5 G + (uccess, or)-2.5 E F2(err)2.5 E(no)-.15 E F0(on f)2.5 E(ailure.)-.1 E F2 + (History Expansion)87 513.6 Q F0(These functions implement history e)108 + 525.6 Q(xpansion.)-.15 E F1(int)108 549.6 Q F2(history_expand)2.5 E F0 + (\()4.166 E F1 -.15(ch)C(ar *string).15 E 1.666(,c)-.1 G(har **output) + -1.816 E F0(\))1.666 E(Expand)108 561.6 Q F1(string)2.5 E F0 2.5(,p)C + (lacing the result into)-2.5 E F1(output)2.5 E F0 2.5(,ap)C + (ointer to a string.)-2.5 E(Returns:)5 E 31(0I)144 573.6 S 3.066(fn)-31 + G 3.066(oe)-3.066 G .566(xpansions took place \(or)-3.216 F 3.065(,i)-.4 + G 3.065(ft)-3.065 G .565(he only change in the te)-3.065 F .565(xt w) + -.15 F .565(as the remo)-.1 F -.25(va)-.15 G 3.065(lo).25 G 3.065(fe) + -3.065 G(scape)-3.065 E(characters preceding the history e)180 585.6 Q + (xpansion character\);)-.15 E 31(1i)144 597.6 S 2.5(fe)-31 G + (xpansions did tak)-2.65 E 2.5(ep)-.1 G(lace;)-2.5 E 25.17(-1 if)144 + 609.6 R(there w)2.5 E(as an error in e)-.1 E(xpansion;)-.15 E 31(2i)144 + 621.6 S 2.5(ft)-31 G(he returned line should be displayed, b)-2.5 E + (ut not e)-.2 E -.15(xe)-.15 G(cuted, as with the).15 E F2(:p)2.5 E F0 + (modi\214er)2.5 E(.)-.55 E(If an error ocurred in e)108 633.6 Q + (xpansion, then)-.15 E F1(output)2.5 E F0(contains a descripti)2.5 E .3 + -.15(ve e)-.25 H(rror message.).15 E F1 -.15(ch)108 657.6 S(ar *).15 E + F2(get_history_e)2.5 E -.1(ve)-.15 G(nt).1 E F0(\()4.166 E F1(const c)A + (har *string)-.15 E 1.666(,i)-.1 G(nt *cinde)-1.666 E -.834(x, int)-.2 F + (qc)2.5 E(har)-.15 E F0(\))3.332 E .262(Returns the te)108 669.6 R .262 + (xt of the history e)-.15 F -.15(ve)-.25 G .262(nt be).15 F .263 + (ginning at)-.15 F F1(string)2.763 E F0(+)2.763 E F1(*cinde)2.763 E(x) + -.2 E F0(.)A F1(*cinde)5.263 E(x)-.2 E F0 .263 + (is modi\214ed to point to after the)2.763 F -2.15 -.25(ev e)108 681.6 T + .71(nt speci\214er).25 F 5.71(.A)-.55 G 3.21(tf)-5.71 G .71 + (unction entry)-3.21 F(,)-.65 E F1(cinde)3.21 E(x)-.2 E F0 .709 + (points to the inde)3.21 F 3.209(xi)-.15 G(nto)-3.209 E F1(string)3.209 + E F0 .709(where the history e)3.209 F -.15(ve)-.25 G .709 + (nt speci\214ca-).15 F .527(tion be)108 693.6 R(gins.)-.15 E F1(qc)5.527 + E(har)-.15 E F0 .527(is a character that is allo)3.027 F .527 + (wed to end the e)-.25 F -.15(ve)-.25 G .528 + (nt speci\214cation in addition to the `).15 F(`normal')-.74 E(')-.74 E + (terminating characters.)108 705.6 Q F1 -.15(ch)108 729.6 S(ar **).15 E + F2(history_tok)2.5 E(enize)-.1 E F0(\()4.166 E F1(const c)A(har *string) + -.15 E F0(\))1.666 E(GNU History 4.2)72 768 Q(2001 Mar 6)141.51 E(5) + 205.67 E EP + %%Page: 6 6 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF(HIST)72 48 Q(OR)-.18 E 357.18(Y\(3\) HIST)-.65 F + (OR)-.18 E(Y\(3\))-.65 E .239(Return an array of tok)108 84 R .239 + (ens parsed out of)-.1 F/F1 10/Times-Italic@0 SF(string)2.739 E F0 2.739 + (,m)C .238(uch as the shell might.)-2.739 F .238(The tok)5.238 F .238 + (ens are split on the charac-)-.1 F(ters in the)108 96 Q/F2 10 + /Times-Bold@0 SF(history_w)2.5 E(ord_delimiters)-.1 E F0 -.25(va)2.5 G + (riable, and shell quoting con).25 E -.15(ve)-.4 G(ntions are obe).15 E + (yed.)-.15 E F1 -.15(ch)108 120 S(ar *).15 E F2(history_ar)2.5 E + (g_extract)-.1 E F0(\()4.166 E F1(int \214r)A -.834(st, int)-.1 F -.834 + (last, const)2.5 F -.15(ch)2.5 G(ar *string).15 E F0(\))3.332 E .025 + (Extract a string se)108 132 R .025(gment consisting of the)-.15 F F1 + <8c72>2.526 E(st)-.1 E F0(through)2.526 E F1(last)2.526 E F0(ar)2.526 E + .026(guments present in)-.18 F F1(string)2.526 E F0 5.026(.A)C -.18(rg) + -5.026 G .026(uments are split).18 F(using)108 144 Q F2(history_tok)2.5 + E(enize\(\))-.1 E F0(.)A F2(History V)87 172.8 Q(ariables)-.92 E F0 + (This section describes the e)108 184.8 Q(xternally-visible v)-.15 E + (ariables e)-.25 E(xported by the GNU History Library)-.15 E(.)-.65 E F1 + (int)108 208.8 Q F2(history_base)2.5 E F0(The logical of)108 220.8 Q + (fset of the \214rst entry in the history list.)-.25 E F1(int)108 244.8 + Q F2(history_length)2.5 E F0 + (The number of entries currently stored in the history list.)108 256.8 Q + F1(int)108 280.8 Q F2(history_max_entries)2.5 E F0 + (The maximum number of history entries.)108 292.8 Q + (This must be changed using)5 E F2(sti\215e_history\(\))2.5 E F0(.)A F1 + -.15(ch)108 316.8 S(ar).15 E F2(history_expansion_char)2.5 E F0 + (The character that introduces a history e)108 328.8 Q -.15(ve)-.25 G + 2.5(nt. The).15 F(def)2.5 E(ault is)-.1 E F2(!)2.5 E F0 5(.S)C + (etting this to 0 inhibits history e)-5 E(xpansion.)-.15 E F1 -.15(ch) + 108 352.8 S(ar).15 E F2(history_subst_char)2.5 E F0 + (The character that in)108 364.8 Q -.2(vo)-.4 G -.1(ke).2 G 2.5(sw).1 G + (ord substitution if found at the start of a line.)-2.6 E(The def)5 E + (ault is)-.1 E F2(^)2.5 E F0(.)A F1 -.15(ch)108 388.8 S(ar).15 E F2 + (history_comment_char)2.5 E F0 .117(During tok)108 400.8 R .117 + (enization, if this character is seen as the \214rst character of a w) + -.1 F .117(ord, then it and all subsequent char)-.1 F(-)-.2 E .276 + (acters up to a ne)108 412.8 R .276 + (wline are ignored, suppressing history e)-.25 F .276 + (xpansion for the remainder of the line.)-.15 F .277(This is dis-)5.276 + F(abled by def)108 424.8 Q(ault.)-.1 E F1 -.15(ch)108 448.8 S(ar *).15 E + F2(history_w)2.5 E(ord_delimiters)-.1 E F0 + (The characters that separate tok)108 460.8 Q(ens for)-.1 E F2 + (history_tok)2.5 E(enize\(\))-.1 E F0 5(.T)C(he def)-5 E(ault v)-.1 E + (alue is)-.25 E F2 2.5("\\)2.5 G(t\\n\(\)<>;&|")-2.5 E F0(.)A F1 -.15 + (ch)108 484.8 S(ar *).15 E F2(history_no_expand_chars)2.5 E F0 2.054 + (The list of characters which inhibit history e)108 496.8 R 2.054 + (xpansion if found immediately follo)-.15 F(wing)-.25 E F2 + (history_expan-)4.554 E(sion_char)108 508.8 Q F0 5(.T)C(he def)-5 E + (ault is space, tab, ne)-.1 E(wline,)-.25 E F2(\\r)2.5 E F0 2.5(,a)C(nd) + -2.5 E F2(=)2.5 E F0(.)A F1 -.15(ch)108 532.8 S(ar *).15 E F2 + (history_sear)2.5 E(ch_delimiter_chars)-.18 E F0 .401(The list of addit\ + ional characters which can delimit a history search string, in addition\ + to space, tab,)108 544.8 R F1(:)2.901 E F0(and)2.901 E F1(?)2.902 E F0 + (in the case of a substring search.)108 556.8 Q(The def)5 E + (ault is empty)-.1 E(.)-.65 E F1(int)108 580.8 Q F2 + (history_quotes_inhibit_expansion)2.5 E F0 .625 + (If non-zero, single-quoted w)108 592.8 R .625 + (ords are not scanned for the history e)-.1 F .624(xpansion character) + -.15 F 5.624(.T)-.55 G .624(he def)-5.624 F .624(ault v)-.1 F .624 + (alue is)-.25 F(0.)108 604.8 Q F1(rl_lineb)108 628.8 Q(uf_func_t *)-.2 E + F2(history_inhibit_expansion_function)2.5 E F0 .347 + (This should be set to the address of a function that tak)108 640.8 R + .348(es tw)-.1 F 2.848(oa)-.1 G -.18(rg)-2.848 G .348(uments: a).18 F F2 + .348(char *)2.848 F F0(\()2.848 E F1(string)A F0 2.848(\)a)C .348(nd an) + -2.848 F F2(int)2.848 E F0(inde)2.848 E(x)-.15 E .228 + (into that string \()108 652.8 R F1(i)A F0 2.728(\). It)B .227 + (should return a non-zero v)2.727 F .227(alue if the history e)-.25 F + .227(xpansion starting at)-.15 F F1(string[i])2.727 E F0 .227 + (should not)2.727 F .019(be performed; zero if the e)108 664.8 R .019 + (xpansion should be done.)-.15 F .019 + (It is intended for use by applications lik)5.019 F(e)-.1 E F2(bash) + 2.519 E F0 .019(that use)2.519 F(the history e)108 676.8 Q + (xpansion character for additional purposes.)-.15 E(By def)5 E + (ault, this v)-.1 E(ariable is set to)-.25 E F2(NULL)2.5 E F0(.)A/F3 + 10.95/Times-Bold@0 SF(FILES)72 693.6 Q F1(~/.history)109.666 705.6 Q F0 + (Def)144 717.6 Q(ault \214lename for reading and writing sa)-.1 E -.15 + (ve)-.2 G 2.5(dh).15 G(istory)-2.5 E(GNU History 4.2)72 768 Q + (2001 Mar 6)141.51 E(6)205.67 E EP + %%Page: 7 7 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF(HIST)72 48 Q(OR)-.18 E 357.18(Y\(3\) HIST)-.65 F + (OR)-.18 E(Y\(3\))-.65 E/F1 10.95/Times-Bold@0 SF(SEE ALSO)72 84 Q/F2 10 + /Times-Italic@0 SF(The Gnu Readline Libr)108 96 Q(ary)-.15 E F0 2.5(,B)C + (rian F)-2.5 E(ox and Chet Rame)-.15 E(y)-.15 E F2(The Gnu History Libr) + 108 108 Q(ary)-.15 E F0 2.5(,B)C(rian F)-2.5 E(ox and Chet Rame)-.15 E + (y)-.15 E F2(bash)108 120 Q F0(\(1\))A F2 -.37(re)108 132 S(adline).37 E + F0(\(3\))A F1 -.548(AU)72 148.8 S(THORS).548 E F0(Brian F)108 160.8 Q + (ox, Free Softw)-.15 E(are F)-.1 E(oundation)-.15 E(bfox@gnu.or)108 + 172.8 Q(g)-.18 E(Chet Rame)108 189.6 Q 1.3 -.65(y, C)-.15 H(ase W).65 E + (estern Reserv)-.8 E 2.5(eU)-.15 G(ni)-2.5 E -.15(ve)-.25 G(rsity).15 E + (chet@ins.CWR)108 201.6 Q(U.Edu)-.4 E F1 -.11(BU)72 218.4 S 2.738(GR).11 + G(EPOR)-2.738 E(TS)-.438 E F0 .16(If you \214nd a b)108 230.4 R .16 + (ug in the)-.2 F/F3 10/Times-Bold@0 SF(history)2.66 E F0(library)2.66 E + 2.66(,y)-.65 G .16(ou should report it.)-2.66 F .16 + (But \214rst, you should mak)5.16 F 2.66(es)-.1 G .16 + (ure that it really is)-2.66 F 2.5(ab)108 242.4 S + (ug, and that it appears in the latest v)-2.7 E(ersion of the)-.15 E F3 + (history)2.5 E F0(library that you ha)2.5 E -.15(ve)-.2 G(.).15 E .704 + (Once you ha)108 259.2 R 1.004 -.15(ve d)-.2 H .704(etermined that a b) + .15 F .704(ug actually e)-.2 F .704(xists, mail a b)-.15 F .705 + (ug report to)-.2 F F2 -.2(bu)3.205 G(g\255r).2 E(eadline)-.37 E F0(@)A + F2(gnu.or)A(g)-.37 E F0 5.705(.I)C 3.205(fy)-5.705 G(ou)-3.205 E(ha)108 + 271.2 Q 1.81 -.15(ve a \214)-.2 H 1.51 + (x, you are welcome to mail that as well!).15 F 1.509 + (Suggestions and `philosophical' b)6.509 F 1.509(ug reports may be)-.2 F + (mailed to)108 283.2 Q F2 -.2(bu)2.5 G(g-r).2 E(eadline)-.37 E F0(@)A F2 + (gnu.or)A(g)-.37 E F0(or posted to the Usenet ne)2.5 E(wsgroup)-.25 E F3 + (gnu.bash.b)2.5 E(ug)-.2 E F0(.)A(Comments and b)108 300 Q + (ug reports concerning this manual page should be directed to)-.2 E F2 + -.15(ch)2.5 G(et@ins.CWR).15 E -.25(U.)-.4 G(Edu).25 E F0(.).25 E + (GNU History 4.2)72 768 Q(2001 Mar 6)141.51 E(7)205.67 E EP + %%Trailer + end + %%EOF diff -Nrc2 readline-4.1/doc/hstech.texinfo readline-4.2/doc/hstech.texinfo *** readline-4.1/doc/hstech.texinfo Tue Sep 21 10:43:27 1999 --- readline-4.2/doc/hstech.texinfo Mon Mar 12 05:37:38 2001 *************** *** 2,6 **** This file documents the user interface to the GNU History library. ! Copyright (C) 1988, 1991, 1994, 1996 Free Software Foundation, Inc. Authored by Brian Fox and Chet Ramey. --- 2,6 ---- This file documents the user interface to the GNU History library. ! Copyright (C) 1988-2001 Free Software Foundation, Inc. Authored by Brian Fox and Chet Ramey. *************** *** 28,34 **** This chapter describes how to interface programs that you write ! with the GNU History Library. It should be considered a technical guide. ! For information on the interactive use of GNU History, @pxref{Using History Interactively}. --- 28,34 ---- This chapter describes how to interface programs that you write ! with the @sc{gnu} History Library. It should be considered a technical guide. ! For information on the interactive use of @sc{gnu} History, @pxref{Using History Interactively}. *************** *** 44,51 **** @section Introduction to History ! Many programs read input from the user a line at a time. The GNU History ! library is able to keep track of those lines, associate arbitrary data with ! each line, and utilize information from previous lines in composing new ! ones. The programmer using the History library has available functions --- 44,51 ---- @section Introduction to History ! Many programs read input from the user a line at a time. The @sc{gnu} ! History library is able to keep track of those lines, associate arbitrary ! data with each line, and utilize information from previous lines in ! composing new ones. The programmer using the History library has available functions *************** *** 81,87 **** @example typedef struct _hist_entry @{ char *line; ! char *data; @} HIST_ENTRY; @end example --- 81,89 ---- @example + typedef void *histdata_t; + typedef struct _hist_entry @{ char *line; ! histdata_t data; @} HIST_ENTRY; @end example *************** *** 96,105 **** @example ! /* A structure used to pass the current state of the history stuff around. */ typedef struct _hist_state @{ ! HIST_ENTRY **entries; /* Pointer to the entries themselves. */ ! int offset; /* The location pointer within this array. */ ! int length; /* Number of elements within this array. */ ! int size; /* Number of slots allocated to this array. */ int flags; @} HISTORY_STATE; --- 98,109 ---- @example ! /* ! * A structure used to pass around the current state of the history. ! */ typedef struct _hist_state @{ ! HIST_ENTRY **entries; /* Pointer to the entries themselves. */ ! int offset; /* The location pointer within this array. */ ! int length; /* Number of elements within this array. */ ! int size; /* Number of slots allocated to this array. */ int flags; @} HISTORY_STATE; *************** *** 113,117 **** This section describes the calling sequence for the various functions ! present in GNU History. @menu --- 117,121 ---- This section describes the calling sequence for the various functions ! exported by the @sc{gnu} History library. @menu *************** *** 140,149 **** functions in your program. ! @deftypefun void using_history () Begin a session in which the history functions might be used. This initializes the interactive variables. @end deftypefun ! @deftypefun {HISTORY_STATE *} history_get_history_state () Return a structure describing the current state of the input history. @end deftypefun --- 144,153 ---- functions in your program. ! @deftypefun void using_history (void) Begin a session in which the history functions might be used. This initializes the interactive variables. @end deftypefun ! @deftypefun {HISTORY_STATE *} history_get_history_state (void) Return a structure describing the current state of the input history. @end deftypefun *************** *** 159,163 **** parameters managing the list itself. ! @deftypefun void add_history (char *string) Place @var{string} at the end of the history list. The associated data field (if any) is set to @code{NULL}. --- 163,167 ---- parameters managing the list itself. ! @deftypefun void add_history (const char *string) Place @var{string} at the end of the history list. The associated data field (if any) is set to @code{NULL}. *************** *** 170,174 **** @end deftypefun ! @deftypefun {HIST_ENTRY *} replace_history_entry (int which, char *line, char *data) Make the history entry at offset @var{which} have @var{line} and @var{data}. This returns the old entry so you can dispose of the data. In the case --- 174,178 ---- @end deftypefun ! @deftypefun {HIST_ENTRY *} replace_history_entry (int which, const char *line, histdata_t data) Make the history entry at offset @var{which} have @var{line} and @var{data}. This returns the old entry so you can dispose of the data. In the case *************** *** 176,180 **** @end deftypefun ! @deftypefun void clear_history () Clear the history list by deleting all the entries. @end deftypefun --- 180,184 ---- @end deftypefun ! @deftypefun void clear_history (void) Clear the history list by deleting all the entries. @end deftypefun *************** *** 184,188 **** @end deftypefun ! @deftypefun int unstifle_history () Stop stifling the history. This returns the previous amount the history was stifled. The value is positive if the history was --- 188,192 ---- @end deftypefun ! @deftypefun int unstifle_history (void) Stop stifling the history. This returns the previous amount the history was stifled. The value is positive if the history was *************** *** 190,194 **** @end deftypefun ! @deftypefun int history_is_stifled () Returns non-zero if the history is stifled, zero if it is not. @end deftypefun --- 194,198 ---- @end deftypefun ! @deftypefun int history_is_stifled (void) Returns non-zero if the history is stifled, zero if it is not. @end deftypefun *************** *** 200,216 **** individual list entries. ! @deftypefun {HIST_ENTRY **} history_list () ! Return a @code{NULL} terminated array of @code{HIST_ENTRY} which is the current input history. Element 0 of this list is the beginning of time. If there is no history, return @code{NULL}. @end deftypefun ! @deftypefun int where_history () Returns the offset of the current history element. @end deftypefun ! @deftypefun {HIST_ENTRY *} current_history () Return the history entry at the current position, as determined by ! @code{where_history ()}. If there is no entry there, return a @code{NULL} pointer. @end deftypefun --- 204,220 ---- individual list entries. ! @deftypefun {HIST_ENTRY **} history_list (void) ! Return a @code{NULL} terminated array of @code{HIST_ENTRY *} which is the current input history. Element 0 of this list is the beginning of time. If there is no history, return @code{NULL}. @end deftypefun ! @deftypefun int where_history (void) Returns the offset of the current history element. @end deftypefun ! @deftypefun {HIST_ENTRY *} current_history (void) Return the history entry at the current position, as determined by ! @code{where_history()}. If there is no entry there, return a @code{NULL} pointer. @end deftypefun *************** *** 218,226 **** @deftypefun {HIST_ENTRY *} history_get (int offset) Return the history entry at position @var{offset}, starting from ! @code{history_base}. If there is no entry there, or if @var{offset} is greater than the history length, return a @code{NULL} pointer. @end deftypefun ! @deftypefun int history_total_bytes () Return the number of bytes that the primary history entries are using. This function returns the sum of the lengths of all the lines in the --- 222,231 ---- @deftypefun {HIST_ENTRY *} history_get (int offset) Return the history entry at position @var{offset}, starting from ! @code{history_base} (@pxref{History Variables}). ! If there is no entry there, or if @var{offset} is greater than the history length, return a @code{NULL} pointer. @end deftypefun ! @deftypefun int history_total_bytes (void) Return the number of bytes that the primary history entries are using. This function returns the sum of the lengths of all the lines in the *************** *** 235,243 **** @deftypefun int history_set_pos (int pos) ! Set the position in the history list to @var{pos}, an absolute index into the list. @end deftypefun ! @deftypefun {HIST_ENTRY *} previous_history () Back up the current history offset to the previous history entry, and return a pointer to that entry. If there is no previous entry, return --- 240,250 ---- @deftypefun int history_set_pos (int pos) ! Set the current history offset to @var{pos}, an absolute index into the list. + Returns 1 on success, 0 if @var{pos} is less than zero or greater + than the number of history entries. @end deftypefun ! @deftypefun {HIST_ENTRY *} previous_history (void) Back up the current history offset to the previous history entry, and return a pointer to that entry. If there is no previous entry, return *************** *** 245,249 **** @end deftypefun ! @deftypefun {HIST_ENTRY *} next_history () Move the current history offset forward to the next history entry, and return the a pointer to that entry. If there is no next entry, return --- 252,256 ---- @end deftypefun ! @deftypefun {HIST_ENTRY *} next_history (void) Move the current history offset forward to the next history entry, and return the a pointer to that entry. If there is no next entry, return *************** *** 261,268 **** @cindex anchored search ! @deftypefun int history_search (char *string, int direction) ! Search the history for @var{string}, starting at the current history ! offset. If @var{direction} < 0, then the search is through previous entries, ! else through subsequent. If @var{string} is found, then the current history index is set to that history entry, and the value returned is the offset in the line of the entry where --- 268,276 ---- @cindex anchored search ! @deftypefun int history_search (const char *string, int direction) ! Search the history for @var{string}, starting at the current history offset. ! If @var{direction} is less than 0, then the search is through ! previous entries, otherwise through subsequent entries. ! If @var{string} is found, then the current history index is set to that history entry, and the value returned is the offset in the line of the entry where *************** *** 271,284 **** @end deftypefun ! @deftypefun int history_search_prefix (char *string, int direction) Search the history for @var{string}, starting at the current history offset. The search is anchored: matching lines must begin with ! @var{string}. If @var{direction} < 0, then the search is through previous ! entries, else through subsequent. If @var{string} is found, then the current history index is set to that entry, and the return value is 0. Otherwise, nothing is changed, and a -1 is returned. @end deftypefun ! @deftypefun int history_search_pos (char *string, int direction, int pos) Search for @var{string} in the history list, starting at @var{pos}, an absolute index into the list. If @var{direction} is negative, the search --- 279,293 ---- @end deftypefun ! @deftypefun int history_search_prefix (const char *string, int direction) Search the history for @var{string}, starting at the current history offset. The search is anchored: matching lines must begin with ! @var{string}. If @var{direction} is less than 0, then the search is ! through previous entries, otherwise through subsequent entries. ! If @var{string} is found, then the current history index is set to that entry, and the return value is 0. Otherwise, nothing is changed, and a -1 is returned. @end deftypefun ! @deftypefun int history_search_pos (const char *string, int direction, int pos) Search for @var{string} in the history list, starting at @var{pos}, an absolute index into the list. If @var{direction} is negative, the search *************** *** 293,306 **** This section documents the functions for managing a history file. ! @deftypefun int read_history (char *filename) ! Add the contents of @var{filename} to the history list, a line at a ! time. If @var{filename} is @code{NULL}, then read from ! @file{~/.history}. Returns 0 if successful, or errno if not. @end deftypefun ! @deftypefun int read_history_range (char *filename, int from, int to) Read a range of lines from @var{filename}, adding them to the history list. ! Start reading at line @var{from} and end at @var{to}. If ! @var{from} is zero, start at the beginning. If @var{to} is less than @var{from}, then read until the end of the file. If @var{filename} is @code{NULL}, then read from @file{~/.history}. Returns 0 if successful, --- 302,315 ---- This section documents the functions for managing a history file. ! @deftypefun int read_history (const char *filename) ! Add the contents of @var{filename} to the history list, a line at a time. ! If @var{filename} is @code{NULL}, then read from @file{~/.history}. ! Returns 0 if successful, or @code{errno} if not. @end deftypefun ! @deftypefun int read_history_range (const char *filename, int from, int to) Read a range of lines from @var{filename}, adding them to the history list. ! Start reading at line @var{from} and end at @var{to}. ! If @var{from} is zero, start at the beginning. If @var{to} is less than @var{from}, then read until the end of the file. If @var{filename} is @code{NULL}, then read from @file{~/.history}. Returns 0 if successful, *************** *** 308,325 **** @end deftypefun ! @deftypefun int write_history (char *filename) Write the current history to @var{filename}, overwriting @var{filename} ! if necessary. If @var{filename} is ! @code{NULL}, then write the history list to @file{~/.history}. Values ! returned are as in @code{read_history ()}. @end deftypefun ! @deftypefun int append_history (int nelements, char *filename) Append the last @var{nelements} of the history list to @var{filename}. @end deftypefun ! @deftypefun int history_truncate_file (char *filename, int nlines) Truncate the history file @var{filename}, leaving only the last @var{nlines} lines. @end deftypefun --- 317,339 ---- @end deftypefun ! @deftypefun int write_history (const char *filename) Write the current history to @var{filename}, overwriting @var{filename} ! if necessary. ! If @var{filename} is @code{NULL}, then write the history list to ! @file{~/.history}. ! Returns 0 on success, or @code{errno} on a read or write error. @end deftypefun ! @deftypefun int append_history (int nelements, const char *filename) Append the last @var{nelements} of the history list to @var{filename}. + If @var{filename} is @code{NULL}, then append to @file{~/.history}. + Returns 0 on success, or @code{errno} on a read or write error. @end deftypefun ! @deftypefun int history_truncate_file (const char *filename, int nlines) Truncate the history file @var{filename}, leaving only the last @var{nlines} lines. + If @var{filename} is @code{NULL}, then @file{~/.history} is truncated. + Returns 0 on success, or @code{errno} on failure. @end deftypefun *************** *** 327,331 **** @subsection History Expansion ! These functions implement @code{csh}-like history expansion. @deftypefun int history_expand (char *string, char **output) --- 341,345 ---- @subsection History Expansion ! These functions implement history expansion. @deftypefun int history_expand (char *string, char **output) *************** *** 335,339 **** @item 0 If no expansions took place (or, if the only change in ! the text was the de-slashifying of the history expansion character); @item 1 --- 349,353 ---- @item 0 If no expansions took place (or, if the only change in ! the text was the removal of escape characters preceding the history expansion character); @item 1 *************** *** 350,359 **** @end deftypefun ! @deftypefun {char *} history_arg_extract (int first, int last, char *string) ! Extract a string segment consisting of the @var{first} through @var{last} ! arguments present in @var{string}. Arguments are broken up as in Bash. ! @end deftypefun ! ! @deftypefun {char *} get_history_event (char *string, int *cindex, int qchar) Returns the text of the history event beginning at @var{string} + @var{*cindex}. @var{*cindex} is modified to point to after the event --- 364,368 ---- @end deftypefun ! @deftypefun {char *} get_history_event (const char *string, int *cindex, int qchar) Returns the text of the history event beginning at @var{string} + @var{*cindex}. @var{*cindex} is modified to point to after the event *************** *** 364,372 **** @end deftypefun ! @deftypefun {char **} history_tokenize (char *string) Return an array of tokens parsed out of @var{string}, much as the ! shell might. The tokens are split on white space and on the ! characters @code{()<>;&|$}, and shell quoting conventions are ! obeyed. @end deftypefun --- 373,387 ---- @end deftypefun ! @deftypefun {char **} history_tokenize (const char *string) Return an array of tokens parsed out of @var{string}, much as the ! shell might. The tokens are split on the characters in the ! @var{history_word_delimiters} variable, ! and shell quoting conventions are obeyed. ! @end deftypefun ! ! @deftypefun {char *} history_arg_extract (int first, int last, const char *string) ! Extract a string segment consisting of the @var{first} through @var{last} ! arguments present in @var{string}. Arguments are split using ! @code{history_tokenize}. @end deftypefun *************** *** 374,379 **** @section History Variables ! This section describes the externally visible variables exported by ! the GNU History Library. @deftypevar int history_base --- 389,394 ---- @section History Variables ! This section describes the externally-visible variables exported by ! the @sc{gnu} History Library. @deftypevar int history_base *************** *** 385,395 **** @end deftypevar ! @deftypevar int max_input_history The maximum number of history entries. This must be changed using ! @code{stifle_history ()}. @end deftypevar @deftypevar char history_expansion_char ! The character that starts a history event. The default is @samp{!}. @end deftypevar --- 400,411 ---- @end deftypevar ! @deftypevar int history_max_entries The maximum number of history entries. This must be changed using ! @code{stifle_history()}. @end deftypevar @deftypevar char history_expansion_char ! The character that introduces a history event. The default is @samp{!}. ! Setting this to 0 inhibits history expansion. @end deftypevar *************** *** 406,418 **** @end deftypevar @deftypevar {char *} history_no_expand_chars The list of characters which inhibit history expansion if found immediately ! following @var{history_expansion_char}. The default is whitespace and ! @samp{=}. @end deftypevar @deftypevar {char *} history_search_delimiter_chars The list of additional characters which can delimit a history search ! string, in addition to whitespace, @samp{:} and @samp{?} in the case of a substring search. The default is empty. @end deftypevar --- 422,439 ---- @end deftypevar + @deftypevar {char *} history_word_delimiters + The characters that separate tokens for \fBhistory_tokenize()\fP. + The default value is @code{" \t\n()<>;&|"}. + @end deftypevar + @deftypevar {char *} history_no_expand_chars The list of characters which inhibit history expansion if found immediately ! following @var{history_expansion_char}. The default is space, tab, newline, ! carriage return, and @samp{=}. @end deftypevar @deftypevar {char *} history_search_delimiter_chars The list of additional characters which can delimit a history search ! string, in addition to space, TAB, @samp{:} and @samp{?} in the case of a substring search. The default is empty. @end deftypevar *************** *** 423,429 **** @end deftypevar ! @deftypevar {Function *} history_inhibit_expansion_function This should be set to the address of a function that takes two arguments: ! a @code{char *} (@var{string}) and an integer index into that string (@var{i}). It should return a non-zero value if the history expansion starting at @var{string[i]} should not be performed; zero if the expansion should --- 444,451 ---- @end deftypevar ! @deftypevar {rl_linebuf_func_t *} history_inhibit_expansion_function This should be set to the address of a function that takes two arguments: ! a @code{char *} (@var{string}) ! and an @code{int} index into that string (@var{i}). It should return a non-zero value if the history expansion starting at @var{string[i]} should not be performed; zero if the expansion should *************** *** 431,435 **** It is intended for use by applications like Bash that use the history expansion character for additional purposes. ! By default, this variable is set to NULL. @end deftypevar --- 453,457 ---- It is intended for use by applications like Bash that use the history expansion character for additional purposes. ! By default, this variable is set to @code{NULL}. @end deftypevar *************** *** 437,444 **** @section History Programming Example ! The following program demonstrates simple use of the GNU History Library. @smallexample ! main () @{ char line[1024], *t; --- 459,471 ---- @section History Programming Example ! The following program demonstrates simple use of the @sc{gnu} History Library. @smallexample ! #include ! #include ! ! main (argc, argv) ! int argc; ! char **argv; @{ char line[1024], *t; diff -Nrc2 readline-4.1/doc/hsuser.texinfo readline-4.2/doc/hsuser.texinfo *** readline-4.1/doc/hsuser.texinfo Fri Dec 17 07:01:17 1999 --- readline-4.2/doc/hsuser.texinfo Wed Nov 22 12:42:50 2000 *************** *** 39,45 **** @end ifset @ifclear BashFeatures ! This chapter describes how to use the GNU History Library interactively, from a user's standpoint. It should be considered a user's guide. For ! information on using the GNU History Library in your own programs, @pxref{Programming with GNU History}. @end ifclear --- 39,45 ---- @end ifset @ifclear BashFeatures ! This chapter describes how to use the @sc{gnu} History Library interactively, from a user's standpoint. It should be considered a user's guide. For ! information on using the @sc{gnu} History Library in your own programs, @pxref{Programming with GNU History}. @end ifclear *************** *** 66,76 **** @cindex history list ! When the @samp{-o history} option to the @code{set} builtin is enabled (@pxref{The Set Builtin}), ! the shell provides access to the @var{command history}, the list of commands previously typed. ! The value of the @code{HISTSIZE} shell variable is used as the number of commands to save in a history list. ! The text of the last @code{$HISTSIZE} commands (default 500) is saved. The shell stores each command in the history list prior to --- 66,76 ---- @cindex history list ! When the @option{-o history} option to the @code{set} builtin is enabled (@pxref{The Set Builtin}), ! the shell provides access to the @dfn{command history}, the list of commands previously typed. ! The value of the @env{HISTSIZE} shell variable is used as the number of commands to save in a history list. ! The text of the last @env{$HISTSIZE} commands (default 500) is saved. The shell stores each command in the history list prior to *************** *** 78,99 **** but after history expansion is performed, subject to the values of the shell variables ! @code{HISTIGNORE} and @code{HISTCONTROL}. When the shell starts up, the history is initialized from the ! file named by the @code{HISTFILE} variable (default @file{~/.bash_history}). ! The file named by the value of @code{HISTFILE} is truncated, if necessary, to contain no more than the number of lines specified by ! the value of the @code{HISTFILESIZE} variable. When an interactive shell exits, the last ! @code{$HISTSIZE} lines are copied from the history list to the file ! named by @code{$HISTFILE}. If the @code{histappend} shell option is set (@pxref{Bash Builtins}), the lines are appended to the history file, otherwise the history file is overwritten. ! If @code{HISTFILE} is unset, or if the history file is unwritable, the history is not saved. After saving the history, the history file is truncated ! to contain no more than @code{$HISTFILESIZE} ! lines. If @code{HISTFILESIZE} is not set, no truncation is performed. The builtin command @code{fc} may be used to list or edit and re-execute --- 78,99 ---- but after history expansion is performed, subject to the values of the shell variables ! @env{HISTIGNORE} and @env{HISTCONTROL}. When the shell starts up, the history is initialized from the ! file named by the @env{HISTFILE} variable (default @file{~/.bash_history}). ! The file named by the value of @env{HISTFILE} is truncated, if necessary, to contain no more than the number of lines specified by ! the value of the @env{HISTFILESIZE} variable. When an interactive shell exits, the last ! @env{$HISTSIZE} lines are copied from the history list to the file ! named by @env{$HISTFILE}. If the @code{histappend} shell option is set (@pxref{Bash Builtins}), the lines are appended to the history file, otherwise the history file is overwritten. ! If @env{HISTFILE} is unset, or if the history file is unwritable, the history is not saved. After saving the history, the history file is truncated ! to contain no more than @env{$HISTFILESIZE} ! lines. If @env{HISTFILESIZE} is not set, no truncation is performed. The builtin command @code{fc} may be used to list or edit and re-execute *************** *** 106,110 **** The shell allows control over which commands are saved on the history ! list. The @code{HISTCONTROL} and @code{HISTIGNORE} variables may be set to cause the shell to save only a subset of the commands entered. --- 106,110 ---- The shell allows control over which commands are saved on the history ! list. The @env{HISTCONTROL} and @env{HISTIGNORE} variables may be set to cause the shell to save only a subset of the commands entered. *************** *** 142,154 **** current command number). If @var{last} is not specified it is set to @var{first}. If @var{first} is not specified it is set to the previous ! command for editing and @minus{}16 for listing. If the @samp{-l} flag is ! given, the commands are listed on standard output. The @samp{-n} flag ! suppresses the command numbers when listing. The @samp{-r} flag reverses the order of the listing. Otherwise, the editor given by @var{ename} is invoked on a file containing those commands. If @var{ename} is not given, the value of the following variable expansion is used: @code{$@{FCEDIT:-$@{EDITOR:-vi@}@}}. This says to use the ! value of the @code{FCEDIT} variable if set, or the value of the ! @code{EDITOR} variable if that is set, or @code{vi} if neither is set. When editing is complete, the edited commands are echoed and executed. --- 142,154 ---- current command number). If @var{last} is not specified it is set to @var{first}. If @var{first} is not specified it is set to the previous ! command for editing and @minus{}16 for listing. If the @option{-l} flag is ! given, the commands are listed on standard output. The @option{-n} flag ! suppresses the command numbers when listing. The @option{-r} flag reverses the order of the listing. Otherwise, the editor given by @var{ename} is invoked on a file containing those commands. If @var{ename} is not given, the value of the following variable expansion is used: @code{$@{FCEDIT:-$@{EDITOR:-vi@}@}}. This says to use the ! value of the @env{FCEDIT} variable if set, or the value of the ! @env{EDITOR} variable if that is set, or @code{vi} if neither is set. When editing is complete, the edited commands are echoed and executed. *************** *** 171,175 **** With no options, display the history list with line numbers. ! Lines prefixed with with a @samp{*} have been modified. An argument of @var{n} lists only the last @var{n} lines. Options, if supplied, have the following meanings: --- 171,175 ---- With no options, display the history list with line numbers. ! Lines prefixed with a @samp{*} have been modified. An argument of @var{n} lists only the last @var{n} lines. Options, if supplied, have the following meanings: *************** *** 212,219 **** @end table ! When any of the @samp{-w}, @samp{-r}, @samp{-a}, or @samp{-n} options is used, if @var{filename} is given, then it is used as the history file. If not, then ! the value of the @code{HISTFILE} variable is used. @end table --- 212,219 ---- @end table ! When any of the @option{-w}, @option{-r}, @option{-a}, or @option{-n} options is used, if @var{filename} is given, then it is used as the history file. If not, then ! the value of the @env{HISTFILE} variable is used. @end table *************** *** 261,267 **** shell option is enabled, a failed history expansion will be reloaded into the Readline editing buffer for correction. ! The @samp{-p} option to the @code{history} builtin command may be used to see what a history expansion will do before using it. ! The @samp{-s} option to the @code{history} builtin may be used to add commands to the end of the history list without actually executing them, so that they are available for subsequent recall. --- 261,267 ---- shell option is enabled, a failed history expansion will be reloaded into the Readline editing buffer for correction. ! The @option{-p} option to the @code{history} builtin command may be used to see what a history expansion will do before using it. ! The @option{-s} option to the @code{history} builtin may be used to add commands to the end of the history list without actually executing them, so that they are available for subsequent recall. diff -Nrc2 readline-4.1/doc/manvers.texinfo readline-4.2/doc/manvers.texinfo *** readline-4.1/doc/manvers.texinfo Wed Jan 19 12:16:33 2000 --- readline-4.2/doc/manvers.texinfo Mon Apr 16 10:54:00 2001 *************** *** 1,6 **** ! @set EDITION 4.1 ! @set VERSION 4.1 ! @set UPDATED 2000 January 19 ! @set UPDATE-MONTH January 2000 ! @set LASTCHANGE Wed Jan 19 12:16:30 EST 2000 --- 1,6 ---- ! @set EDITION 4.2 ! @set VERSION 4.2 ! @set UPDATED 2001 Apr 16 ! @set UPDATE-MONTH Apr 2001 ! @set LASTCHANGE Mon Apr 16 10:53:58 EDT 2001 diff -Nrc2 readline-4.1/doc/readline.0 readline-4.2/doc/readline.0 *** readline-4.1/doc/readline.0 Fri Aug 6 16:00:41 1999 --- readline-4.2/doc/readline.0 Mon Mar 5 11:20:23 2001 *************** *** 10,30 **** SSYYNNOOPPSSIISS ##iinncclluuddee <> ! ##iinncclluuddee <> ! ##iinncclluuddee <> ! cchhaarr **rreeaaddlliinnee ((pprroommpptt)) ! cchhaarr **pprroommpptt;; CCOOPPYYRRIIGGHHTT ! Readline is Copyright (C) 1989, 1991, 1993, 1995, 1996 by ! the Free Software Foundation, Inc. DDEESSCCRRIIPPTTIIOONN rreeaaddlliinnee will read a line from the terminal and return it, ! using pprroommpptt as a prompt. If pprroommpptt is null, no prompt is ! issued. The line returned is allocated with _m_a_l_l_o_c(3), so ! the caller must free it when finished. The line returned ! has the final newline removed, so only the text of the ! line remains. rreeaaddlliinnee offers editing capabilities while the user is --- 10,30 ---- SSYYNNOOPPSSIISS ##iinncclluuddee <> ! ##iinncclluuddee <> ! ##iinncclluuddee <> ! _c_h_a_r _* ! rreeaaddlliinnee (_c_o_n_s_t _c_h_a_r _*_p_r_o_m_p_t); CCOOPPYYRRIIGGHHTT ! Readline is Copyright (C) 1989-2001 by the Free Software ! Foundation, Inc. DDEESSCCRRIIPPTTIIOONN rreeaaddlliinnee will read a line from the terminal and return it, ! using pprroommpptt as a prompt. If pprroommpptt is NNUULLLL or the empty ! string, no prompt is issued. The line returned is allo- ! cated with _m_a_l_l_o_c(3); the caller must free it when fin- ! ished. The line returned has the final newline removed, ! so only the text of the line remains. rreeaaddlliinnee offers editing capabilities while the user is *************** *** 33,66 **** interface is also available. RREETTUURRNN VVAALLUUEE ! rreeaaddlliinnee returns the text of the line read. A blank line ! returns the empty string. If EEOOFF is encountered while ! reading a line, and the line is empty, NNUULLLL is returned. ! If an EEOOFF is read with a non-empty line, it is treated as a newline. NNOOTTAATTIIOONN ! An emacs-style notation is used to denote keystrokes. ! Control keys are denoted by C-_k_e_y, e.g., C-n means Con- trol-N. Similarly, _m_e_t_a keys are denoted by M-_k_e_y, so M-x means Meta-X. (On keyboards without a _m_e_t_a key, M-_x means ! ESC _x, i.e., press the Escape key then the _x key. This ! makes ESC the _m_e_t_a _p_r_e_f_i_x. The combination M-C-_x means ! ESC-Control-_x, or press the Escape key then hold the Con- trol key while pressing the _x key.) ! Readline commands may be given numeric _a_r_g_u_m_e_n_t_s, which normally act as a repeat count. Sometimes, however, it is ! the sign of the argument that is significant. Passing a ! negative argument to a command that acts in the forward ! direction (e.g., kkiillll--lliinnee) causes that command to act in ! a backward direction. Commands whose behavior with argu- ! ments deviates from this are noted. ! ! When a command is described as _k_i_l_l_i_n_g text, the text ! GNU 1999 Jun 1 1 --- 33,66 ---- interface is also available. + This manual page describes only the most basic use of + rreeaaddlliinnee. Much more functionality is available; see _T_h_e + _G_N_U _R_e_a_d_l_i_n_e _L_i_b_r_a_r_y and _T_h_e _G_N_U _H_i_s_t_o_r_y _L_i_b_r_a_r_y for addi- + tional information. + RREETTUURRNN VVAALLUUEE ! rreeaaddlliinnee returns the text of the line read. A blank line ! returns the empty string. If EEOOFF is encountered while ! reading a line, and the line is empty, NNUULLLL is returned. ! If an EEOOFF is read with a non-empty line, it is treated as a newline. NNOOTTAATTIIOONN ! An emacs-style notation is used to denote keystrokes. ! Control keys are denoted by C-_k_e_y, e.g., C-n means Con- trol-N. Similarly, _m_e_t_a keys are denoted by M-_k_e_y, so M-x means Meta-X. (On keyboards without a _m_e_t_a key, M-_x means ! ESC _x, i.e., press the Escape key then the _x key. This ! makes ESC the _m_e_t_a _p_r_e_f_i_x. The combination M-C-_x means ! ESC-Control-_x, or press the Escape key then hold the Con- trol key while pressing the _x key.) ! Readline commands may be given numeric _a_r_g_u_m_e_n_t_s, which normally act as a repeat count. Sometimes, however, it is ! the sign of the argument that is significant. Passing a ! negative argument to a command that acts in the forward ! GNU Readline 4.2 2001 Mar 5 1 *************** *** 71,92 **** ! deleted is saved for possible future retrieval (_y_a_n_k_i_n_g). ! The killed text is saved in a _k_i_l_l _r_i_n_g. Consecutive ! kills cause the text to be accumulated into one unit, ! which can be yanked all at once. Commands which do not kill text separate the chunks of text on the kill ring. IINNIITTIIAALLIIZZAATTIIOONN FFIILLEE ! Readline is customized by putting commands in an initial- ization file (the _i_n_p_u_t_r_c file). The name of this file is ! taken from the value of the IINNPPUUTTRRCC environment variable. ! If that variable is unset, the default is _~_/_._i_n_p_u_t_r_c. ! When a program which uses the readline library starts up, ! the init file is read, and the key bindings and variables are set. There are only a few basic constructs allowed in ! the readline init file. Blank lines are ignored. Lines beginning with a ## are comments. Lines beginning with a $$ ! indicate conditional constructs. Other lines denote key ! bindings and variable settings. Each program using this library may add its own commands and bindings. --- 71,97 ---- ! direction (e.g., kkiillll--lliinnee) causes that command to act in ! a backward direction. Commands whose behavior with argu- ! ments deviates from this are noted. ! ! When a command is described as _k_i_l_l_i_n_g text, the text ! deleted is saved for possible future retrieval (_y_a_n_k_i_n_g). ! The killed text is saved in a _k_i_l_l _r_i_n_g. Consecutive ! kills cause the text to be accumulated into one unit, ! which can be yanked all at once. Commands which do not kill text separate the chunks of text on the kill ring. IINNIITTIIAALLIIZZAATTIIOONN FFIILLEE ! Readline is customized by putting commands in an initial- ization file (the _i_n_p_u_t_r_c file). The name of this file is ! taken from the value of the IINNPPUUTTRRCC environment variable. ! If that variable is unset, the default is _~_/_._i_n_p_u_t_r_c. ! When a program which uses the readline library starts up, ! the init file is read, and the key bindings and variables are set. There are only a few basic constructs allowed in ! the readline init file. Blank lines are ignored. Lines beginning with a ## are comments. Lines beginning with a $$ ! indicate conditional constructs. Other lines denote key ! bindings and variable settings. Each program using this library may add its own commands and bindings. *************** *** 96,107 **** or C-Meta-u: universal-argument ! into the _i_n_p_u_t_r_c would make M-C-u execute the readline command _u_n_i_v_e_r_s_a_l_-_a_r_g_u_m_e_n_t. ! The following symbolic character names are recognized ! while processing key bindings: _R_U_B_O_U_T, _D_E_L, _E_S_C, _L_F_D, _N_E_W_- ! _L_I_N_E, _R_E_T, _R_E_T_U_R_N, _S_P_C, _S_P_A_C_E, and _T_A_B. ! In addition to command names, readline allows keys to be bound to a string that is inserted when the key is pressed (a _m_a_c_r_o). --- 101,113 ---- or C-Meta-u: universal-argument ! ! into the _i_n_p_u_t_r_c would make M-C-u execute the readline command _u_n_i_v_e_r_s_a_l_-_a_r_g_u_m_e_n_t. ! The following symbolic character names are recognized ! while processing key bindings: _D_E_L, _E_S_C, _E_S_C_A_P_E, _L_F_D, _N_E_W_- ! _L_I_N_E, _R_E_T, _R_E_T_U_R_N, _R_U_B_O_U_T, _S_P_A_C_E, _S_P_C, and _T_A_B. ! In addition to command names, readline allows keys to be bound to a string that is inserted when the key is pressed (a _m_a_c_r_o). *************** *** 109,132 **** KKeeyy BBiinnddiinnggss ! The syntax for controlling key bindings in the _i_n_p_u_t_r_c ! file is simple. All that is required is the name of the command or the text of a macro and a key sequence to which ! it should be bound. The name may be specified in one of ! two ways: as a symbolic key name, possibly with _M_e_t_a_- or ! _C_o_n_t_r_o_l_- prefixes, or as a key sequence. When using the ! form kkeeyynnaammee:_f_u_n_c_t_i_o_n_-_n_a_m_e or _m_a_c_r_o, _k_e_y_n_a_m_e is the name ! of a key spelled out in English. For example: ! Control-u: universal-argument ! Meta-Rubout: backward-kill-word ! Control-o: ">&output" - In the above example, _C_-_u is bound to the function uunniivveerr-- - ssaall--aarrgguummeenntt, _M_-_D_E_L is bound to the function bbaacckk-- - wwaarrdd--kkiillll--wwoorrdd, and _C_-_o is bound to run the macro ! ! GNU 1999 Jun 1 2 --- 115,132 ---- KKeeyy BBiinnddiinnggss ! The syntax for controlling key bindings in the _i_n_p_u_t_r_c ! file is simple. All that is required is the name of the command or the text of a macro and a key sequence to which ! it should be bound. The name may be specified in one of ! two ways: as a symbolic key name, possibly with _M_e_t_a_- or ! _C_o_n_t_r_o_l_- prefixes, or as a key sequence. ! When using the form kkeeyynnaammee:_f_u_n_c_t_i_o_n_-_n_a_m_e or _m_a_c_r_o, _k_e_y_- ! _n_a_m_e is the name of a key spelled out in English. For ! example: ! GNU Readline 4.2 2001 Mar 5 2 *************** *** 137,148 **** ! expressed on the right hand side (that is, to insert the ! text _>_&_o_u_t_p_u_t into the line). ! In the second form, ""kkeeyysseeqq"":_f_u_n_c_t_i_o_n_-_n_a_m_e or _m_a_c_r_o, kkeeyy-- sseeqq differs from kkeeyynnaammee above in that strings denoting an ! entire key sequence may be specified by placing the ! sequence within double quotes. Some GNU Emacs style key ! escapes can be used, as in the following example. "\C-u": universal-argument --- 137,156 ---- ! Control-u: universal-argument ! Meta-Rubout: backward-kill-word ! Control-o: "> output" ! ! In the above example, _C_-_u is bound to the function uunniivveerr-- ! ssaall--aarrgguummeenntt, _M_-_D_E_L is bound to the function bbaacckk-- ! wwaarrdd--kkiillll--wwoorrdd, and _C_-_o is bound to run the macro ! expressed on the right hand side (that is, to insert the ! text ``> output'' into the line). ! In the second form, ""kkeeyysseeqq"":_f_u_n_c_t_i_o_n_-_n_a_m_e or _m_a_c_r_o, kkeeyy-- sseeqq differs from kkeeyynnaammee above in that strings denoting an ! entire key sequence may be specified by placing the ! sequence within double quotes. Some GNU Emacs style key ! escapes can be used, as in the following example, but the ! symbolic character names are not recognized. "\C-u": universal-argument *************** *** 153,164 **** vveerrssaall--aarrgguummeenntt. _C_-_x _C_-_r is bound to the function rree--rreeaadd--iinniitt--ffiillee, and _E_S_C _[ _1 _1 _~ is bound to insert the ! text FFuunnccttiioonn KKeeyy 11. The full set of GNU Emacs style ! escape sequences is \\CC-- control prefix \\MM-- meta prefix \\ee an escape character \\\\ backslash ! \\"" literal " ! \\'' literal ' In addition to the GNU Emacs style escape sequences, a --- 161,174 ---- vveerrssaall--aarrgguummeenntt. _C_-_x _C_-_r is bound to the function rree--rreeaadd--iinniitt--ffiillee, and _E_S_C _[ _1 _1 _~ is bound to insert the ! text ``Function Key 1''. ! ! The full set of GNU Emacs style escape sequences available ! when specifying key sequences is \\CC-- control prefix \\MM-- meta prefix \\ee an escape character \\\\ backslash ! \\"" literal ", a double quote ! \\'' literal ', a single quote In addition to the GNU Emacs style escape sequences, a *************** *** 180,198 **** should be used to indicate a macro definition. Unquoted text is assumed to be a function name. In the macro body, ! the backslash escapes described above are expanded. Back- ! slash will quote any other character in the macro text, ! including " and '. - BBaasshh allows the current readline key bindings to be dis- - played or modified with the bbiinndd builtin command. The - editing mode may be switched during interactive use by - using the --oo option to the sseett builtin command. Other - programs using this library provide similar mechanisms. - The _i_n_p_u_t_r_c file may be edited and re-read if a program - does not provide any other means to incorporate new ! ! GNU 1999 Jun 1 3 --- 190,198 ---- should be used to indicate a macro definition. Unquoted text is assumed to be a function name. In the macro body, ! the backslash escapes described above are expanded. ! GNU Readline 4.2 2001 Mar 5 3 *************** *** 203,207 **** ! bindings. VVaarriiaabblleess --- 203,217 ---- ! Backslash will quote any other character in the macro ! text, including " and '. ! ! BBaasshh allows the current readline key bindings to be dis- ! played or modified with the bbiinndd builtin command. The ! editing mode may be switched during interactive use by ! using the --oo option to the sseett builtin command. Other ! programs using this library provide similar mechanisms. ! The _i_n_p_u_t_r_c file may be edited and re-read if a program ! does not provide any other means to incorporate new bind- ! ings. VVaarriiaabblleess *************** *** 213,264 **** Except where noted, readline variables can take the values ! OOnn or OOffff. The variables and their default values are: bbeellll--ssttyyllee ((aauuddiibbllee)) ! Controls what happens when readline wants to ring ! the terminal bell. If set to nnoonnee, readline never rings the bell. If set to vviissiibbllee, readline uses a ! visible bell if one is available. If set to aauuddii-- bbllee, readline attempts to ring the terminal's bell. ccoommmmeenntt--bbeeggiinn ((````##'''')) ! The string that is inserted in vvii mode when the ! iinnsseerrtt--ccoommmmeenntt command is executed. This command ! is bound to MM--## in emacs mode and to ## in vi com- mand mode. ccoommpplleettiioonn--iiggnnoorree--ccaassee ((OOffff)) ! If set to OOnn, readline performs filename matching and completion in a case-insensitive fashion. ccoommpplleettiioonn--qquueerryy--iitteemmss ((110000)) ! This determines when the user is queried about ! viewing the number of possible completions gener- ! ated by the ppoossssiibbllee--ccoommpplleettiioonnss command. It may ! be set to any integer value greater than or equal ! to zero. If the number of possible completions is ! greater than or equal to the value of this vari- able, the user is asked whether or not he wishes to ! view them; otherwise they are simply listed on the terminal. ccoonnvveerrtt--mmeettaa ((OOnn)) If set to OOnn, readline will convert characters with ! the eighth bit set to an ASCII key sequence by ! stripping the eighth bit and prepending an escape ! character (in effect, using escape as the _m_e_t_a _p_r_e_- ! _f_i_x). ! ddiissaabbllee--ccoommpplleettiioonn ((OOffff)) ! If set to OOnn, readline will inhibit word comple- ! tion. Completion characters will be inserted into ! the line as if they had been mapped to sseellff--iinnsseerrtt. ! eeddiittiinngg--mmooddee ((eemmaaccss)) ! Controls whether readline begins with a set of key ! bindings similar to _e_m_a_c_s or _v_i. eeddiittiinngg--mmooddee can ! be set to either eemmaaccss or vvii. ! eennaabbllee--kkeeyyppaadd ((OOffff)) ! When set to OOnn, readline will try to enable the ! application keypad when it is called. Some systems ! need this to enable the arrow keys. ! GNU 1999 Jun 1 4 --- 223,264 ---- Except where noted, readline variables can take the values ! OOnn or OOffff (without regard to case). The variables and ! their default values are: bbeellll--ssttyyllee ((aauuddiibbllee)) ! Controls what happens when readline wants to ring ! the terminal bell. If set to nnoonnee, readline never rings the bell. If set to vviissiibbllee, readline uses a ! visible bell if one is available. If set to aauuddii-- bbllee, readline attempts to ring the terminal's bell. ccoommmmeenntt--bbeeggiinn ((````##'''')) ! The string that is inserted in vvii mode when the ! iinnsseerrtt--ccoommmmeenntt command is executed. This command ! is bound to MM--## in emacs mode and to ## in vi com- mand mode. ccoommpplleettiioonn--iiggnnoorree--ccaassee ((OOffff)) ! If set to OOnn, readline performs filename matching and completion in a case-insensitive fashion. ccoommpplleettiioonn--qquueerryy--iitteemmss ((110000)) ! This determines when the user is queried about ! viewing the number of possible completions gener- ! ated by the ppoossssiibbllee--ccoommpplleettiioonnss command. It may ! be set to any integer value greater than or equal ! to zero. If the number of possible completions is ! greater than or equal to the value of this vari- able, the user is asked whether or not he wishes to ! view them; otherwise they are simply listed on the terminal. ccoonnvveerrtt--mmeettaa ((OOnn)) If set to OOnn, readline will convert characters with ! the eighth bit set to an ASCII key sequence by ! stripping the eighth bit and prefixing it with an ! escape character (in effect, using escape as the ! _m_e_t_a _p_r_e_f_i_x). ! ! GNU Readline 4.2 2001 Mar 5 4 *************** *** 269,302 **** eexxppaanndd--ttiillddee ((OOffff)) ! If set to oonn, tilde expansion is performed when readline attempts word completion. hhoorriizzoonnttaall--ssccrroollll--mmooddee ((OOffff)) ! When set to OOnn, makes readline use a single line ! for display, scrolling the input horizontally on a ! single screen line when it becomes longer than the screen width rather than wrapping to a new line. iinnppuutt--mmeettaa ((OOffff)) ! If set to OOnn, readline will enable eight-bit input ! (that is, it will not strip the high bit from the characters it reads), regardless of what the termi- nal claims it can support. The name mmeettaa--ffllaagg is a synonym for this variable. ! iisseeaarrcchh--tteerrmmiinnaattoorrss ((````CC--[[CC--JJ'''')) ! The string of characters that should terminate an ! incremental search without subsequently executing ! the character as a command. If this variable has ! not been given a value, the characters _E_S_C and _C_-_J will terminate an incremental search. kkeeyymmaapp ((eemmaaccss)) ! Set the current readline keymap. The set of legal ! keymap names is _e_m_a_c_s_, _e_m_a_c_s_-_s_t_a_n_d_a_r_d_, _e_m_a_c_s_-_m_e_t_a_, _e_m_a_c_s_-_c_t_l_x_, _v_i_, _v_i_-_m_o_v_e_, _v_i_-_c_o_m_m_a_n_d, and _v_i_-_i_n_s_e_r_t. _v_i is equivalent to _v_i_-_c_o_m_m_a_n_d; _e_m_a_c_s is equivalent ! to _e_m_a_c_s_-_s_t_a_n_d_a_r_d. The default value is _e_m_a_c_s; the ! value of eeddiittiinngg--mmooddee also affects the default keymap. mmaarrkk--ddiirreeccttoorriieess ((OOnn)) ! If set to OOnn, complete>)) ! Set the mark to the current point. If a numeric ! argument is supplied, the mark is set to that posi- ! tion. ! eexxcchhaannggee--ppooiinntt--aanndd--mmaarrkk ((CC--xx CC--xx)) ! Swap the point with the mark. The current cursor ! position is set to the saved position, and the old ! GNU 1999 Jun 1 12 --- 780,792 ---- bbeellll--ssttyyllee). ddoo--uuppppeerrccaassee--vveerrssiioonn ((MM--aa,, MM--bb,, MM--_x,, ......)) ! If the metafied character _x is lowercase, run the ! command that is bound to the corresponding upper- case character. pprreeffiixx--mmeettaa ((EESSCC)) ! Metafy the next character typed. EESSCC ff is ! GNU Readline 4.2 2001 Mar 5 12 *************** *** 797,800 **** --- 797,816 ---- + equivalent to MMeettaa--ff. + uunnddoo ((CC--__,, CC--xx CC--uu)) + Incremental undo, separately remembered for each + line. + rreevveerrtt--lliinnee ((MM--rr)) + Undo all changes made to this line. This is like + executing the uunnddoo command enough times to return + the line to its initial state. + ttiillddee--eexxppaanndd ((MM--&&)) + Perform tilde expansion on the current word. + sseett--mmaarrkk ((CC--@@,, MM--<>)) + Set the mark to the point. If a numeric argument + is supplied, the mark is set to that position. + eexxcchhaannggee--ppooiinntt--aanndd--mmaarrkk ((CC--xx CC--xx)) + Swap the point with the mark. The current cursor + position is set to the saved position, and the old cursor position is saved as the mark. cchhaarraacctteerr--sseeaarrcchh ((CC--]])) *************** *** 810,815 **** inserted at the beginning of the current line, and the line is accepted as if a newline had been ! typed. This makes the current line a shell com- ! ment. dduummpp--ffuunnccttiioonnss Print all of the functions and their key bindings --- 826,831 ---- inserted at the beginning of the current line, and the line is accepted as if a newline had been ! typed. The default value of ccoommmmeenntt--bbeeggiinn makes ! the current line a shell comment. dduummpp--ffuunnccttiioonnss Print all of the functions and their key bindings *************** *** 836,858 **** vvii editing mode. - DDEEFFAAUULLTT KKEEYY BBIINNDDIINNGGSS - The following is a list of the default emacs and vi bind- - ings. Characters with the 8th bit set are written as - M-, and are referred to as _m_e_t_a_f_i_e_d characters. - The printable ASCII characters not mentioned in the list - of emacs standard bindings are bound to the _s_e_l_f_-_i_n_s_e_r_t - function, which just inserts the given character into the - input line. In vi insertion mode, all characters not - specifically mentioned are bound to _s_e_l_f_-_i_n_s_e_r_t. Charac- - ters assigned to signal generation by _s_t_t_y(1) or the ter- - minal driver, such as C-Z or C-C, retain that function. - Upper and lower case _m_e_t_a_f_i_e_d characters are bound to the - same function in the emacs mode meta keymap. The remain- - ing characters are unbound, which causes readline to ring - the bell (subject to the setting of the bbeellll--ssttyyllee - ! GNU 1999 Jun 1 13 --- 852,858 ---- vvii editing mode. ! GNU Readline 4.2 2001 Mar 5 13 *************** *** 863,867 **** ! variable). EEmmaaccss MMooddee --- 863,882 ---- ! DDEEFFAAUULLTT KKEEYY BBIINNDDIINNGGSS ! The following is a list of the default emacs and vi bind- ! ings. Characters with the eighth bit set are written as ! M-, and are referred to as _m_e_t_a_f_i_e_d characters. ! The printable ASCII characters not mentioned in the list ! of emacs standard bindings are bound to the sseellff--iinnsseerrtt ! function, which just inserts the given character into the ! input line. In vi insertion mode, all characters not ! specifically mentioned are bound to sseellff--iinnsseerrtt. Charac- ! ters assigned to signal generation by _s_t_t_y(1) or the ter- ! minal driver, such as C-Z or C-C, retain that function. ! Upper and lower case metafied characters are bound to the ! same function in the emacs mode meta keymap. The remain- ! ing characters are unbound, which causes readline to ring ! the bell (subject to the setting of the bbeellll--ssttyyllee vari- ! able). EEmmaaccss MMooddee *************** *** 902,905 **** --- 917,932 ---- "M-C-G" abort "M-C-H" backward-kill-word + + + + GNU Readline 4.2 2001 Mar 5 14 + + + + + + READLINE(3) READLINE(3) + + "M-C-I" tab-insert "M-C-J" vi-editing-mode *************** *** 917,932 **** "M-0" digit-argument "M-1" digit-argument - - - - GNU 1999 Jun 1 14 - - - - - - READLINE(3) READLINE(3) - - "M-2" digit-argument "M-3" digit-argument --- 944,947 ---- *************** *** 954,958 **** "M-\" delete-horizontal-space "M-~" tilde-expand ! "M-C-?" backward-delete-word "M-_" yank-last-arg --- 969,973 ---- "M-\" delete-horizontal-space "M-~" tilde-expand ! "M-C-?" backward-kill-word "M-_" yank-last-arg *************** *** 969,972 **** --- 984,998 ---- + + + GNU Readline 4.2 2001 Mar 5 15 + + + + + + READLINE(3) READLINE(3) + + VVII MMooddee bbiinnddiinnggss VI Insert Mode functions *************** *** 983,998 **** "C-V" quoted-insert "C-W" unix-word-rubout - - - - GNU 1999 Jun 1 15 - - - - - - READLINE(3) READLINE(3) - - "C-Y" yank "C-[" vi-movement-mode --- 1009,1012 ---- *************** *** 1021,1024 **** --- 1035,1039 ---- "C-W" unix-word-rubout "C-Y" yank + "C-_" vi-undo " " forward-char "#" insert-comment *************** *** 1034,1037 **** --- 1049,1064 ---- "0" beginning-of-line "1" to "9" vi-arg-digit + + + + GNU Readline 4.2 2001 Mar 5 16 + + + + + + READLINE(3) READLINE(3) + + ";" vi-char-search "=" vi-complete *************** *** 1049,1064 **** "R" vi-replace "S" vi-subst - - - - GNU 1999 Jun 1 16 - - - - - - READLINE(3) READLINE(3) - - "T" vi-char-search "U" revert-line --- 1076,1079 ---- *************** *** 1087,1091 **** "s" vi-subst "t" vi-char-search ! "u" undo "w" vi-next-word "x" vi-delete --- 1102,1106 ---- "s" vi-subst "t" vi-char-search ! "u" vi-undo "w" vi-next-word "x" vi-delete *************** *** 1099,1102 **** --- 1114,1130 ---- _b_a_s_h(1) + + + + + GNU Readline 4.2 2001 Mar 5 17 + + + + + + READLINE(3) READLINE(3) + + FFIILLEESS _~_/_._i_n_p_u_t_r_c *************** *** 1116,1130 **** library that you have. - - - GNU 1999 Jun 1 17 - - - - - - READLINE(3) READLINE(3) - - Once you have determined that a bug actually exists, mail a bug report to _b_u_g_-_r_e_a_d_l_i_n_e@_g_n_u_._o_r_g. If you have a fix, --- 1144,1147 ---- *************** *** 1167,1188 **** ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! GNU 1999 Jun 1 18 --- 1184,1188 ---- ! GNU Readline 4.2 2001 Mar 5 18 diff -Nrc2 readline-4.1/doc/readline.3 readline-4.2/doc/readline.3 *** readline-4.1/doc/readline.3 Fri Aug 6 15:43:04 1999 --- readline-4.2/doc/readline.3 Mon Mar 5 11:11:38 2001 *************** *** 7,13 **** .\" chet@ins.CWRU.Edu .\" ! .\" Last Change: Tue Jun 1 13:28:03 EDT 1999 .\" ! .TH READLINE 3 "1999 Jun 1" GNU .\" .\" File Name macro. This used to be `.PN', for Path Name, --- 7,13 ---- .\" chet@ins.CWRU.Edu .\" ! .\" Last Change: Mon Mar 5 09:58:38 EST 2001 .\" ! .TH READLINE 3 "2001 Mar 5" "GNU Readline 4.2" .\" .\" File Name macro. This used to be `.PN', for Path Name, *************** *** 24,41 **** .ft B #include ! #include ! #include .ft .fi .LP .nf ! .ft B ! char *readline (prompt) ! char *prompt; ! .ft .fi .SH COPYRIGHT ! .if n Readline is Copyright (C) 1989, 1991, 1993, 1995, 1996 by the Free Software Foundation, Inc. ! .if t Readline is Copyright \(co 1989, 1991, 1993, 1995, 1996 by the Free Software Foundation, Inc. .SH DESCRIPTION .LP --- 24,40 ---- .ft B #include ! #include ! #include .ft .fi .LP .nf ! \fIchar *\fP ! .br ! \fBreadline\fP (\fIconst char *prompt\fP); .fi .SH COPYRIGHT ! .if n Readline is Copyright (C) 1989\-2001 by the Free Software Foundation, Inc. ! .if t Readline is Copyright \(co 1989\-2001 by the Free Software Foundation, Inc. .SH DESCRIPTION .LP *************** *** 46,52 **** as a prompt. If .B prompt ! is null, no prompt is issued. The line returned is allocated with ! .IR malloc (3), ! so the caller must free it when finished. The line returned has the final newline removed, so only the text of the line remains. --- 45,52 ---- as a prompt. If .B prompt ! is \fBNULL\fP or the empty string, no prompt is issued. ! The line returned is allocated with ! .IR malloc (3); ! the caller must free it when finished. The line returned has the final newline removed, so only the text of the line remains. *************** *** 58,61 **** --- 58,66 ---- are similar to those of emacs. A vi\-style line editing interface is also available. + .LP + This manual page describes only the most basic use of \fBreadline\fP. + Much more functionality is available; see + \fIThe GNU Readline Library\fP and \fIThe GNU History Library\fP + for additional information. .SH RETURN VALUE .LP *************** *** 131,134 **** --- 136,140 ---- C\-Meta\-u: universal\-argument .RE + .sp into the .I inputrc *************** *** 138,150 **** The following symbolic character names are recognized while processing key bindings: - .IR RUBOUT , .IR DEL , .IR ESC , .IR LFD , .IR NEWLINE , .IR RET , .IR RETURN , ! .IR SPC , .IR SPACE , and .IR TAB . --- 144,157 ---- The following symbolic character names are recognized while processing key bindings: .IR DEL , .IR ESC , + .IR ESCAPE , .IR LFD , .IR NEWLINE , .IR RET , .IR RETURN , ! .IR RUBOUT , .IR SPACE , + .IR SPC , and .IR TAB . *************** *** 162,165 **** --- 169,173 ---- as a symbolic key name, possibly with \fIMeta\-\fP or \fIControl\-\fP prefixes, or as a key sequence. + .PP When using the form \fBkeyname\fP:\^\fIfunction-name\fP or \fImacro\fP, .I keyname *************** *** 171,175 **** Meta\-Rubout: backward\-kill\-word .br ! Control\-o: ">&output" .RE .LP --- 179,183 ---- Meta\-Rubout: backward\-kill\-word .br ! Control\-o: "> output" .RE .LP *************** *** 185,189 **** is bound to run the macro expressed on the right hand side (that is, to insert the text ! .I >&output into the line). .PP --- 193,198 ---- is bound to run the macro expressed on the right hand side (that is, to insert the text ! .if t \f(CW> output\fP ! .if n ``> output'' into the line). .PP *************** *** 195,199 **** an entire key sequence may be specified by placing the sequence within double quotes. Some GNU Emacs style key escapes can be ! used, as in the following example. .sp .RS --- 204,209 ---- an entire key sequence may be specified by placing the sequence within double quotes. Some GNU Emacs style key escapes can be ! used, as in the following example, but the symbolic character names ! are not recognized. .sp .RS *************** *** 215,220 **** .I "ESC [ 1 1 ~" is bound to insert the text ! .BR "Function Key 1" . ! The full set of GNU Emacs style escape sequences is .RS .PD 0 --- 225,233 ---- .I "ESC [ 1 1 ~" is bound to insert the text ! .if t \f(CWFunction Key 1\fP. ! .if n ``Function Key 1''. ! .PP ! The full set of GNU Emacs style escape sequences available when specifying ! key sequences is .RS .PD 0 *************** *** 233,240 **** .TP .B \e" ! literal " .TP .B \e' ! literal ' .RE .PD --- 246,253 ---- .TP .B \e" ! literal ", a double quote .TP .B \e' ! literal ', a single quote .RE .PD *************** *** 314,318 **** .B On or ! .BR Off . The variables and their default values are: .PP --- 327,332 ---- .B On or ! .B Off ! (without regard to case). The variables and their default values are: .PP *************** *** 352,356 **** If set to \fBOn\fP, readline will convert characters with the eighth bit set to an ASCII key sequence ! by stripping the eighth bit and prepending an escape character (in effect, using escape as the \fImeta prefix\fP). .TP --- 366,370 ---- If set to \fBOn\fP, readline will convert characters with the eighth bit set to an ASCII key sequence ! by stripping the eighth bit and prefixing it with an escape character (in effect, using escape as the \fImeta prefix\fP). .TP *************** *** 362,366 **** .B editing\-mode (emacs) Controls whether readline begins with a set of key bindings similar ! to \fIemacs\fP or \fIvi\fP. .B editing\-mode can be set to either --- 376,380 ---- .B editing\-mode (emacs) Controls whether readline begins with a set of key bindings similar ! to emacs or vi. .B editing\-mode can be set to either *************** *** 385,394 **** .B input\-meta (Off) If set to \fBOn\fP, readline will enable eight-bit input (that is, ! it will not strip the high bit from the characters it reads), regardless of what the terminal claims it can support. The name .B meta\-flag is a synonym for this variable. .TP ! .B isearch\-terminators (``C\-[C\-J'') The string of characters that should terminate an incremental search without subsequently executing the character as a command. --- 399,408 ---- .B input\-meta (Off) If set to \fBOn\fP, readline will enable eight-bit input (that is, ! it will not clear the eighth bit in the characters it reads), regardless of what the terminal claims it can support. The name .B meta\-flag is a synonym for this variable. .TP ! .B isearch\-terminators (``C\-[ C\-J'') The string of characters that should terminate an incremental search without subsequently executing the character as a command. *************** *** 403,413 **** \fIvi\fP is equivalent to \fIvi-command\fP; \fIemacs\fP is equivalent to \fIemacs-standard\fP. The default value is ! .IR emacs ; ! the value of .B editing\-mode also affects the default keymap. .TP .B mark\-directories (On) ! If set to \fBOn\fP, complete) ! Set the mark to the current point. If a numeric argument is supplied, the mark is set to that position. .TP --- 901,906 ---- Perform tilde expansion on the current word. .TP ! .B set\-mark (C\-@, M\-) ! Set the mark to the point. If a numeric argument is supplied, the mark is set to that position. .TP *************** *** 895,900 **** .B comment\-begin variable is inserted at the beginning of the current line, and the line ! is accepted as if a newline had been typed. This makes the current line ! a shell comment. .TP .B dump\-functions --- 921,927 ---- .B comment\-begin variable is inserted at the beginning of the current line, and the line ! is accepted as if a newline had been typed. The default value of ! .B comment\-begin ! makes the current line a shell comment. .TP .B dump\-functions *************** *** 933,937 **** .LP The following is a list of the default emacs and vi bindings. ! Characters with the 8th bit set are written as M\-, and are referred to as .I metafied --- 960,964 ---- .LP The following is a list of the default emacs and vi bindings. ! Characters with the eighth bit set are written as M\-, and are referred to as .I metafied *************** *** 939,955 **** The printable ASCII characters not mentioned in the list of emacs standard bindings are bound to the ! .I self\-insert function, which just inserts the given character into the input line. In vi insertion mode, all characters not specifically mentioned are bound to ! .IR self\-insert . Characters assigned to signal generation by .IR stty (1) or the terminal driver, such as C-Z or C-C, retain that function. ! Upper and lower case ! .I metafied ! characters are bound to the same function in the emacs mode ! meta keymap. The remaining characters are unbound, which causes readline to ring the bell (subject to the setting of the --- 966,980 ---- The printable ASCII characters not mentioned in the list of emacs standard bindings are bound to the ! .B self\-insert function, which just inserts the given character into the input line. In vi insertion mode, all characters not specifically mentioned are bound to ! .BR self\-insert . Characters assigned to signal generation by .IR stty (1) or the terminal driver, such as C-Z or C-C, retain that function. ! Upper and lower case metafied characters are bound to the same function in ! the emacs mode meta keymap. The remaining characters are unbound, which causes readline to ring the bell (subject to the setting of the *************** *** 1037,1041 **** "M-\e" delete-horizontal-space "M-~" tilde-expand ! "M-C-?" backward-delete-word "M-_" yank-last-arg .PP --- 1062,1066 ---- "M-\e" delete-horizontal-space "M-~" tilde-expand ! "M-C-?" backward-kill-word "M-_" yank-last-arg .PP *************** *** 1097,1100 **** --- 1122,1126 ---- "C-W" unix-word-rubout "C-Y" yank + "C-_" vi-undo "\^ " forward-char "#" insert-comment *************** *** 1151,1155 **** "s" vi-subst "t" vi-char-search ! "u" undo "w" vi-next-word "x" vi-delete --- 1177,1181 ---- "s" vi-subst "t" vi-char-search ! "u" vi-undo "w" vi-next-word "x" vi-delete Binary files readline-4.1/doc/readline.dvi and readline-4.2/doc/readline.dvi differ diff -Nrc2 readline-4.1/doc/readline.html readline-4.2/doc/readline.html *** readline-4.1/doc/readline.html Wed Mar 1 14:53:12 2000 --- readline-4.2/doc/readline.html Mon Apr 16 11:05:45 2001 *************** *** 2,6 **** GNU Readline Library --- 2,6 ---- GNU Readline Library *************** *** 8,13 ****

    GNU Readline Library

    !

    Edition 4.1, for Readline Library Version 4.1.

    !

    January 2000

    Brian Fox, Free Software Foundation
    Chet Ramey, Case Western Reserve University
    --- 8,13 ----

    GNU Readline Library

    !

    Edition 4.2, for Readline Library Version 4.2.

    !

    Apr 2001

    Brian Fox, Free Software Foundation
    Chet Ramey, Case Western Reserve University
    *************** *** 51,55 ****
  • Custom Functions --- 51,55 ----
  • Custom Functions *************** *** 64,82 ****
  • Redisplay
  • Modifying Text !
  • Utility Functions !
  • Alternate Interface !
  • An Example !
  • Readline Signal Handling !
  • Custom Completers !
  • Concept Index !
  • Function and Variable Index


    --- 64,85 ----

  • Redisplay
  • Modifying Text !
  • Character Input !
  • Terminal Management !
  • Utility Functions !
  • Miscellaneous Functions !
  • Alternate Interface !
  • A Readline Example !
  • Readline Signal Handling !
  • Custom Completers !
  • Concept Index !
  • Function and Variable Index


    *************** *** 115,119 ****

    ! Copyright (C) 1988-1999 Free Software Foundation, Inc.

    --- 118,122 ----

    ! Copyright (C) 1988-2001 Free Software Foundation, Inc.

    *************** *** 170,174 **** If you do not have a Meta or ALT key, or another key working as a Meta key, the identical keystroke can be generated by typing ESC ! first, and then typing k. Either process is known as metafying the k key. --- 173,177 ---- If you do not have a Meta or ALT key, or another key working as a Meta key, the identical keystroke can be generated by typing ESC ! first, and then typing k. Either process is known as metafying the k key. *************** *** 205,210 **** you move the cursor to the place that needs correction, and delete or insert the text of the corrections. Then, when you are satisfied with ! the line, you simply press RETURN. You do not have to be at the ! end of the line to press RETURN; the entire line is accepted regardless of the location of the cursor within the line. --- 208,213 ---- you move the cursor to the place that needs correction, and delete or insert the text of the corrections. Then, when you are satisfied with ! the line, you simply press RET. You do not have to be at the ! end of the line to press RET; the entire line is accepted regardless of the location of the cursor within the line. *************** *** 367,371 **** Word boundaries are the same as those used by M-f. !
    M-DEL
    Kill from the cursor the start of the previous word, or, if between --- 370,374 ---- Word boundaries are the same as those used by M-f. !
    M-DEL
    Kill from the cursor the start of the previous word, or, if between *************** *** 376,380 ****
    Kill from the cursor to the previous whitespace. This is different than ! M-DEL because the word boundaries differ.
  • --- 379,383 ----
    Kill from the cursor to the previous whitespace. This is different than ! M-DEL because the word boundaries differ.
    *************** *** 416,420 **** you have typed one meta digit to get the argument started, you can type the remainder of the digits, and then the command. For example, to give ! the C-d command an argument of 10, you could type `M-1 0 C-d'.

    --- 419,424 ---- you have typed one meta digit to get the argument started, you can type the remainder of the digits, and then the command. For example, to give ! the C-d command an argument of 10, you could type `M-1 0 C-d', ! which will delete the next ten characters on the input line.

    *************** *** 426,430 **** Readline provides commands for searching through the command history for lines containing a specified string. ! There are two search modes: incremental and non-incremental.

    --- 430,434 ---- Readline provides commands for searching through the command history for lines containing a specified string. ! There are two search modes: incremental and non-incremental.

    *************** *** 456,459 **** --- 460,465 ---- For instance, a RET will terminate the search and accept the line, thereby executing the command from the history list. + A movement command will terminate the search, make the last line found + the current line, and begin editing.

    *************** *** 478,482 **** commands in an inputrc file, conventionally in his home directory. The name of this ! file is taken from the value of the environment variable INPUTRC. If that variable is unset, the default is `~/.inputrc'. --- 484,488 ---- commands in an inputrc file, conventionally in his home directory. The name of this ! file is taken from the value of the environment variable @env{INPUTRC}. If that variable is unset, the default is `~/.inputrc'. *************** *** 520,524 **** You can modify the run-time behavior of Readline by altering the values of variables in Readline ! using the set command within the init file. Here is how to change from the default Emacs-like key binding to use vi line editing commands: --- 526,538 ---- You can modify the run-time behavior of Readline by altering the values of variables in Readline ! using the set command within the init file. ! The syntax is simple: ! ! !
    ! set variable value
    ! 
    ! ! Here, for example, is how to change from the default Emacs-like key binding to use vi line editing commands: *************** *** 529,540 ****
    A great deal of run-time behavior is changeable with the following variables.
    bell-style
    ! Controls what happens when Readline wants to ring the terminal bell. If set to `none', Readline never rings the bell. If set to --- 543,558 ----
    + Variable names and values, where appropriate, are recognized without regard + to case. + A great deal of run-time behavior is changeable with the following variables. +
    bell-style
    ! Controls what happens when Readline wants to ring the terminal bell. If set to `none', Readline never rings the bell. If set to *************** *** 545,549 ****
    comment-begin
    ! The string to insert at the beginning of the line when the insert-comment command is executed. The default value --- 563,567 ----
    comment-begin
    ! The string to insert at the beginning of the line when the insert-comment command is executed. The default value *************** *** 558,572 ****
    completion-query-items
    ! The number of possible completions that determines when the user is asked whether he wants to see the list of possibilities. If the number of possible completions is greater than this value, Readline will ask the user whether or not he wishes to view ! them; otherwise, they are simply listed. The default limit is ! 100.
    convert-meta
    ! If set to `on', Readline will convert characters with the eighth bit set to an ASCII key sequence by stripping the eighth --- 576,591 ----
    completion-query-items
    ! The number of possible completions that determines when the user is asked whether he wants to see the list of possibilities. If the number of possible completions is greater than this value, Readline will ask the user whether or not he wishes to view ! them; otherwise, they are simply listed. ! This variable must be set to an integer value greater than or equal to 0. ! The default limit is 100.
    convert-meta
    ! If set to `on', Readline will convert characters with the eighth bit set to an ASCII key sequence by stripping the eighth *************** *** 576,580 ****
    disable-completion
    ! If set to `On', Readline will inhibit word completion. Completion characters will be inserted into the line as if they had --- 595,599 ----
    disable-completion
    ! If set to `On', Readline will inhibit word completion. Completion characters will be inserted into the line as if they had *************** *** 583,587 ****
    editing-mode
    ! The editing-mode variable controls which default set of key bindings is used. By default, Readline starts up in Emacs editing --- 602,606 ----
    editing-mode
    ! The editing-mode variable controls which default set of key bindings is used. By default, Readline starts up in Emacs editing *************** *** 591,595 ****
    enable-keypad
    ! When set to `on', Readline will try to enable the application keypad when it is called. Some systems need this to enable the --- 610,614 ----
    enable-keypad
    ! When set to `on', Readline will try to enable the application keypad when it is called. Some systems need this to enable the *************** *** 598,602 ****
    expand-tilde
    ! If set to `on', tilde expansion is performed when Readline attempts word completion. The default is `off'. --- 617,621 ----
    expand-tilde
    ! If set to `on', tilde expansion is performed when Readline attempts word completion. The default is `off'. *************** *** 604,608 ****
    horizontal-scroll-mode
    ! This variable can be set to either `on' or `off'. Setting it to `on' means that the text of the lines being edited will scroll --- 623,627 ----
    horizontal-scroll-mode
    ! This variable can be set to either `on' or `off'. Setting it to `on' means that the text of the lines being edited will scroll *************** *** 613,620 ****
    input-meta
    - If set to `on', Readline will enable eight-bit input (it ! will not strip the eighth bit from the characters it reads), regardless of what the terminal claims it can support. The default value is `off'. The name meta-flag is a --- 632,639 ----
    input-meta
    + If set to `on', Readline will enable eight-bit input (it ! will not clear the eighth bit in the characters it reads), regardless of what the terminal claims it can support. The default value is `off'. The name meta-flag is a *************** *** 623,627 ****
    isearch-terminators
    ! The string of characters that should terminate an incremental search without subsequently executing the character as a command (see section Searching for Commands in the History). --- 642,646 ----
    isearch-terminators
    ! The string of characters that should terminate an incremental search without subsequently executing the character as a command (see section Searching for Commands in the History). *************** *** 631,635 ****
    keymap
    ! Sets Readline's idea of the current keymap for key binding commands. Acceptable keymap names are --- 650,654 ----
    keymap
    ! Sets Readline's idea of the current keymap for key binding commands. Acceptable keymap names are *************** *** 639,642 **** --- 658,662 ---- emacs-ctlx, vi, + vi-move, vi-command, and vi-insert. *************** *** 653,657 ****
    mark-modified-lines
    ! This variable, when set to `on', causes Readline to display an asterisk (`*') at the start of history lines which have been modified. --- 673,677 ----
    mark-modified-lines
    ! This variable, when set to `on', causes Readline to display an asterisk (`*') at the start of history lines which have been modified. *************** *** 660,664 ****
    output-meta
    ! If set to `on', Readline will display characters with the eighth bit set directly rather than as a meta-prefixed escape --- 680,684 ----
    output-meta
    ! If set to `on', Readline will display characters with the eighth bit set directly rather than as a meta-prefixed escape *************** *** 673,677 ****
    show-all-if-ambiguous
    ! This alters the default behavior of the completion functions. If set to `on', --- 693,697 ----
    show-all-if-ambiguous
    ! This alters the default behavior of the completion functions. If set to `on', *************** *** 682,686 ****
    visible-stats
    ! If set to `on', a character denoting a file's type is appended to the filename when listing possible --- 702,706 ----
    visible-stats
    ! If set to `on', a character denoting a file's type is appended to the filename when listing possible *************** *** 697,705 **** the command does. ! Once you know the name of the command, simply place the name of the key you wish to bind the command to, a colon, and then the name of the ! command on a line in the init file. The name of the key ! can be expressed in different ways, depending on which is most ! comfortable for you.
    --- 717,729 ---- the command does. ! Once you know the name of the command, simply place on a line ! in the init file the name of the key you wish to bind the command to, a colon, and then the name of the ! command. The name of the key ! can be expressed in different ways, depending on what you find most ! comfortable. ! ! In addition to command names, readline allows keys to be bound ! to a string that is inserted when the key is pressed (a macro).
    *************** *** 716,723 **** In the above example, C-u is bound to the function ! universal-argument, and C-o is bound to run the macro expressed on the right hand side (that is, to insert the text `> output' into the line).
    "keyseq": function-name or macro
    --- 740,764 ---- In the above example, C-u is bound to the function ! universal-argument, ! M-DEL is bound to the function backward-kill-word, and ! C-o is bound to run the macro expressed on the right hand side (that is, to insert the text `> output' into the line). + A number of symbolic character names are recognized while + processing this key binding syntax: + DEL, + ESC, + ESCAPE, + LFD, + NEWLINE, + RET, + RETURN, + RUBOUT, + SPACE, + SPC, + and + TAB. +
    "keyseq": function-name or macro
    *************** *** 735,739 **** ! In the above example, C-u is bound to the function universal-argument (just as it was in the first example), `C-x C-r' is bound to the function re-read-init-file, --- 776,780 ---- ! In the above example, C-u is again bound to the function universal-argument (just as it was in the first example), `C-x C-r' is bound to the function re-read-init-file, *************** *** 799,807 ****
    \nnn
    ! the character whose ASCII code is the octal value nnn (one to three digits)
    \xnnn
    ! the character whose ASCII code is the hexadecimal value nnn (one to three digits)
    --- 840,848 ----
    \nnn
    ! the character whose ASCII code is the octal value nnn (one to three digits)
    \xnnn
    ! the character whose ASCII code is the hexadecimal value nnn (one to three digits)
    *************** *** 813,817 **** Backslash will quote any other character in the macro text, including `"' and `''. ! For example, the following binding will make `C-x \' insert a single `\' into the line: --- 854,858 ---- Backslash will quote any other character in the macro text, including `"' and `''. ! For example, the following binding will make `C-x \' insert a single `\' into the line: *************** *** 867,871 **** The application construct is used to include application-specific settings. Each program using the Readline ! library sets the application name, and you can test for it. This could be used to bind key sequences to functions useful for a specific program. For instance, the following command adds a --- 908,913 ---- The application construct is used to include application-specific settings. Each program using the Readline ! library sets the application name, and you can test for ! a particular value. This could be used to bind key sequences to functions useful for a specific program. For instance, the following command adds a *************** *** 895,898 **** --- 937,941 ---- This directive takes a single filename as an argument and reads commands and bindings from that file. + For example, the following directive reads from `/etc/inputrc':
    ***************
    *** 907,911 ****
      
      

    ! Here is an example of an inputrc file. This illustrates key binding, variable assignment, and conditional syntax. --- 950,954 ----

    ! Here is an example of an inputrc file. This illustrates key binding, variable assignment, and conditional syntax. *************** *** 1031,1042 **** This section describes Readline commands that may be bound to key sequences.

    ! Command names without an accompanying key sequence are unbound by default. ! In the following descriptions, point refers to the current cursor ! position, and mark refers to a cursor position saved by the set-mark command. ! The text between the point and mark is referred to as the region.

    --- 1074,1085 ---- This section describes Readline commands that may be bound to key sequences. + Command names without an accompanying key sequence are unbound by default.

    ! In the following descriptions, point refers to the current cursor ! position, and mark refers to a cursor position saved by the set-mark command. ! The text between the point and mark is referred to as the region.

    *************** *** 1048,1072 ****
    beginning-of-line (C-a)
    ! Move to the start of the current line.
    end-of-line (C-e)
    ! Move to the end of the line.
    forward-char (C-f)
    ! Move forward a character.
    backward-char (C-b)
    ! Move back a character.
    forward-word (M-f)
    ! Move forward to the end of the next word. Words are composed of letters and digits. --- 1091,1115 ----
    beginning-of-line (C-a)
    ! Move to the start of the current line.
    end-of-line (C-e)
    ! Move to the end of the line.
    forward-char (C-f)
    ! Move forward a character.
    backward-char (C-b)
    ! Move back a character.
    forward-word (M-f)
    ! Move forward to the end of the next word. Words are composed of letters and digits. *************** *** 1074,1078 ****
    backward-word (M-b)
    ! Move back to the start of the current or previous word. Words are composed of letters and digits. --- 1117,1121 ----
    backward-word (M-b)
    ! Move back to the start of the current or previous word. Words are composed of letters and digits. *************** *** 1080,1084 ****
    clear-screen (C-l)
    ! Clear the screen and redraw the current line, leaving the current line at the top of the screen. --- 1123,1127 ----
    clear-screen (C-l)
    ! Clear the screen and redraw the current line, leaving the current line at the top of the screen. *************** *** 1086,1090 ****
    redraw-current-line ()
    ! Refresh the current line. By default, this is unbound. --- 1129,1133 ----
    redraw-current-line ()
    ! Refresh the current line. By default, this is unbound. *************** *** 1097,1125 ****
    !
    accept-line (Newline, Return)
    ! ! Accept the line regardless of where the cursor is. If this line is ! non-empty, add it to the history list. If this line was a history ! line, then restore the history line to its original state.
    previous-history (C-p)
    ! ! Move `up' through the history list.
    next-history (C-n)
    ! ! Move `down' through the history list.
    beginning-of-history (M-<)
    ! Move to the first line in the history.
    end-of-history (M->)
    ! Move to the end of the input history, i.e., the line currently being entered. --- 1140,1171 ----
    !
    accept-line (Newline or Return)
    ! ! Accept the line regardless of where the cursor is. ! If this line is ! non-empty, it may be added to the history list for future recall with ! add_history(). ! If this line is a modified history line, the history line is restored ! to its original state.
    previous-history (C-p)
    ! ! Move `back' through the history list, fetching the previous command.
    next-history (C-n)
    ! ! Move `forward' through the history list, fetching the next command.
    beginning-of-history (M-<)
    ! Move to the first line in the history.
    end-of-history (M->)
    ! Move to the end of the input history, i.e., the line currently being entered. *************** *** 1127,1131 ****
    reverse-search-history (C-r)
    ! Search backward starting at the current line and moving `up' through the history as necessary. This is an incremental search. --- 1173,1177 ----
    reverse-search-history (C-r)
    ! Search backward starting at the current line and moving `up' through the history as necessary. This is an incremental search. *************** *** 1133,1137 ****
    forward-search-history (C-s)
    ! Search forward starting at the current line and moving `down' through the the history as necessary. This is an incremental search. --- 1179,1183 ----
    forward-search-history (C-s)
    ! Search forward starting at the current line and moving `down' through the the history as necessary. This is an incremental search. *************** *** 1139,1143 ****
    non-incremental-reverse-search-history (M-p)
    ! Search backward starting at the current line and moving `up' through the history as necessary using a non-incremental search --- 1185,1189 ----
    non-incremental-reverse-search-history (M-p)
    ! Search backward starting at the current line and moving `up' through the history as necessary using a non-incremental search *************** *** 1146,1150 ****
    non-incremental-forward-search-history (M-n)
    ! Search forward starting at the current line and moving `down' through the the history as necessary using a non-incremental search --- 1192,1196 ----
    non-incremental-forward-search-history (M-n)
    ! Search forward starting at the current line and moving `down' through the the history as necessary using a non-incremental search *************** *** 1153,1157 ****
    history-search-forward ()
    ! Search forward through the history for the string of characters between the start of the current line and the point. --- 1199,1203 ----
    history-search-forward ()
    ! Search forward through the history for the string of characters between the start of the current line and the point. *************** *** 1161,1165 ****
    history-search-backward ()
    ! Search backward through the history for the string of characters between the start of the current line and the point. This --- 1207,1211 ----
    history-search-backward ()
    ! Search backward through the history for the string of characters between the start of the current line and the point. This *************** *** 1168,1181 ****
    yank-nth-arg (M-C-y)
    ! Insert the first argument to the previous command (usually ! the second word on the previous line). With an argument n, insert the nth word from the previous command (the words in the previous command begin with word 0). A negative argument inserts the nth word from the end of the previous command. !
    yank-last-arg (M-., M-_)
    ! Insert last argument to the previous command (the last word of the previous history entry). With an --- 1214,1228 ----
    yank-nth-arg (M-C-y)
    ! Insert the first argument to the previous command (usually ! the second word on the previous line) at point. ! With an argument n, insert the nth word from the previous command (the words in the previous command begin with word 0). A negative argument inserts the nth word from the end of the previous command. !
    yank-last-arg (M-. or M-_)
    ! Insert last argument to the previous command (the last word of the previous history entry). With an *************** *** 1194,1206 ****
    delete-char (C-d)
    ! ! Delete the character under the cursor. If the cursor is at the beginning of the line, there are no characters in the line, and the last character typed was not bound to delete-char, then ! return EOF.
    backward-delete-char (Rubout)
    ! Delete the character behind the cursor. A numeric argument means to kill the characters instead of deleting them. --- 1241,1253 ----
    delete-char (C-d)
    ! ! Delete the character at point. If point is at the beginning of the line, there are no characters in the line, and the last character typed was not bound to delete-char, then ! return EOF.
    backward-delete-char (Rubout)
    ! Delete the character behind the cursor. A numeric argument means to kill the characters instead of deleting them. *************** *** 1208,1235 ****
    forward-backward-delete-char ()
    ! Delete the character under the cursor, unless the cursor is at the end of the line, in which case the character behind the cursor is deleted. By default, this is not bound to a key. !
    quoted-insert (C-q, C-v)
    ! Add the next character typed to the line verbatim. This is how to insert key sequences like C-q, for example. !
    tab-insert (M-TAB)
    ! Insert a tab character.
    self-insert (a, b, A, 1, !, ...)
    ! Insert yourself.
    transpose-chars (C-t)
    ! Drag the character before the cursor forward over the character at the cursor, moving the --- 1255,1282 ----
    forward-backward-delete-char ()
    ! Delete the character under the cursor, unless the cursor is at the end of the line, in which case the character behind the cursor is deleted. By default, this is not bound to a key. !
    quoted-insert (C-q or C-v)
    ! Add the next character typed to the line verbatim. This is how to insert key sequences like C-q, for example. !
    tab-insert (M-TAB)
    ! Insert a tab character.
    self-insert (a, b, A, 1, !, ...)
    ! Insert yourself.
    transpose-chars (C-t)
    ! Drag the character before the cursor forward over the character at the cursor, moving the *************** *** 1241,1245 ****
    transpose-words (M-t)
    ! Drag the word before point past the word after point, moving point past that word as well. --- 1288,1292 ----
    transpose-words (M-t)
    ! Drag the word before point past the word after point, moving point past that word as well. *************** *** 1247,1251 ****
    upcase-word (M-u)
    ! Uppercase the current (or following) word. With a negative argument, uppercase the previous word, but do not move the cursor. --- 1294,1298 ----
    upcase-word (M-u)
    ! Uppercase the current (or following) word. With a negative argument, uppercase the previous word, but do not move the cursor. *************** *** 1253,1257 ****
    downcase-word (M-l)
    ! Lowercase the current (or following) word. With a negative argument, lowercase the previous word, but do not move the cursor. --- 1300,1304 ----
    downcase-word (M-l)
    ! Lowercase the current (or following) word. With a negative argument, lowercase the previous word, but do not move the cursor. *************** *** 1259,1263 ****
    capitalize-word (M-c)
    ! Capitalize the current (or following) word. With a negative argument, capitalize the previous word, but do not move the cursor. --- 1306,1310 ----
    capitalize-word (M-c)
    ! Capitalize the current (or following) word. With a negative argument, capitalize the previous word, but do not move the cursor. *************** *** 1273,1305 ****
    kill-line (C-k)
    ! Kill the text from point to the end of the line.
    backward-kill-line (C-x Rubout)
    ! Kill backward to the beginning of the line.
    unix-line-discard (C-u)
    ! Kill backward from the cursor to the beginning of the current line.
    kill-whole-line ()
    ! ! Kill all characters on the current line, no matter point is. By default, this is unbound.
    kill-word (M-d)
    ! Kill from point to the end of the current word, or if between words, to the end of the next word. Word boundaries are the same as forward-word. !
    backward-kill-word (M-DEL)
    ! Kill the word behind point. Word boundaries are the same as backward-word. --- 1320,1352 ----
    kill-line (C-k)
    ! Kill the text from point to the end of the line.
    backward-kill-line (C-x Rubout)
    ! Kill backward to the beginning of the line.
    unix-line-discard (C-u)
    ! Kill backward from the cursor to the beginning of the current line.
    kill-whole-line ()
    ! ! Kill all characters on the current line, no matter where point is. By default, this is unbound.
    kill-word (M-d)
    ! Kill from point to the end of the current word, or if between words, to the end of the next word. Word boundaries are the same as forward-word. !
    backward-kill-word (M-DEL)
    ! Kill the word behind point. Word boundaries are the same as backward-word. *************** *** 1307,1311 ****
    unix-word-rubout (C-w)
    ! Kill the word behind point, using white space as a word boundary. The killed text is saved on the kill-ring. --- 1354,1358 ----
    unix-word-rubout (C-w)
    ! Kill the word behind point, using white space as a word boundary. The killed text is saved on the kill-ring. *************** *** 1313,1322 ****
    delete-horizontal-space ()
    ! Delete all spaces and tabs around point. By default, this is unbound.
    kill-region ()
    ! Kill the text in the current region. By default, this command is unbound. --- 1360,1369 ----
    delete-horizontal-space ()
    ! Delete all spaces and tabs around point. By default, this is unbound.
    kill-region ()
    ! Kill the text in the current region. By default, this command is unbound. *************** *** 1324,1328 ****
    copy-region-as-kill ()
    ! Copy the text in the region to the kill buffer, so it can be yanked right away. By default, this command is unbound. --- 1371,1375 ----
    copy-region-as-kill ()
    ! Copy the text in the region to the kill buffer, so it can be yanked right away. By default, this command is unbound. *************** *** 1330,1334 ****
    copy-backward-word ()
    ! Copy the word before point to the kill buffer. The word boundaries are the same as backward-word. --- 1377,1381 ----
    copy-backward-word ()
    ! Copy the word before point to the kill buffer. The word boundaries are the same as backward-word. *************** *** 1337,1341 ****
    copy-forward-word ()
    ! Copy the word following point to the kill buffer. The word boundaries are the same as forward-word. --- 1384,1388 ----
    copy-forward-word ()
    ! Copy the word following point to the kill buffer. The word boundaries are the same as forward-word. *************** *** 1344,1356 ****
    yank (C-y)
    ! ! Yank the top of the kill ring into the buffer at the current ! cursor position.
    yank-pop (M-y)
    ! Rotate the kill-ring, and yank the new top. You can only do this if ! the prior command is yank or yank-pop.
    --- 1391,1402 ----
    yank (C-y)
    ! ! Yank the top of the kill ring into the buffer at point.
    yank-pop (M-y)
    ! Rotate the kill-ring, and yank the new top. You can only do this if ! the prior command is yank or yank-pop.
    *************** *** 1360,1366 ****
    !
    digit-argument (M-0, M-1, ... M--)
    ! Add this digit to the argument already accumulating, or start a new argument. M-- starts a negative argument. --- 1406,1412 ----
    !
    digit-argument (M-0, M-1, ... M--)
    ! Add this digit to the argument already accumulating, or start a new argument. M-- starts a negative argument. *************** *** 1368,1372 ****
    universal-argument ()
    ! This is another way to specify an argument. If this command is followed by one or more digits, optionally with a --- 1414,1418 ----
    universal-argument ()
    ! This is another way to specify an argument. If this command is followed by one or more digits, optionally with a *************** *** 1389,1410 ****
    !
    complete (TAB)
    ! ! Attempt to do completion on the text before the cursor. This is ! application-specific. Generally, if you are typing a filename ! argument, you can do filename completion; if you are typing a command, ! you can do command completion; if you are typing in a symbol to GDB, you ! can do symbol name completion; if you are typing in a variable to Bash, ! you can do variable name completion, and so on.
    possible-completions (M-?)
    ! ! List the possible completions of the text before the cursor.
    insert-completions (M-*)
    ! Insert all completions of the text before point that would have been generated by possible-completions. --- 1435,1453 ----
    !
    complete (TAB)
    ! ! Attempt to perform completion on the text before point. ! The actual completion performed is application-specific. ! The default is filename completion.
    possible-completions (M-?)
    ! ! List the possible completions of the text before point.
    insert-completions (M-*)
    ! Insert all completions of the text before point that would have been generated by possible-completions. *************** *** 1412,1431 ****
    menu-complete ()
    ! Similar to complete, but replaces the word to be completed with a single match from the list of possible completions. Repeated execution of menu-complete steps through the list of possible completions, inserting each match in turn. ! At the end of the list of completions, the bell is rung and the ! original text is restored. An argument of n moves n positions forward in the list of matches; a negative argument may be used to move backward through the list. ! This command is intended to be bound to TAB, but is unbound by default.
    delete-char-or-list ()
    ! Deletes the character under the cursor if not at the beginning or end of the line (like delete-char). --- 1455,1475 ----
    menu-complete ()
    ! Similar to complete, but replaces the word to be completed with a single match from the list of possible completions. Repeated execution of menu-complete steps through the list of possible completions, inserting each match in turn. ! At the end of the list of completions, the bell is rung ! (subject to the setting of bell-style) ! and the original text is restored. An argument of n moves n positions forward in the list of matches; a negative argument may be used to move backward through the list. ! This command is intended to be bound to TAB, but is unbound by default.
    delete-char-or-list ()
    ! Deletes the character under the cursor if not at the beginning or end of the line (like delete-char). *************** *** 1443,1452 ****
    start-kbd-macro (C-x ()
    ! Begin saving the characters typed into the current keyboard macro.
    end-kbd-macro (C-x ))
    ! Stop saving the characters typed into the current keyboard macro and save the definition. --- 1487,1496 ----
    start-kbd-macro (C-x ()
    ! Begin saving the characters typed into the current keyboard macro.
    end-kbd-macro (C-x ))
    ! Stop saving the characters typed into the current keyboard macro and save the definition. *************** *** 1454,1458 ****
    call-last-kbd-macro (C-x e)
    ! Re-execute the last keyboard macro defined, by making the characters in the macro appear as if typed at the keyboard. --- 1498,1502 ----
    call-last-kbd-macro (C-x e)
    ! Re-execute the last keyboard macro defined, by making the characters in the macro appear as if typed at the keyboard. *************** *** 1467,1471 ****
    re-read-init-file (C-x C-r)
    ! Read in the contents of the inputrc file, and incorporate any bindings or variable assignments found there. --- 1511,1515 ----
    re-read-init-file (C-x C-r)
    ! Read in the contents of the inputrc file, and incorporate any bindings or variable assignments found there. *************** *** 1473,1477 ****
    abort (C-g)
    ! Abort the current editing command and ring the terminal's bell (subject to the setting of --- 1517,1521 ----
    abort (C-g)
    ! Abort the current editing command and ring the terminal's bell (subject to the setting of *************** *** 1480,1502 ****
    do-uppercase-version (M-a, M-b, M-x, ...)
    ! If the metafied character x is lowercase, run the command that is bound to the corresponding uppercase character. !
    prefix-meta (ESC)
    ! ! Make the next character typed be metafied. This is for keyboards ! without a meta key. Typing `ESC f' is equivalent to typing ! `M-f'. !
    undo (C-_, C-x C-u)
    ! Incremental undo, separately remembered for each line.
    revert-line (M-r)
    ! Undo all changes made to this line. This is like executing the undo command enough times to get back to the beginning. --- 1524,1546 ----
    do-uppercase-version (M-a, M-b, M-x, ...)
    ! If the metafied character x is lowercase, run the command that is bound to the corresponding uppercase character. !
    prefix-meta (ESC)
    ! ! Metafy the next character typed. This is for keyboards ! without a meta key. Typing `ESC f' is equivalent to typing ! M-f. !
    undo (C-_ or C-x C-u)
    ! Incremental undo, separately remembered for each line.
    revert-line (M-r)
    ! Undo all changes made to this line. This is like executing the undo command enough times to get back to the beginning. *************** *** 1504,1519 ****
    tilde-expand (M-~)
    ! Perform tilde expansion on the current word.
    set-mark (C-@)
    ! ! Set the mark to the current point. If a numeric argument is supplied, the mark is set to that position.
    exchange-point-and-mark (C-x C-x)
    ! Swap the point with the mark. The current cursor position is set to the saved position, and the old cursor position is saved as the mark. --- 1548,1563 ----
    tilde-expand (M-~)
    ! Perform tilde expansion on the current word.
    set-mark (C-@)
    ! ! Set the mark to the point. If a numeric argument is supplied, the mark is set to that position.
    exchange-point-and-mark (C-x C-x)
    ! Swap the point with the mark. The current cursor position is set to the saved position, and the old cursor position is saved as the mark. *************** *** 1521,1525 ****
    character-search (C-])
    ! A character is read and point is moved to the next occurrence of that character. A negative count searches for previous occurrences. --- 1565,1569 ----
    character-search (C-])
    ! A character is read and point is moved to the next occurrence of that character. A negative count searches for previous occurrences. *************** *** 1527,1531 ****
    character-search-backward (M-C-])
    ! A character is read and point is moved to the previous occurrence of that character. A negative count searches for subsequent --- 1571,1575 ----
    character-search-backward (M-C-])
    ! A character is read and point is moved to the previous occurrence of that character. A negative count searches for subsequent *************** *** 1534,1538 ****
    insert-comment (M-#)
    ! The value of the comment-begin variable is inserted at the beginning of the current line, --- 1578,1582 ----
    insert-comment (M-#)
    ! The value of the comment-begin variable is inserted at the beginning of the current line, *************** *** 1541,1545 ****
    dump-functions ()
    ! Print all of the functions and their key bindings to the Readline output stream. If a numeric argument is supplied, --- 1585,1589 ----
    dump-functions ()
    ! Print all of the functions and their key bindings to the Readline output stream. If a numeric argument is supplied, *************** *** 1549,1553 ****
    dump-variables ()
    ! Print all of the settable variables and their values to the Readline output stream. If a numeric argument is supplied, --- 1593,1597 ----
    dump-variables ()
    ! Print all of the settable variables and their values to the Readline output stream. If a numeric argument is supplied, *************** *** 1557,1563 ****
    dump-macros ()
    ! Print all of the Readline key sequences bound to macros and the ! strings they ouput. If a numeric argument is supplied, the output is formatted in such a way that it can be made part of an inputrc file. This command is unbound by default. --- 1601,1607 ----
    dump-macros ()
    ! Print all of the Readline key sequences bound to macros and the ! strings they output. If a numeric argument is supplied, the output is formatted in such a way that it can be made part of an inputrc file. This command is unbound by default. *************** *** 1578,1582 ****

    In order to switch interactively between emacs and vi ! editing modes, use the command M-C-j (toggle-editing-mode). The Readline default is emacs mode. --- 1622,1627 ----

    In order to switch interactively between emacs and vi ! editing modes, use the command M-C-j (bound to emacs-editing-mode ! when in vi mode and to vi-editing-mode in emacs mode). The Readline default is emacs mode. *************** *** 1613,1618 **** aid in writing your own custom functions. !

  • Readline Signal Handling: How Readline behaves when it receives signals. !
  • Custom Completers: Supplanting or supplementing Readline's completion functions. --- 1658,1663 ---- aid in writing your own custom functions. !
  • Readline Signal Handling: How Readline behaves when it receives signals. !
  • Custom Completers: Supplanting or supplementing Readline's completion functions. *************** *** 1627,1646 **** Readline is sufficient. This section describes how to use Readline in the simplest way possible, perhaps to replace calls in your code to ! gets() or fgets ().

    - ! The function readline () prints a prompt and then reads and returns ! a single line of text from the user. The line readline ! returns is allocated with malloc (); you should free () ! the line when you are done with it. The declaration for readline ! in ANSI C is

    ! char *readline (char *prompt);
      
    --- 1672,1695 ---- Readline is sufficient. This section describes how to use Readline in the simplest way possible, perhaps to replace calls in your code to ! gets() or fgets().

    ! ! !

    !

    ! The function readline() prints a prompt prompt ! and then reads and returns a single line of text from the user. ! If prompt is NULL or the empty string, no prompt is displayed. ! The line readline returns is allocated with malloc(); ! the caller should free() the line when it has finished with it. ! The declaration for readline in ANSI C is

    ! char *readline (const char *prompt);
      
    *************** *** 1666,1670 ****

    If you want the user to be able to get at the line later, (with ! C-p for example), you must call add_history () to save the line away in a history list of such lines. --- 1715,1719 ----

    If you want the user to be able to get at the line later, (with ! C-p for example), you must call add_history() to save the line away in a history list of such lines. *************** *** 1682,1686 **** It is preferable to avoid saving empty lines on the history list, since users rarely have a burning need to reuse a blank line. Here is ! a function which usefully replaces the standard gets () library function, and has the advantage of no static buffer to overflow: --- 1731,1735 ---- It is preferable to avoid saving empty lines on the history list, since users rarely have a burning need to reuse a blank line. Here is ! a function which usefully replaces the standard gets() library function, and has the advantage of no static buffer to overflow: *************** *** 1718,1735 **** completion: completion on file names. If you do not want Readline to complete on filenames, you can change the binding of the TAB key ! with rl_bind_key ().

    ! int rl_bind_key (int key, int (*function)());
      

    ! rl_bind_key () takes two arguments: key is the character that you want to bind, and function is the address of the function to ! call when key is pressed. Binding TAB to rl_insert () makes TAB insert itself. ! rl_bind_key () returns non-zero if key is not a valid ASCII character code (between 0 and 255). --- 1767,1784 ---- completion: completion on file names. If you do not want Readline to complete on filenames, you can change the binding of the TAB key ! with rl_bind_key().

    ! int rl_bind_key (int key, rl_command_func_t *function);
      

    ! rl_bind_key() takes two arguments: key is the character that you want to bind, and function is the address of the function to ! call when key is pressed. Binding TAB to rl_insert() makes TAB insert itself. ! rl_bind_key() returns non-zero if key is not a valid ASCII character code (between 0 and 255). *************** *** 1744,1750 ****

    This code should be executed once at the start of your program; you ! might write a function called initialize_readline () which performs this and other desired initializations, such as installing ! custom completers (see section Custom Completers).

    --- 1793,1799 ----

    This code should be executed once at the start of your program; you ! might write a function called initialize_readline() which performs this and other desired initializations, such as installing ! custom completers (see section Custom Completers).

    *************** *** 1772,1776 **** --- 1821,1825 ---- *************** *** 1778,1828 **** !

    The Function Type

    ! For readabilty, we declare a new type of object, called ! Function. A Function is a C function which ! returns an int. The type declaration for Function is:

    ! typedef int Function ();

    ! The reason for declaring this new type is to make it easier to write ! code describing pointers to C functions. Let us say we had a variable ! called func which was a pointer to a function. Instead of the ! classic C declaration

    ! int (*)()func;

    ! we may write

    ! Function *func;

    ! Similarly, there are

    !
    ! typedef void VFunction ();
    ! typedef char *CPFunction (); and
    ! typedef char **CPPFunction ();
    ! 
    !

    ! for functions returning no value, pointer to char, and ! pointer to pointer to char, respectively.

    --- 1827,1914 ---- !

    Readline Typedefs

    ! For readabilty, we declare a number of new object types, all pointers ! to functions.

    ! The reason for declaring these new types is to make it easier to write ! code describing pointers to C functions with appropriately prototyped ! arguments and return values.

    ! For instance, say we want to declare a variable func as a pointer ! to a function which takes two int arguments and returns an ! int (this is the type of all of the Readline bindable functions). ! Instead of the classic C declaration

    ! int (*func)();

    ! or the ANSI-C style declaration

    ! int (*func)(int, int);

    ! we may write

    +

    + rl_command_func_t *func; !

    ! The full list of function pointer types available is

    +
    + +
    typedef int rl_command_func_t (int, int); +
    +
    typedef char *rl_compentry_func_t (const char *, int); +
    +
    typedef char **rl_completion_func_t (const char *, int, int); +
    +
    typedef char *rl_quote_func_t (char *, int, char *); +
    +
    typedef char *rl_dequote_func_t (char *, int); +
    +
    typedef int rl_compignore_func_t (char **); +
    +
    typedef void rl_compdisp_func_t (char **, int, int); +
    +
    typedef int rl_hook_func_t (void); +
    +
    typedef int rl_getc_func_t (FILE *); +
    +
    typedef int rl_linebuf_func_t (char *, int); +
    +
    typedef int rl_intfunc_t (int); +
    +
    #define rl_ivoidfunc_t rl_hook_func_t +
    +
    typedef int rl_icpfunc_t (char *); +
    +
    typedef int rl_icppfunc_t (char **); +
    +
    typedef void rl_voidfunc_t (void); +
    +
    typedef void rl_vintfunc_t (int); +
    +
    typedef void rl_vcpfunc_t (char *); +
    +
    typedef void rl_vcppfunc_t (char **); +
    +
    + *************** *** 1872,1876 ****
    Variable: char * rl_line_buffer !
    This is the line gathered so far. You are welcome to modify the contents of the line, but see section Allowing Undoing. The --- 1958,1962 ----
    Variable: char * rl_line_buffer !
    This is the line gathered so far. You are welcome to modify the contents of the line, but see section Allowing Undoing. The *************** *** 1883,1887 ****
    Variable: int rl_point !
    The offset of the current cursor position in rl_line_buffer (the point). --- 1969,1973 ----
    Variable: int rl_point !
    The offset of the current cursor position in rl_line_buffer (the point). *************** *** 1892,1896 ****
    Variable: int rl_end !
    The number of characters present in rl_line_buffer. When rl_point is at the end of the line, rl_point and --- 1978,1982 ----
    Variable: int rl_end !
    The number of characters present in rl_line_buffer. When rl_point is at the end of the line, rl_point and *************** *** 1902,1907 ****
    Variable: int rl_mark !
    ! The mark (saved position) in the current line. If set, the mark and point define a region.
    --- 1988,1993 ----
    Variable: int rl_mark !
    ! The mark (saved position) in the current line. If set, the mark and point define a region.
    *************** *** 1911,1915 ****
    Variable: int rl_done !
    Setting this to a non-zero value causes Readline to return the current line immediately. --- 1997,2001 ----
    Variable: int rl_done !
    Setting this to a non-zero value causes Readline to return the current line immediately. *************** *** 1919,1924 ****

    Variable: int rl_pending_input !
    Setting this to a value makes it the next keystroke read. This is a way to stuff a single character into the input stream. --- 2005,2020 ----

    +
    Variable: int rl_num_chars_to_read +
    + Setting this to a positive value before calling readline() causes + Readline to return after accepting that many characters, rather + than reading up to a character bound to accept-line. +
    + +

    +

    +

    Variable: int rl_pending_input !
    Setting this to a value makes it the next keystroke read. This is a way to stuff a single character into the input stream. *************** *** 1928,1933 ****

    Variable: int rl_erase_empty_line !
    Setting this to a non-zero value causes Readline to completely erase the current line, including any prompt, any time a newline is typed as --- 2024,2039 ----

    +
    Variable: int rl_dispatching +
    + Set to a non-zero value if a function is being called from a key binding; + zero otherwise. Application functions can test this to discover whether + they were called directly or by Readline's dispatching mechanism. +
    + +

    +

    +

    Variable: int rl_erase_empty_line !
    Setting this to a non-zero value causes Readline to completely erase the current line, including any prompt, any time a newline is typed as *************** *** 1940,1946 ****
    Variable: char * rl_prompt !
    The prompt Readline uses. This is set from the argument to ! readline (), and should not be assigned to directly.
    --- 2046,2054 ----
    Variable: char * rl_prompt !
    The prompt Readline uses. This is set from the argument to ! readline(), and should not be assigned to directly. ! The rl_set_prompt() function (see section Redisplay) may ! be used to modify the prompt string after calling readline().
    *************** *** 1949,1953 ****
    Variable: int rl_already_prompted !
    If an application wishes to display the prompt itself, rather than have Readline do it the first time readline() is called, it should set --- 2057,2061 ----
    Variable: int rl_already_prompted !
    If an application wishes to display the prompt itself, rather than have Readline do it the first time readline() is called, it should set *************** *** 1962,1967 ****

    !
    Variable: char * rl_library_version !
    The version number of this revision of the library.
    --- 2070,2075 ----

    !
    Variable: const char * rl_library_version !
    The version number of this revision of the library.
    *************** *** 1970,1976 ****

    !
    Variable: char * rl_terminal_name !
    ! The terminal type, used for initialization.
    --- 2078,2085 ----

    !
    Variable: int rl_gnu_readline_p !
    ! Always set to 1, denoting that this is GNU readline rather than some ! emulation.
    *************** *** 1978,1983 ****

    !
    Variable: char * rl_readline_name !
    This variable is set to a unique name by each application using Readline. The value allows conditional parsing of the inputrc file --- 2087,2102 ----

    !
    Variable: const char * rl_terminal_name !
    ! The terminal type, used for initialization. If not set by the application, ! Readline sets this to the value of the @env{TERM} environment variable ! the first time it is called. !
    ! !

    !

    !

    !
    Variable: const char * rl_readline_name !
    This variable is set to a unique name by each application using Readline. The value allows conditional parsing of the inputrc file *************** *** 1989,1993 ****
    Variable: FILE * rl_instream !
    The stdio stream from which Readline reads input.
    --- 2108,2112 ----
    Variable: FILE * rl_instream !
    The stdio stream from which Readline reads input.
    *************** *** 1997,2001 ****
    Variable: FILE * rl_outstream !
    The stdio stream to which Readline performs output.
    --- 2116,2120 ----
    Variable: FILE * rl_outstream !
    The stdio stream to which Readline performs output.
    *************** *** 2004,2009 ****

    !
    Variable: Function * rl_startup_hook !
    If non-zero, this is the address of a function to call just before readline prints the first prompt. --- 2123,2138 ----

    !
    Variable: rl_command_func_t * rl_last_func !
    ! The address of the last command function Readline executed. May be used to ! test whether or not a function is being executed twice in succession, for ! example. !
    ! !

    !

    !

    !
    Variable: rl_hook_func_t * rl_startup_hook !
    If non-zero, this is the address of a function to call just before readline prints the first prompt. *************** *** 2013,2018 ****

    !
    Variable: Function * rl_pre_input_hook !
    If non-zero, this is the address of a function to call after the first prompt has been printed and just before readline --- 2142,2147 ----

    !
    Variable: rl_hook_func_t * rl_pre_input_hook !
    If non-zero, this is the address of a function to call after the first prompt has been printed and just before readline *************** *** 2023,2030 ****

    !
    Variable: Function * rl_event_hook !
    If non-zero, this is the address of a function to call periodically ! when readline is waiting for terminal input.
    --- 2152,2161 ----

    !
    Variable: rl_hook_func_t * rl_event_hook !
    If non-zero, this is the address of a function to call periodically ! when Readline is waiting for terminal input. ! By default, this will be called at most ten times a second if there ! is no keyboard input.
    *************** *** 2032,2041 ****

    !
    Variable: Function * rl_getc_function !
    ! If non-zero, readline will call indirectly through this pointer to get a character from the input stream. By default, it is set to ! rl_getc, the default readline character input function ! (see section Utility Functions).
    --- 2163,2172 ----

    !
    Variable: rl_getc_func_t * rl_getc_function !
    ! If non-zero, Readline will call indirectly through this pointer to get a character from the input stream. By default, it is set to ! rl_getc, the default Readline character input function ! (see section Character Input).
    *************** *** 2043,2051 ****

    !
    Variable: VFunction * rl_redisplay_function !
    ! If non-zero, readline will call indirectly through this pointer to update the display with the current contents of the editing buffer. ! By default, it is set to rl_redisplay, the default readline redisplay function (see section Redisplay).
    --- 2174,2182 ----

    !
    Variable: rl_voidfunc_t * rl_redisplay_function !
    ! If non-zero, Readline will call indirectly through this pointer to update the display with the current contents of the editing buffer. ! By default, it is set to rl_redisplay, the default Readline redisplay function (see section Redisplay).
    *************** *** 2054,2059 ****

    Variable: Keymap rl_executing_keymap !
    This variable is set to the keymap (see section Selecting a Keymap) in which the currently executing readline function was found. --- 2185,2214 ----

    +
    Variable: rl_vintfunc_t * rl_prep_term_function +
    + If non-zero, Readline will call indirectly through this pointer + to initialize the terminal. The function takes a single argument, an + int flag that says whether or not to use eight-bit characters. + By default, this is set to rl_prep_terminal + (see section Terminal Management). +
    + +

    +

    +

    +
    Variable: rl_voidfunc_t * rl_deprep_term_function +
    + If non-zero, Readline will call indirectly through this pointer + to reset the terminal. This function should undo the effects of + rl_prep_term_function. + By default, this is set to rl_deprep_terminal + (see section Terminal Management). +
    + +

    +

    +

    Variable: Keymap rl_executing_keymap !
    This variable is set to the keymap (see section Selecting a Keymap) in which the currently executing readline function was found. *************** *** 2064,2068 ****
    Variable: Keymap rl_binding_keymap !
    This variable is set to the keymap (see section Selecting a Keymap) in which the last key binding occurred. --- 2219,2223 ----
    Variable: Keymap rl_binding_keymap !
    This variable is set to the keymap (see section Selecting a Keymap) in which the last key binding occurred. *************** *** 2070,2073 **** --- 2225,2341 ----

    +

    +

    +
    Variable: char * rl_executing_macro +
    + This variable is set to the text of any currently-executing macro. +
    + +

    +

    +

    +
    Variable: int rl_readline_state +
    + A variable with bit values that encapsulate the current Readline state. + A bit is set with the RL_SETSTATE macro, and unset with the + RL_UNSETSTATE macro. Use the RL_ISSTATE macro to test + whether a particular state bit is set. Current state bits include: + +

    +
    + +
    RL_STATE_NONE +
    + Readline has not yet been called, nor has it begun to intialize. +
    RL_STATE_INITIALIZING +
    + Readline is initializing its internal data structures. +
    RL_STATE_INITIALIZED +
    + Readline has completed its initialization. +
    RL_STATE_TERMPREPPED +
    + Readline has modified the terminal modes to do its own input and redisplay. +
    RL_STATE_READCMD +
    + Readline is reading a command from the keyboard. +
    RL_STATE_METANEXT +
    + Readline is reading more input after reading the meta-prefix character. +
    RL_STATE_DISPATCHING +
    + Readline is dispatching to a command. +
    RL_STATE_MOREINPUT +
    + Readline is reading more input while executing an editing command. +
    RL_STATE_ISEARCH +
    + Readline is performing an incremental history search. +
    RL_STATE_NSEARCH +
    + Readline is performing a non-incremental history search. +
    RL_STATE_SEARCH +
    + Readline is searching backward or forward through the history for a string. +
    RL_STATE_NUMERICARG +
    + Readline is reading a numeric argument. +
    RL_STATE_MACROINPUT +
    + Readline is currently getting its input from a previously-defined keyboard + macro. +
    RL_STATE_MACRODEF +
    + Readline is currently reading characters defining a keyboard macro. +
    RL_STATE_OVERWRITE +
    + Readline is in overwrite mode. +
    RL_STATE_COMPLETING +
    + Readline is performing word completion. +
    RL_STATE_SIGHANDLER +
    + Readline is currently executing the readline signal handler. +
    RL_STATE_UNDOING +
    + Readline is performing an undo. +
    RL_STATE_DONE +
    + Readline has read a key sequence bound to accept-line + and is about to return the line to the caller. +
    + +
    + +

    +

    +
    Variable: int rl_explicit_arg +
    + Set to a non-zero value if an explicit numeric argument was specified by + the user. Only valid in a bindable command function. +
    + +

    +

    +

    +
    Variable: int rl_numeric_arg +
    + Set to the value of any numeric argument explicitly specified by the user + before executing the current Readline function. Only valid in a bindable + command function. +
    + +

    +

    +

    +
    Variable: int rl_editing_mode +
    + Set to a value denoting Readline's current editing mode. A value of + 1 means Readline is currently in emacs mode; 0 + means that vi mode is active. +
    + +

    + *************** *** 2084,2089 ****
  • Redisplay: Functions to control line display.
  • Modifying Text: Functions to modify rl_line_buffer. !
  • Utility Functions: Generally useful functions and hooks. !
  • Alternate Interface: Using Readline in a `callback' fashion. --- 2352,2361 ----
  • Redisplay: Functions to control line display.
  • Modifying Text: Functions to modify rl_line_buffer. !
  • Character Input: Functions to read keyboard input. !
  • Terminal Management: Functions to manage terminal settings. !
  • Utility Functions: Generally useful functions and hooks. !
  • Miscellaneous Functions: Functions that don't fall into any category. !
  • Alternate Interface: Using Readline in a `callback' fashion. !
  • A Readline Example: An example Readline function. *************** *** 2113,2121 ****

    !
    Function: int rl_add_defun (char *name, Function *function, int key) !
    Add name to the list of named functions. Make function be the function that gets called. If key is not -1, then bind it to ! function using rl_bind_key ().
    --- 2385,2393 ----

    !
    Function: int rl_add_defun (const char *name, rl_command_func_t *function, int key) !
    Add name to the list of named functions. Make function be the function that gets called. If key is not -1, then bind it to ! function using rl_bind_key().
    *************** *** 2142,2149 ****

    !
    Function: Keymap rl_make_bare_keymap () !
    Returns a new, empty keymap. The space for the keymap is allocated with ! malloc (); you should free () it when you are done.
    --- 2414,2422 ----

    !
    Function: Keymap rl_make_bare_keymap (void) !
    Returns a new, empty keymap. The space for the keymap is allocated with ! malloc(); the caller should free it by calling ! rl_discard_keymap() when done.
    *************** *** 2152,2156 ****
    Function: Keymap rl_copy_keymap (Keymap map) !
    Return a new keymap which is a copy of map.
    --- 2425,2429 ----
    Function: Keymap rl_copy_keymap (Keymap map) !
    Return a new keymap which is a copy of map.
    *************** *** 2159,2164 ****

    !
    Function: Keymap rl_make_keymap () !
    Return a new keymap with the printing characters bound to rl_insert, the lowercase Meta characters bound to run their equivalents, and --- 2432,2437 ----

    !
    Function: Keymap rl_make_keymap (void) !
    Return a new keymap with the printing characters bound to rl_insert, the lowercase Meta characters bound to run their equivalents, and *************** *** 2170,2174 ****
    Function: void rl_discard_keymap (Keymap keymap) !
    Free the storage associated with keymap.
    --- 2443,2447 ----
    Function: void rl_discard_keymap (Keymap keymap) !
    Free the storage associated with keymap.
    *************** *** 2182,2187 ****

    !
    Function: Keymap rl_get_keymap () !
    Returns the currently active keymap.
    --- 2455,2460 ----

    !
    Function: Keymap rl_get_keymap (void) !
    Returns the currently active keymap.
    *************** *** 2191,2195 ****
    Function: void rl_set_keymap (Keymap keymap) !
    Makes keymap the currently active keymap.
    --- 2464,2468 ----
    Function: void rl_set_keymap (Keymap keymap) !
    Makes keymap the currently active keymap.
    *************** *** 2198,2203 ****

    !
    Function: Keymap rl_get_keymap_by_name (char *name) !
    Return the keymap matching name. name is one which would be supplied in a set keymap inputrc line (see section Readline Init File). --- 2471,2476 ----

    !
    Function: Keymap rl_get_keymap_by_name (const char *name) !
    Return the keymap matching name. name is one which would be supplied in a set keymap inputrc line (see section Readline Init File). *************** *** 2208,2212 ****
    Function: char * rl_get_keymap_name (Keymap keymap) !
    Return the name matching keymap. name is one which would be supplied in a set keymap inputrc line (see section Readline Init File). --- 2481,2485 ----
    Function: char * rl_get_keymap_name (Keymap keymap) !
    Return the name matching keymap. name is one which would be supplied in a set keymap inputrc line (see section Readline Init File). *************** *** 2219,2224 ****

    ! You associate keys with functions through the keymap. Readline has ! several internal keymaps: emacs_standard_keymap, emacs_meta_keymap, emacs_ctlx_keymap, vi_movement_keymap, and vi_insertion_keymap. --- 2492,2497 ----

    ! Key sequences are associate with functions through the keymap. ! Readline has several internal keymaps: emacs_standard_keymap, emacs_meta_keymap, emacs_ctlx_keymap, vi_movement_keymap, and vi_insertion_keymap. *************** *** 2228,2234 ****

    ! Since readline installs a set of default key bindings the first time it is called, there is always the danger that a custom binding ! installed before the first call to readline will be overridden. An alternate mechanism is to install custom key bindings in an initialization function assigned to the rl_startup_hook variable --- 2501,2507 ----

    ! Since readline() installs a set of default key bindings the first time it is called, there is always the danger that a custom binding ! installed before the first call to readline() will be overridden. An alternate mechanism is to install custom key bindings in an initialization function assigned to the rl_startup_hook variable *************** *** 2242,2247 ****

    !
    Function: int rl_bind_key (int key, Function *function) !
    Binds key to function in the currently active keymap. Returns non-zero in the case of an invalid key. --- 2515,2520 ----

    !
    Function: int rl_bind_key (int key, rl_command_func_t *function) !
    Binds key to function in the currently active keymap. Returns non-zero in the case of an invalid key. *************** *** 2251,2256 ****

    !
    Function: int rl_bind_key_in_map (int key, Function *function, Keymap map) !
    Bind key to function in map. Returns non-zero in the case of an invalid key. --- 2524,2529 ----

    !
    Function: int rl_bind_key_in_map (int key, rl_command_func_t *function, Keymap map) !
    Bind key to function in map. Returns non-zero in the case of an invalid key. *************** *** 2261,2265 ****
    Function: int rl_unbind_key (int key) !
    Bind key to the null function in the currently active keymap. Returns non-zero in case of error. --- 2534,2538 ----
    Function: int rl_unbind_key (int key) !
    Bind key to the null function in the currently active keymap. Returns non-zero in case of error. *************** *** 2270,2274 ****
    Function: int rl_unbind_key_in_map (int key, Keymap map) !
    Bind key to the null function in map. Returns non-zero in case of error. --- 2543,2547 ----
    Function: int rl_unbind_key_in_map (int key, Keymap map) !
    Bind key to the null function in map. Returns non-zero in case of error. *************** *** 2278,2283 ****

    !
    Function: int rl_unbind_function_in_map (Function *function, Keymap map) !
    Unbind all keys that execute function in map.
    --- 2551,2556 ----

    !
    Function: int rl_unbind_function_in_map (rl_command_func_t *function, Keymap map) !
    Unbind all keys that execute function in map.
    *************** *** 2286,2291 ****

    !
    Function: int rl_unbind_command_in_map (char *command, Keymap map) !
    Unbind all keys that are bound to command in map.
    --- 2559,2564 ----

    !
    Function: int rl_unbind_command_in_map (const char *command, Keymap map) !
    Unbind all keys that are bound to command in map.
    *************** *** 2294,2299 ****

    !
    Function: int rl_generic_bind (int type, char *keyseq, char *data, Keymap map) !
    Bind the key sequence represented by the string keyseq to the arbitrary pointer data. type says what kind of data is pointed to by --- 2567,2582 ----

    !
    Function: int rl_set_key (const char *keyseq, rl_command_func_t *function, Keymap map) !
    ! Bind the key sequence represented by the string keyseq to the function ! function. This makes new keymaps as ! necessary. The initial keymap in which to do bindings is map. !
    ! !

    !

    !

    !
    Function: int rl_generic_bind (int type, const char *keyseq, char *data, Keymap map) !
    Bind the key sequence represented by the string keyseq to the arbitrary pointer data. type says what kind of data is pointed to by *************** *** 2307,2311 ****
    Function: int rl_parse_and_bind (char *line) !
    Parse line as if it had been read from the inputrc file and perform any key bindings and variable assignments found --- 2590,2594 ----
    Function: int rl_parse_and_bind (char *line) !
    Parse line as if it had been read from the inputrc file and perform any key bindings and variable assignments found *************** *** 2316,2321 ****

    !
    Function: int rl_read_init_file (char *filename) !
    Read keybindings and variable assignments from filename (see section Readline Init File). --- 2599,2604 ----

    !
    Function: int rl_read_init_file (const char *filename) !
    Read keybindings and variable assignments from filename (see section Readline Init File). *************** *** 2329,2339 ****

    These functions allow you to find out what keys invoke named functions ! and the functions invoked by a particular key sequence.

    !
    Function: Function * rl_named_function (char *name) !
    Return the function with name name.
    --- 2612,2623 ----

    These functions allow you to find out what keys invoke named functions ! and the functions invoked by a particular key sequence. You may also ! associate a new function name with an arbitrary function.

    !
    Function: rl_command_func_t * rl_named_function (const char *name) !
    Return the function with name name.
    *************** *** 2342,2351 ****

    !
    Function: Function * rl_function_of_keyseq (char *keyseq, Keymap map, int *type) !
    Return the function invoked by keyseq in keymap map. ! If map is NULL, the current keymap is used. If type is ! not NULL, the type of the object is returned in it (one of ISFUNC, ! ISKMAP, or ISMACR).
    --- 2626,2635 ----

    !
    Function: rl_command_func_t * rl_function_of_keyseq (const char *keyseq, Keymap map, int *type) !
    Return the function invoked by keyseq in keymap map. ! If map is NULL, the current keymap is used. If type is ! not NULL, the type of the object is returned in the int variable ! it points to (one of ISFUNC, ISKMAP, or ISMACR).
    *************** *** 2353,2358 ****

    !
    Function: char ** rl_invoking_keyseqs (Function *function) !
    Return an array of strings representing the key sequences used to invoke function in the current keymap. --- 2637,2642 ----

    !
    Function: char ** rl_invoking_keyseqs (rl_command_func_t *function) !
    Return an array of strings representing the key sequences used to invoke function in the current keymap. *************** *** 2362,2367 ****

    !
    Function: char ** rl_invoking_keyseqs_in_map (Function *function, Keymap map) !
    Return an array of strings representing the key sequences used to invoke function in the keymap map. --- 2646,2651 ----

    !
    Function: char ** rl_invoking_keyseqs_in_map (rl_command_func_t *function, Keymap map) !
    Return an array of strings representing the key sequences used to invoke function in the keymap map. *************** *** 2372,2376 ****
    Function: void rl_function_dumper (int readable) !
    Print the readline function names and the key sequences currently bound to them to rl_outstream. If readable is non-zero, --- 2656,2660 ----
    Function: void rl_function_dumper (int readable) !
    Print the readline function names and the key sequences currently bound to them to rl_outstream. If readable is non-zero, *************** *** 2382,2387 ****

    !
    Function: void rl_list_funmap_names () !
    Print the names of all bindable Readline functions to rl_outstream.
    --- 2666,2671 ----

    !
    Function: void rl_list_funmap_names (void) !
    Print the names of all bindable Readline functions to rl_outstream.
    *************** *** 2390,2398 ****

    !
    Function: char ** rl_funmap_names () !
    Return a NULL terminated array of known function names. The array is sorted. The array itself is allocated, but not the strings inside. You ! should free () the array when you done, but not the pointrs.
    --- 2674,2691 ----

    !
    Function: const char ** rl_funmap_names (void) !
    Return a NULL terminated array of known function names. The array is sorted. The array itself is allocated, but not the strings inside. You ! should free() the array when you are done, but not the pointers. !
    ! !

    !

    !

    !
    Function: int rl_add_funmap_entry (const char *name, rl_command_func_t *function) !
    ! Add name to the list of bindable Readline command names, and make ! function the function to be called when name is invoked.
    *************** *** 2405,2415 **** Supporting the undo command is a painless thing, and makes your functions much more useful. It is certainly easy to try ! something if you know you can undo it. I could use an undo function for ! the stock market.

    If your function simply inserts text once, or deletes text once, and ! uses rl_insert_text () or rl_delete_text () to do it, then undoing is already done for you automatically. --- 2698,2707 ---- Supporting the undo command is a painless thing, and makes your functions much more useful. It is certainly easy to try ! something if you know you can undo it.

    If your function simply inserts text once, or deletes text once, and ! uses rl_insert_text() or rl_delete_text() to do it, then undoing is already done for you automatically. *************** *** 2418,2423 **** If you do multiple insertions or multiple deletions, or any combination of these operations, you should group them together into one operation. ! This is done with rl_begin_undo_group () and ! rl_end_undo_group ().

    --- 2710,2715 ---- If you do multiple insertions or multiple deletions, or any combination of these operations, you should group them together into one operation. ! This is done with rl_begin_undo_group() and ! rl_end_undo_group().

    *************** *** 2434,2450 **** Notice that UNDO_DELETE means to insert some text, and UNDO_INSERT means to delete some text. That is, the undo code ! tells undo what to undo, not how to undo it. UNDO_BEGIN and ! UNDO_END are tags added by rl_begin_undo_group () and ! rl_end_undo_group ().

    !
    Function: int rl_begin_undo_group () !
    Begins saving undo information in a group construct. The undo ! information usually comes from calls to rl_insert_text () and ! rl_delete_text (), but could be the result of calls to ! rl_add_undo ().
    --- 2726,2742 ---- Notice that UNDO_DELETE means to insert some text, and UNDO_INSERT means to delete some text. That is, the undo code ! tells what to undo, not how to undo it. UNDO_BEGIN and ! UNDO_END are tags added by rl_begin_undo_group() and ! rl_end_undo_group().

    !
    Function: int rl_begin_undo_group (void) !
    Begins saving undo information in a group construct. The undo ! information usually comes from calls to rl_insert_text() and ! rl_delete_text(), but could be the result of calls to ! rl_add_undo().
    *************** *** 2452,2460 ****

    !
    Function: int rl_end_undo_group () !
    Closes the current undo group started with rl_begin_undo_group ! (). There should be one call to rl_end_undo_group () ! for each call to rl_begin_undo_group ().
    --- 2744,2752 ----

    !
    Function: int rl_end_undo_group (void) !
    Closes the current undo group started with rl_begin_undo_group ! (). There should be one call to rl_end_undo_group() ! for each call to rl_begin_undo_group().
    *************** *** 2463,2467 ****
    Function: void rl_add_undo (enum undo_code what, int start, int end, char *text) !
    Remember how to undo an event (according to what). The affected text runs from start to end, and encompasses text. --- 2755,2759 ----
    Function: void rl_add_undo (enum undo_code what, int start, int end, char *text) !
    Remember how to undo an event (according to what). The affected text runs from start to end, and encompasses text. *************** *** 2471,2476 ****

    !
    Function: void free_undo_list () !
    Free the existing undo list.
    --- 2763,2768 ----

    !
    Function: void rl_free_undo_list (void) !
    Free the existing undo list.
    *************** *** 2479,2484 ****

    !
    Function: int rl_do_undo () !
    Undo the first thing on the undo list. Returns 0 if there was nothing to undo, non-zero if something was undone. --- 2771,2776 ----

    !
    Function: int rl_do_undo (void) !
    Undo the first thing on the undo list. Returns 0 if there was nothing to undo, non-zero if something was undone. *************** *** 2488,2492 ****

    Finally, if you neither insert nor delete text, but directly modify the ! existing text (e.g., change its case), call rl_modifying () once, just before you modify the text. You must supply the indices of the text range that you are going to modify. --- 2780,2784 ----

    Finally, if you neither insert nor delete text, but directly modify the ! existing text (e.g., change its case), call rl_modifying() once, just before you modify the text. You must supply the indices of the text range that you are going to modify. *************** *** 2496,2500 ****

    Function: int rl_modifying (int start, int end) !
    Tell Readline to save the text between start and end as a single undo unit. It is assumed that you will subsequently modify --- 2788,2792 ----
    Function: int rl_modifying (int start, int end) !
    Tell Readline to save the text between start and end as a single undo unit. It is assumed that you will subsequently modify *************** *** 2509,2514 ****

    !
    Function: void rl_redisplay () !
    Change what's displayed on the screen to reflect the current contents of rl_line_buffer. --- 2801,2806 ----

    !
    Function: void rl_redisplay (void) !
    Change what's displayed on the screen to reflect the current contents of rl_line_buffer. *************** *** 2518,2523 ****

    !
    Function: int rl_forced_update_display () !
    Force the line to be updated and redisplayed, whether or not Readline thinks the screen display is correct. --- 2810,2815 ----

    !
    Function: int rl_forced_update_display (void) !
    Force the line to be updated and redisplayed, whether or not Readline thinks the screen display is correct. *************** *** 2527,2532 ****

    !
    Function: int rl_on_new_line () !
    Tell the update functions that we have moved onto a new (empty) line, usually after ouputting a newline. --- 2819,2824 ----

    !
    Function: int rl_on_new_line (void) !
    Tell the update functions that we have moved onto a new (empty) line, usually after ouputting a newline. *************** *** 2536,2541 ****

    !
    Function: int rl_on_new_line_with_prompt () !
    Tell the update functions that we have moved onto a new line, with rl_prompt already displayed. --- 2828,2833 ----

    !
    Function: int rl_on_new_line_with_prompt (void) !
    Tell the update functions that we have moved onto a new line, with rl_prompt already displayed. *************** *** 2549,2554 ****

    !
    Function: int rl_reset_line_state () !
    Reset the display state to a clean state and redisplay the current line starting on a new line. --- 2841,2846 ----

    !
    Function: int rl_reset_line_state (void) !
    Reset the display state to a clean state and redisplay the current line starting on a new line. *************** *** 2558,2565 ****

    !
    Function: int rl_message (va_alist) !
    ! The arguments are a string as would be supplied to printf. The ! resulting string is displayed in the echo area. The echo area is also used to display numeric arguments and search strings.
    --- 2850,2879 ----

    !
    Function: int rl_crlf (void) !
    ! Move the cursor to the start of the next screen line. !
    ! !

    !

    !

    !
    Function: int rl_show_char (int c) !
    ! Display character c on rl_outstream. ! If Readline has not been set to display meta characters directly, this ! will convert meta characters to a meta-prefixed key sequence. ! This is intended for use by applications which wish to do their own ! redisplay. !
    ! !

    !

    !

    !
    Function: int rl_message (const char *, ...) !
    ! The arguments are a format string as would be supplied to printf, ! possibly containing conversion specifications such as `%d', and ! any additional arguments necessary to satisfy the conversion specifications. ! The resulting string is displayed in the echo area. The echo area is also used to display numeric arguments and search strings.
    *************** *** 2568,2573 ****

    !
    Function: int rl_clear_message () !
    Clear the message in the echo area.
    --- 2882,2887 ----

    !
    Function: int rl_clear_message (void) !
    Clear the message in the echo area.
    *************** *** 2576,2583 ****

    !
    Function: void rl_save_prompt () !
    Save the local Readline prompt display state in preparation for ! displaying a new message in the message area with rl_message.
    --- 2890,2897 ----

    !
    Function: void rl_save_prompt (void) !
    Save the local Readline prompt display state in preparation for ! displaying a new message in the message area with rl_message().
    *************** *** 2585,2590 ****

    !
    Function: void rl_restore_prompt () !
    Restore the local Readline prompt display state saved by the most recent call to rl_save_prompt. --- 2899,2904 ----

    !
    Function: void rl_restore_prompt (void) !
    Restore the local Readline prompt display state saved by the most recent call to rl_save_prompt. *************** *** 2592,2595 **** --- 2906,2933 ----

    +

    +

    +
    Function: int rl_expand_prompt (char *prompt) +
    + Expand any special character sequences in prompt and set up the + local Readline prompt redisplay variables. + This function is called by readline(). It may also be called to + expand the primary prompt if the rl_on_new_line_with_prompt() + function or rl_already_prompted variable is used. + It returns the number of visible characters on the last line of the + (possibly multi-line) prompt. +
    + +

    +

    +

    +
    Function: int rl_set_prompt (const char *prompt) +
    + Make Readline use prompt for subsequent redisplay. This calls + rl_expand_prompt() to expand the prompt and sets rl_prompt + to the result. +
    + +

    *************** *** 2598,2603 ****

    !
    Function: int rl_insert_text (char *text) !
    Insert text into the line at the current cursor position.
    --- 2936,2941 ----

    !
    Function: int rl_insert_text (const char *text) !
    Insert text into the line at the current cursor position.
    *************** *** 2607,2611 ****
    Function: int rl_delete_text (int start, int end) !
    Delete the text between start and end in the current line.
    --- 2945,2949 ----
    Function: int rl_delete_text (int start, int end) !
    Delete the text between start and end in the current line.
    *************** *** 2615,2619 ****
    Function: char * rl_copy_text (int start, int end) !
    Return a copy of the text between start and end in the current line. --- 2953,2957 ----
    Function: char * rl_copy_text (int start, int end) !
    Return a copy of the text between start and end in the current line. *************** *** 2624,2628 ****
    Function: int rl_kill_text (int start, int end) !
    Copy the text between start and end in the current line to the kill ring, appending or prepending to the last kill if the --- 2962,2966 ----
    Function: int rl_kill_text (int start, int end) !
    Copy the text between start and end in the current line to the kill ring, appending or prepending to the last kill if the *************** *** 2634,2648 ****

    !

    Utility Functions

    !
    Function: int rl_read_key () !
    ! Return the next character available. This handles input inserted into ! the input stream via pending input (see section Readline Variables) ! and rl_stuff_char (), macros, and characters read from the keyboard.
    --- 2972,2999 ----

    +

    +

    +
    Function: int rl_push_macro_input (char *macro) +
    + Cause macro to be inserted into the line, as if it had been invoked + by a key bound to a macro. Not especially useful; use + rl_insert_text() instead. +
    + +

    !

    Character Input

    !
    Function: int rl_read_key (void) !
    ! Return the next character available from Readline's current input stream. ! This handles input inserted into ! the input stream via rl_pending_input (see section Readline Variables) ! and rl_stuff_char(), macros, and characters read from the keyboard. ! While waiting for input, this function will call any function assigned to ! the rl_event_hook variable.
    *************** *** 2650,2656 ****

    !
    Function: int rl_getc (FILE *) !
    ! Return the next character available from the keyboard.
    --- 3001,3008 ----

    !
    Function: int rl_getc (FILE *stream) !
    ! Return the next character available from stream, which is assumed to ! be the keyboard.
    *************** *** 2659,2666 ****
    Function: int rl_stuff_char (int c) !
    Insert c into the Readline input stream. It will be "read" before Readline attempts to read characters from the terminal with ! rl_read_key ().
    --- 3011,3018 ----
    Function: int rl_stuff_char (int c) !
    Insert c into the Readline input stream. It will be "read" before Readline attempts to read characters from the terminal with ! rl_read_key().
    *************** *** 2668,2675 ****

    !
    Function: int rl_extend_line_buffer (int len) !
    ! Ensure that rl_line_buffer has enough space to hold len ! characters, possibly reallocating it if necessary.
    --- 3020,3027 ----

    !
    Function: int rl_execute_next (int c) !
    ! Make c be the next command to be executed when rl_read_key() ! is called. This sets rl_pending_input.
    *************** *** 2677,2683 ****

    !
    Function: int rl_initialize () !
    ! Initialize or re-initialize Readline's internal state.
    --- 3029,3037 ----

    !
    Function: int rl_clear_pending_input (void) !
    ! Unset rl_pending_input, effectively negating the effect of any ! previous call to rl_execute_next(). This works only if the ! pending input has not already been read with rl_read_key().
    *************** *** 2685,2702 ****

    !
    Function: int rl_reset_terminal (char *terminal_name) !
    Reinitialize Readline's idea of the terminal settings using terminal_name as the terminal type (e.g., vt100). ! If terminal_name is NULL, the value of the TERM environment variable is used.

    !
    Function: int alphabetic (int c) !
    ! Return 1 if c is an alphabetic character.
    --- 3039,3107 ----

    !
    Function: int rl_set_keyboard_input_timeout (int u) !
    ! While waiting for keyboard input in rl_read_key(), Readline will ! wait for u microseconds for input before calling any function ! assigned to rl_event_hook. The default waiting period is ! one-tenth of a second. Returns the old timeout value. !
    ! !

    ! ! !

    Terminal Management

    ! !

    !

    !
    Function: void rl_prep_terminal (int meta_flag) !
    ! Modify the terminal settings for Readline's use, so readline() ! can read a single character at a time from the keyboard. ! The meta_flag argument should be non-zero if Readline should ! read eight-bit input. !
    ! !

    !

    !

    !
    Function: void rl_deprep_terminal (void) !
    ! Undo the effects of rl_prep_terminal(), leaving the terminal in ! the state in which it was before the most recent call to ! rl_prep_terminal(). !
    ! !

    !

    !

    !
    Function: void rl_tty_set_default_bindings (Keymap kmap) !
    ! Read the operating system's terminal editing characters (as would be displayed ! by stty) to their Readline equivalents. The bindings are performed ! in kmap. !
    ! !

    !

    !

    !
    Function: int rl_reset_terminal (const char *terminal_name) !
    Reinitialize Readline's idea of the terminal settings using terminal_name as the terminal type (e.g., vt100). ! If terminal_name is NULL, the value of the TERM environment variable is used.

    + + +

    Utility Functions

    +

    !
    Function: int rl_extend_line_buffer (int len) !
    ! Ensure that rl_line_buffer has enough space to hold len ! characters, possibly reallocating it if necessary.
    *************** *** 2704,2710 ****

    !
    Function: int numeric (int c) !
    ! Return 1 if c is a numeric character.
    --- 3109,3117 ----

    !
    Function: int rl_initialize (void) !
    ! Initialize or re-initialize Readline's internal state. ! It's not strictly necessary to call this; readline() calls it before ! reading any input.
    *************** *** 2712,2717 ****

    !
    Function: int ding () !
    Ring the terminal bell, obeying the setting of bell-style.
    --- 3119,3124 ----

    !
    Function: int rl_ding (void) !
    Ring the terminal bell, obeying the setting of bell-style.
    *************** *** 2720,2725 ****

    Function: void rl_display_match_list (char **matches, int len, int max) !
    A convenience function for displaying a list of strings in columnar format on Readline's output stream. matches is the list --- 3127,3140 ----

    +
    Function: int rl_alphabetic (int c) +
    + Return 1 if c is an alphabetic character. +
    + +

    +

    +

    Function: void rl_display_match_list (char **matches, int len, int max) !
    A convenience function for displaying a list of strings in columnar format on Readline's output stream. matches is the list *************** *** 2733,2743 ****

    ! The following are implemented as macros, defined in chartypes.h.

    !
    Function: int uppercase_p (int c) !
    Return 1 if c is an uppercase alphabetic character.
    --- 3148,3159 ----

    ! The following are implemented as macros, defined in chardefs.h. ! Applications should refrain from using them.

    !
    Function: int _rl_uppercase_p (int c) !
    Return 1 if c is an uppercase alphabetic character.
    *************** *** 2746,2751 ****

    !
    Function: int lowercase_p (int c) !
    Return 1 if c is a lowercase alphabetic character.
    --- 3162,3167 ----

    !
    Function: int _rl_lowercase_p (int c) !
    Return 1 if c is a lowercase alphabetic character.
    *************** *** 2754,2759 ****

    !
    Function: int digit_p (int c) !
    Return 1 if c is a numeric character.
    --- 3170,3175 ----

    !
    Function: int _rl_digit_p (int c) !
    Return 1 if c is a numeric character.
    *************** *** 2762,2767 ****

    !
    Function: int to_upper (int c) !
    If c is a lowercase alphabetic character, return the corresponding uppercase character. --- 3178,3183 ----

    !
    Function: int _rl_to_upper (int c) !
    If c is a lowercase alphabetic character, return the corresponding uppercase character. *************** *** 2771,2776 ****

    !
    Function: int to_lower (int c) !
    If c is an uppercase alphabetic character, return the corresponding lowercase character. --- 3187,3192 ----

    !
    Function: int _rl_to_lower (int c) !
    If c is an uppercase alphabetic character, return the corresponding lowercase character. *************** *** 2780,2785 ****

    !
    Function: int digit_value (int c) !
    If c is a number, return the value it represents.
    --- 3196,3201 ----

    !
    Function: int _rl_digit_value (int c) !
    If c is a number, return the value it represents.
    *************** *** 2788,2792 **** !

    Alternate Interface

    --- 3204,3265 ---- !

    Miscellaneous Functions

    ! !

    !

    !
    Function: int rl_macro_bind (const char *keyseq, const char *macro, Keymap map) !
    ! Bind the key sequence keyseq to invoke the macro macro. ! The binding is performed in map. When keyseq is invoked, the ! macro will be inserted into the line. This function is deprecated; ! use rl_generic_bind() instead. !
    ! !

    !

    !

    !
    Function: void rl_macro_dumper (int readable) !
    ! Print the key sequences bound to macros and their values, using ! the current keymap, to rl_outstream. ! If readable is non-zero, the list is formatted in such a way ! that it can be made part of an inputrc file and re-read. !
    ! !

    !

    !

    !
    Function: int rl_variable_bind (const char *variable, const char *value) !
    ! Make the Readline variable variable have value. ! This behaves as if the readline command ! `set variable value' had been executed in an inputrc ! file (see section Readline Init File Syntax). !
    ! !

    !

    !

    !
    Function: void rl_variable_dumper (int readable) !
    ! Print the readline variable names and their current values ! to rl_outstream. ! If readable is non-zero, the list is formatted in such a way ! that it can be made part of an inputrc file and re-read. !
    ! !

    !

    !

    !
    Function: int rl_set_paren_blink_timeout (int u) !
    ! Set the time interval (in microseconds) that Readline waits when showing ! a balancing character when blink-matching-paren has been enabled. !
    ! !

    ! ! !

    Alternate Interface

    *************** *** 2801,2809 ****

    !
    Function: void rl_callback_handler_install (char *prompt, Vfunction *lhandler) !
    Set up the terminal for readline I/O and display the initial expanded value of prompt. Save the value of lhandler to ! use as a callback when a complete line of input has been entered.
    --- 3274,3283 ----

    !
    Function: void rl_callback_handler_install (const char *prompt, rl_vcpfunc_t *lhandler) !
    Set up the terminal for readline I/O and display the initial expanded value of prompt. Save the value of lhandler to ! use as a function to call when a complete line of input has been entered. ! The function takes the text of the line as an argument.
    *************** *** 2811,2816 ****

    !
    Function: void rl_callback_read_char () !
    Whenever an application determines that keyboard input is available, it should call rl_callback_read_char(), which will read the next --- 3285,3290 ----

    !
    Function: void rl_callback_read_char (void) !
    Whenever an application determines that keyboard input is available, it should call rl_callback_read_char(), which will read the next *************** *** 2825,2830 ****

    !
    Function: void rl_callback_handler_remove () !
    Restore the terminal to its initial state and remove the line handler. This may be called from within a callback as well as independently. --- 3299,3304 ----

    !
    Function: void rl_callback_handler_remove (void) !
    Restore the terminal to its initial state and remove the line handler. This may be called from within a callback as well as independently. *************** *** 2834,2838 **** !

    An Example

    --- 3308,3312 ---- !

    A Readline Example

    *************** *** 2892,2899 **** for (i = start; i != end; i++) { ! if (uppercase_p (rl_line_buffer[i])) ! rl_line_buffer[i] = to_lower (rl_line_buffer[i]); ! else if (lowercase_p (rl_line_buffer[i])) ! rl_line_buffer[i] = to_upper (rl_line_buffer[i]); } /* Move point to on top of the last character changed. */ --- 3366,3373 ---- for (i = start; i != end; i++) { ! if (_rl_uppercase_p (rl_line_buffer[i])) ! rl_line_buffer[i] = _rl_to_lower (rl_line_buffer[i]); ! else if (_rl_lowercase_p (rl_line_buffer[i])) ! rl_line_buffer[i] = _rl_to_upper (rl_line_buffer[i]); } /* Move point to on top of the last character changed. */ *************** *** 2905,2920 **** !

    Readline Signal Handling

    Signals are asynchronous events sent to a process by the Unix kernel, sometimes on behalf of another process. They are intended to indicate ! exceptional events, like a user pressing the interrupt key on his ! terminal, or a network connection being broken. There is a class of ! signals that can be sent to the process currently reading input from ! the keyboard. Since Readline changes the terminal attributes when it ! is called, it needs to perform special processing when a signal is ! received to restore the terminal to a sane state, or provide application ! writers with functions to do so manually.

    --- 3379,3394 ---- !

    Readline Signal Handling

    Signals are asynchronous events sent to a process by the Unix kernel, sometimes on behalf of another process. They are intended to indicate ! exceptional events, like a user pressing the interrupt key on his terminal, ! or a network connection being broken. There is a class of signals that can ! be sent to the process currently reading input from the keyboard. Since ! Readline changes the terminal attributes when it is called, it needs to ! perform special processing when such a signal is received in order to ! restore the terminal to a sane state, or provide application writers with ! functions to do so manually.

    *************** *** 2925,2930 **** When one of these signals is received, the signal handler will reset the terminal attributes to those that were in effect before ! readline () was called, reset the signal handling to what it was ! before readline () was called, and resend the signal to the calling application. If and when the calling application's signal handler returns, Readline --- 3399,3404 ---- When one of these signals is received, the signal handler will reset the terminal attributes to those that were in effect before ! readline() was called, reset the signal handling to what it was ! before readline() was called, and resend the signal to the calling application. If and when the calling application's signal handler returns, Readline *************** *** 2932,2936 **** When a SIGINT is received, the Readline signal handler performs some additional work, which will cause any partially-entered line to be ! aborted (see the description of rl_free_line_state ()).

    --- 3406,3410 ---- When a SIGINT is received, the Readline signal handler performs some additional work, which will cause any partially-entered line to be ! aborted (see the description of rl_free_line_state() below).

    *************** *** 2939,2949 **** the kernel sends to a process whenever the terminal's size changes (for example, if a user resizes an xterm). The Readline SIGWINCH ! handler updates Readline's internal screen size state, and then calls any ! SIGWINCH signal handler the calling application has installed. Readline calls the application's SIGWINCH signal handler without resetting the terminal to its original state. If the application's signal handler does more than update its idea of the terminal size and return (for example, a longjmp back to a main processing loop), it must ! call rl_cleanup_after_signal () (described below), to restore the terminal state. --- 3413,3423 ---- the kernel sends to a process whenever the terminal's size changes (for example, if a user resizes an xterm). The Readline SIGWINCH ! handler updates Readline's internal screen size information, and then calls ! any SIGWINCH signal handler the calling application has installed. Readline calls the application's SIGWINCH signal handler without resetting the terminal to its original state. If the application's signal handler does more than update its idea of the terminal size and return (for example, a longjmp back to a main processing loop), it must ! call rl_cleanup_after_signal() (described below), to restore the terminal state. *************** *** 2953,2957 **** control whether or not it will catch certain signals and act on them when they are received. It is important that applications change the ! values of these variables only when calling readline (), not in a signal handler, so Readline's internal signal state is not corrupted. --- 3427,3431 ---- control whether or not it will catch certain signals and act on them when they are received. It is important that applications change the ! values of these variables only when calling readline(), not in a signal handler, so Readline's internal signal state is not corrupted. *************** *** 2960,2964 ****
    Variable: int rl_catch_signals !
    If this variable is non-zero, Readline will install signal handlers for SIGINT, SIGQUIT, SIGTERM, SIGALRM, --- 3434,3438 ----
    Variable: int rl_catch_signals !
    If this variable is non-zero, Readline will install signal handlers for SIGINT, SIGQUIT, SIGTERM, SIGALRM, *************** *** 2974,2978 ****
    Variable: int rl_catch_sigwinch !
    If this variable is non-zero, Readline will install a signal handler for SIGWINCH. --- 3448,3452 ----
    Variable: int rl_catch_sigwinch !
    If this variable is non-zero, Readline will install a signal handler for SIGWINCH. *************** *** 2995,3001 ****
    Function: void rl_cleanup_after_signal (void) !
    This function will reset the state of the terminal to what it was before ! readline () was called, and remove the Readline signal handlers for all signals, depending on the values of rl_catch_signals and rl_catch_sigwinch. --- 3469,3475 ----
    Function: void rl_cleanup_after_signal (void) !
    This function will reset the state of the terminal to what it was before ! readline() was called, and remove the Readline signal handlers for all signals, depending on the values of rl_catch_signals and rl_catch_sigwinch. *************** *** 3006,3014 ****
    Function: void rl_free_line_state (void) !
    This will free any partial state associated with the current input line (undo information, any partial history entry, any partially-entered keyboard macro, and any partially-entered numeric argument). This ! should be called before rl_cleanup_after_signal (). The Readline signal handler for SIGINT calls this to abort the current input line. --- 3480,3488 ----
    Function: void rl_free_line_state (void) !
    This will free any partial state associated with the current input line (undo information, any partial history entry, any partially-entered keyboard macro, and any partially-entered numeric argument). This ! should be called before rl_cleanup_after_signal(). The Readline signal handler for SIGINT calls this to abort the current input line. *************** *** 3019,3023 ****
    Function: void rl_reset_after_signal (void) !
    This will reinitialize the terminal and reinstall any Readline signal handlers, depending on the values of rl_catch_signals and --- 3493,3497 ----
    Function: void rl_reset_after_signal (void) !
    This will reinitialize the terminal and reinstall any Readline signal handlers, depending on the values of rl_catch_signals and *************** *** 3028,3033 ****

    If an application does not wish Readline to catch SIGWINCH, it may ! call rl_resize_terminal () to force Readline to update its idea of ! the terminal size when a SIGWINCH is received.

    --- 3502,3508 ----

    If an application does not wish Readline to catch SIGWINCH, it may ! call rl_resize_terminal() or rl_set_screen_size() to force ! Readline to update its idea of the terminal size when a SIGWINCH ! is received.

    *************** *** 3035,3040 ****
    Function: void rl_resize_terminal (void) !
    ! Update Readline's internal screen size.
    --- 3510,3539 ----
    Function: void rl_resize_terminal (void) !
    ! Update Readline's internal screen size by reading values from the kernel. !
    ! !

    !

    !

    !
    Function: void rl_set_screen_size (int rows, int cols) !
    ! Set Readline's idea of the terminal size to rows rows and ! cols columns. !
    ! !

    !

    ! If an application does not want to install a SIGWINCH handler, but ! is still interested in the screen dimensions, Readline's idea of the screen ! size may be queried. ! !

    !

    !

    !
    Function: void rl_get_screen_size (int *rows, int *cols) !
    ! Return Readline's idea of the terminal's size in the ! variables pointed to by the arguments.
    *************** *** 3047,3051 ****
    Function: int rl_set_signals (void) !
    Install Readline's signal handler for SIGINT, SIGQUIT, SIGTERM, SIGALRM, SIGTSTP, SIGTTIN, --- 3546,3550 ----
    Function: int rl_set_signals (void) !
    Install Readline's signal handler for SIGINT, SIGQUIT, SIGTERM, SIGALRM, SIGTSTP, SIGTTIN, *************** *** 3058,3064 ****
    Function: int rl_clear_signals (void) !
    Remove all of the Readline signal handlers installed by ! rl_set_signals ().
    --- 3557,3563 ----
    Function: int rl_clear_signals (void) !
    Remove all of the Readline signal handlers installed by ! rl_set_signals().
    *************** *** 3066,3070 **** !

    Custom Completers

    --- 3565,3569 ---- !

    Custom Completers

    *************** *** 3078,3090 ****

    !

    How Completing Works

    --- 3577,3589 ----

    !

    How Completing Works

    *************** *** 3107,3115 ****

  • ! The user-interface function rl_complete (). This function is ! called with the same arguments as other Readline ! functions intended for interactive use: count and ! invoking_key. It isolates the word to be completed and calls ! completion_matches () to generate a list of possible completions. It then either lists the possible completions, inserts the possible completions, or actually performs the --- 3606,3614 ----
  • ! The user-interface function rl_complete(). This function is ! called with the same arguments as other bindable Readline functions: ! count and invoking_key. ! It isolates the word to be completed and calls ! rl_completion_matches() to generate a list of possible completions. It then either lists the possible completions, inserts the possible completions, or actually performs the *************** *** 3118,3136 ****
  • ! The internal function completion_matches () uses your ! generator function to generate the list of possible matches, and ! then returns the array of these matches. You should place the address ! of your generator function in rl_completion_entry_function.
  • The generator function is called repeatedly from ! completion_matches (), returning a string each time. The arguments to the generator function are text and state. text is the partial word to be completed. state is zero the first time the function is called, allowing the generator to perform any necessary initialization, and a positive non-zero integer for ! each subsequent call. When the generator function returns ! (char *)NULL this signals completion_matches () that there are no more possibilities left. Usually the generator function computes the list of possible completions when state is zero, and returns them --- 3617,3636 ----
  • ! The internal function rl_completion_matches() uses an ! application-supplied generator function to generate the list of ! possible matches, and then returns the array of these matches. ! The caller should place the address of its generator function in ! rl_completion_entry_function.
  • The generator function is called repeatedly from ! rl_completion_matches(), returning a string each time. The arguments to the generator function are text and state. text is the partial word to be completed. state is zero the first time the function is called, allowing the generator to perform any necessary initialization, and a positive non-zero integer for ! each subsequent call. The generator function returns ! (char *)NULL to inform rl_completion_matches() that there are no more possibilities left. Usually the generator function computes the list of possible completions when state is zero, and returns them *************** *** 3144,3151 ****
    Function: int rl_complete (int ignore, int invoking_key) !
    Complete the word at or before point. You have supplied the function that does the initial simple matching selection algorithm (see ! completion_matches ()). The default is to do filename completion.
    --- 3644,3651 ----
    Function: int rl_complete (int ignore, int invoking_key) !
    Complete the word at or before point. You have supplied the function that does the initial simple matching selection algorithm (see ! rl_completion_matches()). The default is to do filename completion.
    *************** *** 3153,3162 ****

    !
    Variable: Function * rl_completion_entry_function !
    ! This is a pointer to the generator function for completion_matches ! (). If the value of rl_completion_entry_function is ! (Function *)NULL then the default filename generator function, ! filename_completion_function (), is used.
    --- 3653,3663 ----

    !
    Variable: rl_compentry_func_t * rl_completion_entry_function !
    ! This is a pointer to the generator function for ! rl_completion_matches(). ! If the value of rl_completion_entry_function is ! NULL then the default filename generator ! function, rl_filename_completion_function(), is used.
    *************** *** 3164,3168 **** !

    Completion Functions

    --- 3665,3669 ---- !

    Completion Functions

    *************** *** 3174,3178 ****

    Function: int rl_complete_internal (int what_to_do) !
    Complete the word at or before point. what_to_do says what to do with the completion. A value of `?' means list the possible --- 3675,3679 ----
    Function: int rl_complete_internal (int what_to_do) !
    Complete the word at or before point. what_to_do says what to do with the completion. A value of `?' means list the possible *************** *** 3187,3196 ****
    Function: int rl_complete (int ignore, int invoking_key) !
    Complete the word at or before point. You have supplied the function that does the initial simple matching selection algorithm (see ! completion_matches () and rl_completion_entry_function). The default is to do filename ! completion. This calls rl_complete_internal () with an argument depending on invoking_key.
    --- 3688,3697 ----
    Function: int rl_complete (int ignore, int invoking_key) !
    Complete the word at or before point. You have supplied the function that does the initial simple matching selection algorithm (see ! rl_completion_matches() and rl_completion_entry_function). The default is to do filename ! completion. This calls rl_complete_internal() with an argument depending on invoking_key.
    *************** *** 3199,3206 ****

    !
    Function: int rl_possible_completions (int count, int invoking_key)) !
    List the possible completions. See description of rl_complete ! (). This calls rl_complete_internal () with an argument of `?'.
    --- 3700,3707 ----

    !
    Function: int rl_possible_completions (int count, int invoking_key) !
    List the possible completions. See description of rl_complete ! (). This calls rl_complete_internal() with an argument of `?'.
    *************** *** 3209,3217 ****

    !
    Function: int rl_insert_completions (int count, int invoking_key)) !
    Insert the list of possible completions into the line, deleting the ! partially-completed word. See description of rl_complete (). ! This calls rl_complete_internal () with an argument of `*'.
    --- 3710,3718 ----

    !
    Function: int rl_insert_completions (int count, int invoking_key) !
    Insert the list of possible completions into the line, deleting the ! partially-completed word. See description of rl_complete(). ! This calls rl_complete_internal() with an argument of `*'.
    *************** *** 3219,3226 ****

    !
    Function: char ** completion_matches (char *text, CPFunction *entry_func) !
    ! Returns an array of (char *) which is a list of completions for ! text. If there are no completions, returns (char **)NULL. The first entry in the returned array is the substitution for text. The remaining entries are the possible completions. The array is --- 3720,3727 ----

    !
    Function: char ** rl_completion_matches (const char *text, rl_compentry_func_t *entry_func) !
    ! Returns an array of strings which is a list of completions for ! text. If there are no completions, returns NULL. The first entry in the returned array is the substitution for text. The remaining entries are the possible completions. The array is *************** *** 3230,3234 ****

    entry_func is a function of two args, and returns a ! (char *). The first argument is text. The second is a state argument; it is zero on the first call, and non-zero on subsequent calls. entry_func returns a NULL pointer to the caller --- 3731,3735 ----

    entry_func is a function of two args, and returns a ! char *. The first argument is text. The second is a state argument; it is zero on the first call, and non-zero on subsequent calls. entry_func returns a NULL pointer to the caller *************** *** 3239,3249 ****

    !
    Function: char * filename_completion_function (char *text, int state) !
    ! A generator function for filename completion in the general case. Note ! that completion in Bash is a little different because of all ! the pathnames that must be followed when looking up completions for a ! command. The Bash source is a useful reference for writing custom ! completion functions.
    --- 3740,3750 ----

    !
    Function: char * rl_filename_completion_function (const char *text, int state) !
    ! A generator function for filename completion in the general case. ! text is a partial filename. ! The Bash source is a useful reference for writing custom ! completion functions (the Bash completion functions call this and other ! Readline functions).
    *************** *** 3251,3256 ****

    !
    Function: char * username_completion_function (char *text, int state) !
    A completion generator for usernames. text contains a partial username preceded by a random character (usually `~'). As with all --- 3752,3757 ----

    !
    Function: char * rl_username_completion_function (const char *text, int state) !
    A completion generator for usernames. text contains a partial username preceded by a random character (usually `~'). As with all *************** *** 3262,3273 **** !

    Completion Variables

    !
    Variable: Function * rl_completion_entry_function !
    ! A pointer to the generator function for completion_matches (). ! NULL means to use filename_completion_function (), the default filename completer.
    --- 3763,3774 ---- !

    Completion Variables

    !
    Variable: rl_compentry_func_t * rl_completion_entry_function !
    ! A pointer to the generator function for rl_completion_matches(). ! NULL means to use rl_filename_completion_function(), the default filename completer.
    *************** *** 3276,3289 ****

    !
    Variable: CPPFunction * rl_attempted_completion_function !
    A pointer to an alternative function to create matches. The function is called with text, start, and end. ! start and end are indices in rl_line_buffer saying ! what the boundaries of text are. If this function exists and ! returns NULL, or if this variable is set to NULL, then ! rl_complete () will call the value of rl_completion_entry_function to generate matches, otherwise the array of strings returned will be used.
    --- 3777,3793 ----

    !
    Variable: rl_completion_func_t * rl_attempted_completion_function !
    A pointer to an alternative function to create matches. The function is called with text, start, and end. ! start and end are indices in rl_line_buffer defining ! the boundaries of text, which is a character string. ! If this function exists and returns NULL, or if this variable is ! set to NULL, then rl_complete() will call the value of rl_completion_entry_function to generate matches, otherwise the array of strings returned will be used. + If this function sets the rl_attempted_completion_over + variable to a non-zero value, Readline will not perform its default + completion even if this function returns no matches.
    *************** *** 3291,3298 ****

    !
    Variable: CPFunction * rl_filename_quoting_function !
    ! A pointer to a function that will quote a filename in an application- ! specific fashion. This is called if filename completion is being attempted and one of the characters in rl_filename_quote_characters appears in a completed filename. The function is called with --- 3795,3802 ----

    !
    Variable: rl_quote_func_t * rl_filename_quoting_function !
    ! A pointer to a function that will quote a filename in an ! application-specific fashion. This is called if filename completion is being attempted and one of the characters in rl_filename_quote_characters appears in a completed filename. The function is called with *************** *** 3309,3314 ****

    !
    Variable: CPFunction * rl_filename_dequoting_function !
    A pointer to a function that will remove application-specific quoting characters from a filename before completion is attempted, so those --- 3813,3818 ----

    !
    Variable: rl_dequote_func_t * rl_filename_dequoting_function !
    A pointer to a function that will remove application-specific quoting characters from a filename before completion is attempted, so those *************** *** 3323,3331 ****

    !
    Variable: Function * rl_char_is_quoted_p !
    A pointer to a function to call that determines whether or not a specific character in the line buffer is quoted, according to whatever quoting ! mechanism the program calling readline uses. The function is called with two arguments: text, the text of the line, and index, the index of the character in the line. It is used to decide whether a --- 3827,3835 ----

    !
    Variable: rl_linebuf_func_t * rl_char_is_quoted_p !
    A pointer to a function to call that determines whether or not a specific character in the line buffer is quoted, according to whatever quoting ! mechanism the program calling Readline uses. The function is called with two arguments: text, the text of the line, and index, the index of the character in the line. It is used to decide whether a *************** *** 3338,3342 ****
    Variable: int rl_completion_query_items !
    Up to this many items will be displayed in response to a possible-completions call. After that, we ask the user if she is sure --- 3842,3846 ----
    Variable: int rl_completion_query_items !
    Up to this many items will be displayed in response to a possible-completions call. After that, we ask the user if she is sure *************** *** 3347,3355 ****

    !
    Variable: char * rl_basic_word_break_characters !
    The basic list of characters that signal a break between words for the completer routine. The default value of this variable is the characters ! which break words for completion in Bash, i.e., " \t\n\"\\'`@$><=;|&{(".
    --- 3851,3859 ----

    !
    Variable: const char * rl_basic_word_break_characters !
    The basic list of characters that signal a break between words for the completer routine. The default value of this variable is the characters ! which break words for completion in Bash: " \t\n\"\\'`@$><=;|&{(".
    *************** *** 3358,3364 ****

    !
    Variable: char * rl_basic_quote_characters !
    ! List of quote characters which can cause a word break.
    --- 3862,3868 ----

    !
    Variable: const char * rl_basic_quote_characters !
    ! A list of quote characters which can cause a word break.
    *************** *** 3366,3373 ****

    !
    Variable: char * rl_completer_word_break_characters !
    The list of characters that signal a break between words for ! rl_complete_internal (). The default list is the value of rl_basic_word_break_characters.
    --- 3870,3877 ----

    !
    Variable: const char * rl_completer_word_break_characters !
    The list of characters that signal a break between words for ! rl_complete_internal(). The default list is the value of rl_basic_word_break_characters.
    *************** *** 3376,3382 ****

    !
    Variable: char * rl_completer_quote_characters !
    ! List of characters which can be used to quote a substring of the line. Completion occurs on the entire substring, and within the substring rl_completer_word_break_characters are treated as any other character, --- 3880,3886 ----

    !
    Variable: const char * rl_completer_quote_characters !
    ! A list of characters which can be used to quote a substring of the line. Completion occurs on the entire substring, and within the substring rl_completer_word_break_characters are treated as any other character, *************** *** 3387,3392 ****

    !
    Variable: char * rl_filename_quote_characters !
    A list of characters that cause a filename to be quoted by the completer when they appear in a completed filename. The default is the null string. --- 3891,3896 ----

    !
    Variable: const char * rl_filename_quote_characters !
    A list of characters that cause a filename to be quoted by the completer when they appear in a completed filename. The default is the null string. *************** *** 3396,3401 ****

    !
    Variable: char * rl_special_prefixes !
    The list of characters that are word break characters, but should be left in text when it is passed to the completion function. --- 3900,3905 ----

    !
    Variable: const char * rl_special_prefixes !
    The list of characters that are word break characters, but should be left in text when it is passed to the completion function. *************** *** 3409,3413 ****
    Variable: int rl_completion_append_character !
    When a single completion alternative matches at the end of the command line, this character is appended to the inserted completion text. The --- 3913,3917 ----
    Variable: int rl_completion_append_character !
    When a single completion alternative matches at the end of the command line, this character is appended to the inserted completion text. The *************** *** 3423,3428 ****
    Variable: int rl_ignore_completion_duplicates !
    ! If non-zero, then disallow duplicates in the matches. Default is 1.
    --- 3927,3933 ----
    Variable: int rl_ignore_completion_duplicates !
    ! If non-zero, then duplicates in the matches are removed. ! The default is 1.
    *************** *** 3431,3441 ****
    Variable: int rl_filename_completion_desired !
    Non-zero means that the results of the matches are to be treated as filenames. This is always zero on entry, and can only be changed within a completion entry generator function. If it is set to a non-zero value, directory names have a slash appended and Readline attempts to ! quote completed filenames if they contain any embedded word break ! characters.
    --- 3936,3947 ----
    Variable: int rl_filename_completion_desired !
    Non-zero means that the results of the matches are to be treated as filenames. This is always zero on entry, and can only be changed within a completion entry generator function. If it is set to a non-zero value, directory names have a slash appended and Readline attempts to ! quote completed filenames if they contain any characters in ! rl_filename_quote_characters and rl_filename_quoting_desired ! is set to a non-zero value.
    *************** *** 3444,3448 ****
    Variable: int rl_filename_quoting_desired !
    Non-zero means that the results of the matches are to be quoted using double quotes (or an application-specific quoting mechanism) if the --- 3950,3954 ----
    Variable: int rl_filename_quoting_desired !
    Non-zero means that the results of the matches are to be quoted using double quotes (or an application-specific quoting mechanism) if the *************** *** 3457,3463 ****

    Variable: int rl_inhibit_completion !
    ! If this variable is non-zero, completion is inhibit<ed. The completion character will be inserted as any other bound to self-insert.
    --- 3963,3991 ----

    +
    Variable: int rl_attempted_completion_over +
    + If an application-specific completion function assigned to + rl_attempted_completion_function sets this variable to a non-zero + value, Readline will not perform its default filename completion even + if the application's completion function returns no matches. + It should be set only by an application's completion function. +
    + +

    +

    +

    +
    Variable: int rl_completion_type +
    + Set to a character describing the type of completion Readline is currently + attempting; see the description of rl_complete_internal() + (see section Completion Functions) for the list of characters. +
    + +

    +

    +

    Variable: int rl_inhibit_completion !
    ! If this variable is non-zero, completion is inhibited. The completion character will be inserted as any other bound to self-insert.
    *************** *** 3466,3471 ****

    !
    Variable: Function * rl_ignore_some_completions_function !
    This function, if defined, is called by the completer when real filename completion is done, after all the matching names have been generated. --- 3994,3999 ----

    !
    Variable: rl_compignore_func_t * rl_ignore_some_completions_function !
    This function, if defined, is called by the completer when real filename completion is done, after all the matching names have been generated. *************** *** 3480,3489 ****

    !
    Variable: Function * rl_directory_completion_hook !
    This function, if defined, is allowed to modify the directory portion of filenames Readline completes. It is called with the address of a ! string (the current directory name) as an argument. It could be used ! to expand symbolic links or shell variables in pathnames.
    --- 4008,4023 ----

    !
    Variable: rl_icppfunc_t * rl_directory_completion_hook !
    This function, if defined, is allowed to modify the directory portion of filenames Readline completes. It is called with the address of a ! string (the current directory name) as an argument, and may modify that string. ! If the string is replaced with a new string, the old value should be freed. ! Any modified directory name should have a trailing slash. ! The modified value will be displayed as part of the completion, replacing ! the directory portion of the pathname the user typed. ! It returns an integer that should be non-zero if the function modifies ! its directory argument. ! It could be used to expand symbolic links or shell variables in pathnames.
    *************** *** 3491,3496 ****

    !
    Variable: VFunction * rl_completion_display_matches_hook !
    If non-zero, then this is the address of a function to call when completing a word would normally display the list of possible matches. --- 4025,4030 ----

    !
    Variable: rl_compdisp_func_t * rl_completion_display_matches_hook !
    If non-zero, then this is the address of a function to call when completing a word would normally display the list of possible matches. *************** *** 3509,3513 **** !

    A Short Completion Example

    --- 4043,4047 ---- !

    A Short Completion Example

    *************** *** 3534,3543 **** #include <readline/history.h> - extern char *getwd (); extern char *xmalloc (); /* The names of functions that actually do the manipulation. */ ! int com_list (), com_view (), com_rename (), com_stat (), com_pwd (); ! int com_delete (), com_help (), com_cd (), com_quit (); /* A structure which contains information on the commands this program --- 4068,4083 ---- #include <readline/history.h> extern char *xmalloc (); /* The names of functions that actually do the manipulation. */ ! int com_list __P((char *)); ! int com_view __P((char *)); ! int com_rename __P((char *)); ! int com_stat __P((char *)); ! int com_pwd __P((char *)); ! int com_delete __P((char *)); ! int com_help __P((char *)); ! int com_cd __P((char *)); ! int com_quit __P((char *)); /* A structure which contains information on the commands this program *************** *** 3546,3550 **** typedef struct { char *name; /* User printable name of the function. */ ! Function *func; /* Function to call to do the job. */ char *doc; /* Documentation for this function. */ } COMMAND; --- 4086,4090 ---- typedef struct { char *name; /* User printable name of the function. */ ! rl_icpfunc_t *func; /* Function to call to do the job. */ char *doc; /* Documentation for this function. */ } COMMAND; *************** *** 3562,3566 **** { "stat", com_stat, "Print out statistics on FILE" }, { "view", com_view, "View the contents of FILE" }, ! { (char *)NULL, (Function *)NULL, (char *)NULL } }; --- 4102,4106 ---- { "stat", com_stat, "Print out statistics on FILE" }, { "view", com_view, "View the contents of FILE" }, ! { (char *)NULL, (rl_icpfunc_t *)NULL, (char *)NULL } }; *************** *** 3572,3576 **** char *progname; ! /* When non-zero, this global means the user is done using this program. */ int done; --- 4112,4116 ---- char *progname; ! /* When non-zero, this means the user is done using this program. */ int done; *************** *** 3702,3711 **** /* **************************************************************** */ ! char *command_generator (); ! char **fileman_completion (); ! /* Tell the GNU Readline library how to complete. We want to try to complete ! on command names if this is the first word in the line, or on filenames ! if not. */ initialize_readline () { --- 4242,4251 ---- /* **************************************************************** */ ! char *command_generator __P((const char *, int)); ! char **fileman_completion __P((const char *, int, int)); ! /* Tell the GNU Readline library how to complete. We want to try to ! complete on command names if this is the first word in the line, or ! on filenames if not. */ initialize_readline () { *************** *** 3714,3728 **** /* Tell the completer that we want a crack first. */ ! rl_attempted_completion_function = (CPPFunction *)fileman_completion; } ! /* Attempt to complete on the contents of TEXT. START and END bound the ! region of rl_line_buffer that contains the word to complete. TEXT is ! the word to complete. We can use the entire contents of rl_line_buffer ! in case we want to do some simple parsing. Return the array of matches, ! or NULL if there aren't any. */ char ** fileman_completion (text, start, end) ! char *text; int start, end; { --- 4254,4268 ---- /* Tell the completer that we want a crack first. */ ! rl_attempted_completion_function = fileman_completion; } ! /* Attempt to complete on the contents of TEXT. START and END ! bound the region of rl_line_buffer that contains the word to ! complete. TEXT is the word to complete. We can use the entire ! contents of rl_line_buffer in case we want to do some simple ! parsing. Returnthe array of matches, or NULL if there aren't any. */ char ** fileman_completion (text, start, end) ! const char *text; int start, end; { *************** *** 3735,3749 **** directory. */ if (start == 0) ! matches = completion_matches (text, command_generator); return (matches); } ! /* Generator function for command completion. STATE lets us know whether ! to start from scratch; without any state (i.e. STATE == 0), then we ! start at the top of the list. */ char * command_generator (text, state) ! char *text; int state; { --- 4275,4289 ---- directory. */ if (start == 0) ! matches = rl_completion_matches (text, command_generator); return (matches); } ! /* Generator function for command completion. STATE lets us ! know whether to start from scratch; without any state ! (i.e. STATE == 0), then we start at the top of the list. */ char * command_generator (text, state) ! const char *text; int state; { *************** *** 3751,3757 **** char *name; ! /* If this is a new word to complete, initialize now. This includes ! saving the length of TEXT for efficiency, and initializing the index ! variable to 0. */ if (!state) { --- 4291,4297 ---- char *name; ! /* If this is a new word to complete, initialize now. This ! includes saving the length of TEXT for efficiency, and ! initializing the index variable to 0. */ if (!state) { *************** *** 3760,3764 **** } ! /* Return the next name which partially matches from the command list. */ while (name = commands[list_index].name) { --- 4300,4305 ---- } ! /* Return the next name which partially matches from the ! command list. */ while (name = commands[list_index].name) { *************** *** 3905,3909 **** char dir[1024], *s; ! s = getwd (dir); if (s == 0) { --- 4446,4450 ---- char dir[1024], *s; ! s = getcwd (dir, sizeof(dir) - 1); if (s == 0) { *************** *** 3916,3920 **** } ! /* The user wishes to quit using this program. Just set DONE non-zero. */ com_quit (arg) char *arg; --- 4457,4462 ---- } ! /* The user wishes to quit using this program. Just set DONE ! non-zero. */ com_quit (arg) char *arg; *************** *** 3951,3955 **** !

    Concept Index

    Jump to: --- 4493,4497 ---- !

    Concept Index

    Jump to: *************** *** 3966,3969 **** --- 4508,4513 ---- r - + v + - y

    *************** *** 3992,3996 ****

    r

    !
  • readline, function
  • y

    --- 4536,4544 ----

    r

    !
  • readline, function !
  • !

    v

    ! !
  • variables, readline
  • y

    *************** *** 4002,4008 **** !

    Function and Variable Index

    Jump to: a - --- 4550,4558 ---- !

    Function and Variable Index

    Jump to: + _ + - a - *************** *** 4023,4028 **** k - - l - - m - --- 4573,4576 ---- *************** *** 4047,4325 **** y

    a

    !
  • abort (C-g) !
  • accept-line (Newline, Return) !
  • alphabetic
  • b

    !
  • backward-char (C-b) !
  • backward-delete-char (Rubout) !
  • backward-kill-line (C-x Rubout) !
  • backward-kill-word (M-DEL) !
  • backward-word (M-b) !
  • beginning-of-history (M-&#60;) !
  • beginning-of-line (C-a) !
  • bell-style
  • c

    !
  • call-last-kbd-macro (C-x e) !
  • capitalize-word (M-c) !
  • character-search (C-]) !
  • character-search-backward (M-C-]) !
  • clear-screen (C-l) !
  • comment-begin !
  • complete (TAB) !
  • completion-query-items !
  • completion_matches !
  • convert-meta !
  • copy-backward-word () !
  • copy-forward-word () !
  • copy-region-as-kill ()
  • d

    !
  • delete-char (C-d) !
  • delete-char-or-list () !
  • delete-horizontal-space () !
  • digit-argument (M-0, M-1, ... M--) !
  • digit_p !
  • digit_value !
  • ding !
  • disable-completion !
  • do-uppercase-version (M-a, M-b, M-x, ...) !
  • downcase-word (M-l) !
  • dump-functions () !
  • dump-macros () !
  • dump-variables ()
  • e

    !
  • editing-mode !
  • enable-keypad !
  • end-kbd-macro (C-x )) !
  • end-of-history (M-&#62;) !
  • end-of-line (C-e) !
  • exchange-point-and-mark (C-x C-x) !
  • expand-tilde
  • f

    !
  • filename_completion_function !
  • forward-backward-delete-char () !
  • forward-char (C-f) !
  • forward-search-history (C-s) !
  • forward-word (M-f) !
  • free_undo_list
  • h

    !
  • history-search-backward () !
  • history-search-forward () !
  • horizontal-scroll-mode
  • i

    !
  • input-meta !
  • insert-comment (M-#) !
  • insert-completions (M-*) !
  • isearch-terminators
  • k

    !
  • keymap !
  • kill-line (C-k) !
  • kill-region () !
  • kill-whole-line () !
  • kill-word (M-d) !
  • !

    l

    ! !
  • lowercase_p
  • m

    !
  • mark-modified-lines !
  • menu-complete () !
  • meta-flag
  • n

    !
  • next-history (C-n) !
  • non-incremental-forward-search-history (M-n) !
  • non-incremental-reverse-search-history (M-p) !
  • numeric
  • o

    !
  • output-meta
  • p

    !
  • possible-completions (M-?) !
  • prefix-meta (ESC) !
  • previous-history (C-p)
  • q

    !
  • quoted-insert (C-q, C-v)
  • r

    !
  • re-read-init-file (C-x C-r) !
  • readline !
  • redraw-current-line () !
  • reverse-search-history (C-r) !
  • revert-line (M-r) !
  • rl_add_defun !
  • rl_add_undo !
  • rl_already_prompted !
  • rl_attempted_completion_function !
  • rl_basic_quote_characters !
  • rl_basic_word_break_characters !
  • rl_begin_undo_group !
  • rl_bind_key !
  • rl_bind_key_in_map !
  • rl_binding_keymap !
  • rl_callback_handler_install !
  • rl_callback_handler_remove !
  • rl_callback_read_char !
  • rl_catch_signals !
  • rl_catch_sigwinch !
  • rl_char_is_quoted_p !
  • rl_cleanup_after_signal !
  • rl_clear_message !
  • rl_clear_signals !
  • rl_complete, rl_complete !
  • rl_complete_internal !
  • rl_completer_quote_characters !
  • rl_completer_word_break_characters !
  • rl_completion_append_character !
  • rl_completion_display_matches_hook !
  • rl_completion_entry_function, rl_completion_entry_function !
  • rl_completion_query_items !
  • rl_copy_keymap !
  • rl_copy_text !
  • rl_delete_text !
  • rl_directory_completion_hook !
  • rl_discard_keymap !
  • rl_display_match_list !
  • rl_do_undo !
  • rl_done !
  • rl_end !
  • rl_end_undo_group !
  • rl_erase_empty_line !
  • rl_event_hook !
  • rl_executing_keymap !
  • rl_extend_line_buffer !
  • rl_filename_completion_desired !
  • rl_filename_dequoting_function !
  • rl_filename_quote_characters !
  • rl_filename_quoting_desired !
  • rl_filename_quoting_function !
  • rl_forced_update_display !
  • rl_free_line_state !
  • rl_function_dumper !
  • rl_function_of_keyseq !
  • rl_funmap_names !
  • rl_generic_bind !
  • rl_get_keymap !
  • rl_get_keymap_by_name !
  • rl_get_keymap_name !
  • rl_getc !
  • rl_getc_function !
  • rl_ignore_completion_duplicates !
  • rl_ignore_some_completions_function !
  • rl_inhibit_completion !
  • rl_initialize !
  • rl_insert_completions !
  • rl_insert_text !
  • rl_instream !
  • rl_invoking_keyseqs !
  • rl_invoking_keyseqs_in_map !
  • rl_kill_text !
  • rl_library_version !
  • rl_line_buffer !
  • rl_list_funmap_names !
  • rl_make_bare_keymap !
  • rl_make_keymap !
  • rl_mark !
  • rl_message !
  • rl_modifying !
  • rl_named_function !
  • rl_on_new_line !
  • rl_on_new_line_with_prompt !
  • rl_outstream !
  • rl_parse_and_bind !
  • rl_pending_input !
  • rl_point !
  • rl_possible_completions !
  • rl_pre_input_hook !
  • rl_prompt !
  • rl_read_init_file !
  • rl_read_key !
  • rl_readline_name !
  • rl_redisplay !
  • rl_redisplay_function !
  • rl_reset_after_signal !
  • rl_reset_line_state !
  • rl_reset_terminal !
  • rl_resize_terminal !
  • rl_restore_prompt !
  • rl_save_prompt !
  • rl_set_keymap !
  • rl_set_signals !
  • rl_special_prefixes !
  • rl_startup_hook !
  • rl_stuff_char !
  • rl_terminal_name !
  • rl_unbind_command_in_map !
  • rl_unbind_function_in_map !
  • rl_unbind_key !
  • rl_unbind_key_in_map
  • s

    !
  • self-insert (a, b, A, 1, !, ...) !
  • set-mark (C-@) !
  • show-all-if-ambiguous !
  • start-kbd-macro (C-x ()
  • t

    !
  • tab-insert (M-TAB) !
  • tilde-expand (M-~) !
  • to_lower !
  • to_upper !
  • transpose-chars (C-t) !
  • transpose-words (M-t)
  • u

    !
  • undo (C-_, C-x C-u) !
  • universal-argument () !
  • unix-line-discard (C-u) !
  • unix-word-rubout (C-w) !
  • upcase-word (M-u) !
  • uppercase_p !
  • username_completion_function
  • v

    !
  • visible-stats
  • y

    !
  • yank (C-y) !
  • yank-last-arg (M-., M-_) !
  • yank-nth-arg (M-C-y) !
  • yank-pop (M-y)

  • ! This document was generated on 1 March 2000 using the texi2html translator version 1.52.

    --- 4595,4905 ---- y

    +

    _

    + +
  • _rl_digit_p +
  • _rl_digit_value +
  • _rl_lowercase_p +
  • _rl_to_lower +
  • _rl_to_upper +
  • _rl_uppercase_p +
  • a

    !
  • abort (C-g) !
  • accept-line (Newline or Return)
  • b

    !
  • backward-char (C-b) !
  • backward-delete-char (Rubout) !
  • backward-kill-line (C-x Rubout) !
  • backward-kill-word (M-DEL) !
  • backward-word (M-b) !
  • beginning-of-history (M-&#60;) !
  • beginning-of-line (C-a) !
  • bell-style
  • c

    !
  • call-last-kbd-macro (C-x e) !
  • capitalize-word (M-c) !
  • character-search (C-]) !
  • character-search-backward (M-C-]) !
  • clear-screen (C-l) !
  • comment-begin !
  • complete (TAB) !
  • completion-query-items !
  • convert-meta !
  • copy-backward-word () !
  • copy-forward-word () !
  • copy-region-as-kill ()
  • d

    !
  • delete-char (C-d) !
  • delete-char-or-list () !
  • delete-horizontal-space () !
  • digit-argument (M-0, M-1, ... M--) !
  • disable-completion !
  • do-uppercase-version (M-a, M-b, M-x, ...) !
  • downcase-word (M-l) !
  • dump-functions () !
  • dump-macros () !
  • dump-variables ()
  • e

    !
  • editing-mode !
  • enable-keypad !
  • end-kbd-macro (C-x )) !
  • end-of-history (M-&#62;) !
  • end-of-line (C-e) !
  • exchange-point-and-mark (C-x C-x) !
  • expand-tilde
  • f

    !
  • forward-backward-delete-char () !
  • forward-char (C-f) !
  • forward-search-history (C-s) !
  • forward-word (M-f)
  • h

    !
  • history-search-backward () !
  • history-search-forward () !
  • horizontal-scroll-mode
  • i

    !
  • input-meta !
  • insert-comment (M-#) !
  • insert-completions (M-*) !
  • isearch-terminators
  • k

    !
  • keymap !
  • kill-line (C-k) !
  • kill-region () !
  • kill-whole-line () !
  • kill-word (M-d)
  • m

    !
  • mark-modified-lines !
  • menu-complete () !
  • meta-flag
  • n

    !
  • next-history (C-n) !
  • non-incremental-forward-search-history (M-n) !
  • non-incremental-reverse-search-history (M-p)
  • o

    !
  • output-meta
  • p

    !
  • possible-completions (M-?) !
  • prefix-meta (ESC) !
  • previous-history (C-p)
  • q

    !
  • quoted-insert (C-q or C-v)
  • r

    !
  • re-read-init-file (C-x C-r) !
  • readline !
  • redraw-current-line () !
  • reverse-search-history (C-r) !
  • revert-line (M-r) !
  • rl_add_defun !
  • rl_add_funmap_entry !
  • rl_add_undo !
  • rl_alphabetic !
  • rl_already_prompted !
  • rl_attempted_completion_function !
  • rl_attempted_completion_over !
  • rl_basic_quote_characters !
  • rl_basic_word_break_characters !
  • rl_begin_undo_group !
  • rl_bind_key !
  • rl_bind_key_in_map !
  • rl_binding_keymap !
  • rl_callback_handler_install !
  • rl_callback_handler_remove !
  • rl_callback_read_char !
  • rl_catch_signals !
  • rl_catch_sigwinch !
  • rl_char_is_quoted_p !
  • rl_cleanup_after_signal !
  • rl_clear_message !
  • rl_clear_pending_input !
  • rl_clear_signals !
  • rl_complete, rl_complete !
  • rl_complete_internal !
  • rl_completer_quote_characters !
  • rl_completer_word_break_characters !
  • rl_completion_append_character !
  • rl_completion_display_matches_hook !
  • rl_completion_entry_function, rl_completion_entry_function !
  • rl_completion_matches !
  • rl_completion_query_items !
  • rl_completion_type !
  • rl_copy_keymap !
  • rl_copy_text !
  • rl_crlf !
  • rl_delete_text !
  • rl_deprep_term_function !
  • rl_deprep_terminal !
  • rl_ding !
  • rl_directory_completion_hook !
  • rl_discard_keymap !
  • rl_dispatching !
  • rl_display_match_list !
  • rl_do_undo !
  • rl_done !
  • rl_editing_mode !
  • rl_end !
  • rl_end_undo_group !
  • rl_erase_empty_line !
  • rl_event_hook !
  • rl_execute_next !
  • rl_executing_keymap !
  • rl_executing_macro !
  • rl_expand_prompt !
  • rl_explicit_arg !
  • rl_extend_line_buffer !
  • rl_filename_completion_desired !
  • rl_filename_completion_function !
  • rl_filename_dequoting_function !
  • rl_filename_quote_characters !
  • rl_filename_quoting_desired !
  • rl_filename_quoting_function !
  • rl_forced_update_display !
  • rl_free_line_state !
  • rl_free_undo_list !
  • rl_function_dumper !
  • rl_function_of_keyseq !
  • rl_funmap_names !
  • rl_generic_bind !
  • rl_get_keymap !
  • rl_get_keymap_by_name !
  • rl_get_keymap_name !
  • rl_get_screen_size !
  • rl_getc !
  • rl_getc_function !
  • rl_gnu_readline_p !
  • rl_ignore_completion_duplicates !
  • rl_ignore_some_completions_function !
  • rl_inhibit_completion !
  • rl_initialize !
  • rl_insert_completions !
  • rl_insert_text !
  • rl_instream !
  • rl_invoking_keyseqs !
  • rl_invoking_keyseqs_in_map !
  • rl_kill_text !
  • rl_last_func !
  • rl_library_version !
  • rl_line_buffer !
  • rl_list_funmap_names !
  • rl_macro_bind !
  • rl_macro_dumper !
  • rl_make_bare_keymap !
  • rl_make_keymap !
  • rl_mark !
  • rl_message !
  • rl_modifying !
  • rl_named_function !
  • rl_num_chars_to_read !
  • rl_numeric_arg !
  • rl_on_new_line !
  • rl_on_new_line_with_prompt !
  • rl_outstream !
  • rl_parse_and_bind !
  • rl_pending_input !
  • rl_point !
  • rl_possible_completions !
  • rl_pre_input_hook !
  • rl_prep_term_function !
  • rl_prep_terminal !
  • rl_prompt !
  • rl_push_macro_input !
  • rl_read_init_file !
  • rl_read_key !
  • rl_readline_name !
  • rl_readline_state !
  • rl_redisplay !
  • rl_redisplay_function !
  • rl_reset_after_signal !
  • rl_reset_line_state !
  • rl_reset_terminal !
  • rl_resize_terminal !
  • rl_restore_prompt !
  • rl_save_prompt !
  • rl_set_key !
  • rl_set_keyboard_input_timeout !
  • rl_set_keymap !
  • rl_set_paren_blink_timeout !
  • rl_set_prompt !
  • rl_set_screen_size !
  • rl_set_signals !
  • rl_show_char !
  • rl_special_prefixes !
  • rl_startup_hook !
  • rl_stuff_char !
  • rl_terminal_name !
  • rl_tty_set_default_bindings !
  • rl_unbind_command_in_map !
  • rl_unbind_function_in_map !
  • rl_unbind_key !
  • rl_unbind_key_in_map !
  • rl_username_completion_function !
  • rl_variable_bind !
  • rl_variable_dumper
  • s

    !
  • self-insert (a, b, A, 1, !, ...) !
  • set-mark (C-@) !
  • show-all-if-ambiguous !
  • start-kbd-macro (C-x ()
  • t

    !
  • tab-insert (M-TAB) !
  • tilde-expand (M-~) !
  • transpose-chars (C-t) !
  • transpose-words (M-t)
  • u

    !
  • undo (C-_ or C-x C-u) !
  • universal-argument () !
  • unix-line-discard (C-u) !
  • unix-word-rubout (C-w) !
  • upcase-word (M-u)
  • v

    !
  • visible-stats
  • y

    !
  • yank (C-y) !
  • yank-last-arg (M-. or M-_) !
  • yank-nth-arg (M-C-y) !
  • yank-pop (M-y)

  • ! This document was generated on 16 April 2001 using the texi2html translator version 1.52.

    diff -Nrc2 readline-4.1/doc/readline.info readline-4.2/doc/readline.info *** readline-4.1/doc/readline.info Wed Mar 1 14:52:58 2000 --- readline-4.2/doc/readline.info Mon Apr 16 11:05:39 2001 *************** *** 1,4 **** ! This is Info file readline.info, produced by Makeinfo version 1.68 from ! the input file /usr/homes/chet/src/bash/readline-src/doc/rlman.texinfo. INFO-DIR-SECTION Libraries --- 1,4 ---- ! This is readline.info, produced by makeinfo version 4.0 from ! /usr/homes/chet/src/bash/readline-src/doc/rlman.texinfo. INFO-DIR-SECTION Libraries *************** *** 11,15 **** need to provide a command line interface. ! Copyright (C) 1988-1999 Free Software Foundation, Inc. Permission is granted to make and distribute verbatim copies of this --- 11,15 ---- need to provide a command line interface. ! Copyright (C) 1988-2001 Free Software Foundation, Inc. Permission is granted to make and distribute verbatim copies of this *************** *** 73,80 **** keystrokes. ! The text is read as `Control-K' and describes the character produced when the key is pressed while the Control key is depressed. ! The text is read as `Meta-K' and describes the character produced when the Meta key (if you have one) is depressed, and the key is pressed. The Meta key is labeled on many keyboards. On --- 73,80 ---- keystrokes. ! The text `C-k' is read as `Control-K' and describes the character produced when the key is pressed while the Control key is depressed. ! The text `M-k' is read as `Meta-K' and describes the character produced when the Meta key (if you have one) is depressed, and the key is pressed. The Meta key is labeled on many keyboards. On *************** *** 87,102 **** If you do not have a Meta or key, or another key working as a Meta key, the identical keystroke can be generated by typing ! first, and then typing . Either process is known as "metafying" the ! key. ! The text is read as `Meta-Control-k' and describes the ! character produced by "metafying" . In addition, several keys have their own names. Specifically, , , , , , and all stand for themselves ! when seen in this text, or in an init file (*note Readline Init ! File::.). If your keyboard lacks a key, typing will ! produce the desired character. The key may be labeled ! or on some keyboards.  --- 87,102 ---- If you do not have a Meta or key, or another key working as a Meta key, the identical keystroke can be generated by typing ! _first_, and then typing . Either process is known as "metafying" ! the key. ! The text `M-C-k' is read as `Meta-Control-k' and describes the ! character produced by "metafying" `C-k'. In addition, several keys have their own names. Specifically, , , , , , and all stand for themselves ! when seen in this text, or in an init file (*note Readline Init File::). ! If your keyboard lacks a key, typing will produce the ! desired character. The key may be labeled or on ! some keyboards.  *************** *** 113,119 **** you move the cursor to the place that needs correction, and delete or insert the text of the corrections. Then, when you are satisfied with ! the line, you simply press . You do not have to be at the end ! of the line to press ; the entire line is accepted regardless ! of the location of the cursor within the line. * Menu: --- 113,119 ---- you move the cursor to the place that needs correction, and delete or insert the text of the corrections. Then, when you are satisfied with ! the line, you simply press . You do not have to be at the end of ! the line to press ; the entire line is accepted regardless of the ! location of the cursor within the line. * Menu: *************** *** 138,143 **** Sometimes you may mistype a character, and not notice the error until you have typed several other characters. In that case, you can ! type to move the cursor to the left, and then correct your ! mistake. Afterwards, you can move the cursor to the right with . When you add text in the middle of a line, you will notice that --- 138,143 ---- Sometimes you may mistype a character, and not notice the error until you have typed several other characters. In that case, you can ! type `C-b' to move the cursor to the left, and then correct your ! mistake. Afterwards, you can move the cursor to the right with `C-f'. When you add text in the middle of a line, you will notice that *************** *** 149,156 **** follows. ! Move back one character. ! Move forward one character. --- 149,156 ---- follows. ! `C-b' Move back one character. ! `C-f' Move forward one character. *************** *** 158,162 **** Delete the character to the left of the cursor. ! Delete the character underneath the cursor. --- 158,162 ---- Delete the character to the left of the cursor. ! `C-d' Delete the character underneath the cursor. *************** *** 164,168 **** Insert the character into the line at the cursor. ! or Undo the last editing command. You can undo all the way back to an empty line. --- 164,168 ---- Insert the character into the line at the cursor. ! `C-_' or `C-x C-u' Undo the last editing command. You can undo all the way back to an empty line. *************** *** 170,174 **** (Depending on your configuration, the key be set to delete the character to the left of the cursor and the key set to delete ! the character underneath the cursor, like , rather than the character to the left of the cursor.) --- 170,174 ---- (Depending on your configuration, the key be set to delete the character to the left of the cursor and the key set to delete ! the character underneath the cursor, like `C-d', rather than the character to the left of the cursor.) *************** *** 181,204 **** The above table describes the most basic keystrokes that you need in order to do editing of the input line. For your convenience, many ! other commands have been added in addition to , , , and . Here are some commands for moving more rapidly about the line. ! Move to the start of the line. ! Move to the end of the line. ! Move forward a word, where a word is composed of letters and digits. ! Move backward a word. ! Clear the screen, reprinting the current line at the top. ! Notice how moves forward a character, while moves forward a word. It is a loose convention that control keystrokes operate on characters while meta keystrokes operate on words. --- 181,204 ---- The above table describes the most basic keystrokes that you need in order to do editing of the input line. For your convenience, many ! other commands have been added in addition to `C-b', `C-f', `C-d', and . Here are some commands for moving more rapidly about the line. ! `C-a' Move to the start of the line. ! `C-e' Move to the end of the line. ! `M-f' Move forward a word, where a word is composed of letters and digits. ! `M-b' Move backward a word. ! `C-l' Clear the screen, reprinting the current line at the top. ! Notice how `C-f' moves forward a character, while `M-f' moves forward a word. It is a loose convention that control keystrokes operate on characters while meta keystrokes operate on words. *************** *** 227,258 **** Here is the list of commands for killing text. ! Kill the text from the current cursor position to the end of the line. ! Kill from the cursor to the end of the current word, or, if between words, to the end of the next word. Word boundaries are the same ! as those used by . ! Kill from the cursor the start of the previous word, or, if between words, to the start of the previous word. Word boundaries are the ! same as those used by . ! Kill from the cursor to the previous whitespace. This is ! different than because the word boundaries differ. Here is how to "yank" the text back into the line. Yanking means to copy the most-recently-killed text from the kill buffer. ! Yank the most recently killed text back into the buffer at the cursor. ! Rotate the kill-ring, and yank the new top. You can only do this ! if the prior command is or .  --- 227,258 ---- Here is the list of commands for killing text. ! `C-k' Kill the text from the current cursor position to the end of the line. ! `M-d' Kill from the cursor to the end of the current word, or, if between words, to the end of the next word. Word boundaries are the same ! as those used by `M-f'. ! `M-' Kill from the cursor the start of the previous word, or, if between words, to the start of the previous word. Word boundaries are the ! same as those used by `M-b'. ! `C-w' Kill from the cursor to the previous whitespace. This is ! different than `M-' because the word boundaries differ. Here is how to "yank" the text back into the line. Yanking means to copy the most-recently-killed text from the kill buffer. ! `C-y' Yank the most recently killed text back into the buffer at the cursor. ! `M-y' Rotate the kill-ring, and yank the new top. You can only do this ! if the prior command is `C-y' or `M-y'.  *************** *** 274,278 **** have typed one meta digit to get the argument started, you can type the remainder of the digits, and then the command. For example, to give ! the command an argument of 10, you could type `M-1 0 C-d'.  --- 274,279 ---- have typed one meta digit to get the argument started, you can type the remainder of the digits, and then the command. For example, to give ! the `C-d' command an argument of 10, you could type `M-1 0 C-d', which ! will delete the next ten characters on the input line.  *************** *** 284,288 **** Readline provides commands for searching through the command history for lines containing a specified string. There are two search modes: ! INCREMENTAL and NON-INCREMENTAL. Incremental searches begin before the user has finished typing the --- 285,289 ---- Readline provides commands for searching through the command history for lines containing a specified string. There are two search modes: ! "incremental" and "non-incremental". Incremental searches begin before the user has finished typing the *************** *** 291,310 **** typed so far. An incremental search requires only as many characters as needed to find the desired history entry. To search backward in the ! history for a particular string, type . Typing searches forward through the history. The characters present in the value of the `isearch-terminators' variable are used to terminate an incremental search. If that variable has not been assigned a value, the and ! characters will terminate an incremental search. will abort an incremental search and restore the original line. When the search is terminated, the history entry containing the search string becomes the current line. ! To find other matching entries in the history list, type or ! as appropriate. This will search backward or forward in the history for the next entry matching the search string typed so far. Any other key sequence bound to a Readline command will terminate the search and execute that command. For instance, a will terminate the search and accept the line, thereby executing the command from the ! history list. Non-incremental searches read the entire search string before --- 292,312 ---- typed so far. An incremental search requires only as many characters as needed to find the desired history entry. To search backward in the ! history for a particular string, type `C-r'. Typing `C-s' searches forward through the history. The characters present in the value of the `isearch-terminators' variable are used to terminate an incremental search. If that variable has not been assigned a value, the and ! `C-J' characters will terminate an incremental search. `C-g' will abort an incremental search and restore the original line. When the search is terminated, the history entry containing the search string becomes the current line. ! To find other matching entries in the history list, type `C-r' or ! `C-s' as appropriate. This will search backward or forward in the history for the next entry matching the search string typed so far. Any other key sequence bound to a Readline command will terminate the search and execute that command. For instance, a will terminate the search and accept the line, thereby executing the command from the ! history list. A movement command will terminate the search, make the ! last line found the current line, and begin editing. Non-incremental searches read the entire search string before *************** *** 349,353 **** file. Blank lines are ignored. Lines beginning with a `#' are comments. Lines beginning with a `$' indicate conditional constructs ! (*note Conditional Init Constructs::.). Other lines denote variable settings and key bindings. --- 351,355 ---- file. Blank lines are ignored. Lines beginning with a `#' are comments. Lines beginning with a `$' indicate conditional constructs ! (*note Conditional Init Constructs::). Other lines denote variable settings and key bindings. *************** *** 355,363 **** You can modify the run-time behavior of Readline by altering the values of variables in Readline using the `set' command within the ! init file. Here is how to change from the default Emacs-like key ! binding to use `vi' line editing commands: set editing-mode vi A great deal of run-time behavior is changeable with the following variables. --- 357,372 ---- You can modify the run-time behavior of Readline by altering the values of variables in Readline using the `set' command within the ! init file. The syntax is simple: ! ! set VARIABLE VALUE ! ! Here, for example, is how to change from the default Emacs-like ! key binding to use `vi' line editing commands: set editing-mode vi + Variable names and values, where appropriate, are recognized + without regard to case. + A great deal of run-time behavior is changeable with the following variables. *************** *** 386,390 **** greater than this value, Readline will ask the user whether or not he wishes to view them; otherwise, they are simply ! listed. The default limit is `100'. `convert-meta' --- 395,400 ---- greater than this value, Readline will ask the user whether or not he wishes to view them; otherwise, they are simply ! listed. This variable must be set to an integer value ! greater than or equal to 0. The default limit is `100'. `convert-meta' *************** *** 423,427 **** `input-meta' If set to `on', Readline will enable eight-bit input (it will ! not strip the eighth bit from the characters it reads), regardless of what the terminal claims it can support. The default value is `off'. The name `meta-flag' is a synonym --- 433,437 ---- `input-meta' If set to `on', Readline will enable eight-bit input (it will ! not clear the eighth bit in the characters it reads), regardless of what the terminal claims it can support. The default value is `off'. The name `meta-flag' is a synonym *************** *** 431,436 **** The string of characters that should terminate an incremental search without subsequently executing the character as a ! command (*note Searching::.). If this variable has not been ! given a value, the characters and will terminate an incremental search. --- 441,446 ---- The string of characters that should terminate an incremental search without subsequently executing the character as a ! command (*note Searching::). If this variable has not been ! given a value, the characters and `C-J' will terminate an incremental search. *************** *** 438,442 **** Sets Readline's idea of the current keymap for key binding commands. Acceptable `keymap' names are `emacs', ! `emacs-standard', `emacs-meta', `emacs-ctlx', `vi', `vi-command', and `vi-insert'. `vi' is equivalent to `vi-command'; `emacs' is equivalent to `emacs-standard'. The --- 448,452 ---- Sets Readline's idea of the current keymap for key binding commands. Acceptable `keymap' names are `emacs', ! `emacs-standard', `emacs-meta', `emacs-ctlx', `vi', `vi-move', `vi-command', and `vi-insert'. `vi' is equivalent to `vi-command'; `emacs' is equivalent to `emacs-standard'. The *************** *** 481,489 **** description of what the command does. ! Once you know the name of the command, simply place the name of ! the key you wish to bind the command to, a colon, and then the ! name of the command on a line in the init file. The name of the ! key can be expressed in different ways, depending on which is most ! comfortable for you. KEYNAME: FUNCTION-NAME or MACRO --- 491,502 ---- description of what the command does. ! Once you know the name of the command, simply place on a line in ! the init file the name of the key you wish to bind the command to, ! a colon, and then the name of the command. The name of the key ! can be expressed in different ways, depending on what you find most ! comfortable. ! ! In addition to command names, readline allows keys to be bound to ! a string that is inserted when the key is pressed (a MACRO). KEYNAME: FUNCTION-NAME or MACRO *************** *** 494,502 **** Control-o: "> output" ! In the above example, is bound to the function ! `universal-argument', and is bound to run the macro expressed on the right hand side (that is, to insert the text `> output' into the line). "KEYSEQ": FUNCTION-NAME or MACRO KEYSEQ differs from KEYNAME above in that strings denoting an --- 507,520 ---- Control-o: "> output" ! In the above example, `C-u' is bound to the function ! `universal-argument', `M-DEL' is bound to the function ! `backward-kill-word', and `C-o' is bound to run the macro expressed on the right hand side (that is, to insert the text `> output' into the line). + A number of symbolic character names are recognized while + processing this key binding syntax: DEL, ESC, ESCAPE, LFD, + NEWLINE, RET, RETURN, RUBOUT, SPACE, SPC, and TAB. + "KEYSEQ": FUNCTION-NAME or MACRO KEYSEQ differs from KEYNAME above in that strings denoting an *************** *** 510,518 **** "\e[11~": "Function Key 1" ! In the above example, is bound to the function `universal-argument' (just as it was in the first example), ! ` ' is bound to the function `re-read-init-file', ! and ` <[> <1> <1> <~>' is bound to insert the text ! `Function Key 1'. The following GNU Emacs style escape sequences are available when --- 528,536 ---- "\e[11~": "Function Key 1" ! In the above example, `C-u' is again bound to the function `universal-argument' (just as it was in the first example), ! `C-x C-r' is bound to the function `re-read-init-file', and ! ` <[> <1> <1> <~>' is bound to insert the text `Function ! Key 1'. The following GNU Emacs style escape sequences are available when *************** *** 565,573 **** `\NNN' ! the character whose `ASCII' code is the octal value NNN (one ! to three digits) `\xNNN' ! the character whose `ASCII' code is the hexadecimal value NNN (one to three digits) --- 583,591 ---- `\NNN' ! the character whose ASCII code is the octal value NNN (one to ! three digits) `\xNNN' ! the character whose ASCII code is the hexadecimal value NNN (one to three digits) *************** *** 618,625 **** application-specific settings. Each program using the Readline library sets the APPLICATION NAME, and you can test ! for it. This could be used to bind key sequences to ! functions useful for a specific program. For instance, the ! following command adds a key sequence that quotes the current ! or previous word in Bash: $if Bash # Quote the current or previous word --- 636,643 ---- application-specific settings. Each program using the Readline library sets the APPLICATION NAME, and you can test ! for a particular value. This could be used to bind key ! sequences to functions useful for a specific program. For ! instance, the following command adds a key sequence that ! quotes the current or previous word in Bash: $if Bash # Quote the current or previous word *************** *** 637,641 **** `$include' This directive takes a single filename as an argument and reads ! commands and bindings from that file. $include /etc/inputrc --- 655,660 ---- `$include' This directive takes a single filename as an argument and reads ! commands and bindings from that file. For example, the following ! directive reads from `/etc/inputrc': $include /etc/inputrc *************** *** 646,650 **** ---------------- ! Here is an example of an inputrc file. This illustrates key binding, variable assignment, and conditional syntax. --- 665,669 ---- ---------------- ! Here is an example of an INPUTRC file. This illustrates key binding, variable assignment, and conditional syntax. *************** *** 766,776 **** This section describes Readline commands that may be bound to key ! sequences. ! Command names without an accompanying key sequence are unbound by ! default. In the following descriptions, POINT refers to the current ! cursor position, and MARK refers to a cursor position saved by the `set-mark' command. The text between the point and mark is referred to ! as the REGION.  --- 785,795 ---- This section describes Readline commands that may be bound to key ! sequences. Command names without an accompanying key sequence are ! unbound by default. ! In the following descriptions, "point" refers to the current cursor ! position, and "mark" refers to a cursor position saved by the `set-mark' command. The text between the point and mark is referred to ! as the "region".  *************** *** 813,826 **** ------------------------------------- ! `accept-line (Newline, Return)' Accept the line regardless of where the cursor is. If this line is ! non-empty, add it to the history list. If this line was a history ! line, then restore the history line to its original state. `previous-history (C-p)' ! Move `up' through the history list. `next-history (C-n)' ! Move `down' through the history list. `beginning-of-history (M-<)' --- 832,847 ---- ------------------------------------- ! `accept-line (Newline or Return)' Accept the line regardless of where the cursor is. If this line is ! non-empty, it may be added to the history list for future recall ! with `add_history()'. If this line is a modified history line, ! the history line is restored to its original state. `previous-history (C-p)' ! Move `back' through the history list, fetching the previous ! command. `next-history (C-n)' ! Move `forward' through the history list, fetching the next command. `beginning-of-history (M-<)' *************** *** 862,871 **** `yank-nth-arg (M-C-y)' Insert the first argument to the previous command (usually the ! second word on the previous line). With an argument N, insert the ! Nth word from the previous command (the words in the previous ! command begin with word 0). A negative argument inserts the Nth ! word from the end of the previous command. ! `yank-last-arg (M-., M-_)' Insert last argument to the previous command (the last word of the previous history entry). With an argument, behave exactly like --- 883,892 ---- `yank-nth-arg (M-C-y)' Insert the first argument to the previous command (usually the ! second word on the previous line) at point. With an argument N, ! insert the Nth word from the previous command (the words in the ! previous command begin with word 0). A negative argument inserts ! the Nth word from the end of the previous command. ! `yank-last-arg (M-. or M-_)' Insert last argument to the previous command (the last word of the previous history entry). With an argument, behave exactly like *************** *** 881,888 **** `delete-char (C-d)' ! Delete the character under the cursor. If the cursor is at the ! beginning of the line, there are no characters in the line, and ! the last character typed was not bound to `delete-char', then ! return `EOF'. `backward-delete-char (Rubout)' --- 902,908 ---- `delete-char (C-d)' ! Delete the character at point. If point is at the beginning of ! the line, there are no characters in the line, and the last ! character typed was not bound to `delete-char', then return EOF. `backward-delete-char (Rubout)' *************** *** 895,903 **** deleted. By default, this is not bound to a key. ! `quoted-insert (C-q, C-v)' Add the next character typed to the line verbatim. This is how to ! insert key sequences like , for example. ! `tab-insert (M-TAB)' Insert a tab character. --- 915,923 ---- deleted. By default, this is not bound to a key. ! `quoted-insert (C-q or C-v)' Add the next character typed to the line verbatim. This is how to ! insert key sequences like `C-q', for example. ! `tab-insert (M-)' Insert a tab character. *************** *** 943,948 **** `kill-whole-line ()' ! Kill all characters on the current line, no matter point is. By ! default, this is unbound. `kill-word (M-d)' --- 963,968 ---- `kill-whole-line ()' ! Kill all characters on the current line, no matter where point is. ! By default, this is unbound. `kill-word (M-d)' *************** *** 951,955 **** as `forward-word'. ! `backward-kill-word (M-DEL)' Kill the word behind point. Word boundaries are the same as `backward-word'. --- 971,975 ---- as `forward-word'. ! `backward-kill-word (M-)' Kill the word behind point. Word boundaries are the same as `backward-word'. *************** *** 982,991 **** `yank (C-y)' ! Yank the top of the kill ring into the buffer at the current ! cursor position. `yank-pop (M-y)' Rotate the kill-ring, and yank the new top. You can only do this ! if the prior command is yank or yank-pop.  --- 1002,1010 ---- `yank (C-y)' ! Yank the top of the kill ring into the buffer at point. `yank-pop (M-y)' Rotate the kill-ring, and yank the new top. You can only do this ! if the prior command is `yank' or `yank-pop'.  *************** *** 997,1001 **** `digit-argument (M-0, M-1, ... M--)' Add this digit to the argument already accumulating, or start a new ! argument. starts a negative argument. `universal-argument ()' --- 1016,1020 ---- `digit-argument (M-0, M-1, ... M--)' Add this digit to the argument already accumulating, or start a new ! argument. `M--' starts a negative argument. `universal-argument ()' *************** *** 1018,1032 **** ----------------------------- ! `complete (TAB)' ! Attempt to do completion on the text before the cursor. This is ! application-specific. Generally, if you are typing a filename ! argument, you can do filename completion; if you are typing a ! command, you can do command completion; if you are typing in a ! symbol to GDB, you can do symbol name completion; if you are ! typing in a variable to Bash, you can do variable name completion, ! and so on. `possible-completions (M-?)' ! List the possible completions of the text before the cursor. `insert-completions (M-*)' --- 1037,1047 ---- ----------------------------- ! `complete ()' ! Attempt to perform completion on the text before point. The ! actual completion performed is application-specific. The default ! is filename completion. `possible-completions (M-?)' ! List the possible completions of the text before point. `insert-completions (M-*)' *************** *** 1039,1046 **** execution of `menu-complete' steps through the list of possible completions, inserting each match in turn. At the end of the list ! of completions, the bell is rung and the original text is restored. ! An argument of N moves N positions forward in the list of matches; ! a negative argument may be used to move backward through the list. ! This command is intended to be bound to `TAB', but is unbound by default. --- 1054,1062 ---- execution of `menu-complete' steps through the list of possible completions, inserting each match in turn. At the end of the list ! of completions, the bell is rung (subject to the setting of ! `bell-style') and the original text is restored. An argument of N ! moves N positions forward in the list of matches; a negative ! argument may be used to move backward through the list. This ! command is intended to be bound to , but is unbound by default. *************** *** 1086,1094 **** bound to the corresponding uppercase character. ! `prefix-meta (ESC)' ! Make the next character typed be metafied. This is for keyboards ! without a meta key. Typing `ESC f' is equivalent to typing `M-f'. ! `undo (C-_, C-x C-u)' Incremental undo, separately remembered for each line. --- 1102,1110 ---- bound to the corresponding uppercase character. ! `prefix-meta ()' ! Metafy the next character typed. This is for keyboards without a ! meta key. Typing ` f' is equivalent to typing `M-f'. ! `undo (C-_ or C-x C-u)' Incremental undo, separately remembered for each line. *************** *** 1101,1106 **** `set-mark (C-@)' ! Set the mark to the current point. If a numeric argument is ! supplied, the mark is set to that position. `exchange-point-and-mark (C-x C-x)' --- 1117,1122 ---- `set-mark (C-@)' ! Set the mark to the point. If a numeric argument is supplied, the ! mark is set to that position. `exchange-point-and-mark (C-x C-x)' *************** *** 1138,1144 **** `dump-macros ()' Print all of the Readline key sequences bound to macros and the ! strings they ouput. If a numeric argument is supplied, the output ! is formatted in such a way that it can be made part of an INPUTRC ! file. This command is unbound by default.  --- 1154,1160 ---- `dump-macros ()' Print all of the Readline key sequences bound to macros and the ! strings they output. If a numeric argument is supplied, the ! output is formatted in such a way that it can be made part of an ! INPUTRC file. This command is unbound by default.  *************** *** 1154,1158 **** In order to switch interactively between `emacs' and `vi' editing ! modes, use the command M-C-j (toggle-editing-mode). The Readline default is `emacs' mode. --- 1170,1175 ---- In order to switch interactively between `emacs' and `vi' editing ! modes, use the command `M-C-j' (bound to emacs-editing-mode when in ! `vi' mode and to vi-editing-mode in `emacs' mode). The Readline default is `emacs' mode. *************** *** 1167,1172 **** that need to provide a command line interface. ! Copyright (C) 1988, 1994, 1996, 1998, 1999 Free Software Foundation, ! Inc. Permission is granted to make and distribute verbatim copies of this --- 1184,1188 ---- that need to provide a command line interface. ! Copyright (C) 1988-2001 Free Software Foundation, Inc. Permission is granted to make and distribute verbatim copies of this *************** *** 1219,1230 **** is sufficient. This section describes how to use Readline in the simplest way possible, perhaps to replace calls in your code to ! `gets()' or `fgets ()'. ! The function `readline ()' prints a prompt and then reads and returns ! a single line of text from the user. The line `readline' returns is ! allocated with `malloc ()'; you should `free ()' the line when you are ! done with it. The declaration for `readline' in ANSI C is ! `char *readline (char *PROMPT);' So, one might say --- 1235,1247 ---- is sufficient. This section describes how to use Readline in the simplest way possible, perhaps to replace calls in your code to ! `gets()' or `fgets()'. ! The function `readline()' prints a prompt PROMPT and then reads and ! returns a single line of text from the user. If PROMPT is `NULL' or ! the empty string, no prompt is displayed. The line `readline' returns ! is allocated with `malloc()'; the caller should `free()' the line when ! it has finished with it. The declaration for `readline' in ANSI C is ! `char *readline (const char *PROMPT);' So, one might say *************** *** 1239,1244 **** If you want the user to be able to get at the line later, (with ! for example), you must call `add_history ()' to save the line ! away in a "history" list of such lines. `add_history (line)'; --- 1256,1261 ---- If you want the user to be able to get at the line later, (with ! for example), you must call `add_history()' to save the line away ! in a "history" list of such lines. `add_history (line)'; *************** *** 1248,1252 **** It is preferable to avoid saving empty lines on the history list, since users rarely have a burning need to reuse a blank line. Here is ! a function which usefully replaces the standard `gets ()' library function, and has the advantage of no static buffer to overflow: --- 1265,1269 ---- It is preferable to avoid saving empty lines on the history list, since users rarely have a burning need to reuse a blank line. Here is ! a function which usefully replaces the standard `gets()' library function, and has the advantage of no static buffer to overflow: *************** *** 1279,1290 **** completion: completion on file names. If you do not want Readline to complete on filenames, you can change the binding of the key with ! `rl_bind_key ()'. ! `int rl_bind_key (int KEY, int (*FUNCTION)());' ! `rl_bind_key ()' takes two arguments: KEY is the character that you want to bind, and FUNCTION is the address of the function to call when ! KEY is pressed. Binding to `rl_insert ()' makes insert ! itself. `rl_bind_key ()' returns non-zero if KEY is not a valid ASCII character code (between 0 and 255). --- 1296,1307 ---- completion: completion on file names. If you do not want Readline to complete on filenames, you can change the binding of the key with ! `rl_bind_key()'. ! `int rl_bind_key (int KEY, rl_command_func_t *FUNCTION);' ! `rl_bind_key()' takes two arguments: KEY is the character that you want to bind, and FUNCTION is the address of the function to call when ! KEY is pressed. Binding to `rl_insert()' makes insert ! itself. `rl_bind_key()' returns non-zero if KEY is not a valid ASCII character code (between 0 and 255). *************** *** 1293,1299 **** This code should be executed once at the start of your program; you ! might write a function called `initialize_readline ()' which performs this and other desired initializations, such as installing custom ! completers (*note Custom Completers::.).  --- 1310,1316 ---- This code should be executed once at the start of your program; you ! might write a function called `initialize_readline()' which performs this and other desired initializations, such as installing custom ! completers (*note Custom Completers::).  *************** *** 1318,1358 **** * Menu: ! * The Function Type:: C declarations to make code readable. * Function Writing:: Variables and calling conventions.  ! File: readline.info, Node: The Function Type, Next: Function Writing, Up: Custom Functions ! The Function Type ----------------- ! For readabilty, we declare a new type of object, called "Function". ! A `Function' is a C function which returns an `int'. The type ! declaration for `Function' is: ! ! `typedef int Function ();' ! ! The reason for declaring this new type is to make it easier to write ! code describing pointers to C functions. Let us say we had a variable ! called FUNC which was a pointer to a function. Instead of the classic ! C declaration ! `int (*)()func;' we may write ! `Function *func;' ! Similarly, there are ! typedef void VFunction (); ! typedef char *CPFunction (); and ! typedef char **CPPFunction (); ! for functions returning no value, `pointer to char', and `pointer to ! pointer to char', respectively.  ! File: readline.info, Node: Function Writing, Prev: The Function Type, Up: Custom Functions Writing a New Function --- 1335,1408 ---- * Menu: ! * Readline Typedefs:: C declarations to make code readable. * Function Writing:: Variables and calling conventions.  ! File: readline.info, Node: Readline Typedefs, Next: Function Writing, Up: Custom Functions ! Readline Typedefs ----------------- ! For readabilty, we declare a number of new object types, all pointers ! to functions. ! ! The reason for declaring these new types is to make it easier to ! write code describing pointers to C functions with appropriately ! prototyped arguments and return values. ! ! For instance, say we want to declare a variable FUNC as a pointer to ! a function which takes two `int' arguments and returns an `int' (this ! is the type of all of the Readline bindable functions). Instead of the ! classic C declaration ! `int (*func)();' ! ! or the ANSI-C style declaration ! ! `int (*func)(int, int);' we may write ! `rl_command_func_t *func;' ! ! The full list of function pointer types available is ! ! `typedef int rl_command_func_t (int, int);' ! ! `typedef char *rl_compentry_func_t (const char *, int);' ! ! `typedef char **rl_completion_func_t (const char *, int, int);' ! ! `typedef char *rl_quote_func_t (char *, int, char *);' ! ! `typedef char *rl_dequote_func_t (char *, int);' ! ! `typedef int rl_compignore_func_t (char **);' ! ! `typedef void rl_compdisp_func_t (char **, int, int);' ! ! `typedef int rl_hook_func_t (void);' ! ! `typedef int rl_getc_func_t (FILE *);' ! ! `typedef int rl_linebuf_func_t (char *, int);' ! ! `typedef int rl_intfunc_t (int);' ! ! `#define rl_ivoidfunc_t rl_hook_func_t' ! ! `typedef int rl_icpfunc_t (char *);' ! `typedef int rl_icppfunc_t (char **);' ! `typedef void rl_voidfunc_t (void);' ! `typedef void rl_vintfunc_t (int);' + `typedef void rl_vcpfunc_t (char *);' + + `typedef void rl_vcppfunc_t (char **);'  ! File: readline.info, Node: Function Writing, Prev: Readline Typedefs, Up: Custom Functions Writing a New Function *************** *** 1395,1399 **** - Variable: int rl_point The offset of the current cursor position in `rl_line_buffer' (the ! *point*). - Variable: int rl_end --- 1445,1449 ---- - Variable: int rl_point The offset of the current cursor position in `rl_line_buffer' (the ! _point_). - Variable: int rl_end *************** *** 1403,1408 **** - Variable: int rl_mark ! The mark (saved position) in the current line. If set, the mark ! and point define a *region*. - Variable: int rl_done --- 1453,1458 ---- - Variable: int rl_mark ! The MARK (saved position) in the current line. If set, the mark ! and point define a _region_. - Variable: int rl_done *************** *** 1410,1417 **** --- 1460,1478 ---- current line immediately. + - Variable: int rl_num_chars_to_read + Setting this to a positive value before calling `readline()' causes + Readline to return after accepting that many characters, rather + than reading up to a character bound to `accept-line'. + - Variable: int rl_pending_input Setting this to a value makes it the next keystroke read. This is a way to stuff a single character into the input stream. + - Variable: int rl_dispatching + Set to a non-zero value if a function is being called from a key + binding; zero otherwise. Application functions can test this to + discover whether they were called directly or by Readline's + dispatching mechanism. + - Variable: int rl_erase_empty_line Setting this to a non-zero value causes Readline to completely *************** *** 1422,1426 **** - Variable: char * rl_prompt The prompt Readline uses. This is set from the argument to ! `readline ()', and should not be assigned to directly. - Variable: int rl_already_prompted --- 1483,1489 ---- - Variable: char * rl_prompt The prompt Readline uses. This is set from the argument to ! `readline()', and should not be assigned to directly. The ! `rl_set_prompt()' function (*note Redisplay::) may be used to ! modify the prompt string after calling `readline()'. - Variable: int rl_already_prompted *************** *** 1433,1446 **** value; Readline never sets it. ! - Variable: char * rl_library_version The version number of this revision of the library. ! - Variable: char * rl_terminal_name ! The terminal type, used for initialization. ! - Variable: char * rl_readline_name This variable is set to a unique name by each application using Readline. The value allows conditional parsing of the inputrc file ! (*note Conditional Init Constructs::.). - Variable: FILE * rl_instream --- 1496,1515 ---- value; Readline never sets it. ! - Variable: const char * rl_library_version The version number of this revision of the library. ! - Variable: int rl_gnu_readline_p ! Always set to 1, denoting that this is GNU readline rather than ! some emulation. ! ! - Variable: const char * rl_terminal_name ! The terminal type, used for initialization. If not set by the ! application, Readline sets this to the value of the `TERM' ! environment variable the first time it is called. ! - Variable: const char * rl_readline_name This variable is set to a unique name by each application using Readline. The value allows conditional parsing of the inputrc file ! (*note Conditional Init Constructs::). - Variable: FILE * rl_instream *************** *** 1450,1486 **** The stdio stream to which Readline performs output. ! - Variable: Function * rl_startup_hook If non-zero, this is the address of a function to call just before `readline' prints the first prompt. ! - Variable: Function * rl_pre_input_hook If non-zero, this is the address of a function to call after the first prompt has been printed and just before `readline' starts reading input characters. ! - Variable: Function * rl_event_hook If non-zero, this is the address of a function to call periodically ! when readline is waiting for terminal input. ! ! - Variable: Function * rl_getc_function ! If non-zero, `readline' will call indirectly through this pointer ! to get a character from the input stream. By default, it is set to ! `rl_getc', the default `readline' character input function (*note ! Utility Functions::.). ! ! - Variable: VFunction * rl_redisplay_function ! If non-zero, `readline' will call indirectly through this pointer ! to update the display with the current contents of the editing ! buffer. By default, it is set to `rl_redisplay', the default ! `readline' redisplay function (*note Redisplay::.). - Variable: Keymap rl_executing_keymap ! This variable is set to the keymap (*note Keymaps::.) in which the currently executing readline function was found. - Variable: Keymap rl_binding_keymap ! This variable is set to the keymap (*note Keymaps::.) in which the last key binding occurred.  File: readline.info, Node: Readline Convenience Functions, Next: Readline Signal Handling, Prev: Readline Variables, Up: Programming with GNU Readline --- 1519,1664 ---- The stdio stream to which Readline performs output. ! - Variable: rl_command_func_t * rl_last_func ! The address of the last command function Readline executed. May ! be used to test whether or not a function is being executed twice ! in succession, for example. ! ! - Variable: rl_hook_func_t * rl_startup_hook If non-zero, this is the address of a function to call just before `readline' prints the first prompt. ! - Variable: rl_hook_func_t * rl_pre_input_hook If non-zero, this is the address of a function to call after the first prompt has been printed and just before `readline' starts reading input characters. ! - Variable: rl_hook_func_t * rl_event_hook If non-zero, this is the address of a function to call periodically ! when Readline is waiting for terminal input. By default, this ! will be called at most ten times a second if there is no keyboard ! input. ! ! - Variable: rl_getc_func_t * rl_getc_function ! If non-zero, Readline will call indirectly through this pointer to ! get a character from the input stream. By default, it is set to ! `rl_getc', the default Readline character input function (*note ! Character Input::). ! ! - Variable: rl_voidfunc_t * rl_redisplay_function ! If non-zero, Readline will call indirectly through this pointer to ! update the display with the current contents of the editing buffer. ! By default, it is set to `rl_redisplay', the default Readline ! redisplay function (*note Redisplay::). ! ! - Variable: rl_vintfunc_t * rl_prep_term_function ! If non-zero, Readline will call indirectly through this pointer to ! initialize the terminal. The function takes a single argument, an ! `int' flag that says whether or not to use eight-bit characters. ! By default, this is set to `rl_prep_terminal' (*note Terminal ! Management::). ! ! - Variable: rl_voidfunc_t * rl_deprep_term_function ! If non-zero, Readline will call indirectly through this pointer to ! reset the terminal. This function should undo the effects of ! `rl_prep_term_function'. By default, this is set to ! `rl_deprep_terminal' (*note Terminal Management::). - Variable: Keymap rl_executing_keymap ! This variable is set to the keymap (*note Keymaps::) in which the currently executing readline function was found. - Variable: Keymap rl_binding_keymap ! This variable is set to the keymap (*note Keymaps::) in which the last key binding occurred. + - Variable: char * rl_executing_macro + This variable is set to the text of any currently-executing macro. + + - Variable: int rl_readline_state + A variable with bit values that encapsulate the current Readline + state. A bit is set with the `RL_SETSTATE' macro, and unset with + the `RL_UNSETSTATE' macro. Use the `RL_ISSTATE' macro to test + whether a particular state bit is set. Current state bits include: + + `RL_STATE_NONE' + Readline has not yet been called, nor has it begun to + intialize. + + `RL_STATE_INITIALIZING' + Readline is initializing its internal data structures. + + `RL_STATE_INITIALIZED' + Readline has completed its initialization. + + `RL_STATE_TERMPREPPED' + Readline has modified the terminal modes to do its own input + and redisplay. + + `RL_STATE_READCMD' + Readline is reading a command from the keyboard. + + `RL_STATE_METANEXT' + Readline is reading more input after reading the meta-prefix + character. + + `RL_STATE_DISPATCHING' + Readline is dispatching to a command. + + `RL_STATE_MOREINPUT' + Readline is reading more input while executing an editing + command. + + `RL_STATE_ISEARCH' + Readline is performing an incremental history search. + + `RL_STATE_NSEARCH' + Readline is performing a non-incremental history search. + + `RL_STATE_SEARCH' + Readline is searching backward or forward through the history + for a string. + + `RL_STATE_NUMERICARG' + Readline is reading a numeric argument. + + `RL_STATE_MACROINPUT' + Readline is currently getting its input from a + previously-defined keyboard macro. + + `RL_STATE_MACRODEF' + Readline is currently reading characters defining a keyboard + macro. + + `RL_STATE_OVERWRITE' + Readline is in overwrite mode. + + `RL_STATE_COMPLETING' + Readline is performing word completion. + + `RL_STATE_SIGHANDLER' + Readline is currently executing the readline signal handler. + + `RL_STATE_UNDOING' + Readline is performing an undo. + + `RL_STATE_DONE' + Readline has read a key sequence bound to `accept-line' and + is about to return the line to the caller. + + + - Variable: int rl_explicit_arg + Set to a non-zero value if an explicit numeric argument was + specified by the user. Only valid in a bindable command function. + + - Variable: int rl_numeric_arg + Set to the value of any numeric argument explicitly specified by + the user before executing the current Readline function. Only + valid in a bindable command function. + + - Variable: int rl_editing_mode + Set to a value denoting Readline's current editing mode. A value + of 1 means Readline is currently in emacs mode; 0 means that vi + mode is active. +  File: readline.info, Node: Readline Convenience Functions, Next: Readline Signal Handling, Prev: Readline Variables, Up: Programming with GNU Readline *************** *** 1499,1504 **** --- 1677,1686 ---- * Redisplay:: Functions to control line display. * Modifying Text:: Functions to modify `rl_line_buffer'. + * Character Input:: Functions to read keyboard input. + * Terminal Management:: Functions to manage terminal settings. * Utility Functions:: Generally useful functions and hooks. + * Miscellaneous Functions:: Functions that don't fall into any category. * Alternate Interface:: Using Readline in a `callback' fashion. + * A Readline Example:: An example Readline function.  *************** *** 1516,1527 **** This binds the keystroke to the function ! *descriptively* named `backward-kill-word'. You, as the programmer, should bind the functions you write to descriptive names as well. Readline provides a function for doing that: ! - Function: int rl_add_defun (char *name, Function *function, int key) Add NAME to the list of named functions. Make FUNCTION be the function that gets called. If KEY is not -1, then bind it to ! FUNCTION using `rl_bind_key ()'. Using this function alone is sufficient for most applications. It is --- 1698,1710 ---- This binds the keystroke to the function ! _descriptively_ named `backward-kill-word'. You, as the programmer, should bind the functions you write to descriptive names as well. Readline provides a function for doing that: ! - Function: int rl_add_defun (const char *name, rl_command_func_t ! *function, int key) Add NAME to the list of named functions. Make FUNCTION be the function that gets called. If KEY is not -1, then bind it to ! FUNCTION using `rl_bind_key()'. Using this function alone is sufficient for most applications. It is *************** *** 1542,1554 **** Readline which keymap to use. ! - Function: Keymap rl_make_bare_keymap () Returns a new, empty keymap. The space for the keymap is ! allocated with `malloc ()'; you should `free ()' it when you are ! done. - Function: Keymap rl_copy_keymap (Keymap map) Return a new keymap which is a copy of MAP. ! - Function: Keymap rl_make_keymap () Return a new keymap with the printing characters bound to rl_insert, the lowercase Meta characters bound to run their --- 1725,1737 ---- Readline which keymap to use. ! - Function: Keymap rl_make_bare_keymap (void) Returns a new, empty keymap. The space for the keymap is ! allocated with `malloc()'; the caller should free it by calling ! `rl_discard_keymap()' when done. - Function: Keymap rl_copy_keymap (Keymap map) Return a new keymap which is a copy of MAP. ! - Function: Keymap rl_make_keymap (void) Return a new keymap with the printing characters bound to rl_insert, the lowercase Meta characters bound to run their *************** *** 1562,1566 **** change which keymap is active. ! - Function: Keymap rl_get_keymap () Returns the currently active keymap. --- 1745,1749 ---- change which keymap is active. ! - Function: Keymap rl_get_keymap (void) Returns the currently active keymap. *************** *** 1568,1580 **** Makes KEYMAP the currently active keymap. ! - Function: Keymap rl_get_keymap_by_name (char *name) Return the keymap matching NAME. NAME is one which would be supplied in a `set keymap' inputrc line (*note Readline Init ! File::.). - Function: char * rl_get_keymap_name (Keymap keymap) Return the name matching KEYMAP. NAME is one which would be supplied in a `set keymap' inputrc line (*note Readline Init ! File::.).  --- 1751,1763 ---- Makes KEYMAP the currently active keymap. ! - Function: Keymap rl_get_keymap_by_name (const char *name) Return the keymap matching NAME. NAME is one which would be supplied in a `set keymap' inputrc line (*note Readline Init ! File::). - Function: char * rl_get_keymap_name (Keymap keymap) Return the name matching KEYMAP. NAME is one which would be supplied in a `set keymap' inputrc line (*note Readline Init ! File::).  *************** *** 1584,1608 **** ------------ ! You associate keys with functions through the keymap. Readline has ! several internal keymaps: `emacs_standard_keymap', `emacs_meta_keymap', ! `emacs_ctlx_keymap', `vi_movement_keymap', and `vi_insertion_keymap'. ! `emacs_standard_keymap' is the default, and the examples in this manual ! assume that. ! Since `readline' installs a set of default key bindings the first time it is called, there is always the danger that a custom binding ! installed before the first call to `readline' will be overridden. An alternate mechanism is to install custom key bindings in an initialization function assigned to the `rl_startup_hook' variable ! (*note Readline Variables::.). These functions manage key bindings. ! - Function: int rl_bind_key (int key, Function *function) Binds KEY to FUNCTION in the currently active keymap. Returns non-zero in the case of an invalid KEY. ! - Function: int rl_bind_key_in_map (int key, Function *function, ! Keymap map) Bind KEY to FUNCTION in MAP. Returns non-zero in the case of an invalid KEY. --- 1767,1791 ---- ------------ ! Key sequences are associate with functions through the keymap. ! Readline has several internal keymaps: `emacs_standard_keymap', ! `emacs_meta_keymap', `emacs_ctlx_keymap', `vi_movement_keymap', and ! `vi_insertion_keymap'. `emacs_standard_keymap' is the default, and the ! examples in this manual assume that. ! Since `readline()' installs a set of default key bindings the first time it is called, there is always the danger that a custom binding ! installed before the first call to `readline()' will be overridden. An alternate mechanism is to install custom key bindings in an initialization function assigned to the `rl_startup_hook' variable ! (*note Readline Variables::). These functions manage key bindings. ! - Function: int rl_bind_key (int key, rl_command_func_t *function) Binds KEY to FUNCTION in the currently active keymap. Returns non-zero in the case of an invalid KEY. ! - Function: int rl_bind_key_in_map (int key, rl_command_func_t ! *function, Keymap map) Bind KEY to FUNCTION in MAP. Returns non-zero in the case of an invalid KEY. *************** *** 1616,1628 **** error. ! - Function: int rl_unbind_function_in_map (Function *function, Keymap ! map) Unbind all keys that execute FUNCTION in MAP. ! - Function: int rl_unbind_command_in_map (char *command, Keymap map) Unbind all keys that are bound to COMMAND in MAP. ! - Function: int rl_generic_bind (int type, char *keyseq, char *data, ! Keymap map) Bind the key sequence represented by the string KEYSEQ to the arbitrary pointer DATA. TYPE says what kind of data is pointed to --- 1799,1818 ---- error. ! - Function: int rl_unbind_function_in_map (rl_command_func_t ! *function, Keymap map) Unbind all keys that execute FUNCTION in MAP. ! - Function: int rl_unbind_command_in_map (const char *command, Keymap ! map) Unbind all keys that are bound to COMMAND in MAP. ! - Function: int rl_set_key (const char *keyseq, rl_command_func_t ! *function, Keymap map) ! Bind the key sequence represented by the string KEYSEQ to the ! function FUNCTION. This makes new keymaps as necessary. The ! initial keymap in which to do bindings is MAP. ! ! - Function: int rl_generic_bind (int type, const char *keyseq, char ! *data, Keymap map) Bind the key sequence represented by the string KEYSEQ to the arbitrary pointer DATA. TYPE says what kind of data is pointed to *************** *** 1634,1642 **** Parse LINE as if it had been read from the `inputrc' file and perform any key bindings and variable assignments found (*note ! Readline Init File::.). ! - Function: int rl_read_init_file (char *filename) Read keybindings and variable assignments from FILENAME (*note ! Readline Init File::.).  --- 1824,1832 ---- Parse LINE as if it had been read from the `inputrc' file and perform any key bindings and variable assignments found (*note ! Readline Init File::). ! - Function: int rl_read_init_file (const char *filename) Read keybindings and variable assignments from FILENAME (*note ! Readline Init File::).  *************** *** 1647,1668 **** These functions allow you to find out what keys invoke named ! functions and the functions invoked by a particular key sequence. ! - Function: Function * rl_named_function (char *name) Return the function with name NAME. ! - Function: Function * rl_function_of_keyseq (char *keyseq, Keymap ! map, int *type) Return the function invoked by KEYSEQ in keymap MAP. If MAP is ! NULL, the current keymap is used. If TYPE is not NULL, the type ! of the object is returned in it (one of `ISFUNC', `ISKMAP', or ! `ISMACR'). ! - Function: char ** rl_invoking_keyseqs (Function *function) Return an array of strings representing the key sequences used to invoke FUNCTION in the current keymap. ! - Function: char ** rl_invoking_keyseqs_in_map (Function *function, ! Keymap map) Return an array of strings representing the key sequences used to invoke FUNCTION in the keymap MAP. --- 1837,1859 ---- These functions allow you to find out what keys invoke named ! functions and the functions invoked by a particular key sequence. You ! may also associate a new function name with an arbitrary function. ! - Function: rl_command_func_t * rl_named_function (const char *name) Return the function with name NAME. ! - Function: rl_command_func_t * rl_function_of_keyseq (const char ! *keyseq, Keymap map, int *type) Return the function invoked by KEYSEQ in keymap MAP. If MAP is ! `NULL', the current keymap is used. If TYPE is not `NULL', the ! type of the object is returned in the `int' variable it points to ! (one of `ISFUNC', `ISKMAP', or `ISMACR'). ! - Function: char ** rl_invoking_keyseqs (rl_command_func_t *function) Return an array of strings representing the key sequences used to invoke FUNCTION in the current keymap. ! - Function: char ** rl_invoking_keyseqs_in_map (rl_command_func_t ! *function, Keymap map) Return an array of strings representing the key sequences used to invoke FUNCTION in the keymap MAP. *************** *** 1674,1686 **** `inputrc' file and re-read. ! - Function: void rl_list_funmap_names () Print the names of all bindable Readline functions to `rl_outstream'. ! - Function: char ** rl_funmap_names () Return a NULL terminated array of known function names. The array is sorted. The array itself is allocated, but not the strings ! inside. You should free () the array when you done, but not the ! pointrs.  --- 1865,1882 ---- `inputrc' file and re-read. ! - Function: void rl_list_funmap_names (void) Print the names of all bindable Readline functions to `rl_outstream'. ! - Function: const char ** rl_funmap_names (void) Return a NULL terminated array of known function names. The array is sorted. The array itself is allocated, but not the strings ! inside. You should `free()' the array when you are done, but not ! the pointers. ! ! - Function: int rl_add_funmap_entry (const char *name, ! rl_command_func_t *function) ! Add NAME to the list of bindable Readline command names, and make ! FUNCTION the function to be called when NAME is invoked.  *************** *** 1692,1706 **** Supporting the undo command is a painless thing, and makes your functions much more useful. It is certainly easy to try something if ! you know you can undo it. I could use an undo function for the stock ! market. If your function simply inserts text once, or deletes text once, and ! uses `rl_insert_text ()' or `rl_delete_text ()' to do it, then undoing ! is already done for you automatically. If you do multiple insertions or multiple deletions, or any combination of these operations, you should group them together into ! one operation. This is done with `rl_begin_undo_group ()' and ! `rl_end_undo_group ()'. The types of events that can be undone are: --- 1888,1901 ---- Supporting the undo command is a painless thing, and makes your functions much more useful. It is certainly easy to try something if ! you know you can undo it. If your function simply inserts text once, or deletes text once, and ! uses `rl_insert_text()' or `rl_delete_text()' to do it, then undoing is ! already done for you automatically. If you do multiple insertions or multiple deletions, or any combination of these operations, you should group them together into ! one operation. This is done with `rl_begin_undo_group()' and ! `rl_end_undo_group()'. The types of events that can be undone are: *************** *** 1710,1726 **** Notice that `UNDO_DELETE' means to insert some text, and `UNDO_INSERT' means to delete some text. That is, the undo code tells ! undo what to undo, not how to undo it. `UNDO_BEGIN' and `UNDO_END' are ! tags added by `rl_begin_undo_group ()' and `rl_end_undo_group ()'. ! - Function: int rl_begin_undo_group () Begins saving undo information in a group construct. The undo ! information usually comes from calls to `rl_insert_text ()' and ! `rl_delete_text ()', but could be the result of calls to ! `rl_add_undo ()'. ! - Function: int rl_end_undo_group () Closes the current undo group started with `rl_begin_undo_group ! ()'. There should be one call to `rl_end_undo_group ()' for each ! call to `rl_begin_undo_group ()'. - Function: void rl_add_undo (enum undo_code what, int start, int end, --- 1905,1921 ---- Notice that `UNDO_DELETE' means to insert some text, and `UNDO_INSERT' means to delete some text. That is, the undo code tells ! what to undo, not how to undo it. `UNDO_BEGIN' and `UNDO_END' are tags ! added by `rl_begin_undo_group()' and `rl_end_undo_group()'. ! - Function: int rl_begin_undo_group (void) Begins saving undo information in a group construct. The undo ! information usually comes from calls to `rl_insert_text()' and ! `rl_delete_text()', but could be the result of calls to ! `rl_add_undo()'. ! - Function: int rl_end_undo_group (void) Closes the current undo group started with `rl_begin_undo_group ! ()'. There should be one call to `rl_end_undo_group()' for each ! call to `rl_begin_undo_group()'. - Function: void rl_add_undo (enum undo_code what, int start, int end, *************** *** 1729,1741 **** text runs from START to END, and encompasses TEXT. ! - Function: void free_undo_list () Free the existing undo list. ! - Function: int rl_do_undo () Undo the first thing on the undo list. Returns `0' if there was nothing to undo, non-zero if something was undone. Finally, if you neither insert nor delete text, but directly modify ! the existing text (e.g., change its case), call `rl_modifying ()' once, just before you modify the text. You must supply the indices of the text range that you are going to modify. --- 1924,1936 ---- text runs from START to END, and encompasses TEXT. ! - Function: void rl_free_undo_list (void) Free the existing undo list. ! - Function: int rl_do_undo (void) Undo the first thing on the undo list. Returns `0' if there was nothing to undo, non-zero if something was undone. Finally, if you neither insert nor delete text, but directly modify ! the existing text (e.g., change its case), call `rl_modifying()' once, just before you modify the text. You must supply the indices of the text range that you are going to modify. *************** *** 1752,1768 **** --------- ! - Function: void rl_redisplay () Change what's displayed on the screen to reflect the current contents of `rl_line_buffer'. ! - Function: int rl_forced_update_display () Force the line to be updated and redisplayed, whether or not Readline thinks the screen display is correct. ! - Function: int rl_on_new_line () Tell the update functions that we have moved onto a new (empty) line, usually after ouputting a newline. ! - Function: int rl_on_new_line_with_prompt () Tell the update functions that we have moved onto a new line, with RL_PROMPT already displayed. This could be used by applications --- 1947,1963 ---- --------- ! - Function: void rl_redisplay (void) Change what's displayed on the screen to reflect the current contents of `rl_line_buffer'. ! - Function: int rl_forced_update_display (void) Force the line to be updated and redisplayed, whether or not Readline thinks the screen display is correct. ! - Function: int rl_on_new_line (void) Tell the update functions that we have moved onto a new (empty) line, usually after ouputting a newline. ! - Function: int rl_on_new_line_with_prompt (void) Tell the update functions that we have moved onto a new line, with RL_PROMPT already displayed. This could be used by applications *************** *** 1771,1801 **** should be used after setting RL_ALREADY_PROMPTED. ! - Function: int rl_reset_line_state () Reset the display state to a clean state and redisplay the current line starting on a new line. ! - Function: int rl_message (va_alist) ! The arguments are a string as would be supplied to `printf'. The ! resulting string is displayed in the "echo area". The echo area ! is also used to display numeric arguments and search strings. ! - Function: int rl_clear_message () Clear the message in the echo area. ! - Function: void rl_save_prompt () Save the local Readline prompt display state in preparation for ! displaying a new message in the message area with `rl_message'. ! - Function: void rl_restore_prompt () Restore the local Readline prompt display state saved by the most recent call to `rl_save_prompt'.  ! File: readline.info, Node: Modifying Text, Next: Utility Functions, Prev: Redisplay, Up: Readline Convenience Functions Modifying Text -------------- ! - Function: int rl_insert_text (char *text) Insert TEXT into the line at the current cursor position. --- 1966,2022 ---- should be used after setting RL_ALREADY_PROMPTED. ! - Function: int rl_reset_line_state (void) Reset the display state to a clean state and redisplay the current line starting on a new line. ! - Function: int rl_crlf (void) ! Move the cursor to the start of the next screen line. ! ! - Function: int rl_show_char (int c) ! Display character C on `rl_outstream'. If Readline has not been ! set to display meta characters directly, this will convert meta ! characters to a meta-prefixed key sequence. This is intended for ! use by applications which wish to do their own redisplay. ! ! - Function: int rl_message (const char *, ...) ! The arguments are a format string as would be supplied to `printf', ! possibly containing conversion specifications such as `%d', and ! any additional arguments necessary to satisfy the conversion ! specifications. The resulting string is displayed in the "echo ! area". The echo area is also used to display numeric arguments ! and search strings. ! - Function: int rl_clear_message (void) Clear the message in the echo area. ! - Function: void rl_save_prompt (void) Save the local Readline prompt display state in preparation for ! displaying a new message in the message area with `rl_message()'. ! - Function: void rl_restore_prompt (void) Restore the local Readline prompt display state saved by the most recent call to `rl_save_prompt'. + - Function: int rl_expand_prompt (char *prompt) + Expand any special character sequences in PROMPT and set up the + local Readline prompt redisplay variables. This function is + called by `readline()'. It may also be called to expand the + primary prompt if the `rl_on_new_line_with_prompt()' function or + `rl_already_prompted' variable is used. It returns the number of + visible characters on the last line of the (possibly multi-line) + prompt. + + - Function: int rl_set_prompt (const char *prompt) + Make Readline use PROMPT for subsequent redisplay. This calls + `rl_expand_prompt()' to expand the prompt and sets `rl_prompt' to + the result. +  ! File: readline.info, Node: Modifying Text, Next: Character Input, Prev: Redisplay, Up: Readline Convenience Functions Modifying Text -------------- ! - Function: int rl_insert_text (const char *text) Insert TEXT into the line at the current cursor position. *************** *** 1814,1859 **** last command was not a kill, a new kill ring slot is used. !  ! File: readline.info, Node: Utility Functions, Next: Alternate Interface, Prev: Modifying Text, Up: Readline Convenience Functions ! Utility Functions ! ----------------- ! - Function: int rl_read_key () ! Return the next character available. This handles input inserted ! into the input stream via PENDING INPUT (*note Readline ! Variables::.) and `rl_stuff_char ()', macros, and characters read ! from the keyboard. ! - Function: int rl_getc (FILE *) ! Return the next character available from the keyboard. - Function: int rl_stuff_char (int c) Insert C into the Readline input stream. It will be "read" before Readline attempts to read characters from the terminal with ! `rl_read_key ()'. ! - Function: int rl_extend_line_buffer (int len) ! Ensure that `rl_line_buffer' has enough space to hold LEN ! characters, possibly reallocating it if necessary. ! - Function: int rl_initialize () ! Initialize or re-initialize Readline's internal state. ! - Function: int rl_reset_terminal (char *terminal_name) Reinitialize Readline's idea of the terminal settings using TERMINAL_NAME as the terminal type (e.g., `vt100'). If ! TERMINAL_NAME is NULL, the value of the `TERM' environment variable is used. ! - Function: int alphabetic (int c) ! Return 1 if C is an alphabetic character. ! - Function: int numeric (int c) ! Return 1 if C is a numeric character. ! - Function: int ding () Ring the terminal bell, obeying the setting of `bell-style'. - Function: void rl_display_match_list (char **matches, int len, int max) --- 2035,2130 ---- last command was not a kill, a new kill ring slot is used. ! - Function: int rl_push_macro_input (char *macro) ! Cause MACRO to be inserted into the line, as if it had been invoked ! by a key bound to a macro. Not especially useful; use ! `rl_insert_text()' instead. !  ! File: readline.info, Node: Character Input, Next: Terminal Management, Prev: Modifying Text, Up: Readline Convenience Functions ! Character Input ! --------------- ! - Function: int rl_read_key (void) ! Return the next character available from Readline's current input ! stream. This handles input inserted into the input stream via ! RL_PENDING_INPUT (*note Readline Variables::) and ! `rl_stuff_char()', macros, and characters read from the keyboard. ! While waiting for input, this function will call any function ! assigned to the `rl_event_hook' variable. ! ! - Function: int rl_getc (FILE *stream) ! Return the next character available from STREAM, which is assumed ! to be the keyboard. - Function: int rl_stuff_char (int c) Insert C into the Readline input stream. It will be "read" before Readline attempts to read characters from the terminal with ! `rl_read_key()'. ! - Function: int rl_execute_next (int c) ! Make C be the next command to be executed when `rl_read_key()' is ! called. This sets RL_PENDING_INPUT. ! ! - Function: int rl_clear_pending_input (void) ! Unset RL_PENDING_INPUT, effectively negating the effect of any ! previous call to `rl_execute_next()'. This works only if the ! pending input has not already been read with `rl_read_key()'. ! - Function: int rl_set_keyboard_input_timeout (int u) ! While waiting for keyboard input in `rl_read_key()', Readline will ! wait for U microseconds for input before calling any function ! assigned to `rl_event_hook'. The default waiting period is ! one-tenth of a second. Returns the old timeout value. !  ! File: readline.info, Node: Terminal Management, Next: Utility Functions, Prev: Character Input, Up: Readline Convenience Functions ! ! Terminal Management ! ------------------- ! ! - Function: void rl_prep_terminal (int meta_flag) ! Modify the terminal settings for Readline's use, so `readline()' ! can read a single character at a time from the keyboard. The ! META_FLAG argument should be non-zero if Readline should read ! eight-bit input. ! ! - Function: void rl_deprep_terminal (void) ! Undo the effects of `rl_prep_terminal()', leaving the terminal in ! the state in which it was before the most recent call to ! `rl_prep_terminal()'. ! ! - Function: void rl_tty_set_default_bindings (Keymap kmap) ! Read the operating system's terminal editing characters (as would ! be displayed by `stty') to their Readline equivalents. The ! bindings are performed in KMAP. ! ! - Function: int rl_reset_terminal (const char *terminal_name) Reinitialize Readline's idea of the terminal settings using TERMINAL_NAME as the terminal type (e.g., `vt100'). If ! TERMINAL_NAME is `NULL', the value of the `TERM' environment variable is used. !  ! File: readline.info, Node: Utility Functions, Next: Miscellaneous Functions, Prev: Terminal Management, Up: Readline Convenience Functions ! Utility Functions ! ----------------- ! - Function: int rl_extend_line_buffer (int len) ! Ensure that `rl_line_buffer' has enough space to hold LEN ! characters, possibly reallocating it if necessary. ! ! - Function: int rl_initialize (void) ! Initialize or re-initialize Readline's internal state. It's not ! strictly necessary to call this; `readline()' calls it before ! reading any input. ! ! - Function: int rl_ding (void) Ring the terminal bell, obeying the setting of `bell-style'. + - Function: int rl_alphabetic (int c) + Return 1 if C is an alphabetic character. + - Function: void rl_display_match_list (char **matches, int len, int max) *************** *** 1864,1893 **** length of the longest string in `matches'. This function uses the setting of `print-completions-horizontally' to select how the ! matches are displayed (*note Readline Init File Syntax::.). ! The following are implemented as macros, defined in `chartypes.h'. ! - Function: int uppercase_p (int c) Return 1 if C is an uppercase alphabetic character. ! - Function: int lowercase_p (int c) Return 1 if C is a lowercase alphabetic character. ! - Function: int digit_p (int c) Return 1 if C is a numeric character. ! - Function: int to_upper (int c) If C is a lowercase alphabetic character, return the corresponding uppercase character. ! - Function: int to_lower (int c) If C is an uppercase alphabetic character, return the corresponding lowercase character. ! - Function: int digit_value (int c) If C is a number, return the value it represents.  ! File: readline.info, Node: Alternate Interface, Prev: Utility Functions, Up: Readline Convenience Functions Alternate Interface --- 2135,2201 ---- length of the longest string in `matches'. This function uses the setting of `print-completions-horizontally' to select how the ! matches are displayed (*note Readline Init File Syntax::). ! The following are implemented as macros, defined in `chardefs.h'. ! Applications should refrain from using them. ! - Function: int _rl_uppercase_p (int c) Return 1 if C is an uppercase alphabetic character. ! - Function: int _rl_lowercase_p (int c) Return 1 if C is a lowercase alphabetic character. ! - Function: int _rl_digit_p (int c) Return 1 if C is a numeric character. ! - Function: int _rl_to_upper (int c) If C is a lowercase alphabetic character, return the corresponding uppercase character. ! - Function: int _rl_to_lower (int c) If C is an uppercase alphabetic character, return the corresponding lowercase character. ! - Function: int _rl_digit_value (int c) If C is a number, return the value it represents.  ! File: readline.info, Node: Miscellaneous Functions, Next: Alternate Interface, Prev: Utility Functions, Up: Readline Convenience Functions ! ! Miscellaneous Functions ! ----------------------- ! ! - Function: int rl_macro_bind (const char *keyseq, const char *macro, ! Keymap map) ! Bind the key sequence KEYSEQ to invoke the macro MACRO. The ! binding is performed in MAP. When KEYSEQ is invoked, the MACRO ! will be inserted into the line. This function is deprecated; use ! `rl_generic_bind()' instead. ! ! - Function: void rl_macro_dumper (int readable) ! Print the key sequences bound to macros and their values, using ! the current keymap, to `rl_outstream'. If READABLE is non-zero, ! the list is formatted in such a way that it can be made part of an ! `inputrc' file and re-read. ! ! - Function: int rl_variable_bind (const char *variable, const char ! *value) ! Make the Readline variable VARIABLE have VALUE. This behaves as ! if the readline command `set VARIABLE VALUE' had been executed in ! an `inputrc' file (*note Readline Init File Syntax::). ! ! - Function: void rl_variable_dumper (int readable) ! Print the readline variable names and their current values to ! `rl_outstream'. If READABLE is non-zero, the list is formatted in ! such a way that it can be made part of an `inputrc' file and ! re-read. ! ! - Function: int rl_set_paren_blink_timeout (int u) ! Set the time interval (in microseconds) that Readline waits when ! showing a balancing character when `blink-matching-paren' has been ! enabled. ! !  ! File: readline.info, Node: Alternate Interface, Next: A Readline Example, Prev: Miscellaneous Functions, Up: Readline Convenience Functions Alternate Interface *************** *** 1901,1911 **** functions available to make this easy. ! - Function: void rl_callback_handler_install (char *prompt, Vfunction ! *lhandler) Set up the terminal for readline I/O and display the initial expanded value of PROMPT. Save the value of LHANDLER to use as a ! callback when a complete line of input has been entered. ! - Function: void rl_callback_read_char () Whenever an application determines that keyboard input is available, it should call `rl_callback_read_char()', which will --- 2209,2220 ---- functions available to make this easy. ! - Function: void rl_callback_handler_install (const char *prompt, ! rl_vcpfunc_t *lhandler) Set up the terminal for readline I/O and display the initial expanded value of PROMPT. Save the value of LHANDLER to use as a ! function to call when a complete line of input has been entered. ! The function takes the text of the line as an argument. ! - Function: void rl_callback_read_char (void) Whenever an application determines that keyboard input is available, it should call `rl_callback_read_char()', which will *************** *** 1916,1926 **** `NULL' line. ! - Function: void rl_callback_handler_remove () Restore the terminal to its initial state and remove the line handler. This may be called from within a callback as well as independently. ! An Example ! ---------- Here is a function which changes lowercase characters to their --- 2225,2238 ---- `NULL' line. ! - Function: void rl_callback_handler_remove (void) Restore the terminal to its initial state and remove the line handler. This may be called from within a callback as well as independently. !  ! File: readline.info, Node: A Readline Example, Prev: Alternate Interface, Up: Readline Convenience Functions ! ! A Readline Example ! ------------------ Here is a function which changes lowercase characters to their *************** *** 1976,1983 **** for (i = start; i != end; i++) { ! if (uppercase_p (rl_line_buffer[i])) ! rl_line_buffer[i] = to_lower (rl_line_buffer[i]); ! else if (lowercase_p (rl_line_buffer[i])) ! rl_line_buffer[i] = to_upper (rl_line_buffer[i]); } /* Move point to on top of the last character changed. */ --- 2288,2295 ---- for (i = start; i != end; i++) { ! if (_rl_uppercase_p (rl_line_buffer[i])) ! rl_line_buffer[i] = _rl_to_lower (rl_line_buffer[i]); ! else if (_rl_lowercase_p (rl_line_buffer[i])) ! rl_line_buffer[i] = _rl_to_upper (rl_line_buffer[i]); } /* Move point to on top of the last character changed. */ *************** *** 1998,2004 **** signals that can be sent to the process currently reading input from the keyboard. Since Readline changes the terminal attributes when it ! is called, it needs to perform special processing when a signal is ! received to restore the terminal to a sane state, or provide application ! writers with functions to do so manually. Readline contains an internal signal handler that is installed for a --- 2310,2316 ---- signals that can be sent to the process currently reading input from the keyboard. Since Readline changes the terminal attributes when it ! is called, it needs to perform special processing when such a signal is ! received in order to restore the terminal to a sane state, or provide ! application writers with functions to do so manually. Readline contains an internal signal handler that is installed for a *************** *** 2006,2011 **** `SIGTSTP', `SIGTTIN', and `SIGTTOU'). When one of these signals is received, the signal handler will reset the terminal attributes to ! those that were in effect before `readline ()' was called, reset the ! signal handling to what it was before `readline ()' was called, and resend the signal to the calling application. If and when the calling application's signal handler returns, Readline will reinitialize the --- 2318,2323 ---- `SIGTSTP', `SIGTTIN', and `SIGTTOU'). When one of these signals is received, the signal handler will reset the terminal attributes to ! those that were in effect before `readline()' was called, reset the ! signal handling to what it was before `readline()' was called, and resend the signal to the calling application. If and when the calling application's signal handler returns, Readline will reinitialize the *************** *** 2013,2034 **** the Readline signal handler performs some additional work, which will cause any partially-entered line to be aborted (see the description of ! `rl_free_line_state ()'). There is an additional Readline signal handler, for `SIGWINCH', which the kernel sends to a process whenever the terminal's size changes (for example, if a user resizes an `xterm'). The Readline `SIGWINCH' ! handler updates Readline's internal screen size state, and then calls ! any `SIGWINCH' signal handler the calling application has installed. ! Readline calls the application's `SIGWINCH' signal handler without ! resetting the terminal to its original state. If the application's ! signal handler does more than update its idea of the terminal size and ! return (for example, a `longjmp' back to a main processing loop), it ! *must* call `rl_cleanup_after_signal ()' (described below), to restore ! the terminal state. Readline provides two variables that allow application writers to control whether or not it will catch certain signals and act on them when they are received. It is important that applications change the ! values of these variables only when calling `readline ()', not in a signal handler, so Readline's internal signal state is not corrupted. --- 2325,2346 ---- the Readline signal handler performs some additional work, which will cause any partially-entered line to be aborted (see the description of ! `rl_free_line_state()' below). There is an additional Readline signal handler, for `SIGWINCH', which the kernel sends to a process whenever the terminal's size changes (for example, if a user resizes an `xterm'). The Readline `SIGWINCH' ! handler updates Readline's internal screen size information, and then ! calls any `SIGWINCH' signal handler the calling application has ! installed. Readline calls the application's `SIGWINCH' signal handler ! without resetting the terminal to its original state. If the ! application's signal handler does more than update its idea of the ! terminal size and return (for example, a `longjmp' back to a main ! processing loop), it _must_ call `rl_cleanup_after_signal()' (described ! below), to restore the terminal state. Readline provides two variables that allow application writers to control whether or not it will catch certain signals and act on them when they are received. It is important that applications change the ! values of these variables only when calling `readline()', not in a signal handler, so Readline's internal signal state is not corrupted. *************** *** 2053,2057 **** - Function: void rl_cleanup_after_signal (void) This function will reset the state of the terminal to what it was ! before `readline ()' was called, and remove the Readline signal handlers for all signals, depending on the values of `rl_catch_signals' and `rl_catch_sigwinch'. --- 2365,2369 ---- - Function: void rl_cleanup_after_signal (void) This function will reset the state of the terminal to what it was ! before `readline()' was called, and remove the Readline signal handlers for all signals, depending on the values of `rl_catch_signals' and `rl_catch_sigwinch'. *************** *** 2062,2066 **** partially-entered keyboard macro, and any partially-entered numeric argument). This should be called before ! `rl_cleanup_after_signal ()'. The Readline signal handler for `SIGINT' calls this to abort the current input line. --- 2374,2378 ---- partially-entered keyboard macro, and any partially-entered numeric argument). This should be called before ! `rl_cleanup_after_signal()'. The Readline signal handler for `SIGINT' calls this to abort the current input line. *************** *** 2071,2079 **** If an application does not wish Readline to catch `SIGWINCH', it may ! call `rl_resize_terminal ()' to force Readline to update its idea of ! the terminal size when a `SIGWINCH' is received. - Function: void rl_resize_terminal (void) ! Update Readline's internal screen size. The following functions install and remove Readline's signal --- 2383,2404 ---- If an application does not wish Readline to catch `SIGWINCH', it may ! call `rl_resize_terminal()' or `rl_set_screen_size()' to force Readline ! to update its idea of the terminal size when a `SIGWINCH' is received. - Function: void rl_resize_terminal (void) ! Update Readline's internal screen size by reading values from the ! kernel. ! ! - Function: void rl_set_screen_size (int rows, int cols) ! Set Readline's idea of the terminal size to ROWS rows and COLS ! columns. ! ! If an application does not want to install a `SIGWINCH' handler, but ! is still interested in the screen dimensions, Readline's idea of the ! screen size may be queried. ! ! - Function: void rl_get_screen_size (int *rows, int *cols) ! Return Readline's idea of the terminal's size in the variables ! pointed to by the arguments. The following functions install and remove Readline's signal *************** *** 2088,2092 **** - Function: int rl_clear_signals (void) Remove all of the Readline signal handlers installed by ! `rl_set_signals ()'.  --- 2413,2417 ---- - Function: int rl_clear_signals (void) Remove all of the Readline signal handlers installed by ! `rl_set_signals()'.  *************** *** 2126,2155 **** There are three major functions used to perform completion: ! 1. The user-interface function `rl_complete ()'. This function is ! called with the same arguments as other Readline functions ! intended for interactive use: COUNT and INVOKING_KEY. It ! isolates the word to be completed and calls `completion_matches ! ()' to generate a list of possible completions. It then either ! lists the possible completions, inserts the possible completions, ! or actually performs the completion, depending on which behavior ! is desired. ! ! 2. The internal function `completion_matches ()' uses your ! "generator" function to generate the list of possible matches, and ! then returns the array of these matches. You should place the ! address of your generator function in `rl_completion_entry_function'. 3. The generator function is called repeatedly from ! `completion_matches ()', returning a string each time. The arguments to the generator function are TEXT and STATE. TEXT is the partial word to be completed. STATE is zero the first time the function is called, allowing the generator to perform any necessary initialization, and a positive non-zero integer for each ! subsequent call. When the generator function returns `(char ! *)NULL' this signals `completion_matches ()' that there are no ! more possibilities left. Usually the generator function computes ! the list of possible completions when STATE is zero, and returns ! them one at a time on subsequent calls. Each string the generator function returns as a match must be allocated with `malloc()'; Readline frees the strings when it has finished with them. --- 2451,2479 ---- There are three major functions used to perform completion: ! 1. The user-interface function `rl_complete()'. This function is ! called with the same arguments as other bindable Readline ! functions: COUNT and INVOKING_KEY. It isolates the word to be ! completed and calls `rl_completion_matches()' to generate a list ! of possible completions. It then either lists the possible ! completions, inserts the possible completions, or actually ! performs the completion, depending on which behavior is desired. ! ! 2. The internal function `rl_completion_matches()' uses an ! application-supplied "generator" function to generate the list of ! possible matches, and then returns the array of these matches. ! The caller should place the address of its generator function in `rl_completion_entry_function'. 3. The generator function is called repeatedly from ! `rl_completion_matches()', returning a string each time. The arguments to the generator function are TEXT and STATE. TEXT is the partial word to be completed. STATE is zero the first time the function is called, allowing the generator to perform any necessary initialization, and a positive non-zero integer for each ! subsequent call. The generator function returns `(char *)NULL' to ! inform `rl_completion_matches()' that there are no more ! possibilities left. Usually the generator function computes the ! list of possible completions when STATE is zero, and returns them ! one at a time on subsequent calls. Each string the generator function returns as a match must be allocated with `malloc()'; Readline frees the strings when it has finished with them. *************** *** 2159,2170 **** Complete the word at or before point. You have supplied the function that does the initial simple matching selection algorithm ! (see `completion_matches ()'). The default is to do filename completion. ! - Variable: Function * rl_completion_entry_function ! This is a pointer to the generator function for `completion_matches ! ()'. If the value of `rl_completion_entry_function' is `(Function ! *)NULL' then the default filename generator function, ! `filename_completion_function ()', is used.  --- 2483,2494 ---- Complete the word at or before point. You have supplied the function that does the initial simple matching selection algorithm ! (see `rl_completion_matches()'). The default is to do filename completion. ! - Variable: rl_compentry_func_t * rl_completion_entry_function ! This is a pointer to the generator function for ! `rl_completion_matches()'. If the value of ! `rl_completion_entry_function' is `NULL' then the default filename ! generator function, `rl_filename_completion_function()', is used.  *************** *** 2188,2227 **** Complete the word at or before point. You have supplied the function that does the initial simple matching selection algorithm ! (see `completion_matches ()' and `rl_completion_entry_function'). The default is to do filename completion. This calls ! `rl_complete_internal ()' with an argument depending on INVOKING_KEY. ! - Function: int rl_possible_completions (int count, int invoking_key)) List the possible completions. See description of `rl_complete ! ()'. This calls `rl_complete_internal ()' with an argument of `?'. ! - Function: int rl_insert_completions (int count, int invoking_key)) Insert the list of possible completions into the line, deleting the ! partially-completed word. See description of `rl_complete ()'. ! This calls `rl_complete_internal ()' with an argument of `*'. ! - Function: char ** completion_matches (char *text, CPFunction ! *entry_func) ! Returns an array of `(char *)' which is a list of completions for ! TEXT. If there are no completions, returns `(char **)NULL'. The ! first entry in the returned array is the substitution for TEXT. ! The remaining entries are the possible completions. The array is terminated with a `NULL' pointer. ! ENTRY_FUNC is a function of two args, and returns a `(char *)'. ! The first argument is TEXT. The second is a state argument; it is zero on the first call, and non-zero on subsequent calls. ENTRY_FUNC returns a `NULL' pointer to the caller when there are no more matches. ! - Function: char * filename_completion_function (char *text, int state) A generator function for filename completion in the general case. ! Note that completion in Bash is a little different because of all ! the pathnames that must be followed when looking up completions ! for a command. The Bash source is a useful reference for writing ! custom completion functions. ! - Function: char * username_completion_function (char *text, int state) A completion generator for usernames. TEXT contains a partial username preceded by a random character (usually `~'). As with all --- 2512,2552 ---- Complete the word at or before point. You have supplied the function that does the initial simple matching selection algorithm ! (see `rl_completion_matches()' and `rl_completion_entry_function'). The default is to do filename completion. This calls ! `rl_complete_internal()' with an argument depending on INVOKING_KEY. ! - Function: int rl_possible_completions (int count, int invoking_key) List the possible completions. See description of `rl_complete ! ()'. This calls `rl_complete_internal()' with an argument of `?'. ! - Function: int rl_insert_completions (int count, int invoking_key) Insert the list of possible completions into the line, deleting the ! partially-completed word. See description of `rl_complete()'. ! This calls `rl_complete_internal()' with an argument of `*'. ! - Function: char ** rl_completion_matches (const char *text, ! rl_compentry_func_t *entry_func) ! Returns an array of strings which is a list of completions for ! TEXT. If there are no completions, returns `NULL'. The first ! entry in the returned array is the substitution for TEXT. The ! remaining entries are the possible completions. The array is terminated with a `NULL' pointer. ! ENTRY_FUNC is a function of two args, and returns a `char *'. The ! first argument is TEXT. The second is a state argument; it is zero on the first call, and non-zero on subsequent calls. ENTRY_FUNC returns a `NULL' pointer to the caller when there are no more matches. ! - Function: char * rl_filename_completion_function (const char *text, ! int state) A generator function for filename completion in the general case. ! TEXT is a partial filename. The Bash source is a useful reference ! for writing custom completion functions (the Bash completion ! functions call this and other Readline functions). ! - Function: char * rl_username_completion_function (const char *text, ! int state) A completion generator for usernames. TEXT contains a partial username preceded by a random character (usually `~'). As with all *************** *** 2235,2255 **** -------------------- ! - Variable: Function * rl_completion_entry_function ! A pointer to the generator function for `completion_matches ()'. ! `NULL' means to use `filename_completion_function ()', the default ! filename completer. ! - Variable: CPPFunction * rl_attempted_completion_function A pointer to an alternative function to create matches. The function is called with TEXT, START, and END. START and END are ! indices in `rl_line_buffer' saying what the boundaries of TEXT ! are. If this function exists and returns `NULL', or if this ! variable is set to `NULL', then `rl_complete ()' will call the ! value of `rl_completion_entry_function' to generate matches, ! otherwise the array of strings returned will be used. ! - Variable: CPFunction * rl_filename_quoting_function A pointer to a function that will quote a filename in an ! application- specific fashion. This is called if filename completion is being attempted and one of the characters in `rl_filename_quote_characters' appears in a completed filename. --- 2560,2583 ---- -------------------- ! - Variable: rl_compentry_func_t * rl_completion_entry_function ! A pointer to the generator function for `rl_completion_matches()'. ! `NULL' means to use `rl_filename_completion_function()', the ! default filename completer. ! - Variable: rl_completion_func_t * rl_attempted_completion_function A pointer to an alternative function to create matches. The function is called with TEXT, START, and END. START and END are ! indices in `rl_line_buffer' defining the boundaries of TEXT, which ! is a character string. If this function exists and returns ! `NULL', or if this variable is set to `NULL', then `rl_complete()' ! will call the value of `rl_completion_entry_function' to generate ! matches, otherwise the array of strings returned will be used. If ! this function sets the `rl_attempted_completion_over' variable to ! a non-zero value, Readline will not perform its default completion ! even if this function returns no matches. ! - Variable: rl_quote_func_t * rl_filename_quoting_function A pointer to a function that will quote a filename in an ! application-specific fashion. This is called if filename completion is being attempted and one of the characters in `rl_filename_quote_characters' appears in a completed filename. *************** *** 2262,2266 **** choose to reset this character. ! - Variable: CPFunction * rl_filename_dequoting_function A pointer to a function that will remove application-specific quoting characters from a filename before completion is attempted, --- 2590,2594 ---- choose to reset this character. ! - Variable: rl_dequote_func_t * rl_filename_dequoting_function A pointer to a function that will remove application-specific quoting characters from a filename before completion is attempted, *************** *** 2271,2278 **** QUOTE_CHAR is zero, the filename was not in an embedded string. ! - Variable: Function * rl_char_is_quoted_p A pointer to a function to call that determines whether or not a specific character in the line buffer is quoted, according to ! whatever quoting mechanism the program calling readline uses. The function is called with two arguments: TEXT, the text of the line, and INDEX, the index of the character in the line. It is used to --- 2599,2606 ---- QUOTE_CHAR is zero, the filename was not in an embedded string. ! - Variable: rl_linebuf_func_t * rl_char_is_quoted_p A pointer to a function to call that determines whether or not a specific character in the line buffer is quoted, according to ! whatever quoting mechanism the program calling Readline uses. The function is called with two arguments: TEXT, the text of the line, and INDEX, the index of the character in the line. It is used to *************** *** 2286,2315 **** sure she wants to see them all. The default value is 100. ! - Variable: char * rl_basic_word_break_characters The basic list of characters that signal a break between words for the completer routine. The default value of this variable is the ! characters which break words for completion in Bash, i.e., `" \t\n\"\\'`@$><=;|&{("'. ! - Variable: char * rl_basic_quote_characters ! List of quote characters which can cause a word break. ! - Variable: char * rl_completer_word_break_characters The list of characters that signal a break between words for ! `rl_complete_internal ()'. The default list is the value of `rl_basic_word_break_characters'. ! - Variable: char * rl_completer_quote_characters ! List of characters which can be used to quote a substring of the line. Completion occurs on the entire substring, and within the substring `rl_completer_word_break_characters' are treated as any other character, unless they also appear within this list. ! - Variable: char * rl_filename_quote_characters A list of characters that cause a filename to be quoted by the completer when they appear in a completed filename. The default is the null string. ! - Variable: char * rl_special_prefixes The list of characters that are word break characters, but should be left in TEXT when it is passed to the completion function. --- 2614,2643 ---- sure she wants to see them all. The default value is 100. ! - Variable: const char * rl_basic_word_break_characters The basic list of characters that signal a break between words for the completer routine. The default value of this variable is the ! characters which break words for completion in Bash: `" \t\n\"\\'`@$><=;|&{("'. ! - Variable: const char * rl_basic_quote_characters ! A list of quote characters which can cause a word break. ! - Variable: const char * rl_completer_word_break_characters The list of characters that signal a break between words for ! `rl_complete_internal()'. The default list is the value of `rl_basic_word_break_characters'. ! - Variable: const char * rl_completer_quote_characters ! A list of characters which can be used to quote a substring of the line. Completion occurs on the entire substring, and within the substring `rl_completer_word_break_characters' are treated as any other character, unless they also appear within this list. ! - Variable: const char * rl_filename_quote_characters A list of characters that cause a filename to be quoted by the completer when they appear in a completed filename. The default is the null string. ! - Variable: const char * rl_special_prefixes The list of characters that are word break characters, but should be left in TEXT when it is passed to the completion function. *************** *** 2328,2341 **** - Variable: int rl_ignore_completion_duplicates ! If non-zero, then disallow duplicates in the matches. Default is ! 1. - Variable: int rl_filename_completion_desired Non-zero means that the results of the matches are to be treated as ! filenames. This is *always* zero on entry, and can only be changed within a completion entry generator function. If it is set to a non-zero value, directory names have a slash appended and Readline ! attempts to quote completed filenames if they contain any embedded ! word break characters. - Variable: int rl_filename_quoting_desired --- 2656,2670 ---- - Variable: int rl_ignore_completion_duplicates ! If non-zero, then duplicates in the matches are removed. The ! default is 1. - Variable: int rl_filename_completion_desired Non-zero means that the results of the matches are to be treated as ! filenames. This is _always_ zero on entry, and can only be changed within a completion entry generator function. If it is set to a non-zero value, directory names have a slash appended and Readline ! attempts to quote completed filenames if they contain any ! characters in `rl_filename_quote_characters' and ! `rl_filename_quoting_desired' is set to a non-zero value. - Variable: int rl_filename_quoting_desired *************** *** 2343,2357 **** using double quotes (or an application-specific quoting mechanism) if the completed filename contains any characters in ! `rl_filename_quote_chars'. This is *always* non-zero on entry, and can only be changed within a completion entry generator function. The quoting is effected via a call to the function pointed to by `rl_filename_quoting_function'. - Variable: int rl_inhibit_completion ! If this variable is non-zero, completion is inhibit - extern char *getwd (); extern char *xmalloc (); /* The names of functions that actually do the manipulation. */ ! int com_list (), com_view (), com_rename (), com_stat (), com_pwd (); ! int com_delete (), com_help (), com_cd (), com_quit (); /* A structure which contains information on the commands this program --- 2753,2768 ---- #include extern char *xmalloc (); /* The names of functions that actually do the manipulation. */ ! int com_list __P((char *)); ! int com_view __P((char *)); ! int com_rename __P((char *)); ! int com_stat __P((char *)); ! int com_pwd __P((char *)); ! int com_delete __P((char *)); ! int com_help __P((char *)); ! int com_cd __P((char *)); ! int com_quit __P((char *)); /* A structure which contains information on the commands this program *************** *** 2417,2421 **** typedef struct { char *name; /* User printable name of the function. */ ! Function *func; /* Function to call to do the job. */ char *doc; /* Documentation for this function. */ } COMMAND; --- 2771,2775 ---- typedef struct { char *name; /* User printable name of the function. */ ! rl_icpfunc_t *func; /* Function to call to do the job. */ char *doc; /* Documentation for this function. */ } COMMAND; *************** *** 2433,2437 **** { "stat", com_stat, "Print out statistics on FILE" }, { "view", com_view, "View the contents of FILE" }, ! { (char *)NULL, (Function *)NULL, (char *)NULL } }; --- 2787,2791 ---- { "stat", com_stat, "Print out statistics on FILE" }, { "view", com_view, "View the contents of FILE" }, ! { (char *)NULL, (rl_icpfunc_t *)NULL, (char *)NULL } }; *************** *** 2443,2447 **** char *progname; ! /* When non-zero, this global means the user is done using this program. */ int done; --- 2797,2801 ---- char *progname; ! /* When non-zero, this means the user is done using this program. */ int done; *************** *** 2573,2582 **** /* **************************************************************** */ ! char *command_generator (); ! char **fileman_completion (); ! /* Tell the GNU Readline library how to complete. We want to try to complete ! on command names if this is the first word in the line, or on filenames ! if not. */ initialize_readline () { --- 2927,2936 ---- /* **************************************************************** */ ! char *command_generator __P((const char *, int)); ! char **fileman_completion __P((const char *, int, int)); ! /* Tell the GNU Readline library how to complete. We want to try to ! complete on command names if this is the first word in the line, or ! on filenames if not. */ initialize_readline () { *************** *** 2585,2599 **** /* Tell the completer that we want a crack first. */ ! rl_attempted_completion_function = (CPPFunction *)fileman_completion; } ! /* Attempt to complete on the contents of TEXT. START and END bound the ! region of rl_line_buffer that contains the word to complete. TEXT is ! the word to complete. We can use the entire contents of rl_line_buffer ! in case we want to do some simple parsing. Return the array of matches, ! or NULL if there aren't any. */ char ** fileman_completion (text, start, end) ! char *text; int start, end; { --- 2939,2953 ---- /* Tell the completer that we want a crack first. */ ! rl_attempted_completion_function = fileman_completion; } ! /* Attempt to complete on the contents of TEXT. START and END ! bound the region of rl_line_buffer that contains the word to ! complete. TEXT is the word to complete. We can use the entire ! contents of rl_line_buffer in case we want to do some simple ! parsing. Returnthe array of matches, or NULL if there aren't any. */ char ** fileman_completion (text, start, end) ! const char *text; int start, end; { *************** *** 2606,2620 **** directory. */ if (start == 0) ! matches = completion_matches (text, command_generator); return (matches); } ! /* Generator function for command completion. STATE lets us know whether ! to start from scratch; without any state (i.e. STATE == 0), then we ! start at the top of the list. */ char * command_generator (text, state) ! char *text; int state; { --- 2960,2974 ---- directory. */ if (start == 0) ! matches = rl_completion_matches (text, command_generator); return (matches); } ! /* Generator function for command completion. STATE lets us ! know whether to start from scratch; without any state ! (i.e. STATE == 0), then we start at the top of the list. */ char * command_generator (text, state) ! const char *text; int state; { *************** *** 2622,2628 **** char *name; ! /* If this is a new word to complete, initialize now. This includes ! saving the length of TEXT for efficiency, and initializing the index ! variable to 0. */ if (!state) { --- 2976,2982 ---- char *name; ! /* If this is a new word to complete, initialize now. This ! includes saving the length of TEXT for efficiency, and ! initializing the index variable to 0. */ if (!state) { *************** *** 2631,2635 **** } ! /* Return the next name which partially matches from the command list. */ while (name = commands[list_index].name) { --- 2985,2990 ---- } ! /* Return the next name which partially matches from the ! command list. */ while (name = commands[list_index].name) { *************** *** 2776,2780 **** char dir[1024], *s; ! s = getwd (dir); if (s == 0) { --- 3131,3135 ---- char dir[1024], *s; ! s = getcwd (dir, sizeof(dir) - 1); if (s == 0) { *************** *** 2787,2791 **** } ! /* The user wishes to quit using this program. Just set DONE non-zero. */ com_quit (arg) char *arg; --- 3142,3147 ---- } ! /* The user wishes to quit using this program. Just set DONE ! non-zero. */ com_quit (arg) char *arg; *************** *** 2835,2838 **** --- 3191,3195 ---- * notation, readline: Readline Bare Essentials. * readline, function: Basic Behavior. + * variables, readline: Readline Init File Syntax. * yanking text: Readline Killing Commands. *************** *** 2845,2855 **** * Menu: * abort (C-g): Miscellaneous Commands. ! * accept-line (Newline, Return): Commands For History. ! * alphabetic: Utility Functions. * backward-char (C-b): Commands For Moving. * backward-delete-char (Rubout): Commands For Text. * backward-kill-line (C-x Rubout): Commands For Killing. ! * backward-kill-word (M-DEL): Commands For Killing. * backward-word (M-b): Commands For Moving. * beginning-of-history (M-<): Commands For History. --- 3202,3217 ---- * Menu: + * _rl_digit_p: Utility Functions. + * _rl_digit_value: Utility Functions. + * _rl_lowercase_p: Utility Functions. + * _rl_to_lower: Utility Functions. + * _rl_to_upper: Utility Functions. + * _rl_uppercase_p: Utility Functions. * abort (C-g): Miscellaneous Commands. ! * accept-line (Newline or Return): Commands For History. * backward-char (C-b): Commands For Moving. * backward-delete-char (Rubout): Commands For Text. * backward-kill-line (C-x Rubout): Commands For Killing. ! * backward-kill-word (M-): Commands For Killing. * backward-word (M-b): Commands For Moving. * beginning-of-history (M-<): Commands For History. *************** *** 2862,2868 **** * clear-screen (C-l): Commands For Moving. * comment-begin: Readline Init File Syntax. ! * complete (TAB): Commands For Completion. * completion-query-items: Readline Init File Syntax. - * completion_matches: Completion Functions. * convert-meta: Readline Init File Syntax. * copy-backward-word (): Commands For Killing. --- 3224,3229 ---- * clear-screen (C-l): Commands For Moving. * comment-begin: Readline Init File Syntax. ! * complete (): Commands For Completion. * completion-query-items: Readline Init File Syntax. * convert-meta: Readline Init File Syntax. * copy-backward-word (): Commands For Killing. *************** *** 2873,2879 **** * delete-horizontal-space (): Commands For Killing. * digit-argument (M-0, M-1, ... M--): Numeric Arguments. - * digit_p: Utility Functions. - * digit_value: Utility Functions. - * ding: Utility Functions. * disable-completion: Readline Init File Syntax. * do-uppercase-version (M-a, M-b, M-X, ...): Miscellaneous Commands. --- 3234,3237 ---- *************** *** 2889,2898 **** * exchange-point-and-mark (C-x C-x): Miscellaneous Commands. * expand-tilde: Readline Init File Syntax. - * filename_completion_function: Completion Functions. * forward-backward-delete-char (): Commands For Text. * forward-char (C-f): Commands For Moving. * forward-search-history (C-s): Commands For History. * forward-word (M-f): Commands For Moving. - * free_undo_list: Allowing Undoing. * history-search-backward (): Commands For History. * history-search-forward (): Commands For History. --- 3247,3254 ---- *************** *** 2907,2911 **** * kill-whole-line (): Commands For Killing. * kill-word (M-d): Commands For Killing. - * lowercase_p: Utility Functions. * mark-modified-lines: Readline Init File Syntax. * menu-complete (): Commands For Completion. --- 3263,3266 ---- *************** *** 2914,2923 **** * non-incremental-forward-search-history (M-n): Commands For History. * non-incremental-reverse-search-history (M-p): Commands For History. - * numeric: Utility Functions. * output-meta: Readline Init File Syntax. * possible-completions (M-?): Commands For Completion. ! * prefix-meta (ESC): Miscellaneous Commands. * previous-history (C-p): Commands For History. ! * quoted-insert (C-q, C-v): Commands For Text. * re-read-init-file (C-x C-r): Miscellaneous Commands. * readline: Basic Behavior. --- 3269,3277 ---- * non-incremental-forward-search-history (M-n): Commands For History. * non-incremental-reverse-search-history (M-p): Commands For History. * output-meta: Readline Init File Syntax. * possible-completions (M-?): Commands For Completion. ! * prefix-meta (): Miscellaneous Commands. * previous-history (C-p): Commands For History. ! * quoted-insert (C-q or C-v): Commands For Text. * re-read-init-file (C-x C-r): Miscellaneous Commands. * readline: Basic Behavior. *************** *** 2926,2932 **** --- 3280,3289 ---- * revert-line (M-r): Miscellaneous Commands. * rl_add_defun: Function Naming. + * rl_add_funmap_entry: Associating Function Names and Bindings. * rl_add_undo: Allowing Undoing. + * rl_alphabetic: Utility Functions. * rl_already_prompted: Readline Variables. * rl_attempted_completion_function: Completion Variables. + * rl_attempted_completion_over: Completion Variables. * rl_basic_quote_characters: Completion Variables. * rl_basic_word_break_characters: Completion Variables. *************** *** 2943,2946 **** --- 3300,3304 ---- * rl_cleanup_after_signal: Readline Signal Handling. * rl_clear_message: Redisplay. + * rl_clear_pending_input: Character Input. * rl_clear_signals: Readline Signal Handling. * rl_complete <1>: Completion Functions. *************** *** 2953,2972 **** --- 3311,3343 ---- * rl_completion_entry_function <1>: Completion Variables. * rl_completion_entry_function: How Completing Works. + * rl_completion_matches: Completion Functions. * rl_completion_query_items: Completion Variables. + * rl_completion_type: Completion Variables. * rl_copy_keymap: Keymaps. * rl_copy_text: Modifying Text. + * rl_crlf: Redisplay. * rl_delete_text: Modifying Text. + * rl_deprep_term_function: Readline Variables. + * rl_deprep_terminal: Terminal Management. + * rl_ding: Utility Functions. * rl_directory_completion_hook: Completion Variables. * rl_discard_keymap: Keymaps. + * rl_dispatching: Readline Variables. * rl_display_match_list: Utility Functions. * rl_do_undo: Allowing Undoing. * rl_done: Readline Variables. + * rl_editing_mode: Readline Variables. * rl_end: Readline Variables. * rl_end_undo_group: Allowing Undoing. * rl_erase_empty_line: Readline Variables. * rl_event_hook: Readline Variables. + * rl_execute_next: Character Input. * rl_executing_keymap: Readline Variables. + * rl_executing_macro: Readline Variables. + * rl_expand_prompt: Redisplay. + * rl_explicit_arg: Readline Variables. * rl_extend_line_buffer: Utility Functions. * rl_filename_completion_desired: Completion Variables. + * rl_filename_completion_function: Completion Functions. * rl_filename_dequoting_function: Completion Variables. * rl_filename_quote_characters: Completion Variables. *************** *** 2975,2978 **** --- 3346,3350 ---- * rl_forced_update_display: Redisplay. * rl_free_line_state: Readline Signal Handling. + * rl_free_undo_list: Allowing Undoing. * rl_function_dumper: Associating Function Names and Bindings. * rl_function_of_keyseq: Associating Function Names and Bindings. *************** *** 2982,2987 **** * rl_get_keymap_by_name: Keymaps. * rl_get_keymap_name: Keymaps. ! * rl_getc: Utility Functions. * rl_getc_function: Readline Variables. * rl_ignore_completion_duplicates: Completion Variables. * rl_ignore_some_completions_function: Completion Variables. --- 3354,3361 ---- * rl_get_keymap_by_name: Keymaps. * rl_get_keymap_name: Keymaps. ! * rl_get_screen_size: Readline Signal Handling. ! * rl_getc: Character Input. * rl_getc_function: Readline Variables. + * rl_gnu_readline_p: Readline Variables. * rl_ignore_completion_duplicates: Completion Variables. * rl_ignore_some_completions_function: Completion Variables. *************** *** 2994,3000 **** --- 3368,3377 ---- * rl_invoking_keyseqs_in_map: Associating Function Names and Bindings. * rl_kill_text: Modifying Text. + * rl_last_func: Readline Variables. * rl_library_version: Readline Variables. * rl_line_buffer: Readline Variables. * rl_list_funmap_names: Associating Function Names and Bindings. + * rl_macro_bind: Miscellaneous Functions. + * rl_macro_dumper: Miscellaneous Functions. * rl_make_bare_keymap: Keymaps. * rl_make_keymap: Keymaps. *************** *** 3003,3006 **** --- 3380,3385 ---- * rl_modifying: Allowing Undoing. * rl_named_function: Associating Function Names and Bindings. + * rl_num_chars_to_read: Readline Variables. + * rl_numeric_arg: Readline Variables. * rl_on_new_line: Redisplay. * rl_on_new_line_with_prompt: Redisplay. *************** *** 3011,3054 **** * rl_possible_completions: Completion Functions. * rl_pre_input_hook: Readline Variables. * rl_prompt: Readline Variables. * rl_read_init_file: Binding Keys. ! * rl_read_key: Utility Functions. * rl_readline_name: Readline Variables. * rl_redisplay: Redisplay. * rl_redisplay_function: Readline Variables. * rl_reset_after_signal: Readline Signal Handling. * rl_reset_line_state: Redisplay. ! * rl_reset_terminal: Utility Functions. * rl_resize_terminal: Readline Signal Handling. * rl_restore_prompt: Redisplay. * rl_save_prompt: Redisplay. * rl_set_keymap: Keymaps. * rl_set_signals: Readline Signal Handling. * rl_special_prefixes: Completion Variables. * rl_startup_hook: Readline Variables. ! * rl_stuff_char: Utility Functions. * rl_terminal_name: Readline Variables. * rl_unbind_command_in_map: Binding Keys. * rl_unbind_function_in_map: Binding Keys. * rl_unbind_key: Binding Keys. * rl_unbind_key_in_map: Binding Keys. * self-insert (a, b, A, 1, !, ...): Commands For Text. * set-mark (C-@): Miscellaneous Commands. * show-all-if-ambiguous: Readline Init File Syntax. * start-kbd-macro (C-x (): Keyboard Macros. - * to_lower: Utility Functions. - * to_upper: Utility Functions. * transpose-chars (C-t): Commands For Text. * transpose-words (M-t): Commands For Text. ! * undo (C-_, C-x C-u): Miscellaneous Commands. * universal-argument (): Numeric Arguments. * unix-line-discard (C-u): Commands For Killing. * unix-word-rubout (C-w): Commands For Killing. * upcase-word (M-u): Commands For Text. - * uppercase_p: Utility Functions. - * username_completion_function: Completion Functions. * visible-stats: Readline Init File Syntax. * yank (C-y): Commands For Killing. ! * yank-last-arg (M-., M-_): Commands For History. * yank-nth-arg (M-C-y): Commands For History. * yank-pop (M-y): Commands For Killing. --- 3390,3443 ---- * rl_possible_completions: Completion Functions. * rl_pre_input_hook: Readline Variables. + * rl_prep_term_function: Readline Variables. + * rl_prep_terminal: Terminal Management. * rl_prompt: Readline Variables. + * rl_push_macro_input: Modifying Text. * rl_read_init_file: Binding Keys. ! * rl_read_key: Character Input. * rl_readline_name: Readline Variables. + * rl_readline_state: Readline Variables. * rl_redisplay: Redisplay. * rl_redisplay_function: Readline Variables. * rl_reset_after_signal: Readline Signal Handling. * rl_reset_line_state: Redisplay. ! * rl_reset_terminal: Terminal Management. * rl_resize_terminal: Readline Signal Handling. * rl_restore_prompt: Redisplay. * rl_save_prompt: Redisplay. + * rl_set_key: Binding Keys. + * rl_set_keyboard_input_timeout: Character Input. * rl_set_keymap: Keymaps. + * rl_set_paren_blink_timeout: Miscellaneous Functions. + * rl_set_prompt: Redisplay. + * rl_set_screen_size: Readline Signal Handling. * rl_set_signals: Readline Signal Handling. + * rl_show_char: Redisplay. * rl_special_prefixes: Completion Variables. * rl_startup_hook: Readline Variables. ! * rl_stuff_char: Character Input. * rl_terminal_name: Readline Variables. + * rl_tty_set_default_bindings: Terminal Management. * rl_unbind_command_in_map: Binding Keys. * rl_unbind_function_in_map: Binding Keys. * rl_unbind_key: Binding Keys. * rl_unbind_key_in_map: Binding Keys. + * rl_username_completion_function: Completion Functions. + * rl_variable_bind: Miscellaneous Functions. + * rl_variable_dumper: Miscellaneous Functions. * self-insert (a, b, A, 1, !, ...): Commands For Text. * set-mark (C-@): Miscellaneous Commands. * show-all-if-ambiguous: Readline Init File Syntax. * start-kbd-macro (C-x (): Keyboard Macros. * transpose-chars (C-t): Commands For Text. * transpose-words (M-t): Commands For Text. ! * undo (C-_ or C-x C-u): Miscellaneous Commands. * universal-argument (): Numeric Arguments. * unix-line-discard (C-u): Commands For Killing. * unix-word-rubout (C-w): Commands For Killing. * upcase-word (M-u): Commands For Text. * visible-stats: Readline Init File Syntax. * yank (C-y): Commands For Killing. ! * yank-last-arg (M-. or M-_): Commands For History. * yank-nth-arg (M-C-y): Commands For History. * yank-pop (M-y): Commands For Killing. *************** *** 3057,3107 ****  Tag Table: ! Node: Top1190 ! Node: Command Line Editing1789 ! Node: Introduction and Notation2440 ! Node: Readline Interaction4058 ! Node: Readline Bare Essentials5251 ! Node: Readline Movement Commands7032 ! Node: Readline Killing Commands7989 ! Node: Readline Arguments9895 ! Node: Searching10870 ! Node: Readline Init File12713 ! Node: Readline Init File Syntax13774 ! Node: Conditional Init Constructs23039 ! Node: Sample Init File25478 ! Node: Bindable Readline Commands28648 ! Node: Commands For Moving29692 ! Node: Commands For History30541 ! Node: Commands For Text33258 ! Node: Commands For Killing35261 ! Node: Numeric Arguments37228 ! Node: Commands For Completion38355 ! Node: Keyboard Macros40103 ! Node: Miscellaneous Commands40662 ! Node: Readline vi Mode43466 ! Node: Programming with GNU Readline45236 ! Node: Basic Behavior46204 ! Node: Custom Functions49530 ! Node: The Function Type50508 ! Node: Function Writing51353 ! Node: Readline Variables52437 ! Node: Readline Convenience Functions56649 ! Node: Function Naming57387 ! Node: Keymaps58615 ! Node: Binding Keys60329 ! Node: Associating Function Names and Bindings62903 ! Node: Allowing Undoing64746 ! Node: Redisplay67331 ! Node: Modifying Text69108 ! Node: Utility Functions70019 ! Node: Alternate Interface72799 ! Node: Readline Signal Handling76093 ! Node: Custom Completers81139 ! Node: How Completing Works81854 ! Node: Completion Functions84850 ! Node: Completion Variables87865 ! Node: A Short Completion Example95768 ! Node: Concept Index108074 ! Node: Function and Variable Index108828  End Tag Table --- 3446,3500 ----  Tag Table: ! Node: Top1164 ! Node: Command Line Editing1763 ! Node: Introduction and Notation2414 ! Node: Readline Interaction4032 ! Node: Readline Bare Essentials5219 ! Node: Readline Movement Commands7000 ! Node: Readline Killing Commands7957 ! Node: Readline Arguments9867 ! Node: Searching10903 ! Node: Readline Init File12859 ! Node: Readline Init File Syntax13920 ! Node: Conditional Init Constructs23842 ! Node: Sample Init File26367 ! Node: Bindable Readline Commands29537 ! Node: Commands For Moving30587 ! Node: Commands For History31436 ! Node: Commands For Text34294 ! Node: Commands For Killing36281 ! Node: Numeric Arguments38232 ! Node: Commands For Completion39360 ! Node: Keyboard Macros40892 ! Node: Miscellaneous Commands41451 ! Node: Readline vi Mode44244 ! Node: Programming with GNU Readline46062 ! Node: Basic Behavior47030 ! Node: Custom Functions50443 ! Node: Readline Typedefs51421 ! Node: Function Writing53050 ! Node: Readline Variables54134 ! Node: Readline Convenience Functions63133 ! Node: Function Naming64115 ! Node: Keymaps65367 ! Node: Binding Keys67123 ! Node: Associating Function Names and Bindings70049 ! Node: Allowing Undoing72294 ! Node: Redisplay74829 ! Node: Modifying Text77900 ! Node: Character Input79033 ! Node: Terminal Management80678 ! Node: Utility Functions81853 ! Node: Miscellaneous Functions83920 ! Node: Alternate Interface85512 ! Node: A Readline Example87135 ! Node: Readline Signal Handling89072 ! Node: Custom Completers94675 ! Node: How Completing Works95390 ! Node: Completion Functions98388 ! Node: Completion Variables101392 ! Node: A Short Completion Example110763 ! Node: Concept Index123288 ! Node: Function and Variable Index124110  End Tag Table diff -Nrc2 readline-4.1/doc/readline.ps readline-4.2/doc/readline.ps *** readline-4.1/doc/readline.ps Wed Mar 1 14:53:16 2000 --- readline-4.2/doc/readline.ps Mon Apr 16 11:05:46 2001 *************** *** 1,6 **** %!PS-Adobe-2.0 ! %%Creator: dvips(k) 5.82 Copyright 1998 Radical Eye Software %%Title: readline.dvi ! %%Pages: 56 %%PageOrder: Ascend %%BoundingBox: 0 0 612 792 --- 1,6 ---- %!PS-Adobe-2.0 ! %%Creator: dvips(k) 5.86 Copyright 1999 Radical Eye Software %%Title: readline.dvi ! %%Pages: 62 %%PageOrder: Ascend %%BoundingBox: 0 0 612 792 *************** *** 9,13 **** %DVIPSCommandLine: dvips -D 300 -t letter -o readline.ps readline.dvi %DVIPSParameters: dpi=300, compressed ! %DVIPSSource: TeX output 2000.03.01:1453 %%BeginProcSet: texc.pro %! --- 9,13 ---- %DVIPSCommandLine: dvips -D 300 -t letter -o readline.ps readline.dvi %DVIPSParameters: dpi=300, compressed ! %DVIPSSource: TeX output 2001.04.16:1105 %%BeginProcSet: texc.pro %! *************** *** 21,27 **** exch round exch]setmatrix}N/@landscape{/isls true N}B/@manualfeed{ statusdict/manualfeed true put}B/@copies{/#copies X}B/FMat[1 0 0 -1 0 0] ! N/FBB[0 0 0 0]N/nn 0 N/IE 0 N/ctr 0 N/df-tail{/nn 8 dict N nn begin /FontType 3 N/FontMatrix fntrx N/FontBBox FBB N string/base X array ! /BitMaps X/BuildChar{CharBuilder}N/Encoding IE N end A{/foo setfont}2 array copy cvx N load 0 nn put/ctr 0 N[}B/sf 0 N/df{/sf 1 N/fntrx FMat N df-tail}B/dfs{div/sf X/fntrx[sf 0 0 sf neg 0 0]N df-tail}B/E{pop nn A --- 21,27 ---- exch round exch]setmatrix}N/@landscape{/isls true N}B/@manualfeed{ statusdict/manualfeed true put}B/@copies{/#copies X}B/FMat[1 0 0 -1 0 0] ! N/FBB[0 0 0 0]N/nn 0 N/IEn 0 N/ctr 0 N/df-tail{/nn 8 dict N nn begin /FontType 3 N/FontMatrix fntrx N/FontBBox FBB N string/base X array ! /BitMaps X/BuildChar{CharBuilder}N/Encoding IEn N end A{/foo setfont}2 array copy cvx N load 0 nn put/ctr 0 N[}B/sf 0 N/df{/sf 1 N/fntrx FMat N df-tail}B/dfs{div/sf X/fntrx[sf 0 0 sf neg 0 0]N df-tail}B/E{pop nn A *************** *** 51,55 **** SI restore userdict/eop-hook known{eop-hook}if showpage}N/@start{ userdict/start-hook known{start-hook}if pop/VResolution X/Resolution X ! 1000 div/DVImag X/IE 256 array N 2 string 0 1 255{IE S A 360 add 36 4 index cvrs cvn put}for pop 65781.76 div/vsize X 65781.76 div/hsize X}N /p{show}N/RMat[1 0 0 -1 0 0]N/BDot 260 string N/Rx 0 N/Ry 0 N/V{}B/RV/v{ --- 51,55 ---- SI restore userdict/eop-hook known{eop-hook}if showpage}N/@start{ userdict/start-hook known{start-hook}if pop/VResolution X/Resolution X ! 1000 div/DVImag X/IEn 256 array N 2 string 0 1 255{IEn S A 360 add 36 4 index cvrs cvn put}for pop 65781.76 div/vsize X 65781.76 div/hsize X}N /p{show}N/RMat[1 0 0 -1 0 0]N/BDot 260 string N/Rx 0 N/Ry 0 N/V{}B/RV/v{ *************** *** 70,85 **** TeXDict begin 40258431 52099146 1000 300 300 (readline.dvi) @start ! %DVIPSBitmapFont: Fa cmti10 10.95 1 ! /Fa 1 47 df<127012F8A212F012E005057B840E>46 D E ! %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fb cmbxti10 14.4 1 ! /Fb 1 47 df<120E123FEA7F80A212FFA21300127E123C0909798815>46 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fc cmmi9 9 1 ! /Fc 1 59 df<126012F0A2126004047D830B>58 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fd cmtt9 9 53 ! /Fd 53 127 df<126012F0AD12601200A4126012F0A212600417789614>33 D35 D46 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fb cmsl9 9 1 ! /Fb 1 121 df<383FC7E038078380EB0200EA038413C8EA01D8EA00F05B7F1201133812 ! 02487EEA081E123838FC3FC013107F8F14>120 D E ! %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fc cmsltt10 9 4 ! /Fc 4 78 df45 D48 ! D<134013E0EA01C01203120F123D12111201EA0380A6EA0700A6120EEAFFE0A20B177B96 ! 14>I<381F81F813C1380FC3E0EA0EC213C6A213CE13CC381CCDC013DD13D9A213F1A238 ! 38E3801303A53870070038FC0FC0A215177F9614>77 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fd cmtt9 9 46 ! /Fd 46 127 df<126012F0AD12601200A4126012F0A212600417789614>33 D35 DI<127012F812FCA2127C120C1218 123012E012C0060A798414>44 DI<127012F8A3127005057984 ! 14>I48 D<1203A25A5A123F12F712471207AEEA7FF0A20C177C ! 9614>I<1306131E133E13F8EA01F0EA03C0EA0F80EA1F00123C12F85A7E123C121FEA0F ! 80EA03C0EA01F0EA00F8133E131E13060F157E9514>60 D<12C012F07E123E7EEA0780EA ! 03E0EA01F0EA0078133E131E133E1378EA01F0EA03E0EA0780EA1F00123E12F85A12C00F ! 157E9514>62 DIIII<3801F180EA07FFEA0E1FEA1C ! 071238EA7003A348C7FCA738700380A338380700121CEA0E0EEA07FCEA01F011177F9614 ! >III76 ! D<38FC1F80A2007C1300EA7637A4EA7777A2EA7367A313E7EA71C7A2EA7007A638F80F80 ! A211177F9614>I<38FE3F80A2383E0E00123BA4138E1239A213CEA31238A213EE136EA4 ! 133E12FEA211177F9614>I82 DI<387FFF80B5FCEAE1C3A43801C000AFEA0FF8A211177F9614>I< ! EAFFE0A21200B3A712FFA20B1D7F9914>93 D95 ! D97 D<12FCA2121CA513F8EA1DFEEA1F07EA1E03001C1380EB01C0 ! A6EB0380001E1300EA1F0EEA1DFCEA0CF81217809614>II<137EA2130E ! A5EA07CEEA0FFEEA1C3EEA301EEA700E12E0A61270EA301EEA383E381FEFC0EA07CF1217 ! 7F9614>II<13FCEA01FEEA038EEA07041300A3EA7FFE12 ! FFEA0700ACEAFFF8A20F177F9614>II<12FCA2121CA51378EA1DFEEA1F86EA1E07121CAA38FF ! 8FE0A21317809614>I<1206120FA21206C7FCA4B4FCA21207ACEAFFF8A20D187C9714>I< ! 12FCA2121CA5EBFF80A2EB1C005B5B5BEA1DC0EA1FE0A2EA1E70EA1C38133C131C7F38FF ! 1F80A21117809614>107 DIIIIIIII<1206120EA4EA7FFC12FFEA0E00A8130EA3131CEA07F8EA01F0 ! 0F157F9414>II<38FE3F80A238 ! 3C1E00EA1C1CA36C5AA3EA0630EA0770A36C5AA311107F8F14>I<38FE3F80A238700700 ! EA380EA3EA39CEA3EA1B6C121AA3EA1E7CA2EA0E3811107F8F14>II<38 ! FE3F80A2381C0E005BA2120E5BA212071330A2EA0370A25B1201A25BA3485A12730077C7 ! FC127E123C11187F8F14>II126 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fe cmsl9 9 2 ! /Fe 2 121 df<1270A212F0126004047D830B>46 D<383FC7E038078380EB0200EA0384 ! 13C8EA01D8EA00F05B7F120113381202487EEA081E123838FC3FC013107F8F14>120 ! D E %EndDVIPSBitmapFont %DVIPSBitmapFont: Ff cmr9 9 39 --- 93,142 ---- EA3FF8EA7FFCEAF39EEA638CEA0380A30F107E9214>I<127012F812FCA2127C120C1218 123012E012C0060A798414>44 DI<127012F8A3127005057984 ! 14>I<1203A25A5A123F12F712471207AEEA7FF0A20C177C9614>49 ! D<1306131E133E13F8EA01F0EA03C0EA0F80EA1F00123C12F85A7E123C121FEA0F80EA03 ! C0EA01F0EA00F8133E131E13060F157E9514>60 D<12C012F07E123E7EEA0780EA03E0EA ! 01F0EA0078133E131E133E1378EA01F0EA03E0EA0780EA1F00123E12F85A12C00F157E95 ! 14>62 DIII<3801F180EA07FFEA0E1FEA1C071238EA7003A348C7FCA738 ! 700380A338380700121CEA0E0EEA07FCEA01F011177F9614>67 D<38FC1F80A2007C1300 ! EA7637A4EA7777A2EA7367A313E7EA71C7A2EA7007A638F80F80A211177F9614>77 ! D<38FE3F80A2383E0E00123BA4138E1239A213CEA31238A213EE136EA4133E12FEA21117 ! 7F9614>I82 D93 ! D95 D97 D<12FCA2121CA513F8EA1DFEEA ! 1F07EA1E03001C1380EB01C0A6EB0380001E1300EA1F0EEA1DFCEA0CF81217809614>I< ! EA03F8EA0FFEEA1C0EEA3804EA7000126012E0A412601270EA380EEA1C1EEA0FFCEA03F0 ! 0F107E8F14>I<137EA2130EA5EA07CEEA0FFEEA1C3EEA301EEA700E12E0A61270EA301E ! EA383E381FEFC0EA07CF12177F9614>II<13FCEA01FEEA ! 038EEA07041300A3EA7FFE12FFEA0700ACEAFFF8A20F177F9614>II<12FCA2121CA51378EA1D ! FEEA1F86EA1E07121CAA38FF8FE0A21317809614>I<1206120FA21206C7FCA4B4FCA212 ! 07ACEAFFF8A20D187C9714>I<12FCA2121CA5EBFF80A2EB1C005B5B5BEA1DC0EA1FE0A2 ! EA1E70EA1C38133C131C7F38FF1F80A21117809614>107 DIIIIIIII<1206120EA4EA7FFC12FFEA ! 0E00A8130EA3131CEA07F8EA01F00F157F9414>II<38FE3F80A2383C1E00EA1C1CA36C5AA3EA0630EA0770A36C5AA311 ! 107F8F14>I<38FE3F80A238700700EA380EA3EA39CEA3EA1B6C121AA3EA1E7CA2EA0E38 ! 11107F8F14>II<38FE3F80A2381C0E005BA2120E5BA212071330A2EA03 ! 70A25B1201A25BA3485A12730077C7FC127E123C11187F8F14>II126 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fe cmti9 9 1 ! /Fe 1 47 df<1230127812F0126005047C830C>46 D E %EndDVIPSBitmapFont %DVIPSBitmapFont: Ff cmr9 9 39 *************** *** 246,302 **** 19>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fi cmtt10 12 24 ! /Fi 24 122 df<13E0A538F0E1E0EAFCE7387EEFC0381FFF00EA07FCEA01F0EA07FCEA1F ! FF387EEFC038FCE7E0EAF0E13800E000A513157D991A>42 D67 D69 D<387FFFFCB5FC7E380E00 ! 1CA51400A2EB0380A3EA0FFFA3EA0E03A390C7FCA8EA7FE012FF127F161E7F9D1A>I73 D<387F03F838FF87FC387F03F8381C01 ! E0EB03C01480EB07005B131E131C5B13785B7F121DEA1FDC139C130EEA1E0F7F001C1380 ! 1303EB01C0A2EB00E0A21470007F13FC38FF81FE387F00FC171E7F9D1A>75 ! DI80 D<38FF01FEA3381C0070A3001E13F0000E13E0A3380701 ! C0A438038380A43801C700A4EA00C613EEA3136C137CA21338171E7F9D1A>86 ! D97 D99 DII<12FEA3120EA6133EEB ! FF80000F13C013C1EB80E01300120EAC38FFE3FE13E713E3171E7F9D1A>104 ! DI< ! 387CE0E038FFFBF8EA7FFF381F1F1CEA1E1EA2EA1C1CAC387F1F1F39FF9F9F80397F1F1F ! 00191580941A>109 DIII<387F81F838FF8FFC387F9FFE ! 3803FE1EEBF80CEBE000A25B5BAAEA7FFFB5FC7E17157F941A>114 ! D<487E1203A6387FFFE0B5FCA238038000AA1470A43801C1E013FF6C1380EB3F00141C7F ! 9B1A>116 D<38FE0FE0A3EA0E00AD1301EA0F033807FFFE7EEA00FC17157F941A>I<387F ! C7FC00FF13FE007F13FC380E00E0A3380701C0A338038380A33801C700A3EA00EEA3137C ! A2133817157F941A>I<387FC7FC00FF13FE007F13FC380E00E0A27EEB01C013811203EB ! 8380EA01C3A2EBC700EA00E7A213E61366136E133CA31338A3137813701230EA78E01271 ! EA7FC06C5A001EC7FC17207F941A>121 D E ! %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fj cmmi10 10.95 1 ! /Fj 1 59 df<127012F8A3127005057C840D>58 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fk cmsltt10 10.95 6 ! /Fk 6 102 df<1206120FEA1F80120FA21203EA0700A25A120E123C127C12F01260090E ! 769B18>39 D<387FFFC0B512E0A26C13C013047C8F18>45 D67 D<3907E01F80000FEB3FC0000714803903B02E ! 00146EA214CE380730DC1331149CA21333141C000E5B13371336133E133C131848C65AA6 ! 38FE03F800FF7F00FE5B1A1C7F9B18>77 D<126012F0A37E1278A3127C123CA3123E121E ! A3121F7EA313801207A313C01203A413E01201A313F0120013600C24789F18>92 ! D<13F8EA07FE487E381F0780EA3C03387801C0127012E0A2B5FCA2148000E0C7FCA21303 ! 3870078038780F00EA3FFE6C5AEA07F012147B9318>101 D E ! %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fl cmbx12 13.14 52 ! /Fl 52 122 df<123C127E12FFA4127E123C08087C8711>46 D48 D<131C133C13FC12FFA21200B3AA --- 241,290 ---- 19>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fi cmtt10 12 29 ! /Fi 29 122 df<13E0A538F0E1E0EAFCE7387EEFC0381FFF00EA07FCEA01F0EA07FCEA1F ! FF387EEFC038FCE7E0EAF0E13800E000A513157D991A>42 D69 ! D<387FFFFCB5FC7E380E001CA51400A2EB0380A3EA0FFFA3EA0E03A390C7FCA8EA7FE012 ! FF127F161E7F9D1A>I73 ! D<387F03F838FF87FC387F03F8381C01E0EB03C01480EB07005B131E131C5B13785B7F12 ! 1DEA1FDC139C130EEA1E0F7F001C13801303EB01C0A2EB00E0A21470007F13FC38FF81FE ! 387F00FC171E7F9D1A>75 DI<387FFFC0B512E0A26C13C013047D7E1A>95 D97 D<12FEA3120EA6133EEBFF80000F13E0EBC1F0EB8070EB00 ! 38120E141CA7000F13381478EB80F0EBC1E0EBFFC0000E138038063E00161E7F9D1A>I< ! EBFF80000313C0000F13E0EA1F01383C00C04813001270A25AA51270A2007813707E381F ! 01F0380FFFE0000313C03800FE0014157D941A>III< ! EB07E0EB1FF0EB3FF8EB7878EBF030EBE000A4387FFFF0B5FCA23800E000AF383FFF8048 ! 13C06C1380151E7F9D1A>I<3801F87C3807FFFE5A381E078C381C0380383801C0A5381C ! 0380EA1E07381FFF005BEA39F80038C7FCA27E381FFF8014E04813F83878007C0070131C ! 48130EA40070131C0078133C003E13F8381FFFF0000713C00001130017217F941A>I<12 ! FEA3120EA6133EEBFF80000F13C013C1EB80E01300120EAC38FFE3FE13E713E3171E7F9D ! 1A>I ! I<12FEA3120EA6EB0FFCEB1FFEEB0FFCEB03C0EB0780EB0F00131E5B5B13FC120F13DE13 ! 8F380E07801303EB01C014E0EB00F038FFE3FE14FF14FE181E7F9D1A>107 ! DI<387CE0E038FFFBF8EA7FFF381F1F1CEA ! 1E1EA2EA1C1CAC387F1F1F39FF9F9F80397F1F1F00191580941A>IIII<3801F8E0EA07FEEA0FFFEA1E07EA3C03EA78011270EAE000A613011270EA ! 7803123CEA1E0FEA0FFFEA07FCEA01F0C7FCA8EB0FFEA317207E941A>I<387F81F838FF ! 8FFC387F9FFE3803FE1EEBF80CEBE000A25B5BAAEA7FFFB5FC7E17157F941A>I<3807FB ! 80EA1FFF127FEA7807EAE003A30078C7FCEA7FC0EA1FFCEA07FE38003F801307386001C0 ! 12E0A2EAF00338FC0780B51200EAEFFEEAE3F812157C941A>I<487E1203A6387FFFE0B5 ! FCA238038000AA1470A43801C1E013FF6C1380EB3F00141C7F9B1A>I<38FE0FE0A3EA0E ! 00AD1301EA0F033807FFFE7EEA00FC17157F941A>I<387FC7FC00FF13FE007F13FC380E ! 00E0A3380701C0A338038380A33801C700A3EA00EEA3137CA2133817157F941A>I<387F ! C7FC00FF13FE007F13FC380E00E0A27EEB01C013811203EB8380EA01C3A2EBC700EA00E7 ! A213E61366136E133CA31338A3137813701230EA78E01271EA7FC06C5A001EC7FC17207F ! 941A>121 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fj cmbx12 13.14 52 ! /Fj 52 122 df<123C127E12FFA4127E123C08087C8711>46 D48 D<131C133C13FC12FFA21200B3AA *************** *** 402,454 **** >I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fm cmsl10 10.95 28 ! /Fm 28 122 df12 ! D45 D<0007B512F83900F800780178133815185B1508A53901E0 ! 0800A314181438EBFFF83803C0301410A491C7FC485AA648C8FC7FEAFFFC1D1F7E9E1E> ! 70 D<3A07FF803FE03A00F8001F000178130C5D4913205D5D4AC7FC1402140848485A5C ! 146014F013E1EBE4F83803C878EBD07CEBE03CEBC03E141E141F48487E81140781140381 ! 380F00016D487E39FFF00FFE231F7E9E23>75 D97 D<1207123F120F7EA2120EA65A137CEA1D83381E0180001C13C0EB00E05A14F0A538 ! 7001E0A214C013031480EB0700EAE80EEACC38EA83E014207B9F19>I<13FEEA0383380E ! 0780121C0038130090C7FC12785AA45AA37E5BEA70026C5AEA1C18EA07E011147D9314> ! I<1438EB01F8EB00781438A21470A614E013FCEA0382EA0601121CEA3C00383801C01278 ! 12F0A438E00380A412F0EA700738380F00381C37803807C7E015207D9F19>I<13F8EA07 ! 0EEA0E07121C383803801278127012F0A2B5FC00F0C7FC5AA46C5AEA7002EA3004EA1C18 ! EA07E011147D9314>II<140EEB3E11EBE1A33801C1C238 ! 0381E0EA07801301120FA3380703C01480EB8700EA04FC48C7FCA21218121CEA0FFF14C0 ! 14E0381800F04813305A5AA3006013606C13C0381C0700EA07FC181F809417>I<13E012 ! 0712011200A2485AA6485AEB8F80EB90E013A0EBC0601380000713E01300A5380E01C0A6 ! 381C0380001E13C038FF8FF014207E9F19>II<13E0120712011200 ! A2485AA6485AEB81FCEB80F014C0EB81801400EA07045B13181338137C131C120E7FA213 ! 0F7F1480EA1C03381E07C038FF8FF016207E9F18>107 D<13E0120712011200A2EA01C0 ! A6EA0380A6EA0700A6120EA65A121EEAFF800B207F9F0C>I<390387C07C391F98618639 ! 07A072073903C03403EB80380007EB7807EB0070A5000EEBE00EA64848485A001EEBE01E ! 3AFFCFFCFFC022147E9326>I<38038F80381F90E0EA07A03803C0601380000713E01300 ! A5380E01C0A6381C0380001E13C038FF8FF014147E9319>I<13FCEA0387380E0180381C ! 00C04813E0A24813F012F0A438E001E0A214C0130300F0138038700700EA380E6C5AEA07 ! E014147D9317>I ! IIII<1380EA0100A35A5A5A121EEAFFF8EA0E00 ! A45AA65A1310A41320A2EA1840EA0F800D1C7C9B12>I<381C0380EAFC1FEA3C07EA1C03 ! A238380700A6EA700EA4131EA25BEA305E381F9F8011147B9319>I<38FF83F8381E00E0 ! 001C13C01480121E380E01005B13025B12075BA25BEA039013A013E05B5B120190C7FC15 ! 147C9318>I<39FF9FE1FC393C078070391C030060148015401580EA0E0790380D810013 ! 09EB19C21311380F21C4EA0720EB40C814E8EB80F0A26C485A1460000213401E147C9321 ! >I<381FF0FF3803C0780001137014403800E0C0EBE180EB73001376133CA2131C132E13 ! 4E1387EA0107380203801204380C01C0383C03E038FE07FC18147F9318>I<390FF83F80 ! 3901E00E00EBC00C140813E000005B143014205C13705CA20171C7FC1339133A133E133C ! 133813181310A25BA25BEA70C0EAF08000F1C8FC12E61278191D809318>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fn cmr8 8 41 ! /Fn 41 124 df<126012F0A212701210A21220A21240A2040A7D960A>39 D45 D<1206120E12FE120EB1EAFFE00B157D9412>49 D<13101338A3135CA3138EA3EA0107A238020380A33807FFC0EA0401A2380800E0A20018 --- 390,513 ---- >I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fk cmsl10 10.95 46 ! /Fk 46 122 df12 ! DI ! 45 D<137EEA01C338030180000713C0EA0E0014E05AA2EA3C0112381278A538F003C0A5 ! 1480130712E01400A2130E1260EA701CEA3038EA3870EA0FC0131F7C9D17>48 ! D<13181338EA01F8EA0E701200A513E0A6EA01C0A6EA0380A6EA07001380EAFFFC0E1E7B ! 9D17>I<1408140C141C143CA2147C147E149EA2EB011EA21302801304A21308A2011013 ! 8014071320A2EB7FFF90384007C0EB8003A2EA0100A21202EC01E01206001F130339FF80 ! 1FFE1F207F9F22>65 D<0007B5FC3900F803C090387801E0EC00F04913F8A515F03801E0 ! 01EC03E015C0EC0F809038FFFE009038E00F803903C003C0EC01E015F0A21400A2485A14 ! 01A215E01403EC07C0390F000F80EC3E00B512F01D1F7E9E20>II<0007B57E3900F801E0903878007081497F151E150E150FA348481480A6 ! 484814005DA3151E153E4848133C5DA25D4A5A4A5A260F000FC7FC143CB512F0211F7E9E ! 23>I<0007B512FC3900F8007C0178131C150C5B1504A414043901E00800A31438EBFFF8 ! EBE0383803C010A4EC00081510485AA21520A2156015C0380F00011407B612801E1F7E9E ! 1F>I<0007B512F83900F800780178133815185B1508A53901E00800A314181438EBFFF8 ! 3803C0301410A491C7FC485AA648C8FC7FEAFFFC1D1F7E9E1E>I<3807FF803800F80013 ! 78A25BA6485AA6485AA6485AA648C7FC7FEAFFF0111F7E9E10>73 ! D<3A07FF803FE03A00F8001F000178130C5D4913205D5D4AC7FC1402140848485A5C1460 ! 14F013E1EBE4F83803C878EBD07CEBE03CEBC03E141E141F48487E81140781140381380F ! 00016D487E39FFF00FFE231F7E9E23>75 D<3807FFE0D800FCC7FC1378A25BA6485AA648 ! 5AA41580EC0100EA0780A25C14021406140E380F001E147CB512FC191F7E9E1C>I78 DI< ! 0007B5FC3900F803C090387800F015785B157CA41578484813F815F0EC01E0EC03C0EC0F ! 00EBFFFCD803C0C7FCA6485AA648C8FC7FEAFFF81E1F7E9E1F>I<3807FFFE3900F80780 ! 90387801E0EC00F05B15F8A415F03801E00115E0EC03C0EC0780EC1E00EBFFF03803C038 ! 80141E140EA2140F48485AA51501D80F0013029038800F8239FFF8078CC7EA01F020207E ! 9E22>82 DI<003FB512F0383C07800030 ! 1430126039400F0010A212C01280A3D8001E1300A65BA65BA65B7F383FFFE01C1F7A9E21 ! >I<39FFF00FF8391F0003E06CEB01801400001EEB0100A6481302A6485BA600705BA25C ! A200785B1238001813C06C48C7FCEA0706EA01F81D20799E22>I<3BFFF07FF81FF03B1F ! 000FC007C0001E903907800380001FED01006C1502140F5EEC17C002135B142301805C00 ! 0713435E14C3913883E0401481D981015B13C1D803C213E193C7FC13C415F2EBC80015F4 ! EA01F015F85B5D5B15605B000014402C207A9E2F>87 D97 D<1207123F120F7EA2120EA65A137CEA1D83381E0180001C13C0EB00E05A14 ! F0A5387001E0A214C013031480EB0700EAE80EEACC38EA83E014207B9F19>I<13FEEA03 ! 83380E0780121C0038130090C7FC12785AA45AA37E5BEA70026C5AEA1C18EA07E011147D ! 9314>I<1438EB01F8EB00781438A21470A614E013FCEA0382EA0601121CEA3C00383801 ! C0127812F0A438E00380A412F0EA700738380F00381C37803807C7E015207D9F19>I<13 ! F8EA070EEA0E07381C038012381278127012F0B5FC00F0C7FCA25AA46C5AEA7002EA3004 ! EA1C18EA07E011147D9314>II<140EEB3E11EBE1A33801 ! C1C2380381E0EA07801301120FA3380703C01480EB8700EA04FC48C7FCA21218121CEA0F ! FF14C014E0381800F04813305A5AA3006013606C13C0381C0700EA07FC181F809417>I< ! 13E0120712011200A2485AA6485AEB8F80EB90E013A0EBC0601380000713E01300A5380E ! 01C0A6381C0380001E13C038FF8FF014207E9F19>II<13E0120712 ! 011200A2485AA6485AEB81FCEB80F014C0EB81801400EA07045B13181338137C131C120E ! 7FA2130F7F1480EA1C03381E07C038FF8FF016207E9F18>107 D<13E0120712011200A2 ! EA01C0A6EA0380A6EA0700A6120EA65A121EEAFF800B207F9F0C>I<390387C07C391F98 ! 61863907A072073903C03403EB80380007EB7807EB0070A5000EEBE00EA64848485A001E ! EBE01E3AFFCFFCFFC022147E9326>I<38038F80381F90E0EA07A03803C0601380000713 ! E01300A5380E01C0A6381C0380001E13C038FF8FF014147E9319>I<13FCEA0387380E01 ! 80381C00C04813E0A24813F012F0A438E001E0A214C0130300F0138038700700EA380E6C ! 5AEA07E014147D9317>IIII< ! EA01F9EA0607EA080312181301EA3802EA3C00121F13F0EA07FCEA01FEEA001FEA400713 ! 03A212601306EAF004EAC818EA87E010147F9312>I<1380EA0100A35A5A5A121EEAFFF8 ! EA0E00A45AA65A1310A41320A2EA1840EA0F800D1C7C9B12>I<381C0380EAFC1FEA3C07 ! EA1C03A238380700A6EA700EA4131EA25BEA305E381F9F8011147B9319>I<38FF83F838 ! 1E00E0001C13C01480121E380E01005B13025B12075BA25BEA039013A013E05B5B120190 ! C7FC15147C9318>I<39FF9FE1FC393C078070391C030060148015401580EA0E0790380D ! 81001309EB19C21311380F21C4EA0720EB40C814E8EB80F0A26C485A1460000213401E14 ! 7C9321>I<381FF0FF3803C0780001137014403800E0C0EBE180EB73001376133CA2131C ! 132E134E1387EA0107380203801204380C01C0383C03E038FE07FC18147F9318>I<390F ! F83F803901E00E00EBC00C140813E000005B143014205C13705CA20171C7FC1339133A13 ! 3E133C133813181310A25BA25BEA70C0EAF08000F1C8FC12E61278191D809318>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fl cmti10 10.95 20 ! /Fl 20 122 df12 ! D<127012F8A212F012E005057B840E>46 D ! 97 D<137EEA01C138030080EA0E07121E001C1300003CC7FC5AA35AA45B12701302EA30 ! 0CEA1830EA07C011147C9315>99 D<1478EB03F8EB0070A414E0A4EB01C0A213F1EA0389 ! 38070780EA0E03121C123C383807001278A3EAF00EA31420EB1C40A2EA703C135C38308C ! 80380F070015207C9F17>I<137CEA01C2EA0701120E121C123CEA3802EA780CEA7FF0EA ! 78005AA4EA7001A21302EA380CEA1830EA07C010147C9315>I103 D<13C0EA01E0A213C0C7FC ! A7120E12131223EA4380EA4700A21287120EA35AA3EA38401380A21270EA31001232121C ! 0B1F7C9E0E>105 D108 D<391C0F80F0392630C318394740640C903880680EEB0070 ! A2008E495A120EA34848485AA3ED70803A3803807100A215E115623970070064D8300313 ! 3821147C9325>I<381C0F80382630C0384740601380EB0070A2008E13E0120EA3381C01 ! C0A3EB038400381388A2EB0708EB031000701330383001C016147C931A>I<137CEA01C3 ! 38030180000E13C0121E001C13E0123C1278A338F003C0A3EB07801400EA700F130EEA30 ! 18EA1870EA07C013147C9317>I<3801C1E0380262183804741C1378EB701EA2EA08E012 ! 00A33801C03CA3143838038078147014E0EBC1C038072380EB1E0090C7FCA2120EA45AA2 ! B47E171D809317>I114 D<13FCEA0302EA0601EA0C03130713061300EA0F8013F0 ! EA07F8EA03FCEA003E130E1270EAF00CA2EAE008EA4010EA2060EA1F8010147D9313>I< ! EA018013C0EA0380A4EA0700A2EAFFF0EA0700120EA45AA45AA31320EA7040A21380A2EA ! 3100121E0C1C7C9B0F>I<000E13C0001313E0382301C0EA4381EA4701A238870380120E ! A3381C0700A31410EB0E201218A2381C1E40EA0C263807C38014147C9318>I<380E0380 ! EA1307002313C0EA4383EA4701130000871380120EA3381C0100A31302A25BA25BEA0E30 ! EA03C012147C9315>I<000EEBC1C0001313E3392301C3E0384381C1384701C015603987 ! 038040120EA3391C070080A3EC0100A21306EB0F02000C5B380E13083803E1F01B147C93 ! 1E>I<000E13C0001313E0382301C0EA4381EA4701A238870380120EA3381C0700A4130E ! 1218A2EA1C1EEA0C3CEA07DCEA001CA25B12F05BEAE060485AEA4380003EC7FC131D7C93 ! 16>121 D E ! %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fm cmr8 8 29 ! /Fm 29 118 df<126012F0A212701210A21220A21240A2040A7D960A>39 D45 D<1206120E12FE120EB1EAFFE00B157D9412>49 D<13101338A3135CA3138EA3EA0107A238020380A33807FFC0EA0401A2380800E0A20018 *************** *** 460,522 **** E0EA1C00146014201410A3EB0400A3130CEA1FFCEA1C0C13041408A2130014181410A214 3014F0B5FC15177F9618>II74 D76 D<00FEEB03F8001E14C000171305A338138009A23811C011A33810E021A2EB7041A3 ! EB3881A2EB1D01A2130EA2123839FE040FF81D177F9620>I<00FC13FE001E1338001F13 ! 101217EA1380EA11C0A2EA10E013701338A2131C130E130F1307EB0390EB01D0A2EB00F0 ! 14701430123800FE131017177F961A>I80 D82 DI<387FFFF8386038 ! 1800401308A200801304A300001300AF3803FF8016177F9619>I<38FF80FE381C003814 ! 10B06C132012066C13403801818038007E0017177F961A>I<12FCA212C0B3AB12FCA206 ! 217D980A>91 D97 D<12F81238A8EA39F0EA3E0CEA380613077F1480A41400 ! 5B1306EA361CEA21F011177F9614>II<133E130EA8EA07CEEA1C3EEA300E1270126012 ! E0A412601270EA301EEA182E3807CF8011177F9614>IIII<1203EA0780A2EA0300C7FCA5EA1F801203AF1243EAE30012E712 ! 7C091D82960B>106 D<12F81238A8133E13381330134013801239EA3FC0EA39E0123813 ! F01378133CA2EAFE7F10177F9613>I<12F81238B3A312FE07177F960A>I110 DIIIII<1208A31218A21238EAFFC0 ! EA3800A71340A4EA1C80EA0F000A147F930E>II<38FEFE7C383838381410133C001C1320134C381E4E60380ECE40138700 ! 0713801303A200031300EA0201160E7F8D19>119 DII123 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fo cmsy9 9 2 ! /Fo 2 106 df<13801201EA0300A31206A25AA35AA35AA25AA35AA21260A37EA27EA37E A37EA27EA3EA0180120009267D9B0F>104 D<12C0A21260A37EA27EA37EA37EA27EA3EA 0180A2EA0300A31206A25AA35AA35AA25AA35AA209267E9B0F>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fp cmcsc10 10.95 8 ! /Fp 8 118 df73 D79 DI<3803F02038 ! 0C0C60381803E0EA30005A146012E01420A36C13007E127CEA7F80EA3FFC6CB4FC000713 ! 80000113C038000FE013031301EB00F014707EA46C136014E06C13C038F8018038C60300 ! EA81FC14217C9F1C>83 D<397FF807FE390FE001F0D807C013C06C6C6C5A000149C7FCEB ! F0023800F806EB78046D5AEB3E18EB1F106D5A14C0130713036D7E497EEB06F8EB0478EB ! 087CEB183EEB101EEB201F496C7EEBC007496C7ED801007F486D7E481300391F8001F83A ! FFC007FF80211F7E9E25>88 D103 D<38FC01FC381E007014201217EA1380A2EA11C0EA10E0A213701338A2131C ! 130E1307A2EB03A0EB01E0A213001460123800FE132016177E961C>110 D<38FF81FC381C00701420B0000C1340120E6C138038018300EA007C16177E961C>117 ! D E %EndDVIPSBitmapFont %DVIPSBitmapFont: Fq cmbx12 17.28 34 --- 519,620 ---- E0EA1C00146014201410A3EB0400A3130CEA1FFCEA1C0C13041408A2130014181410A214 3014F0B5FC15177F9618>II76 D<00FEEB03F8001E14C000171305A338138009A23811C011A3 ! 3810E021A2EB7041A3EB3881A2EB1D01A2130EA2123839FE040FF81D177F9620>I80 D82 DI<387FFFF83860381800401308A200801304A300001300AF3803FF ! 8016177F9619>I<12FCA212C0B3AB12FCA206217D980A>91 D97 ! D<12F81238A8EA39F0EA3E0CEA380613077F1480A414005B1306EA361CEA21F011177F96 ! 14>II101 D<1203EA0780A2EA0300C7FCA5EA1F801203AF1243EAE300 ! 12E7127C091D82960B>106 D<12F81238A8133E13381330134013801239EA3FC0EA39E0 ! 123813F01378133CA2EAFE7F10177F9613>I110 DII114 ! DI<1208A31218A21238EAFFC0EA3800A71340A4EA1C80EA0F000A147F93 ! 0E>II E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fn cmsy9 9 2 ! /Fn 2 106 df<13801201EA0300A31206A25AA35AA35AA25AA35AA21260A37EA27EA37E A37EA27EA3EA0180120009267D9B0F>104 D<12C0A21260A37EA27EA37EA37EA27EA3EA 0180A2EA0300A31206A25AA35AA35AA25AA35AA209267E9B0F>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fo cmsltt10 10.95 29 ! /Fo 29 122 df<1206120FEA1F80120FA21203EA0700A25A120E123C127C12F01260090E ! 769B18>39 D<387FFFC0B512E0A26C13C013047C8F18>45 D<133E13FF000313803807C3 ! C0EA0F01000E13E0EA1C00123C003813F014705AA34813E0A4EB01C0A2130300F01380EA ! 7007EB0F00EA781E6C5AEA1FF85BEA07C0141C7C9B18>48 D<13181338A2137813F81203 ! 120F137012041200A413E0A6EA01C0A6EA7FFE12FF127F0F1C7B9B18>I67 D<3807FFC014E014F03801C0F814 ! 78143C141CEA0380141EA2140EA33807001CA4143C1438120E147014F0EB01E0EB03C013 ! 07387FFF8038FFFE00EA7FF8171C7F9B18>I<0007B5FC5A7E3801C007A3140638038000 ! A2EB818014C0A213FF481380A21303A2140090C7FC120E140C141CA4387FFFF8B5FC7E18 ! 1C7F9B18>I74 D76 D<3907E01F80000FEB3FC0000714803903 ! B02E00146EA214CE380730DC1331149CA21333141C000E5B13371336133E133C131848C6 ! 5AA638FE03F800FF7F00FE5B1A1C7F9B18>I<126012F0A37E1278A3127C123CA3123E12 ! 1EA3121F7EA313801207A313C01203A413E01201A313F0120013600C24789F18>92 ! D<387FFFC0B512E0A26C13C013047E7F18>95 D97 D<127EA3120EA45A137CEA1DFF001F13801383381E01C0123CEB00E012 ! 38A4387801C0A2EB0380A2EB0F00EA7C1FEAFFFCEAEFF8EA63E0131C7C9B18>I100 D<13F8EA07FE487E381F ! 0780EA3C03387801C0127012E0A2B5FCA2148000E0C7FCA213033870078038780F00EA3F ! FE6C5AEA07F012147B9318>III<14C0EB01E013031301EB00C01400A4EBFFC0A31301A2EB0380A6 ! EB0700A6130EA65BA2EA6038EAF078B45A5BEA3F8013277F9C18>106 ! DII<13FCEA03FF000F1380 ! EA1F07383C03C0EA7801007013E0EAE000A4EB01C0A2EB0380EAF007EB0F00EA7C3EEA3F ! FC6C5AEA07E013147C9318>111 D113 D<381FE1F8EBE7FCEBEFFE3800FE1EEBFC0C3801F8005B5B5BA3485AA6EA ! FFFC7F5B17147E9318>II<387E07E0EAFE0FEA7E07EA0E00A2381C01C0A638380380A41307131F383FFF ! E06C13F03807E3E014147D9318>117 D<38FF87F8138F1387383800E0EB01C0A3148013 ! E3EA39F31233EB7700A212371376EA3666136EEA3C7CA2EA383815147C9318>119 ! D<381FE3FC13E713E33803C3C000011380EBE700EA00EE13FC137C1338137813FCEA01DC ! EA038E12071307120E38FF1FE0EB9FF0EB1FE016147E9318>I<380FF1FE381FF9FF380F ! F1FE3803807013C0000113E0A213C114C0A23800E380A2EBE700A213E6136E136C137C13 ! 78A21370A25BA2485A12F3EAF780B4C7FC5A1278181E7F9318>I ! E ! %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fp cmcsc10 10.95 12 ! /Fp 12 121 df<1318A2133CA3134EA213CF1387A238010380A2000313C0EA0201A23807 ! FFE0EA0400A2481370A2001813380038137838FE01FF18177F961C>97 ! D99 ! D101 DII105 D<38FC01FC381E007014201217EA1380A2EA11C0EA10E0A213701338A2131C13 ! 0E1307A2EB03A0EB01E0A213001460123800FE132016177E961C>110 ! D<13FE38038380380E00E0481370003C1378003813380078133C0070131C00F0131EA700 ! 70131C0078133C00381338003C1378001C13706C13E0380383803800FE0017177E961D> ! II115 D<38FF81FC381C00701420B0000C1340120E6C138038018300EA007C16177E961C>117 ! D<38FF80FE381F0070000E13606C1340EB80803803C100EA01C3EA00E213F4137813387F ! 133E134E13C7EB8780380103C0EA0201380600E0000413F0000C1370003C137800FE13FF ! 18177F961C>120 D E %EndDVIPSBitmapFont %DVIPSBitmapFont: Fq cmbx12 17.28 34 *************** *** 603,613 **** %EndDVIPSBitmapFont %DVIPSBitmapFont: Fr cmsy10 10.95 1 ! /Fr 1 14 df<14FF010713E090381F00F80178131E01E01307D80180EB018048C812C000 ! 061560481530A248151848150CA2481506A4481503A900601506A46C150CA26C15186C15 ! 30A26C15606C15C06C6CEB0180D800E0EB07000178131E011F13F8903807FFE0010090C7 ! FC282B7EA02D>13 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fs cmbx12 14.4 55 ! /Fs 55 122 df<123C127FEAFF80A213C0A3127F123E1200A2EA0180A3EA0300A2120612 0E5A5A12100A157B8813>44 D<121C127FA2EAFF80A3EA7F00A2121C09097B8813>46 D<130E131E137EEA07FE12FFA212F81200B3ABB512FEA317277BA622>49 --- 701,711 ---- %EndDVIPSBitmapFont %DVIPSBitmapFont: Fr cmsy10 10.95 1 ! /Fr 1 14 df<14FE903807FFC090381F01F0903878003C01E0130ED80180130348C7EA01 ! 800006EC00C0481560A2481530481518A248150CA4481506A90060150CA46C1518A26C15 ! 306C1560A26C15C06CEC01806C6CEB0300D800E0130E0178133C90381F01F0903807FFC0 ! D900FEC7FC272B7DA02E>13 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fs cmbx12 14.4 54 ! /Fs 54 122 df<123C127FEAFF80A213C0A3127F123E1200A2EA0180A3EA0300A2120612 0E5A5A12100A157B8813>44 D<121C127FA2EAFF80A3EA7F00A2121C09097B8813>46 D<130E131E137EEA07FE12FFA212F81200B3ABB512FEA317277BA622>49 *************** *** 625,691 **** 8091C7FC127EA3EAFE02EB1FF0EB3FFCEB603EEB801F00FF14809038000FC0A24814E0A4 127EA4123E003F14C07EEC1F80D80F8013003807E07E6CB45A6C5B38003FC01B277DA622 ! >I<1238123E003FB512F0A34814E015C0158015003870000EA25C485B5C5CC6485AA249 ! 5A130791C7FC5B5B131E133EA2137E137CA213FCA41201A76C5A13701C297CA822>I57 ! D65 DI<91387FE003903907FFFC07011FEBFF0F90397FF00F9F ! 9039FF0001FFD801FC7F4848147F4848143F4848141F485A160F485A1607127FA290C9FC ! 5AA97E7F1607123FA26C7E160E6C7E6C6C141C6C6C143C6C6C14786CB4EB01F090397FF0 ! 07C0011FB512800107EBFE009038007FF028297CA831>IIII<91387FE003 ! 903907FFFC07011FEBFF0F90397FF00F9F9039FF0001FFD801FC7F484880484880484880 ! 485A82485A82127FA290CAFC5AA892B512F87E7F03001300123FA26C7EA26C7E6C7E6C7E ! 6C7E6CB45B90387FF007011FB5129F0107EBFE0F9039007FF0032D297CA835>II< ! B512F0A33803FC00B3B1B512F0A314297EA819>I75 DIII< ! ECFFC0010F13FC90383F807F9039FE001FC0D801F8EB07E048486D7E48486D7E000F8148 ! 486D7EA24848147FA2007F168090C8123FA34816C0AA6C16806D147FA2003F1600A26C6C ! 14FEA26C6C495A6C6C495A6C6C495A6C6C495A6C6C495A90263FC0FFC7FC90380FFFFC01 ! 0013C02A297CA833>IIII<9038FF80600003EBF0E000 ! 0F13F8381F80FD383F001F003E1307481303A200FC1301A214007EA26C140013C0EA7FFC ! EBFFE06C13F86C13FE80000714806C14C0C6FC010F13E0EB007FEC1FF0140F140700E013 ! 03A46C14E0A26C13076C14C0B4EB0F80EBE03F39E3FFFE0000E15B38C01FF01C297CA825 ! >I<007FB71280A39039807F807FD87C00140F00781507A20070150300F016C0A2481501 ! A5C791C7FCB3A490B612C0A32A287EA72F>IIII89 D<3803FF80000F13F0381F01FC383F80FE147F801580EA1F00C7FCA4EB3FFF3801FC3FEA 0FE0EA1F80EA3F00127E5AA4145F007E13DF393F839FFC381FFE0F3803FC031E1B7E9A21 --- 723,787 ---- 8091C7FC127EA3EAFE02EB1FF0EB3FFCEB603EEB801F00FF14809038000FC0A24814E0A4 127EA4123E003F14C07EEC1F80D80F8013003807E07E6CB45A6C5B38003FC01B277DA622 ! >I ! 57 D65 DI<91387FE003903907FFFC07011FEBFF0F90397FF0 ! 0F9F9039FF0001FFD801FC7F4848147F4848143F4848141F485A160F485A1607127FA290 ! C9FC5AA97E7F1607123FA26C7E160E6C7E6C6C141C6C6C143C6C6C14786CB4EB01F09039 ! 7FF007C0011FB512800107EBFE009038007FF028297CA831>IIII<91387F ! E003903907FFFC07011FEBFF0F90397FF00F9F9039FF0001FFD801FC7F48488048488048 ! 4880485A82485A82127FA290CAFC5AA892B512F87E7F03001300123FA26C7EA26C7E6C7E ! 6C7E6C7E6CB45B90387FF007011FB5129F0107EBFE0F9039007FF0032D297CA835>III75 DII ! III< ! ECFFC0010F13FC90383FC0FF9039FE001FC048486D7ED803F0EB03F000078148486D7E48 ! 486D7EA24848147FA2007F1680A290C8123FA24816C0AA6C16806D147FA2003F1600A26C ! 6C14FE143E3A0FE07F81FC00079038C1C1F83A03F18063F0D801F9EB67E0D800FFEB3FC0 ! 90263FC07FC7FC90380FFFFC01004913C0EC003C811601ED1F8316FF6F1380A21700816F ! 5A6F5A6F5A2A357CA833>II<9038FF80600003EBF0E0 ! 000F13F8381F80FD383F001F003E1307481303A200FC1301A214007EA26C140013C0EA7F ! FCEBFFE06C13F86C13FE80000714806C14C0C6FC010F13E0EB007FEC1FF0140F140700E0 ! 1303A46C14E0A26C13076C14C0B4EB0F80EBE03F39E3FFFE0000E15B38C01FF01C297CA8 ! 25>I<007FB71280A39039807F807FD87C00140F00781507A20070150300F016C0A24815 ! 01A5C791C7FCB3A490B612C0A32A287EA72F>IIII89 D<3803FF80000F13F0381F01FC383F80FE147F801580EA1F00C7FCA4EB3FFF3801FC3FEA 0FE0EA1F80EA3F00127E5AA4145F007E13DF393F839FFC381FFE0F3803FC031E1B7E9A21 *************** *** 731,736 **** EA74F0EA3FE0EA0F8020277F9A23>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Ft cmtt10 10.95 90 ! /Ft 90 127 df<127012F8B012701200A5127012F8A31270051C779B18>33 DI --- 827,832 ---- EA74F0EA3FE0EA0F8020277F9A23>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Ft cmtt10 10.95 91 ! /Ft 91 127 df<127012F8B012701200A5127012F8A31270051C779B18>33 DI *************** *** 783,788 **** IIII<3801F1C0EA03FD EA0FFFEA1F0FEA1C03123813011270A290C7FC5AA5EB0FF0131F130F387001C0A2130312 38A2EA1C07EA1F0FEA0FFFEA03FDEA01F1141C7E9B18>I<387F07F038FF8FF8387F07F0 --- 879,884 ---- IIII<3801F1C0EA03FD EA0FFFEA1F0FEA1C03123813011270A290C7FC5AA5EB0FF0131F130F387001C0A2130312 38A2EA1C07EA1F0FEA0FFFEA03FDEA01F1141C7E9B18>I<387F07F038FF8FF8387F07F0 *************** *** 812,864 **** 03001E13C0387F07F000FF13F8007F13F0151C7F9B18>I<38FE03F8EAFF07EAFE03381C 01C0EA1E03000E1380EA0F0700071300A2EA038EA2EA01DCA3EA00F8A21370A9EA01FC48 ! 7E6C5A151C7F9B18>I91 ! D<126012F0A27E1278127C123CA2123E121E121F7EA27F12077F1203A27F12017F12007F ! 1378A2137C133C133E131EA2131F7F14801307A2EB030011247D9F18>II<387FFFC0B512E0A26C13C013047E7F18>95 ! D<1206121E123E12381270A212E0A312F812FC127CA21238070E789E18>II<127E12FE127E120EA5133EEBFF80000F13C0EBC1E0 ! 1380EB0070120E1438A6000F1370A2EB80E013C1EBFFC0000E138038063E00151C809B18 ! >IIIII< ! 3801E1F03807FFF85A381E1E30381C0E00487EA5EA1C0EEA1E1EEA1FFC5BEA39E00038C7 ! FC7EEA1FFEEBFFC04813E0387801F038700070481338A4007813F0EA7E03381FFFC06C13 ! 803801FC00151F7F9318>I<127E12FE127E120EA5133EEBFF80000F13C013C1EB80E013 ! 00120EAB387FC7FC38FFE7FE387FC7FC171C809B18>II<1338137CA313381300A4EA0FFCA3EA00 ! 1CB3A4EA6038EAF078EAFFF0EA7FE0EA3F800E277E9C18>I<127E12FE127E120EA5EB3F ! F0A3EB0780EB0F00131E5B5B5BEA0FF87F139C130EEA0E0F7FEB038014C0387FC7F812FF ! 127F151C7F9B18>II<38F9C1C038FFF7F013 ! FF383E3E38EA3C3CA2EA3838AB38FE3E3EEB7E7EEB3E3E1714809318>IIII<3801F380EA07FBEA1FFFEA3E1FEA380FEA7007A2EAE003A6 ! EA7007A2EA380FEA3C1FEA1FFFEA0FFBEA03E3EA0003A7EB1FF0EB3FF8EB1FF0151E7E93 ! 18>I<38FF0FC0EB3FE0EB7FF0EA07F0EBE060EBC0005BA290C7FCA9EAFFFC7F5B14147E ! 9318>II<487E1203A4387FFFC0B5 ! FCA238038000A9144014E0A33801C1C013FF6C1380EB3E0013197F9818>I<387E07E0EA ! FE0FEA7E07EA0E00AC1301EA0F033807FFFC6C13FE3801FCFC1714809318>I<387F8FF0 ! 00FF13F8007F13F0381C01C0380E0380A338070700A3138FEA038EA3EA01DCA3EA00F8A2 ! 137015147F9318>I<38FF07F8138F1307383800E0A4381C01C0137113F9A213D9EA1DDD ! 000D1380A3138DEA0F8FA23807070015147F9318>I<387F8FF0139F138F380F0700EA07 ! 8EEA039EEA01DC13F81200137013F07FEA01DCEA039E138EEA0707000E1380387F8FF000 ! FF13F8007F13F015147F9318>I<387F8FF000FF13F8007F13F0380E01C0EB0380A21207 ! EB0700A2EA0387A2138EEA01CEA213CC120013DC1378A31370A313F05B1279EA7BC0EA7F ! 806CC7FC121E151E7F9318>I<383FFFF05AA2387001E0EB03C0EB078038000F00131E5B ! 13F8485AEA03C0485A380F0070121E5A5AB512F0A314147F9318>I ! I<126012F0B3B012600424769F18>I<127CB4FC13C01203C67EAB7FEB7FC0EB3FE0A2EB ! 7FC0EBF0005BABEA03C012FF90C7FC127C13247E9F18>II E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fu cmr10 10.95 78 ! /Fu 78 123 df<90381F83E09038F06E303901C07878380380F8903800F03048EB7000A7 B612803907007000B2383FE3FF1D20809F1B>11 D<133FEBE0C0EA01C0380381E0EA0701 A290C7FCA6B512E0EA0700B2383FC3FC1620809F19>II<38FE03F8EAFF07EAFE03381C 01C0EA1E03000E1380EA0F0700071300A2EA038EA2EA01DCA3EA00F8A21370A9EA01FC48 ! 7E6C5A151C7F9B18>I<383FFFE05AA2387001C01303EB07801400C65A131E131C133C5B ! 137013F0485A5B1203485A90C7FC5A001E13E0121C123C5A1270B5FCA3131C7E9B18>I< ! EAFFF8A3EAE000B3ACEAFFF8A30D24779F18>I<126012F0A27E1278127C123CA2123E12 ! 1E121F7EA27F12077F1203A27F12017F12007F1378A2137C133C133E131EA2131F7F1480 ! 1307A2EB030011247D9F18>II<387FFFC0 ! B512E0A26C13C013047E7F18>95 D<1206121E123E12381270A212E0A312F812FC127CA2 ! 1238070E789E18>II<127E12FE127E12 ! 0EA5133EEBFF80000F13C0EBC1E01380EB0070120E1438A6000F1370A2EB80E013C1EBFF ! C0000E138038063E00151C809B18>IIIII<3801E1F03807FFF85A381E1E30381C0E00487EA5EA1C ! 0EEA1E1EEA1FFC5BEA39E00038C7FC7EEA1FFEEBFFC04813E0387801F038700070481338 ! A4007813F0EA7E03381FFFC06C13803801FC00151F7F9318>I<127E12FE127E120EA513 ! 3EEBFF80000F13C013C1EB80E01300120EAB387FC7FC38FFE7FE387FC7FC171C809B18> ! II<1338 ! 137CA313381300A4EA0FFCA3EA001CB3A4EA6038EAF078EAFFF0EA7FE0EA3F800E277E9C ! 18>I<127E12FE127E120EA5EB3FF0A3EB0780EB0F00131E5B5B5BEA0FF87F139C130EEA ! 0E0F7FEB038014C0387FC7F812FF127F151C7F9B18>II<38F9C1C038FFF7F013FF383E3E38EA3C3CA2EA3838AB38FE3E3EEB7E7EEB ! 3E3E1714809318>III< ! EA7E3E38FEFF80007F13C0380FC1E01380EB0070120E1438A6000F1370A2EB80E013C1EB ! FFC0000E1380EB3E0090C7FCA7EA7FC0487E6C5A151E809318>I<3801F380EA07FBEA1F ! FFEA3E1FEA380FEA7007A2EAE003A6EA7007A2EA380FEA3C1FEA1FFFEA0FFBEA03E3EA00 ! 03A7EB1FF0EB3FF8EB1FF0151E7E9318>I<38FF0FC0EB3FE0EB7FF0EA07F0EBE060EBC0 ! 005BA290C7FCA9EAFFFC7F5B14147E9318>II<487E1203A4387FFFC0B5FCA238038000A9144014E0A33801C1C013FF6C1380 ! EB3E0013197F9818>I<387E07E0EAFE0FEA7E07EA0E00AC1301EA0F033807FFFC6C13FE ! 3801FCFC1714809318>I<387F8FF000FF13F8007F13F0381C01C0380E0380A338070700 ! A3138FEA038EA3EA01DCA3EA00F8A2137015147F9318>I<38FF07F8138F1307383800E0 ! A4381C01C0137113F9A213D9EA1DDD000D1380A3138DEA0F8FA23807070015147F9318> ! I<387F8FF0139F138F380F0700EA078EEA039EEA01DC13F81200137013F07FEA01DCEA03 ! 9E138EEA0707000E1380387F8FF000FF13F8007F13F015147F9318>I<387F8FF000FF13 ! F8007F13F0380E01C0EB0380A21207EB0700A2EA0387A2138EEA01CEA213CC120013DC13 ! 78A31370A313F05B1279EA7BC0EA7F806CC7FC121E151E7F9318>I<383FFFF05AA23870 ! 01E0EB03C0EB078038000F00131E5B13F8485AEA03C0485A380F0070121E5A5AB512F0A3 ! 14147F9318>II<126012F0B3B012600424769F18>I<127CB4FC13C0 ! 1203C67EAB7FEB7FC0EB3FE0A2EB7FC0EBF0005BABEA03C012FF90C7FC127C13247E9F18 ! >II E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fu cmr10 10.95 77 ! /Fu 77 123 df<90381F83E09038F06E303901C07878380380F8903800F03048EB7000A7 B612803907007000B2383FE3FF1D20809F1B>11 D<133FEBE0C0EA01C0380381E0EA0701 A290C7FCA6B512E0EA0700B2383FC3FC1620809F19>III<13801203120F12F31203B3A6EA ! 07C0EAFFFE0F1E7C9D17>IIII<13801203120F12F31203B3A6EA ! 07C0EA7FFE0F1E7C9D17>IIII<90380FE0109038381C309038E002703803C00139078000F048C71270121E ! 15305A1510127C127800F81400A7EC3FFEEC01F000781300127C123CA27EA27E6C7E3903 ! C001703900E002309038380C1090380FF0001F217E9F24>I<39FFF07FF8390F000780AD ! 90B5FCEB0007AF39FFF07FF81D1F7E9E22>II< ! 3807FFC038003E00131EB3A3122012F8A3EAF01CEA403CEA6038EA1070EA0FC012207F9E ! 17>I<39FFF007FC390F0003E0EC0180150014025C5C5C5C5C5C49C7FC5B497E130FEB13 ! C0EB21E01341EB80F0EB0078A28080A280EC0780A2EC03C015E015F039FFF01FFE1F1F7E ! 9E23>I ! IIIII< ! B57E380F00F0143C8080A21580A41500A2141E5C14F0EBFF80EB01C0EB0070A280143CA3 ! 143EA31504143F141FEC0F0839FFF00788C7EA01F01E207E9E21>82 D<3803F040380C0CC0EA1803EA3001EA6000A212E01440A36C13007E127CEA7F80EA3FF8 6CB4FC00071380C613C0EB1FE013031301EB00F014707EA46C136014E06C13C038F80180 --- 1003,1023 ---- 001440A3EC0020A31540A315C01401EC0380140FB6FC1B1F7E9E1F>II<90380FE02090387818609038E004E03803800238070001481300001E1460 ! A25A1520127C127800F81400A7EC7FFCEC03E000781301127C123CA27EA27E7E38038002 ! 3900E00460903878182090380FE0001E217D9F24>I<39FFF07FF8390F000780AD90B5FC ! EB0007AF39FFF07FF81D1F7E9E22>II<39FFF0 ! 07FC390F0003E0EC0180150014025C5C5C5C5C5C49C7FC5B497E130FEB13C0EB21E01341 ! EB80F0EB0078A28080A280EC0780A2EC03C015E015F039FFF01FFE1F1F7E9E23>75 ! DI ! IIII82 D<3803F040380C0CC0EA1803EA3001EA6000A212E01440A36C13007E127CEA7F80EA3FF8 6CB4FC00071380C613C0EB1FE013031301EB00F014707EA46C136014E06C13C038F80180 *************** *** 939,943 **** 40A3EAB85CEAFC7EA2EA7C3EEA381C0F0E7A9F17>I<12FFA21203B3B3A512FFA2082D80 A10D>I<120812101220A21240A21280A312B812FCA2127C1238060E7D9F0D>96 ! DI<121C12FC121CAA137CEA1D87381E0180EB00 C0001C13E01470A21478A6147014F014E0001E13C0381A018038198700EA107C15207E9F --- 1035,1039 ---- 40A3EAB85CEAFC7EA2EA7C3EEA381C0F0E7A9F17>I<12FFA21203B3B3A512FFA2082D80 A10D>I<120812101220A21240A21280A312B812FCA2127C1238060E7D9F0D>96 ! DI<121C12FC121CAA137CEA1D87381E0180EB00 C0001C13E01470A21478A6147014F014E0001E13C0381A018038198700EA107C15207E9F *************** *** 945,977 **** 0100EA0706EA01F811147F9314>III<137CEA01C6EA030F1207EA0E061300A7EAFFF0EA0E00B2EA7FE0 ! 1020809F0E>I<14E03803E330EA0E3CEA1C1C38380E00EA780FA5EA380E6C5AEA1E38EA ! 33E00020C7FCA21230A2EA3FFE381FFF8014C0383001E038600070481330A4006013606C ! 13C0381C03803803FC00141F7F9417>I<121C12FC121CAA137C1386EA1D03001E1380A2 ! 121CAE38FF8FF014207E9F19>I<1238127CA31238C7FCA6121C12FC121CB1EAFF80091F ! 7F9E0C>I<13E0EA01F0A3EA00E01300A61370EA07F012001370B3A31260EAF06013C0EA ! 6180EA3F000C28829E0E>I<121C12FC121CAAEB1FE0EB0780EB060013045B5B5B136013 ! E0EA1DF0EA1E70EA1C38133C131C7F130F7F148014C038FF9FF014207E9F18>I<121C12 ! FC121CB3ABEAFF8009207F9F0C>I<391C3E03E039FCC30C30391D039038391E01E01CA2 ! 001C13C0AE3AFF8FF8FF8021147E9326>IIII<3801F04038070CC0EA0E02EA1C03EA38011278127012F0A612 ! 7012781238EA1C03EA0C05EA0709EA01F1EA0001A8EB0FF8151D7F9318>III<1202A31206A2120EA2123EEAFFF8EA0E00AB1304A5EA07081203EA01F00E1C ! 7F9B12>I<381C0380EAFC1FEA1C03AE1307120CEA061B3803E3F014147E9319>I<38FF83 ! F8383E00E0001C13C06C1380A338070100A21383EA0382A2EA01C4A213E4EA00E8A21370 ! A3132015147F9318>I<39FF9FE1FC393C078070391C030060EC8020000E1440A214C0D8 ! 0704138014E0A239038861001471A23801D032143A143E3800E01CA2EB6018EB40081E14 ! 7F9321>I<38FF87F8381E03C0380E0180EB0300EA0702EA0384EA01C813D8EA00F01370 ! 137813F8139CEA010E1202EA060738040380000C13C0003C13E038FE07FC16147F9318> ! I<38FF83F8383E00E0001C13C06C1380A338070100A21383EA0382A2EA01C4A213E4EA00 ! E8A21370A31320A25BA3EAF080A200F1C7FC1262123C151D7F9318>II E %EndDVIPSBitmapFont %DVIPSBitmapFont: Fv cmbx12 20.736 14 --- 1041,1073 ---- 0100EA0706EA01F811147F9314>III<137CEA01C6EA030F1207EA0E061300A7EAFFF0EA0E00B2EA7FE010 ! 20809F0E>I<14E03803E330EA0E3CEA1C1C38380E00EA780FA5EA380E6C5AEA1E38EA33 ! E00020C7FCA21230A2EA3FFE381FFF8014C0383001E038600070481330A4006013606C13 ! C0381C03803803FC00141F7F9417>I<121C12FC121CAA137C1386EA1D03001E1380A212 ! 1CAE38FF8FF014207E9F19>I<1238127CA31238C7FCA6121C12FC121CB1EAFF80091F7F ! 9E0C>I<13E0EA01F0A3EA00E01300A61370EA07F012001370B3A31260EAF06013C0EA61 ! 80EA3F000C28829E0E>I<121C12FC121CAAEB1FE0EB0780EB060013045B5B5B136013E0 ! EA1DF0EA1E70EA1C38133C131C7F130F7F148014C038FF9FF014207E9F18>I<121C12FC ! 121CB3ABEAFF8009207F9F0C>I<391C3E03E039FCC30C30391D019018001EEBE01CA200 ! 1C13C0AE3AFF8FF8FF8021147E9326>IIII<3801F04038070CC0EA0E02EA1C03EA38011278127012F0A61270 ! 12781238EA1C03EA0C05EA0709EA01F1EA0001A8EB0FF8151D7F9318>III<1202A31206A2120EA2123EEAFFF8EA0E00AB1304A5EA07081203EA01F00E1C7F ! 9B12>I<381C0380EAFC1FEA1C03AE1307120CEA061B3803E3F014147E9319>I<38FF83F8 ! 383E00E0001C13C06C1380A338070100A21383EA0382A2EA01C4A213E4EA00E8A21370A3 ! 132015147F9318>I<39FF9FE1FC393C078070391C030060EC8020000E1440A214C0D807 ! 04138014E0A239038861001471A23801D032143A143E3800E01CA2EB6018EB40081E147F ! 9321>I<38FF87F8381E03C0380E0180EB0300EA0702EA0384EA01C813D8EA00F0137013 ! 7813F8139CEA010E1202EA060738040380000C13C0003C13E038FE07FC16147F9318>I< ! 38FF83F8383E00E0001C13C06C1380A338070100A21383EA0382A2EA01C4A213E4EA00E8 ! A21370A31320A25BA3EAF080A200F1C7FC1262123C151D7F9318>II E %EndDVIPSBitmapFont %DVIPSBitmapFont: Fv cmbx12 20.736 14 *************** *** 1028,1272 **** %%EndSetup %%Page: 1 1 ! 1 0 bop 75 693 a Fv(GNU)33 b(Readline)h(Library)p 75 ! 743 1800 17 v 936 791 a Fu(Edition)17 b(4.1,)c(for)i ! Ft(Readline)f(Library)g Fu(V)l(ersion)i(4.1.)1609 845 ! y(Jan)o(uary)f(2000)75 2467 y Fs(Brian)23 b(F)-6 b(o)n(x,)23 b(F)-6 b(ree)23 b(Soft)n(w)n(are)f(F)-6 b(oundation)75 2534 y(Chet)22 b(Ramey)-6 b(,)23 b(Case)e(W)-6 b(estern)23 b(Reserv)n(e)f(Univ)n(ersit)n(y)p 75 2570 1800 9 v eop %%Page: 2 2 ! 2 1 bop 75 250 a Fu(This)14 b(do)q(cumen)o(t)h(describ)q(es)g(the)f ! (GNU)g(Readline)i(Library)l(,)e(a)g(utilit)o(y)h(whic)o(h)f(aids)g(in)h ! (the)f(consistency)75 305 y(of)h(user)g(in)o(terface)h(across)e (discrete)i(programs)e(that)h(need)h(to)e(pro)o(vide)i(a)f(command)g ! (line)i(in)o(terface.)75 373 y(Published)g(b)o(y)f(the)f(F)l(ree)g ! (Soft)o(w)o(are)f(F)l(oundation)75 427 y(59)h(T)l(emple)h(Place,)f ! (Suite)i(330,)75 482 y(Boston,)d(MA)h(02111)f(USA)75 ! 549 y(P)o(ermission)j(is)f(gran)o(ted)g(to)f(mak)o(e)h(and)g (distribute)i(v)o(erbatim)d(copies)i(of)f(this)h(man)o(ual)f(pro)o ! (vided)h(the)75 604 y(cop)o(yrigh)o(t)e(notice)h(and)f(this)h(p)q (ermission)g(notice)g(are)f(preserv)o(ed)h(on)f(all)h(copies.)75 ! 671 y(P)o(ermission)c(is)h(gran)o(ted)e(to)g(cop)o(y)h(and)g (distribute)h(mo)q(di\014ed)g(v)o(ersions)f(of)f(this)h(man)o(ual)g ! (under)h(the)f(con-)75 726 y(ditions)k(for)e(v)o(erbatim)h(cop)o(ying,) g(pro)o(vided)h(that)e(the)h(en)o(tire)h(resulting)g(deriv)o(ed)g(w)o ! (ork)e(is)h(distributed)75 781 y(under)h(the)f(terms)g(of)g(a)f(p)q (ermission)j(notice)f(iden)o(tical)h(to)e(this)g(one.)75 ! 848 y(P)o(ermission)i(is)g(gran)o(ted)f(to)g(cop)o(y)h(and)f (distribute)i(translations)f(of)f(this)h(man)o(ual)g(in)o(to)f(another) ! g(lan-)75 903 y(guage,)e(under)h(the)f(ab)q(o)o(v)o(e)g(conditions)i (for)d(mo)q(di\014ed)j(v)o(ersions,)e(except)h(that)f(this)h(p)q ! (ermission)g(notice)75 958 y(ma)o(y)f(b)q(e)i(stated)f(in)h(a)f (translation)g(appro)o(v)o(ed)g(b)o(y)g(the)g(F)l(ree)h(Soft)o(w)o(are) d(F)l(oundation.)75 2661 y(Cop)o(yrigh)o(t)301 2660 y(c)289 ! 2661 y Fr(\015)i Fu(1988-1999)e(F)l(ree)i(Soft)o(w)o(are)f(F)l (oundation,)h(Inc.)p eop %%Page: 1 3 1 2 bop 75 -58 a Fu(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1077 ! b(1)75 183 y Fq(1)41 b(Command)28 b(Line)e(Editing)137 ! 299 y Fu(This)16 b(c)o(hapter)f(describ)q(es)i(the)e(basic)h(features)f (of)g(the)g Fp(gnu)g Fu(command)g(line)i(editing)f(in)o(terface.)75 ! 426 y Fs(1.1)33 b(In)n(tro)r(duction)24 b(to)e(Line)i(Editing)137 ! 522 y Fu(The)16 b(follo)o(wing)g(paragraphs)e(describ)q(e)j(the)e (notation)g(used)h(to)e(represen)o(t)i(k)o(eystrok)o(es.)137 ! 589 y(The)h(text)327 587 y Fo(h)p 339 561 56 2 v 339 ! 589 a Fn(C-k)p 339 597 V 393 587 a Fo(i)424 589 y Fu(is)f(read)g(as)g ! (`Con)o(trol-K')f(and)h(describ)q(es)i(the)e(c)o(haracter)g(pro)q ! (duced)h(when)f(the)1831 587 y Fo(h)p 1844 561 19 2 v ! 1844 589 a Fn(k)p 1844 597 V 1860 587 a Fo(i)75 644 y ! Fu(k)o(ey)f(is)h(pressed)g(while)g(the)f(Con)o(trol)g(k)o(ey)g(is)h ! (depressed.)137 711 y(The)f(text)325 709 y Fo(h)p 337 ! 683 63 2 v 337 711 a Fn(M-k)p 337 719 V 397 709 a Fo(i)427 ! 711 y Fu(is)g(read)g(as)f(`Meta-K')g(and)h(describ)q(es)i(the)e(c)o ! (haracter)f(pro)q(duced)i(when)f(the)g(Meta)75 766 y(k)o(ey)f(\(if)g(y) o(ou)g(ha)o(v)o(e)g(one\))g(is)h(depressed,)g(and)f(the)930 ! 764 y Fo(h)p 942 738 19 2 v 942 766 a Fn(k)p 942 774 ! V 958 764 a Fo(i)987 766 y Fu(k)o(ey)g(is)h(pressed.)20 ! b(The)15 b(Meta)e(k)o(ey)h(is)h(lab)q(eled)1779 764 y ! Fo(h)p 1791 738 72 2 v 1791 766 a Fn(AL)m(T)p 1791 774 ! V 1860 764 a Fo(i)75 821 y Fu(on)e(man)o(y)g(k)o(eyb)q(oards.)19 b(On)13 b(k)o(eyb)q(oards)g(with)h(t)o(w)o(o)e(k)o(eys)g(lab)q(eled) ! 1213 819 y Fo(h)p 1225 793 V 1225 821 a Fn(AL)m(T)p 1225 ! 828 V 1294 819 a Fo(i)1322 821 y Fu(\(usually)i(to)e(either)i(side)g ! (of)f(the)75 876 y(space)j(bar\),)f(the)388 874 y Fo(h)p ! 400 847 V 400 876 a Fn(AL)m(T)p 400 883 V 469 874 a Fo(i)499 ! 876 y Fu(on)h(the)g(left)g(side)g(is)g(generally)h(set)f(to)f(w)o(ork)g ! (as)g(a)g(Meta)g(k)o(ey)l(.)22 b(The)1697 874 y Fo(h)p ! 1709 847 V 1709 876 a Fn(AL)m(T)p 1709 883 V 1778 874 ! a Fo(i)1808 876 y Fu(k)o(ey)75 930 y(on)17 b(the)f(righ)o(t)h(ma)o(y)f (also)h(b)q(e)g(con\014gured)g(to)f(w)o(ork)g(as)g(a)h(Meta)f(k)o(ey)g ! (or)g(ma)o(y)g(b)q(e)i(con\014gured)f(as)f(some)75 985 y(other)f(mo)q(di\014er,)h(suc)o(h)f(as)g(a)g(Comp)q(ose)g(k)o(ey)g ! (for)f(t)o(yping)i(accen)o(ted)f(c)o(haracters.)137 1052 y(If)c(y)o(ou)g(do)g(not)f(ha)o(v)o(e)h(a)f(Meta)h(or)694 ! 1050 y Fo(h)p 706 1024 V 706 1052 a Fn(AL)m(T)p 706 1060 ! V 775 1050 a Fo(i)801 1052 y Fu(k)o(ey)l(,)g(or)g(another)f(k)o(ey)h(w) o(orking)f(as)h(a)f(Meta)h(k)o(ey)l(,)g(the)g(iden)o(tical)75 ! 1107 y(k)o(eystrok)o(e)f(can)i(b)q(e)f(generated)h(b)o(y)f(t)o(yping) ! 809 1105 y Fo(h)p 821 1079 70 2 v 821 1107 a Fn(ESC)p ! 821 1115 V 888 1105 a Fo(i)915 1107 y Fm(\014rst)p Fu(,)g(and)g(then)h ! (t)o(yping)1339 1105 y Fo(h)p 1351 1079 19 2 v 1351 1107 ! a Fn(k)p 1351 1115 V 1368 1105 a Fo(i)1383 1107 y Fu(.)18 ! b(Either)12 b(pro)q(cess)f(is)h(kno)o(wn)75 1162 y(as)j ! Fm(metafying)k Fu(the)425 1160 y Fo(h)p 437 1134 V 437 ! 1162 a Fn(k)p 437 1169 V 454 1160 a Fo(i)484 1162 y Fu(k)o(ey)l(.)137 ! 1229 y(The)h(text)334 1227 y Fo(h)p 347 1201 100 2 v ! 347 1229 a Fn(M-C-k)p 347 1236 V 444 1227 a Fo(i)479 ! 1229 y Fu(is)g(read)g(as)f(`Meta-Con)o(trol-k')f(and)i(describ)q(es)h ! (the)f(c)o(haracter)f(pro)q(duced)i(b)o(y)75 1283 y Fm(metafying)291 ! 1281 y Fo(h)p 303 1255 56 2 v 303 1283 a Fn(C-k)p 303 ! 1291 V 357 1281 a Fo(i)372 1283 y Fu(.)137 1350 y(In)e(addition,)h(sev) ! o(eral)f(k)o(eys)f(ha)o(v)o(e)g(their)h(o)o(wn)f(names.)30 ! b(Sp)q(eci\014cally)l(,)1384 1348 y Fo(h)p 1396 1322 ! 73 2 v 1396 1350 a Fn(DEL)p 1396 1358 V 1467 1348 a Fo(i)1482 ! 1350 y Fu(,)1514 1348 y Fo(h)p 1526 1322 70 2 v 1526 ! 1350 a Fn(ESC)p 1526 1358 V 1593 1348 a Fo(i)1608 1350 ! y Fu(,)1640 1348 y Fo(h)p 1652 1322 72 2 v 1652 1350 ! a Fn(LFD)p 1652 1358 V 1722 1348 a Fo(i)1737 1350 y Fu(,)1768 ! 1348 y Fo(h)p 1780 1322 70 2 v 1780 1350 a Fn(SPC)p 1780 ! 1358 V 1847 1348 a Fo(i)1862 1350 y Fu(,)75 1403 y Fo(h)p ! 87 1377 76 2 v 87 1405 a Fn(RET)p 87 1413 V 160 1403 ! a Fo(i)175 1405 y Fu(,)23 b(and)306 1403 y Fo(h)p 318 ! 1377 74 2 v 318 1405 a Fn(T)m(AB)p 318 1413 V 390 1403 ! a Fo(i)427 1405 y Fu(all)f(stand)g(for)f(themselv)o(es)h(when)h(seen)f (in)g(this)g(text,)h(or)e(in)i(an)e(init)i(\014le)g(\(see)75 ! 1460 y(Section)d(1.3)f([Readline)i(Init)f(File],)h(page)e(4\).)32 b(If)19 b(y)o(our)g(k)o(eyb)q(oard)h(lac)o(ks)f(a)1444 ! 1458 y Fo(h)p 1456 1432 72 2 v 1456 1460 a Fn(LFD)p 1456 ! 1468 V 1526 1458 a Fo(i)1560 1460 y Fu(k)o(ey)l(,)h(t)o(yping)1802 ! 1458 y Fo(h)p 1814 1432 49 2 v 1814 1460 a Fn(C-j)p 1814 ! 1468 V 1860 1458 a Fo(i)75 1515 y Fu(will)c(pro)q(duce)g(the)f(desired) ! h(c)o(haracter.)j(The)874 1513 y Fo(h)p 886 1487 76 2 ! v 886 1515 a Fn(RET)p 886 1522 V 959 1513 a Fo(i)989 ! 1515 y Fu(k)o(ey)c(ma)o(y)f(b)q(e)h(lab)q(eled)1385 1513 ! y Fo(h)p 1397 1487 109 2 v 1397 1515 a Fn(Return)p 1397 ! 1522 V 1503 1513 a Fo(i)1533 1515 y Fu(or)1588 1513 y ! Fo(h)p 1600 1487 86 2 v 1600 1515 a Fn(En)o(ter)p 1600 ! 1522 V 1684 1513 a Fo(i)1714 1515 y Fu(on)f(some)75 1569 ! y(k)o(eyb)q(oards.)75 1697 y Fs(1.2)33 b(Readline)23 ! b(In)n(teraction)137 1793 y Fu(Often)13 b(during)h(an)e(in)o(teractiv)o (e)h(session)g(y)o(ou)g(t)o(yp)q(e)f(in)i(a)e(long)h(line)h(of)e(text,) ! h(only)g(to)f(notice)h(that)f(the)75 1848 y(\014rst)k(w)o(ord)f(on)h ! (the)h(line)h(is)e(missp)q(elled.)26 b(The)16 b(Readline)j(library)e (giv)o(es)f(y)o(ou)g(a)g(set)g(of)g(commands)g(for)75 ! 1903 y(manipulating)g(the)f(text)g(as)f(y)o(ou)h(t)o(yp)q(e)g(it)g(in,) g(allo)o(wing)h(y)o(ou)f(to)f(just)h(\014x)g(y)o(our)f(t)o(yp)q(o,)g ! (and)h(not)g(forcing)75 1958 y(y)o(ou)f(to)f(ret)o(yp)q(e)h(the)g(ma)s (jorit)o(y)f(of)h(the)g(line.)21 b(Using)15 b(these)f(editing)h ! (commands,)f(y)o(ou)g(mo)o(v)o(e)f(the)h(cursor)75 2012 y(to)i(the)i(place)g(that)e(needs)i(correction,)g(and)f(delete)h(or)f (insert)g(the)h(text)e(of)h(the)g(corrections.)26 b(Then,)75 ! 2067 y(when)16 b(y)o(ou)f(are)h(satis\014ed)g(with)g(the)f(line,)i(y)o ! (ou)e(simply)i(press)1160 2065 y Fo(h)p 1172 2039 155 ! 2 v 1172 2067 a Fn(RETURN)p 1172 2075 V 1324 2065 a Fo(i)1339 ! 2067 y Fu(.)k(Y)l(ou)16 b(do)f(not)g(ha)o(v)o(e)g(to)g(b)q(e)i(at)75 ! 2122 y(the)g(end)g(of)f(the)g(line)i(to)e(press)634 2120 ! y Fo(h)p 646 2094 V 646 2122 a Fn(RETURN)p 646 2130 V ! 798 2120 a Fo(i)813 2122 y Fu(;)g(the)h(en)o(tire)g(line)h(is)f ! (accepted)g(regardless)g(of)f(the)g(lo)q(cation)75 2177 ! y(of)f(the)g(cursor)g(within)h(the)g(line.)75 2288 y ! Fl(1.2.1)30 b(Readline)20 b(Bare)g(Essen)n(tials)137 ! 2384 y Fu(In)12 b(order)g(to)f(en)o(ter)g(c)o(haracters)g(in)o(to)g ! (the)h(line,)h(simply)g(t)o(yp)q(e)f(them.)18 b(The)12 ! b(t)o(yp)q(ed)g(c)o(haracter)f(app)q(ears)75 2439 y(where)16 ! b(the)h(cursor)f(w)o(as,)f(and)h(then)h(the)f(cursor)g(mo)o(v)o(es)g ! (one)g(space)g(to)g(the)g(righ)o(t.)23 b(If)17 b(y)o(ou)f(mist)o(yp)q ! (e)g(a)75 2493 y(c)o(haracter,)e(y)o(ou)h(can)g(use)h(y)o(our)f(erase)g ! (c)o(haracter)f(to)h(bac)o(k)g(up)g(and)h(delete)g(the)f(mist)o(yp)q ! (ed)h(c)o(haracter.)137 2560 y(Sometimes)g(y)o(ou)f(ma)o(y)g(mist)o(yp) ! q(e)h(a)f(c)o(haracter,)f(and)i(not)f(notice)h(the)f(error)g(un)o(til)i ! (y)o(ou)e(ha)o(v)o(e)g(t)o(yp)q(ed)75 2615 y(sev)o(eral)f(other)f(c)o ! (haracters.)19 b(In)14 b(that)g(case,)f(y)o(ou)h(can)g(t)o(yp)q(e)1102 ! 2613 y Fo(h)p 1114 2587 57 2 v 1114 2615 a Fn(C-b)p 1114 ! 2623 V 1168 2613 a Fo(i)1197 2615 y Fu(to)f(mo)o(v)o(e)g(the)h(cursor)g ! (to)f(the)h(left,)g(and)75 2670 y(then)i(correct)e(y)o(our)h(mistak)o ! (e.)20 b(Afterw)o(ards,)13 b(y)o(ou)i(can)g(mo)o(v)o(e)g(the)g(cursor)g ! (to)g(the)g(righ)o(t)g(with)1714 2668 y Fo(h)p 1727 2642 ! 49 2 v 1727 2670 a Fn(C-f)p 1727 2678 V 1772 2668 a Fo(i)1787 ! 2670 y Fu(.)p eop %%Page: 2 4 ! 2 3 bop 75 -58 a Fu(2)1322 b(GNU)15 b(Readline)i(Library)137 ! 183 y(When)g(y)o(ou)f(add)g(text)g(in)h(the)g(middle)h(of)e(a)f(line,)j (y)o(ou)e(will)i(notice)f(that)f(c)o(haracters)f(to)h(the)g(righ)o(t)75 ! 238 y(of)e(the)g(cursor)g(are)g(`pushed)h(o)o(v)o(er')f(to)f(mak)o(e)h (ro)q(om)g(for)f(the)i(text)f(that)f(y)o(ou)h(ha)o(v)o(e)g(inserted.)21 ! b(Lik)o(ewise,)75 293 y(when)e(y)o(ou)g(delete)h(text)e(b)q(ehind)j (the)e(cursor,)g(c)o(haracters)f(to)g(the)h(righ)o(t)f(of)g(the)h ! (cursor)g(are)f(`pulled)75 348 y(bac)o(k')11 b(to)g(\014ll)h(in)h(the)e (blank)h(space)g(created)f(b)o(y)h(the)f(remo)o(v)m(al)g(of)g(the)h (text.)18 b(A)11 b(list)h(of)f(the)h(bare)f(essen)o(tials)75 ! 402 y(for)k(editing)h(the)f(text)g(of)g(an)g(input)h(line)h(follo)o ! (ws.)75 479 y Fo(h)p 87 453 57 2 v 87 481 a Fn(C-b)p ! 87 489 V 142 479 a Fo(i)315 481 y Fu(Mo)o(v)o(e)d(bac)o(k)h(one)h(c)o ! (haracter.)75 558 y Fo(h)p 87 532 49 2 v 87 560 a Fn(C-f)p ! 87 567 V 133 558 a Fo(i)315 560 y Fu(Mo)o(v)o(e)e(forw)o(ard)g(one)h(c) ! o(haracter.)75 636 y Fo(h)p 87 610 73 2 v 87 638 a Fn(DEL)p ! 87 646 V 158 636 a Fo(i)188 638 y Fu(or)244 636 y Fo(h)p ! 256 610 159 2 v 256 638 a Fn(Bac)o(kspace)p 256 646 V ! 412 636 a Fo(i)315 693 y Fu(Delete)h(the)f(c)o(haracter)g(to)f(the)h ! (left)h(of)f(the)g(cursor.)75 770 y Fo(h)p 87 744 57 ! 2 v 87 772 a Fn(C-d)p 87 779 V 142 770 a Fo(i)315 772 ! y Fu(Delete)h(the)f(c)o(haracter)g(underneath)h(the)f(cursor.)75 ! 850 y(Prin)o(ting)h(c)o(haracters)315 905 y(Insert)f(the)h(c)o (haracter)e(in)o(to)h(the)h(line)h(at)d(the)h(cursor.)75 ! 981 y Fo(h)p 87 955 50 2 v 87 983 a Fn(C-)p 126 983 11 ! 2 v 87 991 50 2 v 135 981 a Fo(i)165 983 y Fu(or)221 ! 981 y Fo(h)p 233 955 125 2 v 233 983 a Fn(C-x)c(C-u)p ! 233 991 V 355 981 a Fo(i)315 1038 y Fu(Undo)17 b(the)g(last)f(editing)i ! (command.)25 b(Y)l(ou)17 b(can)g(undo)g(all)g(the)g(w)o(a)o(y)f(bac)o ! (k)h(to)f(an)g(empt)o(y)315 1093 y(line.)75 1172 y(\(Dep)q(ending)i(on) ! f(y)o(our)g(con\014guration,)g(the)863 1170 y Fo(h)p ! 875 1144 159 2 v 875 1172 a Fn(Bac)o(kspace)p 875 1179 ! V 1032 1170 a Fo(i)1063 1172 y Fu(k)o(ey)g(b)q(e)h(set)f(to)f(delete)i ! (the)f(c)o(haracter)g(to)f(the)75 1226 y(left)h(of)f(the)h(cursor)f ! (and)g(the)596 1224 y Fo(h)p 608 1198 73 2 v 608 1226 ! a Fn(DEL)p 608 1234 V 679 1224 a Fo(i)710 1226 y Fu(k)o(ey)h(set)f(to)g ! (delete)h(the)g(c)o(haracter)f(underneath)h(the)g(cursor,)f(lik)o(e)75 ! 1279 y Fo(h)p 87 1253 57 2 v 87 1281 a Fn(C-d)p 87 1289 ! V 142 1279 a Fo(i)157 1281 y Fu(,)f(rather)f(than)h(the)h(c)o(haracter) ! e(to)h(the)g(left)g(of)g(the)g(cursor.\))75 1392 y Fl(1.2.2)30 ! b(Readline)20 b(Mo)n(v)n(emen)n(t)i(Commands)137 1487 ! y Fu(The)14 b(ab)q(o)o(v)o(e)e(table)i(describ)q(es)g(the)g(most)e (basic)i(k)o(eystrok)o(es)d(that)i(y)o(ou)g(need)h(in)f(order)g(to)g ! (do)g(editing)75 1542 y(of)f(the)h(input)h(line.)21 b(F)l(or)12 b(y)o(our)g(con)o(v)o(enience,)i(man)o(y)f(other)f(commands)h(ha)o(v)o ! (e)f(b)q(een)i(added)f(in)h(addition)75 1597 y(to)130 ! 1595 y Fo(h)p 142 1569 V 142 1597 a Fn(C-b)p 142 1605 ! V 197 1595 a Fo(i)212 1597 y Fu(,)239 1595 y Fo(h)p 251 ! 1569 49 2 v 251 1597 a Fn(C-f)p 251 1605 V 297 1595 a ! Fo(i)312 1597 y Fu(,)339 1595 y Fo(h)p 351 1569 57 2 ! v 351 1597 a Fn(C-d)p 351 1605 V 406 1595 a Fo(i)421 ! 1597 y Fu(,)g(and)536 1595 y Fo(h)p 548 1569 73 2 v 548 ! 1597 a Fn(DEL)p 548 1605 V 619 1595 a Fo(i)634 1597 y ! Fu(.)20 b(Here)15 b(are)f(some)g(commands)h(for)f(mo)o(ving)g(more)h ! (rapidly)g(ab)q(out)g(the)75 1652 y(line.)75 1728 y Fo(h)p ! 87 1702 55 2 v 87 1730 a Fn(C-a)p 87 1738 V 140 1728 ! a Fo(i)315 1730 y Fu(Mo)o(v)o(e)f(to)h(the)g(start)f(of)h(the)g(line.) ! 75 1807 y Fo(h)p 87 1781 53 2 v 87 1809 a Fn(C-e)p 87 ! 1817 V 138 1807 a Fo(i)315 1809 y Fu(Mo)o(v)o(e)f(to)h(the)g(end)h(of)f ! (the)g(line.)75 1885 y Fo(h)p 87 1859 55 2 v 87 1887 ! a Fn(M-f)p 87 1895 V 140 1885 a Fo(i)315 1887 y Fu(Mo)o(v)o(e)f(forw)o ! (ard)g(a)h(w)o(ord,)f(where)i(a)e(w)o(ord)h(is)h(comp)q(osed)f(of)g ! (letters)g(and)h(digits.)75 1964 y Fo(h)p 87 1938 64 ! 2 v 87 1966 a Fn(M-b)p 87 1974 V 149 1964 a Fo(i)315 ! 1966 y Fu(Mo)o(v)o(e)e(bac)o(kw)o(ard)h(a)g(w)o(ord.)75 ! 2043 y Fo(h)p 87 2017 48 2 v 87 2045 a Fn(C-l)p 87 2052 ! V 132 2043 a Fo(i)315 2045 y Fu(Clear)g(the)h(screen,)f(reprin)o(ting)h ! (the)f(curren)o(t)g(line)i(at)e(the)g(top.)137 2123 y(Notice)d(ho)o(w) ! 368 2121 y Fo(h)p 380 2095 49 2 v 380 2123 a Fn(C-f)p ! 380 2131 V 426 2121 a Fo(i)452 2123 y Fu(mo)o(v)o(es)f(forw)o(ard)f(a)i ! (c)o(haracter,)f(while)1105 2121 y Fo(h)p 1117 2095 55 ! 2 v 1117 2123 a Fn(M-f)p 1117 2131 V 1170 2121 a Fo(i)1197 ! 2123 y Fu(mo)o(v)o(es)f(forw)o(ard)h(a)g(w)o(ord.)18 ! b(It)12 b(is)g(a)g(lo)q(ose)75 2178 y(con)o(v)o(en)o(tion)j(that)f(con) o(trol)h(k)o(eystrok)o(es)f(op)q(erate)h(on)f(c)o(haracters)h(while)h ! (meta)e(k)o(eystrok)o(es)g(op)q(erate)h(on)75 2233 y(w)o(ords.)75 ! 2343 y Fl(1.2.3)30 b(Readline)20 b(Killing)h(Commands)137 ! 2439 y Fm(Killing)26 b Fu(text)18 b(means)g(to)g(delete)i(the)f(text)f (from)g(the)h(line,)i(but)d(to)g(sa)o(v)o(e)g(it)h(a)o(w)o(a)o(y)e(for) ! h(later)h(use,)75 2494 y(usually)f(b)o(y)f Fm(y)o(anking)22 b Fu(\(re-inserting\))17 b(it)g(bac)o(k)g(in)o(to)g(the)h(line.)27 b(\(`Cut')15 b(and)j(`paste')e(are)g(more)h(recen)o(t)75 ! 2549 y(jargon)d(for)h(`kill')h(and)g(`y)o(ank'.\))137 2615 y(If)g(the)f(description)h(for)f(a)g(command)g(sa)o(ys)f(that)h (it)g(`kills')h(text,)e(then)i(y)o(ou)f(can)g(b)q(e)h(sure)f(that)f(y)o --- 1124,1339 ---- %%EndSetup %%Page: 1 1 ! 1 0 bop 75 659 a Fv(GNU)33 b(Readline)h(Library)p 75 ! 709 1800 17 v 936 757 a Fu(Edition)17 b(4.2,)c(for)i ! Ft(Readline)f(Library)g Fu(V)l(ersion)i(4.2.)1692 811 ! y(Apr)f(2001)75 2467 y Fs(Brian)23 b(F)-6 b(o)n(x,)23 b(F)-6 b(ree)23 b(Soft)n(w)n(are)f(F)-6 b(oundation)75 2534 y(Chet)22 b(Ramey)-6 b(,)23 b(Case)e(W)-6 b(estern)23 b(Reserv)n(e)f(Univ)n(ersit)n(y)p 75 2570 1800 9 v eop %%Page: 2 2 ! 2 1 bop 75 217 a Fu(This)14 b(do)q(cumen)o(t)h(describ)q(es)g(the)f ! (GNU)g(Readline)h(Library)l(,)f(a)g(utilit)o(y)h(whic)o(h)f(aids)g(in)h ! (the)f(consistency)75 271 y(of)h(user)g(in)o(terface)h(across)e (discrete)i(programs)e(that)h(need)h(to)e(pro)o(vide)i(a)f(command)g ! (line)i(in)o(terface.)75 339 y(Published)g(b)o(y)f(the)f(F)l(ree)g ! (Soft)o(w)o(are)f(F)l(oundation)75 394 y(59)h(T)l(emple)h(Place,)f ! (Suite)i(330,)75 448 y(Boston,)d(MA)h(02111)f(USA)75 ! 516 y(P)o(ermission)j(is)f(gran)o(ted)g(to)f(mak)o(e)h(and)g (distribute)i(v)o(erbatim)d(copies)i(of)f(this)h(man)o(ual)f(pro)o ! (vided)h(the)75 570 y(cop)o(yrigh)o(t)e(notice)h(and)f(this)h(p)q (ermission)g(notice)g(are)f(preserv)o(ed)h(on)f(all)h(copies.)75 ! 638 y(P)o(ermission)c(is)h(gran)o(ted)e(to)g(cop)o(y)h(and)g (distribute)h(mo)q(di\014ed)g(v)o(ersions)f(of)f(this)h(man)o(ual)g ! (under)h(the)f(con-)75 692 y(ditions)k(for)e(v)o(erbatim)h(cop)o(ying,) g(pro)o(vided)h(that)e(the)h(en)o(tire)h(resulting)g(deriv)o(ed)g(w)o ! (ork)e(is)h(distributed)75 747 y(under)h(the)f(terms)g(of)g(a)f(p)q (ermission)j(notice)f(iden)o(tical)h(to)e(this)g(one.)75 ! 814 y(P)o(ermission)i(is)g(gran)o(ted)f(to)g(cop)o(y)h(and)f (distribute)i(translations)f(of)f(this)h(man)o(ual)g(in)o(to)f(another) ! g(lan-)75 869 y(guage,)e(under)h(the)f(ab)q(o)o(v)o(e)g(conditions)i (for)d(mo)q(di\014ed)j(v)o(ersions,)e(except)h(that)f(this)h(p)q ! (ermission)g(notice)75 924 y(ma)o(y)f(b)q(e)i(stated)f(in)h(a)f (translation)g(appro)o(v)o(ed)g(b)o(y)g(the)g(F)l(ree)h(Soft)o(w)o(are) d(F)l(oundation.)75 2661 y(Cop)o(yrigh)o(t)301 2660 y(c)289 ! 2661 y Fr(\015)h Fu(1988-2001)f(F)l(ree)i(Soft)o(w)o(are)f(F)l (oundation,)h(Inc.)p eop %%Page: 1 3 1 2 bop 75 -58 a Fu(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1077 ! b(1)75 149 y Fq(1)41 b(Command)28 b(Line)e(Editing)137 ! 271 y Fu(This)16 b(c)o(hapter)f(describ)q(es)i(the)e(basic)h(features)f (of)g(the)g Fp(gnu)g Fu(command)g(line)i(editing)f(in)o(terface.)75 ! 403 y Fs(1.1)33 b(In)n(tro)r(duction)24 b(to)e(Line)i(Editing)137 ! 501 y Fu(The)16 b(follo)o(wing)g(paragraphs)e(describ)q(e)j(the)e (notation)g(used)h(to)e(represen)o(t)i(k)o(eystrok)o(es.)137 ! 569 y(The)h(text)f Fo(C-k)h Fu(is)g(read)g(as)f(`Con)o(trol-K')g(and)h ! (describ)q(es)h(the)f(c)o(haracter)f(pro)q(duced)h(when)h(the)1831 ! 567 y Fn(h)p 1844 541 19 2 v 1844 569 a Fm(k)p 1844 577 ! V 1860 567 a Fn(i)75 624 y Fu(k)o(ey)d(is)h(pressed)g(while)g(the)f ! (Con)o(trol)g(k)o(ey)g(is)h(depressed.)137 693 y(The)g(text)g ! Fo(M-k)f Fu(is)i(read)f(as)f(`Meta-K')g(and)h(describ)q(es)i(the)e(c)o ! (haracter)f(pro)q(duced)i(when)g(the)f(Meta)75 747 y(k)o(ey)e(\(if)g(y) o(ou)g(ha)o(v)o(e)g(one\))g(is)h(depressed,)g(and)f(the)930 ! 745 y Fn(h)p 942 719 V 942 747 a Fm(k)p 942 755 V 958 ! 745 a Fn(i)987 747 y Fu(k)o(ey)g(is)h(pressed.)20 b(The)15 ! b(Meta)e(k)o(ey)h(is)h(lab)q(eled)1779 745 y Fn(h)p 1791 ! 719 72 2 v 1791 747 a Fm(AL)m(T)p 1791 755 V 1860 745 ! a Fn(i)75 802 y Fu(on)e(man)o(y)g(k)o(eyb)q(oards.)19 b(On)13 b(k)o(eyb)q(oards)g(with)h(t)o(w)o(o)e(k)o(eys)g(lab)q(eled) ! 1213 800 y Fn(h)p 1225 774 V 1225 802 a Fm(AL)m(T)p 1225 ! 810 V 1294 800 a Fn(i)1322 802 y Fu(\(usually)i(to)e(either)i(side)g ! (of)f(the)75 857 y(space)j(bar\),)f(the)388 855 y Fn(h)p ! 400 829 V 400 857 a Fm(AL)m(T)p 400 865 V 469 855 a Fn(i)499 ! 857 y Fu(on)h(the)g(left)g(side)g(is)g(generally)h(set)f(to)f(w)o(ork)g ! (as)g(a)g(Meta)g(k)o(ey)l(.)22 b(The)1697 855 y Fn(h)p ! 1709 829 V 1709 857 a Fm(AL)m(T)p 1709 865 V 1778 855 ! a Fn(i)1808 857 y Fu(k)o(ey)75 912 y(on)17 b(the)f(righ)o(t)h(ma)o(y)f (also)h(b)q(e)g(con\014gured)g(to)f(w)o(ork)g(as)g(a)h(Meta)f(k)o(ey)g ! (or)g(ma)o(y)g(b)q(e)i(con\014gured)f(as)f(some)75 967 y(other)f(mo)q(di\014er,)h(suc)o(h)f(as)g(a)g(Comp)q(ose)g(k)o(ey)g ! (for)f(t)o(yping)i(accen)o(ted)f(c)o(haracters.)137 1035 y(If)c(y)o(ou)g(do)g(not)f(ha)o(v)o(e)h(a)f(Meta)h(or)694 ! 1033 y Fn(h)p 706 1007 V 706 1035 a Fm(AL)m(T)p 706 1043 ! V 775 1033 a Fn(i)801 1035 y Fu(k)o(ey)l(,)g(or)g(another)f(k)o(ey)h(w) o(orking)f(as)h(a)f(Meta)h(k)o(ey)l(,)g(the)g(iden)o(tical)75 ! 1090 y(k)o(eystrok)o(e)f(can)i(b)q(e)g(generated)f(b)o(y)g(t)o(yping) ! 809 1088 y Fn(h)p 822 1062 70 2 v 822 1090 a Fm(ESC)p ! 822 1098 V 888 1088 a Fn(i)915 1090 y Fl(\014rst)p Fu(,)g(and)g(then)h ! (t)o(yping)1339 1088 y Fn(h)p 1351 1062 19 2 v 1351 1090 ! a Fm(k)p 1351 1098 V 1368 1088 a Fn(i)1383 1090 y Fu(.)18 ! b(Either)12 b(pro)q(cess)f(is)h(kno)o(wn)75 1145 y(as)j ! Fk(metafying)k Fu(the)425 1143 y Fn(h)p 437 1117 V 437 ! 1145 a Fm(k)p 437 1153 V 454 1143 a Fn(i)484 1145 y Fu(k)o(ey)l(.)137 ! 1214 y(The)i(text)e Fo(M-C-k)h Fu(is)h(read)f(as)f(`Meta-Con)o(trol-k') ! g(and)h(describ)q(es)i(the)e(c)o(haracter)g(pro)q(duced)h(b)o(y)75 ! 1268 y Fk(metafying)e Fo(C-k)p Fu(.)137 1337 y(In)g(addition,)h(sev)o ! (eral)f(k)o(eys)f(ha)o(v)o(e)g(their)h(o)o(wn)f(names.)30 ! b(Sp)q(eci\014cally)l(,)1384 1335 y Fn(h)p 1396 1309 ! 73 2 v 1396 1337 a Fm(DEL)p 1396 1345 V 1467 1335 a Fn(i)1482 ! 1337 y Fu(,)1514 1335 y Fn(h)p 1526 1309 70 2 v 1526 ! 1337 a Fm(ESC)p 1526 1345 V 1593 1335 a Fn(i)1608 1337 ! y Fu(,)1640 1335 y Fn(h)p 1652 1309 72 2 v 1652 1337 ! a Fm(LFD)p 1652 1345 V 1722 1335 a Fn(i)1737 1337 y Fu(,)1768 ! 1335 y Fn(h)p 1780 1309 70 2 v 1780 1337 a Fm(SPC)p 1780 ! 1345 V 1847 1335 a Fn(i)1862 1337 y Fu(,)75 1390 y Fn(h)p ! 87 1364 76 2 v 87 1392 a Fm(RET)p 87 1399 V 160 1390 ! a Fn(i)175 1392 y Fu(,)23 b(and)306 1390 y Fn(h)p 318 ! 1364 74 2 v 318 1392 a Fm(T)m(AB)p 318 1399 V 390 1390 ! a Fn(i)427 1392 y Fu(all)f(stand)g(for)f(themselv)o(es)h(when)h(seen)f (in)g(this)g(text,)h(or)e(in)i(an)e(init)i(\014le)g(\(see)75 ! 1447 y(Section)d(1.3)f([Readline)h(Init)g(File],)h(page)e(4\).)32 b(If)19 b(y)o(our)g(k)o(eyb)q(oard)h(lac)o(ks)f(a)1444 ! 1445 y Fn(h)p 1456 1419 72 2 v 1456 1447 a Fm(LFD)p 1456 ! 1454 V 1526 1445 a Fn(i)1560 1447 y Fu(k)o(ey)l(,)h(t)o(yping)1802 ! 1445 y Fn(h)p 1814 1419 49 2 v 1814 1447 a Fm(C-j)p 1814 ! 1454 V 1860 1445 a Fn(i)75 1501 y Fu(will)c(pro)q(duce)g(the)f(desired) ! h(c)o(haracter.)j(The)874 1499 y Fn(h)p 886 1473 76 2 ! v 886 1501 a Fm(RET)p 886 1509 V 959 1499 a Fn(i)989 ! 1501 y Fu(k)o(ey)c(ma)o(y)f(b)q(e)h(lab)q(eled)1385 1499 ! y Fn(h)p 1397 1473 109 2 v 1397 1501 a Fm(Return)p 1397 ! 1509 V 1503 1499 a Fn(i)1533 1501 y Fu(or)1588 1499 y ! Fn(h)p 1600 1473 86 2 v 1600 1501 a Fm(En)o(ter)p 1600 ! 1509 V 1684 1499 a Fn(i)1714 1501 y Fu(on)f(some)75 1556 ! y(k)o(eyb)q(oards.)75 1688 y Fs(1.2)33 b(Readline)23 ! b(In)n(teraction)137 1786 y Fu(Often)13 b(during)h(an)e(in)o(teractiv)o (e)h(session)g(y)o(ou)g(t)o(yp)q(e)f(in)i(a)e(long)h(line)h(of)e(text,) ! h(only)g(to)f(notice)h(that)f(the)75 1841 y(\014rst)k(w)o(ord)f(on)h ! (the)h(line)h(is)e(missp)q(elled.)26 b(The)16 b(Readline)i(library)f (giv)o(es)f(y)o(ou)g(a)g(set)g(of)g(commands)g(for)75 ! 1896 y(manipulating)g(the)f(text)g(as)f(y)o(ou)h(t)o(yp)q(e)g(it)g(in,) g(allo)o(wing)h(y)o(ou)f(to)f(just)h(\014x)g(y)o(our)f(t)o(yp)q(o,)g ! (and)h(not)g(forcing)75 1950 y(y)o(ou)f(to)f(ret)o(yp)q(e)h(the)g(ma)s (jorit)o(y)f(of)h(the)g(line.)21 b(Using)15 b(these)f(editing)h ! (commands,)f(y)o(ou)g(mo)o(v)o(e)f(the)h(cursor)75 2005 y(to)i(the)i(place)g(that)e(needs)i(correction,)g(and)f(delete)h(or)f (insert)g(the)h(text)e(of)h(the)g(corrections.)26 b(Then,)75 ! 2060 y(when)16 b(y)o(ou)f(are)h(satis\014ed)g(with)g(the)f(line,)i(y)o ! (ou)e(simply)i(press)1160 2058 y Fn(h)p 1172 2032 76 ! 2 v 1172 2060 a Fm(RET)p 1172 2068 V 1245 2058 a Fn(i)1260 ! 2060 y Fu(.)k(Y)l(ou)16 b(do)f(not)h(ha)o(v)o(e)f(to)g(b)q(e)h(at)f ! (the)75 2115 y(end)k(of)e(the)h(line)i(to)d(press)563 ! 2113 y Fn(h)p 575 2087 V 575 2115 a Fm(RET)p 575 2122 ! V 648 2113 a Fn(i)663 2115 y Fu(;)i(the)f(en)o(tire)h(line)g(is)g ! (accepted)f(regardless)g(of)g(the)g(lo)q(cation)g(of)g(the)75 ! 2170 y(cursor)d(within)h(the)g(line.)75 2284 y Fj(1.2.1)30 ! b(Readline)20 b(Bare)g(Essen)n(tials)137 2382 y Fu(In)12 ! b(order)g(to)f(en)o(ter)g(c)o(haracters)g(in)o(to)g(the)h(line,)h ! (simply)g(t)o(yp)q(e)f(them.)18 b(The)12 b(t)o(yp)q(ed)g(c)o(haracter)f ! (app)q(ears)75 2437 y(where)16 b(the)h(cursor)f(w)o(as,)f(and)h(then)h ! (the)f(cursor)g(mo)o(v)o(es)g(one)g(space)g(to)g(the)g(righ)o(t.)23 ! b(If)17 b(y)o(ou)f(mist)o(yp)q(e)g(a)75 2492 y(c)o(haracter,)e(y)o(ou)h ! (can)g(use)h(y)o(our)f(erase)g(c)o(haracter)f(to)h(bac)o(k)g(up)g(and)h ! (delete)g(the)f(mist)o(yp)q(ed)h(c)o(haracter.)137 2560 ! y(Sometimes)g(y)o(ou)f(ma)o(y)g(mist)o(yp)q(e)h(a)f(c)o(haracter,)f ! (and)i(not)f(notice)h(the)f(error)g(un)o(til)i(y)o(ou)e(ha)o(v)o(e)g(t) ! o(yp)q(ed)75 2615 y(sev)o(eral)g(other)f(c)o(haracters.)19 ! b(In)c(that)e(case,)i(y)o(ou)f(can)g(t)o(yp)q(e)h Fo(C-b)f ! Fu(to)g(mo)o(v)o(e)f(the)i(cursor)f(to)g(the)g(left,)h(and)75 ! 2670 y(then)h(correct)e(y)o(our)h(mistak)o(e.)20 b(Afterw)o(ards,)13 ! b(y)o(ou)i(can)g(mo)o(v)o(e)g(the)g(cursor)g(to)g(the)g(righ)o(t)g ! (with)g Fo(C-f)p Fu(.)p eop %%Page: 2 4 ! 2 3 bop 75 -58 a Fu(2)1322 b(GNU)15 b(Readline)h(Library)137 ! 149 y(When)h(y)o(ou)f(add)g(text)g(in)h(the)g(middle)h(of)e(a)f(line,)j (y)o(ou)e(will)i(notice)f(that)f(c)o(haracters)f(to)h(the)g(righ)o(t)75 ! 204 y(of)e(the)g(cursor)g(are)g(`pushed)h(o)o(v)o(er')f(to)f(mak)o(e)h (ro)q(om)g(for)f(the)i(text)f(that)f(y)o(ou)h(ha)o(v)o(e)g(inserted.)21 ! b(Lik)o(ewise,)75 259 y(when)e(y)o(ou)g(delete)h(text)e(b)q(ehind)j (the)e(cursor,)g(c)o(haracters)f(to)g(the)h(righ)o(t)f(of)g(the)h ! (cursor)g(are)f(`pulled)75 314 y(bac)o(k')11 b(to)g(\014ll)h(in)h(the)e (blank)h(space)g(created)f(b)o(y)h(the)f(remo)o(v)m(al)g(of)g(the)h (text.)18 b(A)11 b(list)h(of)f(the)h(bare)f(essen)o(tials)75 ! 369 y(for)k(editing)h(the)f(text)g(of)g(an)g(input)h(line)h(follo)o ! (ws.)75 449 y Fo(C-b)168 b Fu(Mo)o(v)o(e)14 b(bac)o(k)h(one)h(c)o ! (haracter.)75 530 y Fo(C-f)168 b Fu(Mo)o(v)o(e)14 b(forw)o(ard)g(one)h ! (c)o(haracter.)75 608 y Fn(h)p 87 582 73 2 v 87 610 a ! Fm(DEL)p 87 618 V 158 608 a Fn(i)188 610 y Fu(or)244 ! 608 y Fn(h)p 256 582 159 2 v 256 610 a Fm(Bac)o(kspace)p ! 256 618 V 412 608 a Fn(i)315 665 y Fu(Delete)h(the)f(c)o(haracter)g(to) ! f(the)h(left)h(of)f(the)g(cursor.)75 745 y Fo(C-d)168 ! b Fu(Delete)16 b(the)f(c)o(haracter)g(underneath)h(the)f(cursor.)75 ! 825 y(Prin)o(ting)h(c)o(haracters)315 880 y(Insert)f(the)h(c)o (haracter)e(in)o(to)h(the)h(line)h(at)d(the)h(cursor.)75 ! 961 y Fo(C-_)g Fu(or)f Fo(C-x)h(C-u)315 1015 y Fu(Undo)i(the)g(last)f ! (editing)i(command.)25 b(Y)l(ou)17 b(can)g(undo)g(all)g(the)g(w)o(a)o ! (y)f(bac)o(k)h(to)f(an)g(empt)o(y)315 1070 y(line.)75 ! 1151 y(\(Dep)q(ending)i(on)f(y)o(our)g(con\014guration,)g(the)863 ! 1149 y Fn(h)p 875 1123 V 875 1151 a Fm(Bac)o(kspace)p ! 875 1159 V 1032 1149 a Fn(i)1063 1151 y Fu(k)o(ey)g(b)q(e)h(set)f(to)f ! (delete)i(the)f(c)o(haracter)g(to)f(the)75 1206 y(left)h(of)f(the)h ! (cursor)f(and)g(the)596 1204 y Fn(h)p 608 1178 73 2 v ! 608 1206 a Fm(DEL)p 608 1213 V 679 1204 a Fn(i)710 1206 ! y Fu(k)o(ey)h(set)f(to)g(delete)h(the)g(c)o(haracter)f(underneath)h ! (the)g(cursor,)f(lik)o(e)75 1260 y Fo(C-d)p Fu(,)e(rather)h(than)g(the) ! g(c)o(haracter)g(to)f(the)i(left)f(of)g(the)g(cursor.\))75 ! 1374 y Fj(1.2.2)30 b(Readline)20 b(Mo)n(v)n(emen)n(t)i(Commands)137 ! 1471 y Fu(The)14 b(ab)q(o)o(v)o(e)e(table)i(describ)q(es)g(the)g(most)e (basic)i(k)o(eystrok)o(es)d(that)i(y)o(ou)g(need)h(in)f(order)g(to)g ! (do)g(editing)75 1526 y(of)f(the)h(input)h(line.)21 b(F)l(or)12 b(y)o(our)g(con)o(v)o(enience,)i(man)o(y)f(other)f(commands)h(ha)o(v)o ! (e)f(b)q(een)i(added)f(in)h(addition)75 1580 y(to)h Fo(C-b)p ! Fu(,)h Fo(C-f)p Fu(,)f Fo(C-d)p Fu(,)g(and)522 1578 y ! Fn(h)p 534 1552 V 534 1580 a Fm(DEL)p 534 1588 V 605 ! 1578 a Fn(i)619 1580 y Fu(.)23 b(Here)16 b(are)g(some)f(commands)h(for) ! f(mo)o(ving)h(more)g(rapidly)h(ab)q(out)f(the)75 1635 ! y(line.)75 1716 y Fo(C-a)168 b Fu(Mo)o(v)o(e)14 b(to)h(the)g(start)f ! (of)h(the)g(line.)75 1796 y Fo(C-e)168 b Fu(Mo)o(v)o(e)14 ! b(to)h(the)g(end)h(of)f(the)g(line.)75 1876 y Fo(M-f)168 ! b Fu(Mo)o(v)o(e)14 b(forw)o(ard)g(a)h(w)o(ord,)f(where)i(a)e(w)o(ord)h ! (is)h(comp)q(osed)f(of)g(letters)g(and)h(digits.)75 1957 ! y Fo(M-b)168 b Fu(Mo)o(v)o(e)14 b(bac)o(kw)o(ard)h(a)g(w)o(ord.)75 ! 2037 y Fo(C-l)168 b Fu(Clear)15 b(the)h(screen,)f(reprin)o(ting)h(the)f ! (curren)o(t)g(line)i(at)e(the)g(top.)137 2118 y(Notice)e(ho)o(w)f ! Fo(C-f)g Fu(mo)o(v)o(es)f(forw)o(ard)g(a)h(c)o(haracter,)g(while)i ! Fo(M-f)e Fu(mo)o(v)o(es)f(forw)o(ard)g(a)h(w)o(ord.)18 ! b(It)13 b(is)g(a)f(lo)q(ose)75 2173 y(con)o(v)o(en)o(tion)j(that)f(con) o(trol)h(k)o(eystrok)o(es)f(op)q(erate)h(on)f(c)o(haracters)h(while)h ! (meta)e(k)o(eystrok)o(es)g(op)q(erate)h(on)75 2227 y(w)o(ords.)75 ! 2341 y Fj(1.2.3)30 b(Readline)20 b(Killing)h(Commands)137 ! 2438 y Fk(Killing)26 b Fu(text)18 b(means)g(to)g(delete)i(the)f(text)f (from)g(the)h(line,)i(but)d(to)g(sa)o(v)o(e)g(it)h(a)o(w)o(a)o(y)e(for) ! h(later)h(use,)75 2493 y(usually)f(b)o(y)f Fk(y)o(anking)22 b Fu(\(re-inserting\))17 b(it)g(bac)o(k)g(in)o(to)g(the)h(line.)27 b(\(`Cut')15 b(and)j(`paste')e(are)g(more)h(recen)o(t)75 ! 2547 y(jargon)d(for)h(`kill')h(and)g(`y)o(ank'.\))137 2615 y(If)g(the)f(description)h(for)f(a)g(command)g(sa)o(ys)f(that)h (it)g(`kills')h(text,)e(then)i(y)o(ou)f(can)g(b)q(e)h(sure)f(that)f(y)o *************** *** 1275,2216 **** %%Page: 3 5 3 4 bop 75 -58 a Fu(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1077 ! b(3)137 183 y(When)12 b(y)o(ou)g(use)g(a)f(kill)i(command,)f(the)g ! (text)f(is)h(sa)o(v)o(ed)f(in)i(a)e Fm(kill-ring)p Fu(.)21 b(An)o(y)12 b(n)o(um)o(b)q(er)g(of)f(consecutiv)o(e)75 ! 238 y(kills)17 b(sa)o(v)o(e)e(all)h(of)f(the)h(killed)i(text)d (together,)f(so)h(that)g(when)h(y)o(ou)f(y)o(ank)g(it)h(bac)o(k,)f(y)o ! (ou)g(get)g(it)h(all.)22 b(The)75 293 y(kill)c(ring)f(is)f(not)g(line)i (sp)q(eci\014c;)g(the)e(text)g(that)f(y)o(ou)h(killed)j(on)d(a)g (previously)h(t)o(yp)q(ed)g(line)h(is)e(a)o(v)m(ailable)75 ! 348 y(to)f(b)q(e)g(y)o(ank)o(ed)g(bac)o(k)h(later,)e(when)i(y)o(ou)f ! (are)g(t)o(yping)g(another)g(line.)137 415 y(Here)h(is)f(the)h(list)g ! (of)e(commands)h(for)g(killing)j(text.)75 492 y Fo(h)p ! 87 466 56 2 v 87 494 a Fn(C-k)p 87 502 V 141 492 a Fo(i)315 ! 494 y Fu(Kill)f(the)f(text)e(from)h(the)g(curren)o(t)g(cursor)g(p)q ! (osition)h(to)f(the)g(end)h(of)f(the)g(line.)75 571 y ! Fo(h)p 87 545 64 2 v 87 573 a Fn(M-d)p 87 581 V 149 571 ! a Fo(i)315 573 y Fu(Kill)g(from)e(the)g(cursor)g(to)f(the)i(end)g(of)e (the)i(curren)o(t)f(w)o(ord,)f(or,)h(if)g(b)q(et)o(w)o(een)h(w)o(ords,) ! e(to)h(the)315 628 y(end)j(of)f(the)g(next)g(w)o(ord.)k(W)l(ord)c(b)q ! (oundaries)i(are)e(the)g(same)g(as)g(those)f(used)i(b)o(y)1728 ! 626 y Fo(h)p 1740 600 55 2 v 1740 628 a Fn(M-f)p 1740 ! 636 V 1793 626 a Fo(i)1808 628 y Fu(.)75 705 y Fo(h)p ! 87 679 118 2 v 87 707 a Fn(M-DEL)p 87 715 V 202 705 a ! Fo(i)315 707 y Fu(Kill)21 b(from)e(the)g(cursor)f(the)h(start)f(of)h ! (the)g(previous)h(w)o(ord,)f(or,)g(if)g(b)q(et)o(w)o(een)h(w)o(ords,)f ! (to)315 762 y(the)14 b(start)f(of)g(the)h(previous)g(w)o(ord.)19 b(W)l(ord)14 b(b)q(oundaries)h(are)e(the)h(same)g(as)f(those)h(used)g ! (b)o(y)315 815 y Fo(h)p 327 789 64 2 v 327 817 a Fn(M-b)p ! 327 825 V 389 815 a Fo(i)404 817 y Fu(.)75 894 y Fo(h)p ! 87 868 63 2 v 87 896 a Fn(C-w)p 87 904 V 148 894 a Fo(i)315 ! 896 y Fu(Kill)k(from)d(the)h(cursor)g(to)f(the)h(previous)h ! (whitespace.)22 b(This)17 b(is)f(di\013eren)o(t)g(than)1733 ! 894 y Fo(h)p 1745 868 118 2 v 1745 896 a Fn(M-DEL)p 1745 ! 904 V 1860 894 a Fo(i)315 951 y Fu(b)q(ecause)g(the)f(w)o(ord)g(b)q ! (oundaries)h(di\013er.)137 1030 y(Here)21 b(is)h(ho)o(w)e(to)g ! Fm(y)o(ank)j Fu(the)e(text)f(bac)o(k)h(in)o(to)g(the)f(line.)39 ! b(Y)l(anking)21 b(means)g(to)f(cop)o(y)h(the)g(most-)75 ! 1085 y(recen)o(tly-killed)d(text)d(from)f(the)i(kill)h(bu\013er.)75 ! 1163 y Fo(h)p 87 1137 56 2 v 87 1165 a Fn(C-y)p 87 1172 ! V 141 1163 a Fo(i)315 1165 y Fu(Y)l(ank)e(the)h(most)e(recen)o(tly)i ! (killed)h(text)e(bac)o(k)g(in)o(to)g(the)h(bu\013er)f(at)f(the)i ! (cursor.)75 1242 y Fo(h)p 87 1216 63 2 v 87 1244 a Fn(M-y)p ! 87 1252 V 148 1242 a Fo(i)315 1244 y Fu(Rotate)h(the)g(kill-ring,)j ! (and)d(y)o(ank)g(the)h(new)f(top.)26 b(Y)l(ou)17 b(can)h(only)g(do)f ! (this)h(if)f(the)h(prior)315 1299 y(command)d(is)568 ! 1297 y Fo(h)p 580 1271 56 2 v 580 1299 a Fn(C-y)p 580 ! 1306 V 634 1297 a Fo(i)664 1299 y Fu(or)719 1297 y Fo(h)p ! 732 1271 63 2 v 732 1299 a Fn(M-y)p 732 1306 V 792 1297 ! a Fo(i)807 1299 y Fu(.)75 1410 y Fl(1.2.4)30 b(Readline)20 ! b(Argumen)n(ts)137 1506 y Fu(Y)l(ou)15 b(can)g(pass)f(n)o(umeric)i ! (argumen)o(ts)e(to)g(Readline)i(commands.)k(Sometimes)15 ! b(the)g(argumen)o(t)e(acts)75 1561 y(as)20 b(a)g(rep)q(eat)g(coun)o(t,) ! h(other)f(times)g(it)h(is)g(the)f Fm(sign)h Fu(of)f(the)g(argumen)o(t)f ! (that)h(is)h(signi\014can)o(t.)36 b(If)20 b(y)o(ou)75 ! 1616 y(pass)d(a)f(negativ)o(e)h(argumen)o(t)f(to)g(a)g(command)h(whic)o ! (h)h(normally)f(acts)f(in)i(a)e(forw)o(ard)g(direction,)i(that)75 ! 1671 y(command)g(will)h(act)e(in)i(a)e(bac)o(kw)o(ard)g(direction.)28 ! b(F)l(or)17 b(example,)i(to)e(kill)j(text)d(bac)o(k)g(to)g(the)h(start) ! e(of)75 1726 y(the)f(line,)i(y)o(ou)e(migh)o(t)g(t)o(yp)q(e)g(`)p ! Ft(M--)f(C-k)p Fu('.)137 1793 y(The)h(general)f(w)o(a)o(y)f(to)h(pass)g ! (n)o(umeric)h(argumen)o(ts)e(to)g(a)h(command)g(is)h(to)e(t)o(yp)q(e)h ! (meta)g(digits)h(b)q(efore)75 1847 y(the)h(command.)k(If)c(the)f ! (\014rst)g(`digit')h(t)o(yp)q(ed)f(is)h(a)g(min)o(us)g(sign)g(\(`)p ! Ft(-)p Fu('\),)d(then)j(the)f(sign)h(of)f(the)h(argumen)o(t)75 ! 1902 y(will)g(b)q(e)f(negativ)o(e.)k(Once)c(y)o(ou)f(ha)o(v)o(e)g(t)o ! (yp)q(ed)g(one)h(meta)e(digit)i(to)f(get)f(the)h(argumen)o(t)g ! (started,)f(y)o(ou)h(can)75 1957 y(t)o(yp)q(e)19 b(the)g(remainder)g ! (of)f(the)h(digits,)h(and)f(then)g(the)g(command.)30 ! b(F)l(or)18 b(example,)i(to)e(giv)o(e)h(the)1793 1955 ! y Fo(h)p 1805 1929 57 2 v 1805 1957 a Fn(C-d)p 1805 1965 ! V 1860 1955 a Fo(i)75 2012 y Fu(command)c(an)g(argumen)o(t)g(of)f(10,)h ! (y)o(ou)f(could)j(t)o(yp)q(e)e(`)p Ft(M-1)f(0)h(C-d)p ! Fu('.)75 2123 y Fl(1.2.5)30 b(Searc)n(hing)21 b(for)f(Commands)h(in)f ! (the)h(History)137 2219 y Fu(Readline)e(pro)o(vides)d(commands)g(for)g ! (searc)o(hing)g(through)g(the)g(command)g(history)g(for)g(lines)i(con-) ! 75 2274 y(taining)e(a)f(sp)q(eci\014ed)i(string.)j(There)c(are)e(t)o(w) ! o(o)g(searc)o(h)h(mo)q(des:)20 b Fm(incremen)o(tal)e ! Fu(and)e Fm(non-incremen)o(tal)p Fu(.)137 2341 y(Incremen)o(tal)e ! (searc)o(hes)f(b)q(egin)h(b)q(efore)f(the)g(user)g(has)g(\014nished)h ! (t)o(yping)f(the)g(searc)o(h)g(string.)19 b(As)13 b(eac)o(h)75 ! 2396 y(c)o(haracter)k(of)g(the)h(searc)o(h)g(string)f(is)h(t)o(yp)q ! (ed,)h(Readline)h(displa)o(ys)e(the)g(next)g(en)o(try)f(from)g(the)h ! (history)75 2451 y(matc)o(hing)12 b(the)g(string)g(t)o(yp)q(ed)g(so)g ! (far.)18 b(An)13 b(incremen)o(tal)g(searc)o(h)f(requires)g(only)h(as)f ! (man)o(y)f(c)o(haracters)g(as)75 2506 y(needed)16 b(to)d(\014nd)j(the)e ! (desired)i(history)e(en)o(try)l(.)19 b(T)l(o)c(searc)o(h)f(bac)o(kw)o ! (ard)f(in)j(the)e(history)g(for)g(a)g(particular)75 2560 ! y(string,)g(t)o(yp)q(e)317 2558 y Fo(h)p 329 2532 51 ! 2 v 329 2560 a Fn(C-r)p 329 2568 V 378 2558 a Fo(i)393 ! 2560 y Fu(.)19 b(T)o(yping)580 2558 y Fo(h)p 592 2532 ! 52 2 v 592 2560 a Fn(C-s)p 592 2568 V 641 2558 a Fo(i)670 ! 2560 y Fu(searc)o(hes)14 b(forw)o(ard)f(through)g(the)h(history)l(.)20 ! b(The)14 b(c)o(haracters)f(presen)o(t)75 2615 y(in)20 ! b(the)f(v)m(alue)h(of)f(the)g Ft(isearch-terminators)d Fu(v)m(ariable)k(are)f(used)h(to)e(terminate)h(an)g(incremen)o(tal)75 ! 2670 y(searc)o(h.)29 b(If)19 b(that)e(v)m(ariable)j(has)e(not)g(b)q ! (een)i(assigned)f(a)f(v)m(alue,)i(the)1282 2668 y Fo(h)p ! 1294 2642 70 2 v 1294 2670 a Fn(ESC)p 1294 2678 V 1361 ! 2668 a Fo(i)1395 2670 y Fu(and)1486 2668 y Fo(h)p 1498 ! 2642 56 2 v 1498 2670 a Fn(C-J)p 1498 2678 V 1551 2668 ! a Fo(i)1585 2670 y Fu(c)o(haracters)d(will)p eop %%Page: 4 6 ! 4 5 bop 75 -58 a Fu(4)1322 b(GNU)15 b(Readline)i(Library)75 ! 183 y(terminate)k(an)f(incremen)o(tal)i(searc)o(h.)780 ! 181 y Fo(h)p 792 155 55 2 v 792 183 a Fn(C-g)p 792 191 ! V 845 181 a Fo(i)880 183 y Fu(will)g(ab)q(ort)e(an)h(incremen)o(tal)h ! (searc)o(h)e(and)h(restore)f(the)75 238 y(original)c(line.)21 b(When)15 b(the)f(searc)o(h)g(is)h(terminated,)g(the)f(history)h(en)o ! (try)f(con)o(taining)h(the)g(searc)o(h)f(string)75 293 ! y(b)q(ecomes)i(the)f(curren)o(t)g(line.)137 357 y(T)l(o)g(\014nd)h ! (other)e(matc)o(hing)h(en)o(tries)h(in)f(the)g(history)g(list,)h(t)o ! (yp)q(e)1231 355 y Fo(h)p 1243 329 51 2 v 1243 357 a ! Fn(C-r)p 1243 364 V 1292 355 a Fo(i)1322 357 y Fu(or)1377 ! 355 y Fo(h)p 1389 329 52 2 v 1389 357 a Fn(C-s)p 1389 ! 364 V 1438 355 a Fo(i)1468 357 y Fu(as)f(appropriate.)k(This)75 ! 412 y(will)c(searc)o(h)e(bac)o(kw)o(ard)f(or)g(forw)o(ard)g(in)i(the)f ! (history)g(for)g(the)g(next)g(en)o(try)g(matc)o(hing)g(the)g(searc)o(h) ! g(string)75 466 y(t)o(yp)q(ed)19 b(so)g(far.)30 b(An)o(y)19 ! b(other)f(k)o(ey)h(sequence)h(b)q(ound)g(to)e(a)h(Readline)i(command)d ! (will)j(terminate)e(the)75 521 y(searc)o(h)h(and)h(execute)g(that)f ! (command.)35 b(F)l(or)20 b(instance,)i(a)1151 519 y Fo(h)p ! 1163 493 76 2 v 1163 521 a Fn(RET)p 1163 529 V 1236 519 ! a Fo(i)1271 521 y Fu(will)g(terminate)f(the)f(searc)o(h)h(and)75 ! 576 y(accept)15 b(the)h(line,)g(thereb)o(y)f(executing)i(the)e(command) ! g(from)g(the)g(history)g(list.)137 640 y(Non-incremen)o(tal)25 ! b(searc)o(hes)e(read)h(the)f(en)o(tire)h(searc)o(h)f(string)g(b)q ! (efore)h(starting)f(to)f(searc)o(h)i(for)75 695 y(matc)o(hing)d ! (history)h(lines.)39 b(The)22 b(searc)o(h)f(string)g(ma)o(y)g(b)q(e)h ! (t)o(yp)q(ed)f(b)o(y)h(the)f(user)h(or)e(b)q(e)i(part)f(of)g(the)75 ! 750 y(con)o(ten)o(ts)15 b(of)f(the)i(curren)o(t)f(line.)75 ! 868 y Fs(1.3)33 b(Readline)23 b(Init)h(File)137 961 y ! Fu(Although)f(the)g(Readline)i(library)e(comes)g(with)g(a)f(set)g(of)g ! (Emacs-lik)o(e)i(k)o(eybindings)g(installed)75 1016 y(b)o(y)d(default,) ! h(it)f(is)h(p)q(ossible)g(to)e(use)i(a)e(di\013eren)o(t)h(set)g(of)f(k) ! o(eybindings.)39 b(An)o(y)20 b(user)h(can)g(customize)75 ! 1071 y(programs)15 b(that)h(use)g(Readline)j(b)o(y)d(putting)g ! (commands)g(in)i(an)e Fm(inputrc)k Fu(\014le,)d(con)o(v)o(en)o ! (tionally)g(in)g(his)75 1126 y(home)g(directory)l(.)24 ! b(The)17 b(name)g(of)f(this)h(\014le)g(is)g(tak)o(en)g(from)e(the)i(v)m ! (alue)h(of)e(the)h(en)o(vironmen)o(t)g(v)m(ariable)75 ! 1181 y Ft(INPUTRC)p Fu(.)i(If)c(that)g(v)m(ariable)h(is)g(unset,)f(the) ! g(default)h(is)g(`)p Ft(~/.inputrc)p Fu('.)137 1244 y(When)f(a)g ! (program)f(whic)o(h)h(uses)g(the)g(Readline)i(library)f(starts)d(up,)i ! (the)g(init)h(\014le)g(is)f(read,)g(and)g(the)75 1299 ! y(k)o(ey)g(bindings)i(are)e(set.)137 1363 y(In)f(addition,)h(the)e Ft(C-x)i(C-r)e Fu(command)g(re-reads)h(this)g(init)g(\014le,)h(th)o(us) ! e(incorp)q(orating)h(an)o(y)f(c)o(hanges)75 1418 y(that)h(y)o(ou)h ! (migh)o(t)g(ha)o(v)o(e)g(made)g(to)g(it.)75 1520 y Fl(1.3.1)30 ! b(Readline)20 b(Init)g(File)h(Syn)n(tax)137 1613 y Fu(There)c(are)g (only)g(a)g(few)f(basic)i(constructs)e(allo)o(w)o(ed)i(in)f(the)g ! (Readline)i(init)f(\014le.)26 b(Blank)18 b(lines)g(are)75 ! 1668 y(ignored.)36 b(Lines)22 b(b)q(eginning)h(with)d(a)h(`)p Ft(#)p Fu(')e(are)h(commen)o(ts.)35 b(Lines)22 b(b)q(eginning)h(with)e ! (a)f(`)p Ft($)p Fu(')f(indicate)75 1723 y(conditional)c(constructs)f (\(see)g(Section)g(1.3.2)f([Conditional)h(Init)h(Constructs],)e(page)h ! (8\).)k(Other)c(lines)75 1778 y(denote)h(v)m(ariable)i(settings)e(and)h ! (k)o(ey)f(bindings.)75 1851 y(V)l(ariable)h(Settings)315 ! 1906 y(Y)l(ou)k(can)h(mo)q(dify)g(the)f(run-time)h(b)q(eha)o(vior)g(of) ! e(Readline)k(b)o(y)d(altering)h(the)f(v)m(alues)h(of)315 ! 1960 y(v)m(ariables)13 b(in)g(Readline)i(using)d(the)g ! Ft(set)g Fu(command)g(within)h(the)f(init)h(\014le.)20 ! b(Here)13 b(is)f(ho)o(w)g(to)315 2015 y(c)o(hange)e(from)g(the)g ! (default)h(Emacs-lik)o(e)g(k)o(ey)f(binding)i(to)e(use)g ! Ft(vi)g Fu(line)i(editing)g(commands:)435 2076 y Ft(set)23 ! b(editing-mode)g(vi)315 2140 y Fu(A)15 b(great)g(deal)g(of)g(run-time)h ! (b)q(eha)o(vior)g(is)g(c)o(hangeable)g(with)f(the)h(follo)o(wing)f(v)m ! (ariables.)315 2213 y Ft(bell-style)555 2268 y Fu(Con)o(trols)21 ! b(what)h(happ)q(ens)h(when)f(Readline)i(w)o(an)o(ts)d(to)g(ring)i(the)f ! (termi-)555 2323 y(nal)d(b)q(ell.)32 b(If)19 b(set)f(to)g(`)p ! Ft(none)p Fu(',)g(Readline)j(nev)o(er)e(rings)g(the)f(b)q(ell.)32 ! b(If)19 b(set)g(to)555 2378 y(`)p Ft(visible)p Fu(',)c(Readline)j(uses) ! f(a)f(visible)j(b)q(ell)g(if)e(one)f(is)h(a)o(v)m(ailable.)26 ! b(If)16 b(set)h(to)555 2432 y(`)p Ft(audible)p Fu(')g(\(the)h ! (default\),)i(Readline)h(attempts)d(to)g(ring)h(the)g(terminal's)555 ! 2487 y(b)q(ell.)315 2560 y Ft(comment-begin)555 2615 ! y Fu(The)c(string)f(to)g(insert)i(at)d(the)i(b)q(eginning)i(of)d(the)h ! (line)h(when)f(the)g Ft(insert-)555 2670 y(comment)f ! Fu(command)h(is)h(executed.)21 b(The)15 b(default)h(v)m(alue)g(is)g ! Ft("#")p Fu(.)p eop %%Page: 5 7 5 6 bop 75 -58 a Fu(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1077 ! b(5)315 183 y Ft(completion-ignore-case)555 238 y Fu(If)14 ! b(set)f(to)g(`)p Ft(on)p Fu(',)g(Readline)j(p)q(erforms)d(\014lename)i ! (matc)o(hing)f(and)g(completion)555 293 y(in)i(a)f(case-insensitiv)o(e) ! i(fashion.)k(The)15 b(default)h(v)m(alue)g(is)g(`)p Ft(off)p ! Fu('.)315 384 y Ft(completion-query-items)555 439 y Fu(The)d(n)o(um)o ! (b)q(er)h(of)e(p)q(ossible)j(completions)g(that)d(determines)i(when)g ! (the)f(user)555 494 y(is)21 b(ask)o(ed)g(whether)g(he)h(w)o(an)o(ts)d ! (to)i(see)g(the)g(list)h(of)e(p)q(ossibilitie)q(s.)40 ! b(If)21 b(the)555 549 y(n)o(um)o(b)q(er)14 b(of)f(p)q(ossible)i ! (completions)f(is)g(greater)f(than)g(this)h(v)m(alue,)h(Readline)555 ! 604 y(will)g(ask)e(the)g(user)h(whether)f(or)g(not)g(he)g(wishes)h(to)f ! (view)h(them;)f(otherwise,)555 658 y(they)i(are)g(simply)i(listed.)k ! (The)15 b(default)h(limit)h(is)e Ft(100)p Fu(.)315 750 ! y Ft(convert-meta)555 805 y Fu(If)i(set)g(to)g(`)p Ft(on)p ! Fu(',)f(Readline)k(will)e(con)o(v)o(ert)f(c)o(haracters)f(with)i(the)f ! (eigh)o(th)g(bit)555 860 y(set)f(to)f(an)h(ASCI)q(I)h(k)o(ey)f ! (sequence)h(b)o(y)f(stripping)h(the)f(eigh)o(th)h(bit)f(and)h(pre-)555 ! 915 y(\014xing)i(an)749 913 y Fo(h)p 761 887 70 2 v 761 ! 915 a Fn(ESC)p 761 922 V 828 913 a Fo(i)861 915 y Fu(c)o(haracter,)f ! (con)o(v)o(erting)g(them)g(to)g(a)f(meta-pre\014xed)i(k)o(ey)555 ! 969 y(sequence.)i(The)15 b(default)h(v)m(alue)h(is)e(`)p ! Ft(on)p Fu('.)315 1061 y Ft(disable-completion)555 1116 ! y Fu(If)k(set)f(to)f(`)p Ft(On)p Fu(',)h(Readline)j(will)f(inhibit)g(w) ! o(ord)e(completion.)30 b(Completion)555 1171 y(c)o(haracters)12 ! b(will)j(b)q(e)f(inserted)g(in)o(to)f(the)g(line)h(as)f(if)h(they)f ! (had)g(b)q(een)h(mapp)q(ed)555 1225 y(to)h Ft(self-insert)p ! Fu(.)j(The)d(default)h(is)g(`)p Ft(off)p Fu('.)315 1317 ! y Ft(editing-mode)555 1372 y Fu(The)f Ft(editing-mode)d ! Fu(v)m(ariable)k(con)o(trols)e(whic)o(h)h(default)g(set)f(of)g(k)o(ey)g ! (bind-)555 1427 y(ings)f(is)g(used.)20 b(By)12 b(default,)i(Readline)g ! (starts)e(up)h(in)g(Emacs)f(editing)i(mo)q(de,)555 1481 ! y(where)h(the)f(k)o(eystrok)o(es)g(are)g(most)g(similar)i(to)d(Emacs.) ! 20 b(This)15 b(v)m(ariable)h(can)555 1536 y(b)q(e)g(set)f(to)f(either)i ! (`)p Ft(emacs)p Fu(')e(or)h(`)p Ft(vi)p Fu('.)315 1628 ! y Ft(enable-keypad)555 1683 y Fu(When)d(set)f(to)h(`)p ! Ft(on)p Fu(',)e(Readline)k(will)g(try)d(to)g(enable)i(the)f ! (application)h(k)o(eypad)555 1737 y(when)h(it)f(is)h(called.)21 ! b(Some)13 b(systems)g(need)h(this)g(to)f(enable)h(the)g(arro)o(w)e(k)o ! (eys.)555 1792 y(The)j(default)h(is)g(`)p Ft(off)p Fu('.)315 ! 1884 y Ft(expand-tilde)555 1939 y Fu(If)e(set)g(to)f(`)p ! Ft(on)p Fu(',)f(tilde)k(expansion)e(is)h(p)q(erformed)f(when)g ! (Readline)i(attempts)555 1994 y(w)o(ord)f(completion.)21 ! b(The)15 b(default)h(is)f(`)p Ft(off)p Fu('.)315 2085 ! y Ft(horizontal-scroll-mode)555 2140 y Fu(This)k(v)m(ariable)g(can)f(b) ! q(e)g(set)g(to)f(either)i(`)p Ft(on)p Fu(')e(or)g(`)p ! Ft(off)p Fu('.)27 b(Setting)19 b(it)f(to)f(`)p Ft(on)p ! Fu(')555 2195 y(means)c(that)f(the)i(text)e(of)h(the)g(lines)i(b)q ! (eing)f(edited)g(will)h(scroll)f(horizon)o(tally)555 ! 2250 y(on)i(a)f(single)i(screen)g(line)g(when)g(they)f(are)f(longer)h ! (than)g(the)g(width)g(of)g(the)555 2304 y(screen,)e(instead)f(of)g (wrapping)g(on)o(to)f(a)h(new)g(screen)h(line.)21 b(By)13 ! b(default,)h(this)555 2359 y(v)m(ariable)j(is)e(set)g(to)g(`)p ! Ft(off)p Fu('.)315 2451 y Ft(input-meta)555 2506 y Fu(If)h(set)g(to)f ! (`)p Ft(on)p Fu(',)f(Readline)k(will)g(enable)f(eigh)o(t-bit)f(input)h ! (\(it)f(will)h(not)f(strip)555 2560 y(the)f(eigh)o(th)g(bit)h(from)e ! (the)h(c)o(haracters)f(it)i(reads\),)e(regardless)h(of)f(what)h(the)555 ! 2615 y(terminal)21 b(claims)g(it)f(can)g(supp)q(ort.)34 ! b(The)20 b(default)h(v)m(alue)g(is)g(`)p Ft(off)p Fu('.)33 ! b(The)555 2670 y(name)15 b Ft(meta-flag)f Fu(is)i(a)f(synon)o(ym)g(for) ! f(this)i(v)m(ariable.)p eop %%Page: 6 8 ! 6 7 bop 75 -58 a Fu(6)1322 b(GNU)15 b(Readline)i(Library)315 ! 183 y Ft(isearch-terminators)555 238 y Fu(The)26 b(string)g(of)f(c)o ! (haracters)g(that)g(should)i(terminate)f(an)g(incremen)o(tal)555 ! 293 y(searc)o(h)e(without)h(subsequen)o(tly)g(executing)h(the)e(c)o ! (haracter)g(as)g(a)g(com-)555 348 y(mand)19 b(\(see)f(Section)i(1.2.5)d ! ([Searc)o(hing],)i(page)f(3\).)29 b(If)19 b(this)g(v)m(ariable)h(has) ! 555 402 y(not)13 b(b)q(een)h(giv)o(en)g(a)f(v)m(alue,)i(the)e(c)o ! (haracters)1312 400 y Fo(h)p 1324 374 70 2 v 1324 402 ! a Fn(ESC)p 1324 410 V 1391 400 a Fo(i)1419 402 y Fu(and)1505 ! 400 y Fo(h)p 1518 374 56 2 v 1518 402 a Fn(C-J)p 1518 ! 410 V 1571 400 a Fo(i)1599 402 y Fu(will)i(terminate)555 ! 457 y(an)g(incremen)o(tal)h(searc)o(h.)315 540 y Ft(keymap)114 ! b Fu(Sets)17 b(Readline's)j(idea)e(of)f(the)h(curren)o(t)g(k)o(eymap)f ! (for)g(k)o(ey)g(binding)j(com-)555 595 y(mands.)41 b(Acceptable)23 ! b Ft(keymap)f Fu(names)g(are)f Ft(emacs)p Fu(,)i Ft(emacs-standard)p ! Fu(,)555 650 y Ft(emacs-meta)p Fu(,)15 b Ft(emacs-ctlx)p ! Fu(,)h Ft(vi)p Fu(,)g Ft(vi-command)p Fu(,)g(and)h Ft(vi-insert)p ! Fu(.)23 b Ft(vi)16 b Fu(is)555 705 y(equiv)m(alen)o(t)e(to)f ! Ft(vi-command)p Fu(;)e Ft(emacs)h Fu(is)i(equiv)m(alen)o(t)g(to)e ! Ft(emacs-standard)p Fu(.)555 759 y(The)f(default)h(v)m(alue)g(is)f ! Ft(emacs)p Fu(.)18 b(The)11 b(v)m(alue)i(of)d(the)h Ft(editing-mode)f ! Fu(v)m(ariable)555 814 y(also)15 b(a\013ects)g(the)g(default)h(k)o ! (eymap.)315 897 y Ft(mark-directories)555 952 y Fu(If)j(set)g(to)g(`)p ! Ft(on)p Fu(',)f(completed)i(directory)g(names)f(ha)o(v)o(e)f(a)h(slash) ! h(app)q(ended.)555 1007 y(The)15 b(default)h(is)g(`)p ! Ft(on)p Fu('.)315 1090 y Ft(mark-modified-lines)555 1145 ! y Fu(This)j(v)m(ariable,)g(when)g(set)e(to)h(`)p Ft(on)p ! Fu(',)f(causes)h(Readline)i(to)d(displa)o(y)i(an)f(as-)555 ! 1200 y(terisk)f(\(`)p Ft(*)p Fu('\))e(at)i(the)f(start)g(of)h(history)f ! (lines)j(whic)o(h)e(ha)o(v)o(e)g(b)q(een)h(mo)q(di\014ed.)555 ! 1254 y(This)e(v)m(ariable)g(is)g(`)p Ft(off)p Fu(')e(b)o(y)h(default.) ! 315 1337 y Ft(output-meta)555 1392 y Fu(If)j(set)f(to)g(`)p ! Ft(on)p Fu(',)g(Readline)j(will)g(displa)o(y)f(c)o(haracters)d(with)j ! (the)e(eigh)o(th)h(bit)555 1447 y(set)g(directly)i(rather)d(than)h(as)g ! (a)g(meta-pre\014xed)h(escap)q(e)g(sequence.)30 b(The)555 ! 1502 y(default)16 b(is)f(`)p Ft(off)p Fu('.)315 1585 ! y Ft(print-completions-horizont)o(ally)555 1640 y Fu(If)d(set)g(to)f(`) ! p Ft(on)p Fu(',)h(Readline)i(will)f(displa)o(y)h(completions)f(with)f ! (matc)o(hes)f(sorted)555 1694 y(horizon)o(tally)23 b(in)f(alphab)q ! (etical)i(order,)f(rather)e(than)g(do)o(wn)h(the)g(screen.)555 ! 1749 y(The)15 b(default)h(is)g(`)p Ft(off)p Fu('.)315 ! 1832 y Ft(show-all-if-ambiguous)555 1887 y Fu(This)g(alters)e(the)i ! (default)f(b)q(eha)o(vior)h(of)e(the)h(completion)h(functions.)21 ! b(If)15 b(set)555 1942 y(to)e(`)p Ft(on)p Fu(',)g(w)o(ords)g(whic)o(h)h ! (ha)o(v)o(e)g(more)f(than)g(one)h(p)q(ossible)i(completion)f(cause)555 ! 1997 y(the)20 b(matc)o(hes)f(to)f(b)q(e)j(listed)f(immediately)h ! (instead)f(of)f(ringing)i(the)e(b)q(ell.)555 2051 y(The)c(default)h(v)m ! (alue)h(is)e(`)p Ft(off)p Fu('.)315 2134 y Ft(visible-stats)555 ! 2189 y Fu(If)h(set)g(to)f(`)p Ft(on)p Fu(',)g(a)h(c)o(haracter)f ! (denoting)h(a)g(\014le's)h(t)o(yp)q(e)f(is)g(app)q(ended)i(to)d(the)555 ! 2244 y(\014lename)h(when)g(listing)h(p)q(ossible)g(completions.)j(The)c ! (default)g(is)f(`)p Ft(off)p Fu('.)75 2327 y(Key)h(Bindings)315 ! 2382 y(The)21 b(syn)o(tax)f(for)h(con)o(trolling)h(k)o(ey)f(bindings)h (in)g(the)f(init)h(\014le)g(is)g(simple.)39 b(First)20 ! b(y)o(ou)315 2437 y(need)15 b(to)e(\014nd)h(the)g(name)g(of)g(the)f (command)h(that)f(y)o(ou)h(w)o(an)o(t)f(to)g(c)o(hange.)19 ! b(The)14 b(follo)o(wing)315 2491 y(sections)k(con)o(tain)h(tables)f(of) ! f(the)h(command)g(name,)g(the)g(default)h(k)o(eybinding,)h(if)e(an)o(y) ! l(,)315 2546 y(and)d(a)g(short)g(description)i(of)d(what)h(the)g ! (command)g(do)q(es.)315 2615 y(Once)j(y)o(ou)g(kno)o(w)e(the)i(name)f ! (of)g(the)h(command,)f(simply)i(place)g(the)e(name)h(of)f(the)g(k)o(ey) ! 315 2670 y(y)o(ou)c(wish)h(to)f(bind)i(the)f(command)f(to,)g(a)g ! (colon,)h(and)g(then)f(the)h(name)f(of)h(the)f(command)p ! eop %%Page: 7 9 7 8 bop 75 -58 a Fu(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1077 ! b(7)315 183 y(on)19 b(a)g(line)i(in)f(the)g(init)g(\014le.)34 ! b(The)19 b(name)h(of)e(the)i(k)o(ey)f(can)h(b)q(e)g(expressed)g(in)g ! (di\013eren)o(t)315 238 y(w)o(a)o(ys,)14 b(dep)q(ending)j(on)e(whic)o ! (h)h(is)g(most)e(comfortable)h(for)g(y)o(ou.)315 316 ! y Fm(k)o(eyname)s Fu(:)k Fm(function-name)g Fu(or)c Fm(macro)555 ! 371 y(k)o(eyname)i Fu(is)e(the)f(name)h(of)f(a)g(k)o(ey)g(sp)q(elled)j ! (out)d(in)h(English.)21 b(F)l(or)13 b(example:)675 435 ! y Ft(Control-u:)22 b(universal-argument)675 487 y(Meta-Rubout:)g ! (backward-kill-word)675 538 y(Control-o:)g(">)i(output")555 ! 605 y Fu(In)19 b(the)f(ab)q(o)o(v)o(e)g(example,)1023 ! 603 y Fo(h)p 1035 577 57 2 v 1035 605 a Fn(C-u)p 1035 ! 613 V 1090 603 a Fo(i)1123 605 y Fu(is)h(b)q(ound)g(to)f(the)g ! (function)h Ft(universal-)555 660 y(argument)p Fu(,)g(and)872 ! 658 y Fo(h)p 884 632 55 2 v 884 660 a Fn(C-o)p 884 667 ! V 937 658 a Fo(i)971 660 y Fu(is)h(b)q(ound)g(to)f(run)h(the)f(macro)g ! (expressed)h(on)g(the)555 715 y(righ)o(t)13 b(hand)h(side)h(\(that)e ! (is,)h(to)f(insert)h(the)g(text)f(`)p Ft(>)h(output)p ! Fu(')f(in)o(to)g(the)h(line\).)315 793 y Ft(")p Fm(k)o(eyseq)q ! Ft(")p Fu(:)20 b Fm(function-name)e Fu(or)d Fm(macro)555 ! 848 y(k)o(eyseq)i Fu(di\013ers)e(from)g Fm(k)o(eyname)j ! Fu(ab)q(o)o(v)o(e)d(in)i(that)d(strings)i(denoting)g(an)f(en-)555 ! 902 y(tire)i(k)o(ey)g(sequence)h(can)f(b)q(e)g(sp)q(eci\014ed,)i(b)o(y) ! e(placing)h(the)f(k)o(ey)g(sequence)h(in)555 957 y(double)e(quotes.)j ! (Some)c Fp(gnu)g Fu(Emacs)f(st)o(yle)h(k)o(ey)g(escap)q(es)g(can)g(b)q ! (e)g(used,)g(as)555 1012 y(in)j(the)f(follo)o(wing)g(example,)h(but)f ! (the)g(sp)q(ecial)i(c)o(haracter)d(names)h(are)f(not)555 ! 1067 y(recognized.)675 1130 y Ft("\\C-u":)23 b(universal-argument)675 ! 1182 y("\\C-x\\C-r":)f(re-read-init-file)675 1234 y("\\e[11~":)h ! ("Function)f(Key)i(1")555 1301 y Fu(In)19 b(the)f(ab)q(o)o(v)o(e)g ! (example,)1023 1299 y Fo(h)p 1035 1273 57 2 v 1035 1301 ! a Fn(C-u)p 1035 1308 V 1090 1299 a Fo(i)1123 1301 y Fu(is)h(b)q(ound)g ! (to)f(the)g(function)h Ft(universal-)555 1355 y(argument)9 ! b Fu(\(just)h(as)h(it)g(w)o(as)e(in)j(the)e(\014rst)h(example\),)g(`) ! 1463 1353 y Fo(h)p 1475 1327 56 2 v 1475 1355 a Fn(C-x)p ! 1475 1363 V 1529 1353 a Fo(i)k(h)p 1571 1327 51 2 v 1571 ! 1355 a Fn(C-r)p 1571 1363 V 1620 1353 a Fo(i)1635 1355 ! y Fu(')10 b(is)h(b)q(ound)h(to)555 1410 y(the)k(function)i ! Ft(re-read-init-file)p Fu(,)c(and)i(`)1351 1408 y Fo(h)p ! 1363 1382 70 2 v 1363 1410 a Fn(ESC)p 1363 1418 V 1430 ! 1408 a Fo(i)f(h)p 1472 1382 10 2 v 1472 1410 a Fn([)p ! 1472 1419 V 1480 1408 a Fo(i)g(h)p 1522 1382 18 2 v 1522 ! 1410 a Fn(1)p 1522 1418 V 1538 1408 a Fo(i)g(h)p 1580 ! 1382 V 1580 1410 a Fn(1)p 1580 1418 V 1595 1408 a Fo(i)g(h)p ! 1637 1382 24 2 v 1637 1410 a Ft(~)p 1637 1418 V 1659 ! 1408 a Fo(i)1674 1410 y Fu(')h(is)h(b)q(ound)555 1465 ! y(to)e(insert)g(the)g(text)g(`)p Ft(Function)f(Key)h(1)p ! Fu('.)315 1543 y(The)g(follo)o(wing)h Fp(gnu)e Fu(Emacs)h(st)o(yle)g ! (escap)q(e)h(sequences)g(are)e(a)o(v)m(ailable)j(when)e(sp)q(ecifying) ! 315 1598 y(k)o(ey)g(sequences:)315 1676 y Fk(\\C-)168 ! b Fu(con)o(trol)15 b(pre\014x)315 1755 y Fk(\\M-)168 ! b Fu(meta)15 b(pre\014x)315 1833 y Fk(\\e)192 b Fu(an)15 ! b(escap)q(e)h(c)o(haracter)315 1911 y Fk(\\\\)192 b Fu(bac)o(kslash)315 ! 1989 y Fk(\\)p Ft(")555 1987 y Fo(h)p 567 1961 V 567 ! 1989 a Ft(")p 567 1997 V 589 1987 a Fo(i)604 1989 y Fu(,)15 ! b(a)f(double)j(quotation)e(mark)315 2068 y Fk(\\')555 ! 2066 y Fo(h)p 567 2040 10 2 v 567 2068 a Fn(')p 567 2075 ! V 575 2066 a Fo(i)590 2068 y Fu(,)g(a)f(single)j(quote)e(or)g(ap)q ! (ostrophe)315 2146 y(In)f(addition)h(to)f(the)f Fp(gnu)h ! Fu(Emacs)g(st)o(yle)f(escap)q(e)i(sequences,)g(a)e(second)i(set)e(of)h ! (bac)o(kslash)315 2201 y(escap)q(es)i(is)g(a)o(v)m(ailable:)315 ! 2279 y Ft(\\a)192 b Fu(alert)15 b(\(b)q(ell\))315 2357 ! y Ft(\\b)192 b Fu(bac)o(kspace)315 2435 y Ft(\\d)g Fu(delete)315 ! 2514 y Ft(\\f)g Fu(form)14 b(feed)315 2592 y Ft(\\n)192 ! b Fu(newline)315 2670 y Ft(\\r)g Fu(carriage)15 b(return)p eop %%Page: 8 10 ! 8 9 bop 75 -58 a Fu(8)1322 b(GNU)15 b(Readline)i(Library)315 ! 183 y Ft(\\t)192 b Fu(horizon)o(tal)16 b(tab)315 262 ! y Ft(\\v)192 b Fu(v)o(ertical)16 b(tab)315 340 y Ft(\\)p ! Fm(nnn)141 b Fu(the)13 b(c)o(haracter)e(whose)i Ft(ASCII)e ! Fu(co)q(de)j(is)f(the)f(o)q(ctal)h(v)m(alue)h Fm(nnn)f ! Fu(\(one)f(to)g(three)555 395 y(digits\))315 473 y Ft(\\x)p ! Fm(nnn)117 b Fu(the)15 b(c)o(haracter)e(whose)i Ft(ASCII)e ! Fu(co)q(de)j(is)f(the)f(hexadecimal)i(v)m(alue)g Fm(nnn)f ! Fu(\(one)555 528 y(to)g(three)g(digits\))315 607 y(When)k(en)o(tering)g ! (the)g(text)f(of)g(a)h(macro,)f(single)i(or)e(double)i(quotes)f(m)o ! (ust)f(b)q(e)h(used)h(to)315 662 y(indicate)12 b(a)f(macro)f ! (de\014nition.)20 b(Unquoted)11 b(text)f(is)i(assumed)e(to)h(b)q(e)g(a) ! f(function)i(name.)18 b(In)315 716 y(the)11 b(macro)f(b)q(o)q(dy)l(,)i ! (the)f(bac)o(kslash)g(escap)q(es)g(describ)q(ed)i(ab)q(o)o(v)o(e)d(are) ! g(expanded.)20 b(Bac)o(kslash)315 771 y(will)i(quote)d(an)o(y)h(other)g ! (c)o(haracter)f(in)i(the)f(macro)f(text,)h(including)j(`)p ! Ft(")p Fu(')c(and)h(`)p Ft(')p Fu('.)34 b(F)l(or)315 ! 826 y(example,)14 b(the)f(follo)o(wing)g(binding)i(will)g(mak)o(e)d(`)p ! Ft(C-x)i(\\)p Fu(')f(insert)g(a)g(single)h(`)p Ft(\\)p ! Fu(')e(in)o(to)h(the)g(line:)435 890 y Ft("\\C-x\\\\":)23 ! b("\\\\")75 1000 y Fl(1.3.2)30 b(Conditional)20 b(Init)g(Constructs)137 ! 1096 y Fu(Readline)g(implemen)o(ts)f(a)f(facilit)o(y)g(similar)h(in)g ! (spirit)f(to)f(the)h(conditional)h(compilation)g(features)75 ! 1150 y(of)e(the)g(C)g(prepro)q(cessor)g(whic)o(h)i(allo)o(ws)e(k)o(ey)g ! (bindings)i(and)f(v)m(ariable)g(settings)f(to)g(b)q(e)h(p)q(erformed)f ! (as)75 1205 y(the)e(result)h(of)f(tests.)k(There)c(are)g(four)g(parser) ! g(directiv)o(es)h(used.)75 1284 y Ft($if)168 b Fu(The)16 ! b Ft($if)f Fu(construct)g(allo)o(ws)h(bindings)i(to)d(b)q(e)h(made)g ! (based)g(on)f(the)h(editing)h(mo)q(de,)f(the)315 1338 ! y(terminal)k(b)q(eing)g(used,)g(or)f(the)g(application)i(using)e ! (Readline.)34 b(The)19 b(text)g(of)f(the)i(test)315 1393 ! y(extends)c(to)e(the)h(end)h(of)f(the)g(line;)i(no)e(c)o(haracters)f ! (are)h(required)i(to)d(isolate)i(it.)315 1472 y Ft(mode)144 ! b Fu(The)11 b Ft(mode=)e Fu(form)h(of)g(the)h Ft($if)f ! Fu(directiv)o(e)h(is)g(used)g(to)f(test)g(whether)h(Readline)555 ! 1527 y(is)k(in)h Ft(emacs)e Fu(or)g Ft(vi)g Fu(mo)q(de.)20 b(This)c(ma)o(y)e(b)q(e)h(used)g(in)h(conjunction)g(with)f(the)555 ! 1581 y(`)p Ft(set)f(keymap)p Fu(')f(command,)g(for)h(instance,)g(to)f ! (set)h(bindings)h(in)g(the)f Ft(emacs-)555 1636 y(standard)d ! Fu(and)i Ft(emacs-ctlx)e Fu(k)o(eymaps)h(only)i(if)f(Readline)h(is)f ! (starting)f(out)555 1691 y(in)k Ft(emacs)f Fu(mo)q(de.)315 ! 1769 y Ft(term)144 b Fu(The)14 b Ft(term=)e Fu(form)h(ma)o(y)g(b)q(e)h (used)g(to)f(include)j(terminal-sp)q(eci\014c)g(k)o(ey)d(bind-)555 ! 1824 y(ings,)19 b(p)q(erhaps)g(to)e(bind)i(the)g(k)o(ey)e(sequences)j ! (output)e(b)o(y)g(the)g(terminal's)555 1879 y(function)13 b(k)o(eys.)18 b(The)13 b(w)o(ord)e(on)h(the)g(righ)o(t)g(side)g(of)g ! (the)g(`)p Ft(=)p Fu(')f(is)h(tested)g(against)555 1934 y(b)q(oth)j(the)g(full)i(name)e(of)f(the)h(terminal)h(and)f(the)g(p)q ! (ortion)h(of)e(the)h(terminal)555 1989 y(name)i(b)q(efore)g(the)g (\014rst)f(`)p Ft(-)p Fu('.)24 b(This)17 b(allo)o(ws)g Ft(sun)f Fu(to)g(matc)o(h)h(b)q(oth)f Ft(sun)h Fu(and)555 ! 2043 y Ft(sun-cmd)p Fu(,)d(for)g(instance.)315 2122 y ! Ft(application)555 2177 y Fu(The)d Fm(application)i Fu(construct)e(is)g ! (used)h(to)e(include)j(application-sp)q(eci)q(\014c)h(set-)555 ! 2231 y(tings.)19 b(Eac)o(h)12 b(program)f(using)j(the)e(Readline)j ! (library)e(sets)f(the)g Fm(application)555 2286 y(name)p ! Fu(,)17 b(and)f(y)o(ou)h(can)f(test)g(for)g(it.)24 b(This)18 ! b(could)f(b)q(e)g(used)g(to)f(bind)i(k)o(ey)f(se-)555 ! 2341 y(quences)c(to)e(functions)i(useful)g(for)e(a)h(sp)q(eci\014c)i ! (program.)j(F)l(or)12 b(instance,)h(the)555 2396 y(follo)o(wing)i ! (command)f(adds)g(a)f(k)o(ey)h(sequence)h(that)f(quotes)f(the)i(curren) ! o(t)e(or)555 2451 y(previous)j(w)o(ord)e(in)i(Bash:)675 ! 2514 y Ft($if)23 b(Bash)675 2566 y(#)h(Quote)f(the)g(current)g(or)h ! (previous)f(word)675 2618 y("\\C-xq":)g("\\eb\\"\\ef\\"")675 ! 2670 y($endif)p eop %%Page: 9 11 9 10 bop 75 -58 a Fu(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1077 ! b(9)75 183 y Ft($endif)96 b Fu(This)16 b(command,)e(as)h(seen)h(in)g ! (the)f(previous)h(example,)g(terminates)f(an)g Ft($if)f ! Fu(command.)75 263 y Ft($else)120 b Fu(Commands)15 b(in)h(this)f(branc) o(h)h(of)e(the)i Ft($if)e Fu(directiv)o(e)j(are)e(executed)h(if)g(the)f ! (test)g(fails.)75 343 y Ft($include)48 b Fu(This)14 b(directiv)o(e)i ! (tak)o(es)d(a)g(single)i(\014lename)g(as)f(an)f(argumen)o(t)g(and)h ! (reads)g(commands)g(and)315 397 y(bindings)j(from)e(that)f(\014le.)435 ! 462 y Ft($include)23 b(/etc/inputrc)75 574 y Fl(1.3.3)30 ! b(Sample)20 b(Init)h(File)137 670 y Fu(Here)16 b(is)g(an)f(example)h ! (of)f(an)h(inputrc)g(\014le.)22 b(This)16 b(illustrates)g(k)o(ey)g ! (binding,)h(v)m(ariable)f(assignmen)o(t,)75 725 y(and)f(conditional)i ! (syn)o(tax.)p eop %%Page: 10 12 ! 10 11 bop 75 -58 a Fu(10)1299 b(GNU)15 b(Readline)i(Library)195 ! 235 y Ft(#)24 b(This)f(file)g(controls)g(the)h(behaviour)e(of)i(line)f ! (input)g(editing)g(for)195 287 y(#)h(programs)e(that)i(use)f(the)h(Gnu) f(Readline)g(library.)47 b(Existing)22 b(programs)195 ! 339 y(#)i(include)f(FTP,)g(Bash,)g(and)h(Gdb.)195 391 ! y(#)195 443 y(#)g(You)f(can)h(re-read)f(the)g(inputrc)g(file)g(with)h ! (C-x)f(C-r.)195 495 y(#)h(Lines)f(beginning)g(with)g('#')g(are)h ! (comments.)195 546 y(#)195 598 y(#)g(First,)f(include)g(any)g (systemwide)g(bindings)f(and)i(variable)f(assignments)f(from)195 ! 650 y(#)i(/etc/Inputrc)195 702 y($include)f(/etc/Inputrc)195 ! 806 y(#)195 858 y(#)h(Set)f(various)g(bindings)g(for)g(emacs)g(mode.) ! 195 962 y(set)g(editing-mode)g(emacs)195 1065 y($if)g(mode=emacs)195 ! 1169 y(Meta-Control-h:)46 b(backward-kill-word)21 b(Text)i(after)h(the) ! f(function)g(name)g(is)h(ignored)p 1986 1179 21 38 v ! 195 1273 a(#)195 1325 y(#)g(Arrow)f(keys)g(in)h(keypad)f(mode)195 ! 1377 y(#)195 1429 y(#"\\M-OD":)190 b(backward-char)195 ! 1480 y(#"\\M-OC":)g(forward-char)195 1532 y(#"\\M-OA":)g ! (previous-history)195 1584 y(#"\\M-OB":)g(next-history)195 ! 1636 y(#)195 1688 y(#)24 b(Arrow)f(keys)g(in)h(ANSI)f(mode)195 ! 1740 y(#)195 1792 y("\\M-[D":)190 b(backward-char)195 ! 1844 y("\\M-[C":)g(forward-char)195 1896 y("\\M-[A":)g ! (previous-history)195 1947 y("\\M-[B":)g(next-history)195 ! 1999 y(#)195 2051 y(#)24 b(Arrow)f(keys)g(in)h(8)g(bit)f(keypad)g(mode) ! 195 2103 y(#)195 2155 y(#"\\M-\\C-OD":)165 b(backward-char)195 ! 2207 y(#"\\M-\\C-OC":)g(forward-char)195 2259 y(#"\\M-\\C-OA":)g ! (previous-history)195 2311 y(#"\\M-\\C-OB":)g(next-history)195 ! 2363 y(#)195 2414 y(#)24 b(Arrow)f(keys)g(in)h(8)g(bit)f(ANSI)g(mode) ! 195 2466 y(#)195 2518 y(#"\\M-\\C-[D":)165 b(backward-char)195 ! 2570 y(#"\\M-\\C-[C":)g(forward-char)195 2622 y(#"\\M-\\C-[A":)g ! (previous-history)p eop %%Page: 11 13 11 12 bop 75 -58 a Fu(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1055 ! b(11)195 183 y Ft(#"\\M-\\C-[B":)165 b(next-history)195 ! 287 y(C-q:)23 b(quoted-insert)195 391 y($endif)195 495 ! y(#)h(An)f(old-style)g(binding.)47 b(This)23 b(happens)g(to)g(be)h(the) ! f(default.)195 546 y(TAB:)g(complete)195 650 y(#)h(Macros)f(that)g(are) ! h(convenient)e(for)h(shell)h(interaction)195 702 y($if)f(Bash)195 ! 754 y(#)h(edit)f(the)g(path)195 806 y("\\C-xp":)g ! ("PATH=${PATH}\\e\\C-e\\C-a\\)o(ef\\C-f")195 858 y(#)h(prepare)f(to)g ! (type)h(a)f(quoted)g(word)h(--)f(insert)g(open)h(and)f(close)g(double)g ! (quotes)195 910 y(#)h(and)f(move)g(to)h(just)f(after)h(the)f(open)g ! (quote)195 962 y("\\C-x\\"":)g("\\"\\"\\C-b")195 1013 ! y(#)h(insert)f(a)g(backslash)g(\(testing)g(backslash)g(escapes)f(in)i ! (sequences)f(and)g(macros\))195 1065 y("\\C-x\\\\":)g("\\\\")195 ! 1117 y(#)h(Quote)f(the)g(current)g(or)h(previous)f(word)195 ! 1169 y("\\C-xq":)g("\\eb\\"\\ef\\"")195 1221 y(#)h(Add)f(a)h(binding)f (to)g(refresh)g(the)h(line,)f(which)g(is)h(unbound)195 ! 1273 y("\\C-xr":)f(redraw-current-line)195 1325 y(#)h(Edit)f(variable)g ! (on)g(current)g(line.)195 1377 y("\\M-\\C-v":)f ! ("\\C-a\\C-k$\\C-y\\M-\\C-e\\C-a\\C-y=)o(")195 1429 y($endif)195 ! 1532 y(#)i(use)f(a)h(visible)f(bell)g(if)h(one)f(is)h(available)195 ! 1584 y(set)f(bell-style)g(visible)195 1688 y(#)h(don't)f(strip)g ! (characters)g(to)g(7)h(bits)f(when)h(reading)195 1740 ! y(set)f(input-meta)g(on)195 1844 y(#)h(allow)f(iso-latin1)f(characters) h(to)g(be)h(inserted)f(rather)g(than)g(converted)g(to)195 ! 1896 y(#)h(prefix-meta)e(sequences)195 1947 y(set)h(convert-meta)g(off) ! 195 2051 y(#)h(display)f(characters)f(with)h(the)h(eighth)f(bit)g(set)h ! (directly)f(rather)g(than)195 2103 y(#)h(as)f(meta-prefixed)f ! (characters)195 2155 y(set)h(output-meta)g(on)195 2259 y(#)h(if)f(there)g(are)h(more)f(than)h(150)f(possible)g(completions)f ! (for)i(a)f(word,)h(ask)f(the)195 2311 y(#)h(user)f(if)h(he)f(wants)g ! (to)h(see)f(all)h(of)f(them)195 2363 y(set)g(completion-query-items)e ! (150)195 2466 y(#)j(For)f(FTP)195 2518 y($if)g(Ftp)195 ! 2570 y("\\C-xg":)g("get)g(\\M-?")195 2622 y("\\C-xt":)g("put)g(\\M-?")p eop %%Page: 12 14 ! 12 13 bop 75 -58 a Fu(12)1299 b(GNU)15 b(Readline)i(Library)195 ! 183 y Ft("\\M-.":)23 b(yank-last-arg)195 235 y($endif)75 ! 359 y Fs(1.4)33 b(Bindable)24 b(Readline)f(Commands)137 ! 453 y Fu(This)16 b(section)g(describ)q(es)h(Readline)g(commands)e(that) ! g(ma)o(y)f(b)q(e)i(b)q(ound)g(to)f(k)o(ey)g(sequences.)137 ! 519 y(Command)j(names)g(without)h(an)f(accompan)o(ying)g(k)o(ey)g ! (sequence)i(are)e(un)o(b)q(ound)h(b)o(y)g(default.)29 ! b(In)75 573 y(the)15 b(follo)o(wing)h(descriptions,)g ! Fm(p)q(oin)o(t)h Fu(refers)e(to)f(the)i(curren)o(t)f(cursor)f(p)q ! (osition,)i(and)g Fm(mark)h Fu(refers)e(to)f(a)75 628 ! y(cursor)h(p)q(osition)h(sa)o(v)o(ed)e(b)o(y)h(the)g ! Ft(set-mark)f Fu(command.)20 b(The)15 b(text)g(b)q(et)o(w)o(een)g(the)g ! (p)q(oin)o(t)h(and)f(mark)f(is)75 683 y(referred)h(to)g(as)g(the)g ! Fm(region)p Fu(.)75 790 y Fl(1.4.1)30 b(Commands)21 b(F)-5 ! b(or)19 b(Mo)n(ving)75 895 y Ft(beginning-of-line)13 ! b(\(C-a\))315 950 y Fu(Mo)o(v)o(e)h(to)h(the)g(start)f(of)h(the)g ! (curren)o(t)g(line.)75 1026 y Ft(end-of-line)f(\(C-e\))315 ! 1081 y Fu(Mo)o(v)o(e)g(to)h(the)g(end)h(of)f(the)g(line.)75 ! 1157 y Ft(forward-char)f(\(C-f\))315 1212 y Fu(Mo)o(v)o(e)g(forw)o(ard) ! g(a)h(c)o(haracter.)75 1288 y Ft(backward-char)e(\(C-b\))315 ! 1343 y Fu(Mo)o(v)o(e)h(bac)o(k)h(a)g(c)o(haracter.)75 ! 1419 y Ft(forward-word)f(\(M-f\))315 1474 y Fu(Mo)o(v)o(e)g(forw)o(ard) ! g(to)g(the)i(end)g(of)e(the)h(next)h(w)o(ord.)j(W)l(ords)c(are)f(comp)q ! (osed)i(of)f(letters)g(and)315 1529 y(digits.)75 1605 ! y Ft(backward-word)e(\(M-b\))315 1660 y Fu(Mo)o(v)o(e)j(bac)o(k)g(to)h ! (the)f(start)g(of)g(the)h(curren)o(t)g(or)f(previous)i(w)o(ord.)24 ! b(W)l(ords)16 b(are)h(comp)q(osed)315 1715 y(of)e(letters)g(and)g ! (digits.)75 1791 y Ft(clear-screen)f(\(C-l\))315 1846 ! y Fu(Clear)f(the)h(screen)g(and)f(redra)o(w)g(the)g(curren)o(t)g(line,) ! i(lea)o(ving)g(the)e(curren)o(t)g(line)i(at)e(the)g(top)315 ! 1900 y(of)i(the)g(screen.)75 1977 y Ft(redraw-current-line)e(\(\))315 ! 2031 y Fu(Refresh)j(the)f(curren)o(t)g(line.)22 b(By)15 ! b(default,)h(this)f(is)h(un)o(b)q(ound.)75 2138 y Fl(1.4.2)30 ! b(Commands)21 b(F)-5 b(or)19 b(Manipulating)i(The)f(History)75 ! 2244 y Ft(accept-line)14 b(\(Newline,)g(Return\))315 ! 2298 y Fu(Accept)h(the)g(line)i(regardless)e(of)g(where)g(the)g(cursor) ! f(is.)20 b(If)c(this)f(line)h(is)g(non-empt)o(y)l(,)f(add)315 ! 2353 y(it)f(to)g(the)g(history)g(list.)20 b(If)14 b(this)h(line)g(w)o ! (as)e(a)h(history)g(line,)i(then)e(restore)f(the)h(history)g(line)315 ! 2408 y(to)h(its)g(original)h(state.)75 2484 y Ft(previous-history)d ! (\(C-p\))315 2539 y Fu(Mo)o(v)o(e)h(`up')h(through)g(the)g(history)g ! (list.)75 2615 y Ft(next-history)f(\(C-n\))315 2670 y ! Fu(Mo)o(v)o(e)g(`do)o(wn')g(through)h(the)h(history)f(list.)p ! eop %%Page: 13 15 13 14 bop 75 -58 a Fu(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1055 ! b(13)75 183 y Ft(beginning-of-history)12 b(\(M-<\))315 ! 238 y Fu(Mo)o(v)o(e)i(to)h(the)g(\014rst)g(line)i(in)f(the)f(history)l ! (.)75 314 y Ft(end-of-history)e(\(M->\))315 369 y Fu(Mo)o(v)o(e)h(to)h (the)g(end)h(of)f(the)g(input)h(history)l(,)f(i.e.,)g(the)g(line)i ! (curren)o(tly)f(b)q(eing)g(en)o(tered.)75 445 y Ft ! (reverse-search-history)c(\(C-r\))315 500 y Fu(Searc)o(h)k(bac)o(kw)o (ard)e(starting)h(at)g(the)h(curren)o(t)f(line)j(and)d(mo)o(ving)h ! (`up')f(through)g(the)h(his-)315 555 y(tory)e(as)h(necessary)l(.)20 ! b(This)c(is)g(an)f(incremen)o(tal)h(searc)o(h.)75 631 ! y Ft(forward-search-history)c(\(C-s\))315 686 y Fu(Searc)o(h)j(forw)o (ard)e(starting)h(at)h(the)f(curren)o(t)h(line)h(and)f(mo)o(ving)g(`do) ! o(wn')f(through)g(the)h(the)315 741 y(history)g(as)g(necessary)l(.)20 ! b(This)c(is)g(an)f(incremen)o(tal)h(searc)o(h.)75 817 y Ft(non-incremental-reverse-se)o(arch-hi)o(story)c(\(M-p\))315 ! 872 y Fu(Searc)o(h)k(bac)o(kw)o(ard)e(starting)h(at)g(the)h(curren)o(t) f(line)j(and)d(mo)o(ving)h(`up')f(through)g(the)h(his-)315 ! 926 y(tory)h(as)h(necessary)g(using)h(a)e(non-incremen)o(tal)j(searc)o ! (h)e(for)f(a)h(string)g(supplied)i(b)o(y)e(the)315 981 ! y(user.)75 1057 y Ft(non-incremental-forward-se)o(arch-hi)o(story)12 ! b(\(M-n\))315 1112 y Fu(Searc)o(h)j(forw)o(ard)e(starting)h(at)h(the)f (curren)o(t)h(line)h(and)f(mo)o(ving)g(`do)o(wn')f(through)g(the)h(the) ! 315 1167 y(history)e(as)g(necessary)h(using)g(a)f(non-incremen)o(tal)i (searc)o(h)e(for)g(a)g(string)g(supplied)j(b)o(y)d(the)315 ! 1222 y(user.)75 1298 y Ft(history-search-forward)f(\(\))315 ! 1353 y Fu(Searc)o(h)21 b(forw)o(ard)e(through)i(the)f(history)h(for)f (the)h(string)g(of)f(c)o(haracters)g(b)q(et)o(w)o(een)h(the)315 ! 1407 y(start)16 b(of)h(the)h(curren)o(t)g(line)h(and)e(the)h(p)q(oin)o (t.)28 b(This)18 b(is)g(a)f(non-incremen)o(tal)i(searc)o(h.)27 ! b(By)315 1462 y(default,)15 b(this)h(command)f(is)h(un)o(b)q(ound.)75 ! 1538 y Ft(history-search-backward)c(\(\))315 1593 y Fu(Searc)o(h)18 b(bac)o(kw)o(ard)e(through)h(the)h(history)f(for)g(the)g(string)h(of)f ! (c)o(haracters)f(b)q(et)o(w)o(een)i(the)315 1648 y(start)e(of)h(the)h (curren)o(t)g(line)h(and)e(the)h(p)q(oin)o(t.)28 b(This)18 b(is)g(a)f(non-incremen)o(tal)i(searc)o(h.)27 b(By)315 ! 1703 y(default,)15 b(this)h(command)f(is)h(un)o(b)q(ound.)75 ! 1779 y Ft(yank-nth-arg)e(\(M-C-y\))315 1834 y Fu(Insert)f(the)g (\014rst)g(argumen)o(t)f(to)g(the)i(previous)f(command)g(\(usually)h ! (the)f(second)h(w)o(ord)e(on)315 1889 y(the)i(previous)i(line\).)21 ! b(With)14 b(an)h(argumen)o(t)e Fm(n)p Fu(,)i(insert)f(the)h ! Fm(n)p Fu(th)f(w)o(ord)g(from)g(the)g(previous)315 1943 ! y(command)f(\(the)h(w)o(ords)f(in)h(the)g(previous)g(command)g(b)q ! (egin)h(with)f(w)o(ord)e(0\).)19 b(A)14 b(negativ)o(e)315 ! 1998 y(argumen)o(t)g(inserts)i(the)f Fm(n)p Fu(th)h(w)o(ord)e(from)h ! (the)g(end)h(of)e(the)i(previous)g(command.)75 2074 y ! Ft(yank-last-arg)d(\(M-.,)i(M-_\))315 2129 y Fu(Insert)j(last)f ! (argumen)o(t)g(to)g(the)g(previous)i(command)e(\(the)g(last)h(w)o(ord)f ! (of)g(the)g(previous)315 2184 y(history)e(en)o(try\).)20 ! b(With)15 b(an)g(argumen)o(t,)g(b)q(eha)o(v)o(e)g(exactly)h(lik)o(e)g ! Ft(yank-nth-arg)p Fu(.)j(Succes-)315 2239 y(siv)o(e)f(calls)g(to)f ! Ft(yank-last-arg)e Fu(mo)o(v)o(e)i(bac)o(k)g(through)g(the)g(history)g ! (list,)i(inserting)f(the)315 2294 y(last)d(argumen)o(t)g(of)f(eac)o(h)i ! (line)g(in)g(turn.)75 2400 y Fl(1.4.3)30 b(Commands)21 ! b(F)-5 b(or)19 b(Changing)i(T)-5 b(ext)75 2506 y Ft(delete-char)14 ! b(\(C-d\))315 2560 y Fu(Delete)j(the)f(c)o(haracter)g(under)h(the)f ! (cursor.)23 b(If)16 b(the)h(cursor)f(is)h(at)e(the)i(b)q(eginning)h(of) ! e(the)315 2615 y(line,)j(there)e(are)g(no)g(c)o(haracters)f(in)i(the)g ! (line,)h(and)e(the)g(last)g(c)o(haracter)g(t)o(yp)q(ed)g(w)o(as)f(not) ! 315 2670 y(b)q(ound)g(to)f Ft(delete-char)p Fu(,)e(then)j(return)f ! Ft(EOF)p Fu(.)p eop %%Page: 14 16 ! 14 15 bop 75 -58 a Fu(14)1299 b(GNU)15 b(Readline)i(Library)75 ! 183 y Ft(backward-delete-char)12 b(\(Rubout\))315 238 ! y Fu(Delete)k(the)f(c)o(haracter)f(b)q(ehind)j(the)f(cursor.)j(A)c(n)o ! (umeric)h(argumen)o(t)e(means)i(to)e(kill)j(the)315 293 ! y(c)o(haracters)d(instead)i(of)f(deleting)i(them.)75 ! 378 y Ft(forward-backward-delete-ch)o(ar)12 b(\(\))315 ! 432 y Fu(Delete)20 b(the)f(c)o(haracter)f(under)i(the)f(cursor,)h (unless)g(the)f(cursor)g(is)h(at)e(the)h(end)h(of)f(the)315 ! 487 y(line,)e(in)g(whic)o(h)g(case)e(the)h(c)o(haracter)g(b)q(ehind)h (the)f(cursor)g(is)g(deleted.)23 b(By)16 b(default,)h(this)315 ! 542 y(is)f(not)f(b)q(ound)h(to)e(a)h(k)o(ey)l(.)75 627 ! y Ft(quoted-insert)e(\(C-q,)i(C-v\))315 682 y Fu(Add)j(the)f(next)g(c)o ! (haracter)g(t)o(yp)q(ed)g(to)f(the)i(line)g(v)o(erbatim.)26 ! b(This)18 b(is)f(ho)o(w)g(to)g(insert)g(k)o(ey)315 736 ! y(sequences)f(lik)o(e)605 734 y Fo(h)p 617 708 56 2 v ! 617 736 a Fn(C-q)p 617 744 V 671 734 a Fo(i)685 736 y ! Fu(,)f(for)g(example.)75 821 y Ft(tab-insert)f(\(M-TAB\))315 ! 876 y Fu(Insert)h(a)g(tab)g(c)o(haracter.)75 961 y Ft(self-insert)f ! (\(a,)g(b,)h(A,)g(1,)g(!,)g(...\))315 1016 y Fu(Insert)g(y)o(ourself.) ! 75 1100 y Ft(transpose-chars)e(\(C-t\))315 1155 y Fu(Drag)i(the)h(c)o ! (haracter)f(b)q(efore)h(the)h(cursor)e(forw)o(ard)g(o)o(v)o(er)g(the)h ! (c)o(haracter)f(at)h(the)g(cursor,)315 1210 y(mo)o(ving)i(the)f(cursor) ! h(forw)o(ard)e(as)i(w)o(ell.)28 b(If)18 b(the)g(insertion)h(p)q(oin)o ! (t)f(is)g(at)f(the)h(end)h(of)e(the)315 1265 y(line,)c(then)e(this)h ! (transp)q(oses)e(the)h(last)g(t)o(w)o(o)f(c)o(haracters)g(of)h(the)g ! (line.)20 b(Negativ)o(e)11 b(argumen)o(ts)315 1320 y(ha)o(v)o(e)k(no)g ! (e\013ect.)75 1404 y Ft(transpose-words)e(\(M-t\))315 ! 1459 y Fu(Drag)i(the)h(w)o(ord)g(b)q(efore)g(p)q(oin)o(t)h(past)f(the)g ! (w)o(ord)f(after)h(p)q(oin)o(t,)g(mo)o(ving)g(p)q(oin)o(t)h(past)f ! (that)315 1514 y(w)o(ord)f(as)f(w)o(ell.)75 1599 y Ft(upcase-word)g ! (\(M-u\))315 1654 y Fu(Upp)q(ercase)j(the)f(curren)o(t)g(\(or)f(follo)o ! (wing\))h(w)o(ord.)22 b(With)16 b(a)g(negativ)o(e)g(argumen)o(t,)f(upp) ! q(er-)315 1708 y(case)g(the)g(previous)h(w)o(ord,)f(but)g(do)g(not)g ! (mo)o(v)o(e)f(the)i(cursor.)75 1793 y Ft(downcase-word)d(\(M-l\))315 ! 1848 y Fu(Lo)o(w)o(ercase)d(the)h(curren)o(t)g(\(or)f(follo)o(wing\))h (w)o(ord.)17 b(With)11 b(a)g(negativ)o(e)g(argumen)o(t,)f(lo)o(w)o ! (ercase)315 1903 y(the)15 b(previous)h(w)o(ord,)e(but)i(do)f(not)g(mo)o ! (v)o(e)f(the)h(cursor.)75 1988 y Ft(capitalize-word)e(\(M-c\))315 ! 2042 y Fu(Capitalize)f(the)f(curren)o(t)f(\(or)g(follo)o(wing\))h(w)o (ord.)18 b(With)11 b(a)f(negativ)o(e)h(argumen)o(t,)f(capitalize)315 ! 2097 y(the)15 b(previous)h(w)o(ord,)e(but)i(do)f(not)g(mo)o(v)o(e)f ! (the)h(cursor.)75 2220 y Fl(1.4.4)30 b(Killing)20 b(And)h(Y)-5 ! b(anking)75 2336 y Ft(kill-line)14 b(\(C-k\))315 2391 y Fu(Kill)j(the)f(text)e(from)h(p)q(oin)o(t)h(to)e(the)h(end)h(of)f ! (the)g(line.)75 2476 y Ft(backward-kill-line)e(\(C-x)h(Rubout\))315 ! 2530 y Fu(Kill)j(bac)o(kw)o(ard)e(to)f(the)i(b)q(eginning)h(of)e(the)g ! (line.)75 2615 y Ft(unix-line-discard)e(\(C-u\))315 2670 ! y Fu(Kill)k(bac)o(kw)o(ard)e(from)f(the)i(cursor)e(to)h(the)g(b)q ! (eginning)j(of)c(the)i(curren)o(t)f(line.)p eop %%Page: 15 17 15 16 bop 75 -58 a Fu(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1055 ! b(15)75 183 y Ft(kill-whole-line)13 b(\(\))315 238 y ! Fu(Kill)20 b(all)f(c)o(haracters)e(on)h(the)g(curren)o(t)f(line,)j(no)e ! (matter)f(p)q(oin)o(t)h(is.)28 b(By)18 b(default,)h(this)f(is)315 ! 293 y(un)o(b)q(ound.)75 374 y Ft(kill-word)c(\(M-d\))315 ! 429 y Fu(Kill)j(from)d(p)q(oin)o(t)h(to)f(the)h(end)g(of)f(the)h ! (curren)o(t)g(w)o(ord,)e(or)i(if)g(b)q(et)o(w)o(een)g(w)o(ords,)e(to)i ! (the)f(end)315 483 y(of)h(the)g(next)g(w)o(ord.)20 b(W)l(ord)14 ! b(b)q(oundaries)j(are)e(the)g(same)g(as)g Ft(forward-word)p ! Fu(.)75 564 y Ft(backward-kill-word)e(\(M-DEL\))315 619 ! y Fu(Kill)k(the)d(w)o(ord)g(b)q(ehind)i(p)q(oin)o(t.)21 ! b(W)l(ord)14 b(b)q(oundaries)h(are)f(the)h(same)f(as)g ! Ft(backward-word)p Fu(.)75 700 y Ft(unix-word-rubout)f(\(C-w\))315 ! 755 y Fu(Kill)18 b(the)e(w)o(ord)f(b)q(ehind)j(p)q(oin)o(t,)e(using)h ! (white)f(space)g(as)g(a)f(w)o(ord)g(b)q(oundary)l(.)23 ! b(The)16 b(killed)315 810 y(text)f(is)g(sa)o(v)o(ed)g(on)g(the)h ! (kill-ring.)75 891 y Ft(delete-horizontal-space)c(\(\))315 ! 946 y Fu(Delete)k(all)g(spaces)f(and)h(tabs)e(around)i(p)q(oin)o(t.)k ! (By)15 b(default,)h(this)f(is)h(un)o(b)q(ound.)75 1027 ! y Ft(kill-region)e(\(\))315 1082 y Fu(Kill)j(the)f(text)e(in)i(the)g (curren)o(t)f(region.)20 b(By)15 b(default,)h(this)f(command)g(is)h(un) ! o(b)q(ound.)75 1163 y Ft(copy-region-as-kill)d(\(\))315 ! 1217 y Fu(Cop)o(y)j(the)i(text)e(in)i(the)f(region)g(to)g(the)g(kill)h (bu\013er,)f(so)g(it)g(can)g(b)q(e)h(y)o(ank)o(ed)f(righ)o(t)g(a)o(w)o ! (a)o(y)l(.)315 1272 y(By)e(default,)h(this)f(command)g(is)h(un)o(b)q ! (ound.)75 1353 y Ft(copy-backward-word)d(\(\))315 1408 y Fu(Cop)o(y)19 b(the)g(w)o(ord)g(b)q(efore)g(p)q(oin)o(t)h(to)e(the)i (kill)h(bu\013er.)32 b(The)19 b(w)o(ord)g(b)q(oundaries)h(are)f(the)315 ! 1463 y(same)c(as)g Ft(backward-word)p Fu(.)j(By)d(default,)g(this)h ! (command)f(is)h(un)o(b)q(ound.)75 1544 y Ft(copy-forward-word)d(\(\)) ! 315 1599 y Fu(Cop)o(y)i(the)h(w)o(ord)e(follo)o(wing)j(p)q(oin)o(t)f (to)f(the)g(kill)j(bu\013er.)i(The)c(w)o(ord)f(b)q(oundaries)i(are)e ! (the)315 1653 y(same)g(as)g Ft(forward-word)p Fu(.)j(By)d(default,)h ! (this)f(command)g(is)h(un)o(b)q(ound.)75 1734 y Ft(yank)f(\(C-y\))315 ! 1789 y Fu(Y)l(ank)g(the)h(top)f(of)f(the)i(kill)h(ring)e(in)o(to)g(the) ! h(bu\013er)f(at)f(the)i(curren)o(t)f(cursor)g(p)q(osition.)75 ! 1870 y Ft(yank-pop)f(\(M-y\))315 1925 y Fu(Rotate)j(the)g(kill-ring,)j ! (and)d(y)o(ank)g(the)h(new)f(top.)26 b(Y)l(ou)17 b(can)h(only)g(do)f ! (this)h(if)f(the)h(prior)315 1980 y(command)d(is)h(y)o(ank)f(or)f(y)o ! (ank-p)q(op.)75 2095 y Fl(1.4.5)30 b(Sp)r(ecifying)20 ! b(Numeric)h(Argumen)n(ts)75 2205 y Ft(digit-argument)13 ! b(\(M-0,)i(M-1,)f(...)h(M--\))315 2260 y Fu(Add)f(this)g(digit)g(to)f ! (the)h(argumen)o(t)e(already)i(accum)o(ulating,)g(or)f(start)f(a)h(new) ! h(argumen)o(t.)315 2313 y Fo(h)p 327 2287 50 2 v 327 ! 2315 a Fn(M{)p 327 2323 V 375 2313 a Fo(i)405 2315 y ! Fu(starts)g(a)h(negativ)o(e)g(argumen)o(t.)75 2396 y ! Ft(universal-argument)e(\(\))315 2451 y Fu(This)g(is)h(another)e(w)o(a) ! o(y)g(to)g(sp)q(ecify)i(an)f(argumen)o(t.)18 b(If)13 b(this)g(command)g(is)g(follo)o(w)o(ed)g(b)o(y)g(one)315 ! 2506 y(or)h(more)h(digits,)g(optionally)h(with)f(a)g(leading)h(min)o ! (us)f(sign,)g(those)g(digits)g(de\014ne)h(the)f(ar-)315 ! 2560 y(gumen)o(t.)k(If)c(the)g(command)f(is)h(follo)o(w)o(ed)g(b)o(y)g ! (digits,)g(executing)g Ft(universal-argument)315 2615 y Fu(again)h(ends)g(the)g(n)o(umeric)h(argumen)o(t,)e(but)h(is)h (otherwise)f(ignored.)22 b(As)16 b(a)g(sp)q(ecial)h(case,)315 ! 2670 y(if)g(this)g(command)f(is)h(immediately)h(follo)o(w)o(ed)f(b)o(y) ! f(a)g(c)o(haracter)g(that)g(is)h(neither)g(a)f(digit)p ! eop ! %%Page: 16 18 ! 16 17 bop 75 -58 a Fu(16)1299 b(GNU)15 b(Readline)i(Library)315 ! 183 y(or)c(min)o(us)i(sign,)f(the)g(argumen)o(t)g(coun)o(t)f(for)h(the) g(next)g(command)g(is)g(m)o(ultiplied)j(b)o(y)d(four.)315 ! 238 y(The)19 b(argumen)o(t)f(coun)o(t)g(is)h(initially)j(one,)d(so)f (executing)i(this)f(function)h(the)e(\014rst)h(time)315 ! 293 y(mak)o(es)c(the)h(argumen)o(t)f(coun)o(t)h(four,)f(a)h(second)g (time)g(mak)o(es)g(the)g(argumen)o(t)f(coun)o(t)g(six-)315 ! 348 y(teen,)g(and)g(so)g(on.)20 b(By)15 b(default,)h(this)f(is)h(not)f ! (b)q(ound)h(to)f(a)g(k)o(ey)l(.)75 472 y Fl(1.4.6)30 b(Letting)20 b(Readline)g(T)n(yp)r(e)h(F)-5 b(or)19 b(Y)-5 ! b(ou)75 590 y Ft(complete)14 b(\(TAB\))315 644 y Fu(A)o(ttempt)j(to)g ! (do)h(completion)g(on)g(the)g(text)f(b)q(efore)h(the)g(cursor.)27 ! b(This)18 b(is)g(application-)315 699 y(sp)q(eci\014c.)k(Generally)l(,) ! 15 b(if)g(y)o(ou)g(are)f(t)o(yping)h(a)g(\014lename)g(argumen)o(t,)f(y) ! o(ou)g(can)h(do)g(\014lename)315 754 y(completion;)h(if)g(y)o(ou)f(are) ! g(t)o(yping)h(a)f(command,)f(y)o(ou)h(can)h(do)f(command)g(completion;) ! h(if)315 809 y(y)o(ou)i(are)g(t)o(yping)g(in)h(a)f(sym)o(b)q(ol)h(to)e ! (GDB,)h(y)o(ou)g(can)g(do)g(sym)o(b)q(ol)h(name)f(completion;)i(if)315 ! 864 y(y)o(ou)13 b(are)g(t)o(yping)g(in)h(a)f(v)m(ariable)h(to)f(Bash,)g ! (y)o(ou)g(can)g(do)g(v)m(ariable)h(name)f(completion,)i(and)315 ! 918 y(so)g(on.)75 1004 y Ft(possible-completions)d(\(M-?\))315 ! 1059 y Fu(List)k(the)f(p)q(ossible)i(completions)f(of)f(the)g(text)g(b) ! q(efore)h(the)f(cursor.)75 1145 y Ft(insert-completions)e(\(M-*\))315 ! 1199 y Fu(Insert)j(all)g(completions)g(of)f(the)g(text)g(b)q(efore)h(p) q(oin)o(t)f(that)g(w)o(ould)h(ha)o(v)o(e)f(b)q(een)h(generated)315 ! 1254 y(b)o(y)f Ft(possible-completions)p Fu(.)75 1340 ! y Ft(menu-complete)e(\(\))315 1395 y Fu(Similar)g(to)f Ft(complete)p Fu(,)f(but)h(replaces)h(the)f(w)o(ord)f(to)g(b)q(e)i ! (completed)f(with)h(a)e(single)j(matc)o(h)315 1450 y(from)k(the)h(list) ! h(of)e(p)q(ossible)j(completions.)32 b(Rep)q(eated)20 ! b(execution)g(of)f Ft(menu-complete)315 1504 y Fu(steps)h(through)g (the)g(list)h(of)f(p)q(ossible)i(completions,)g(inserting)f(eac)o(h)f ! (matc)o(h)f(in)i(turn.)315 1559 y(A)o(t)c(the)g(end)h(of)f(the)h(list)g ! (of)f(completions,)i(the)e(b)q(ell)j(is)e(rung)f(and)h(the)f(original)i ! (text)d(is)315 1614 y(restored.)26 b(An)17 b(argumen)o(t)g(of)g ! Fm(n)g Fu(mo)o(v)o(es)g Fm(n)g Fu(p)q(ositions)h(forw)o(ard)e(in)i(the) ! g(list)g(of)f(matc)o(hes;)315 1669 y(a)j(negativ)o(e)g(argumen)o(t)f ! (ma)o(y)g(b)q(e)i(used)f(to)f(mo)o(v)o(e)h(bac)o(kw)o(ard)f(through)g ! (the)h(list.)35 b(This)315 1724 y(command)15 b(is)h(in)o(tended)g(to)f ! (b)q(e)h(b)q(ound)g(to)f Ft(TAB)p Fu(,)f(but)h(is)h(un)o(b)q(ound)g(b)o ! (y)f(default.)75 1809 y Ft(delete-char-or-list)e(\(\))315 ! 1864 y Fu(Deletes)h(the)f(c)o(haracter)g(under)h(the)g(cursor)f(if)h ! (not)f(at)g(the)g(b)q(eginning)j(or)d(end)h(of)f(the)g(line)315 ! 1919 y(\(lik)o(e)i Ft(delete-char)p Fu(\).)j(If)d(at)f(the)h(end)g(of)f ! (the)g(line,)i(b)q(eha)o(v)o(es)f(iden)o(tically)i(to)d ! Ft(possible-)315 1974 y(completions)p Fu(.)k(This)e(command)f(is)h(un)o ! (b)q(ound)g(b)o(y)f(default.)75 2098 y Fl(1.4.7)30 b(Keyb)r(oard)20 ! b(Macros)75 2216 y Ft(start-kbd-macro)13 b(\(C-x)i(\(\))315 ! 2270 y Fu(Begin)h(sa)o(ving)f(the)h(c)o(haracters)e(t)o(yp)q(ed)i(in)o ! (to)f(the)g(curren)o(t)g(k)o(eyb)q(oard)g(macro.)75 2356 ! y Ft(end-kbd-macro)e(\(C-x)i(\)\))315 2411 y Fu(Stop)f(sa)o(ving)f(the) ! h(c)o(haracters)f(t)o(yp)q(ed)h(in)o(to)f(the)h(curren)o(t)g(k)o(eyb)q ! (oard)f(macro)g(and)h(sa)o(v)o(e)f(the)315 2466 y(de\014nition.)75 ! 2552 y Ft(call-last-kbd-macro)g(\(C-x)h(e\))315 2606 ! y Fu(Re-execute)19 b(the)f(last)f(k)o(eyb)q(oard)h(macro)f(de\014ned,)i ! (b)o(y)e(making)h(the)g(c)o(haracters)e(in)j(the)315 ! 2661 y(macro)14 b(app)q(ear)i(as)f(if)g(t)o(yp)q(ed)h(at)e(the)i(k)o ! (eyb)q(oard.)p eop %%Page: 17 19 17 18 bop 75 -58 a Fu(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1055 ! b(17)75 183 y Fl(1.4.8)30 b(Some)20 b(Miscellaneous)h(Commands)75 ! 298 y Ft(re-read-init-file)13 b(\(C-x)h(C-r\))315 353 ! y Fu(Read)e(in)f(the)g(con)o(ten)o(ts)g(of)f(the)h Fm(inputrc)k ! Fu(\014le,)d(and)g(incorp)q(orate)f(an)o(y)f(bindings)j(or)e(v)m ! (ariable)315 407 y(assignmen)o(ts)k(found)h(there.)75 ! 491 y Ft(abort)e(\(C-g\))315 546 y Fu(Ab)q(ort)f(the)g(curren)o(t)h (editing)g(command)f(and)h(ring)f(the)h(terminal's)f(b)q(ell)i(\(sub)s ! (ject)e(to)g(the)315 600 y(setting)i(of)g Ft(bell-style)p ! Fu(\).)75 684 y Ft(do-uppercase-version)d(\(M-a,)j(M-b,)f(M-)p ! Fm(x)p Ft(,)h Fj(:)8 b(:)g(:)n Ft(\))315 739 y Fu(If)14 ! b(the)g(meta\014ed)g(c)o(haracter)f Fm(x)k Fu(is)d(lo)o(w)o(ercase,)g ! (run)g(the)g(command)f(that)h(is)g(b)q(ound)h(to)e(the)315 ! 794 y(corresp)q(onding)j(upp)q(ercase)g(c)o(haracter.)75 ! 877 y Ft(prefix-meta)e(\(ESC\))315 932 y Fu(Mak)o(e)j(the)i(next)f(c)o ! (haracter)f(t)o(yp)q(ed)i(b)q(e)g(meta\014ed.)28 b(This)19 ! b(is)g(for)e(k)o(eyb)q(oards)h(without)g(a)315 987 y(meta)d(k)o(ey)l(.) ! 20 b(T)o(yping)15 b(`)p Ft(ESC)g(f)p Fu(')f(is)i(equiv)m(alen)o(t)h(to) ! d(t)o(yping)i(`)p Ft(M-f)p Fu('.)75 1070 y Ft(undo)f(\(C-_,)f(C-x)h ! (C-u\))315 1125 y Fu(Incremen)o(tal)h(undo,)f(separately)h(remem)o(b)q ! (ered)g(for)e(eac)o(h)h(line.)75 1209 y Ft(revert-line)f(\(M-r\))315 ! 1263 y Fu(Undo)j(all)g(c)o(hanges)g(made)f(to)g(this)h(line.)26 b(This)17 b(is)g(lik)o(e)h(executing)f(the)g Ft(undo)f ! Fu(command)315 1318 y(enough)g(times)f(to)g(get)f(bac)o(k)h(to)g(the)g ! (b)q(eginning.)75 1402 y Ft(tilde-expand)f(\(M-~\))315 ! 1456 y Fu(P)o(erform)g(tilde)j(expansion)f(on)f(the)g(curren)o(t)g(w)o ! (ord.)75 1540 y Ft(set-mark)f(\(C-@\))315 1595 y Fu(Set)g(the)f(mark)g ! (to)g(the)h(curren)o(t)g(p)q(oin)o(t.)19 b(If)14 b(a)g(n)o(umeric)g ! (argumen)o(t)f(is)h(supplied,)i(the)e(mark)315 1650 y(is)i(set)f(to)f ! (that)h(p)q(osition.)75 1733 y Ft(exchange-point-and-mark)d(\(C-x)j ! (C-x\))315 1788 y Fu(Sw)o(ap)g(the)h(p)q(oin)o(t)g(with)g(the)g(mark.)k ! (The)c(curren)o(t)f(cursor)h(p)q(osition)g(is)g(set)g(to)f(the)g(sa)o ! (v)o(ed)315 1843 y(p)q(osition,)h(and)f(the)h(old)f(cursor)g(p)q ! (osition)h(is)g(sa)o(v)o(ed)f(as)g(the)g(mark.)75 1926 ! y Ft(character-search)e(\(C-]\))315 1981 y Fu(A)f(c)o(haracter)g(is)h ! (read)g(and)f(p)q(oin)o(t)h(is)g(mo)o(v)o(ed)f(to)g(the)g(next)h(o)q ! (ccurrence)g(of)f(that)g(c)o(haracter.)315 2036 y(A)j(negativ)o(e)h ! (coun)o(t)f(searc)o(hes)g(for)f(previous)i(o)q(ccurrences.)75 ! 2119 y Ft(character-search-backward)c(\(M-C-]\))315 2174 ! y Fu(A)22 b(c)o(haracter)g(is)h(read)f(and)h(p)q(oin)o(t)g(is)g(mo)o(v) ! o(ed)f(to)g(the)g(previous)h(o)q(ccurrence)h(of)e(that)315 ! 2229 y(c)o(haracter.)d(A)c(negativ)o(e)h(coun)o(t)f(searc)o(hes)g(for)f ! (subsequen)o(t)i(o)q(ccurrences.)75 2312 y Ft(insert-comment)d(\(M-#\)) ! 315 2367 y Fu(The)19 b(v)m(alue)i(of)e(the)g Ft(comment-begin)e Fu(v)m(ariable)k(is)f(inserted)g(at)e(the)i(b)q(eginning)h(of)e(the)315 ! 2422 y(curren)o(t)c(line,)i(and)e(the)g(line)i(is)f(accepted)g(as)e(if) ! i(a)f(newline)i(had)f(b)q(een)g(t)o(yp)q(ed.)75 2506 ! y Ft(dump-functions)d(\(\))315 2560 y Fu(Prin)o(t)g(all)h(of)f(the)g ! (functions)h(and)g(their)g(k)o(ey)f(bindings)i(to)d(the)i(Readline)h ! (output)e(stream.)315 2615 y(If)j(a)g(n)o(umeric)g(argumen)o(t)f(is)i ! (supplied,)h(the)e(output)f(is)i(formatted)d(in)j(suc)o(h)f(a)g(w)o(a)o ! (y)f(that)315 2670 y(it)g(can)h(b)q(e)g(made)f(part)f(of)h(an)g ! Fm(inputrc)k Fu(\014le.)i(This)16 b(command)f(is)h(un)o(b)q(ound)g(b)o ! (y)f(default.)p eop %%Page: 18 20 ! 18 19 bop 75 -58 a Fu(18)1299 b(GNU)15 b(Readline)i(Library)75 ! 183 y Ft(dump-variables)c(\(\))315 238 y Fu(Prin)o(t)e(all)g(of)f(the)h ! (settable)g(v)m(ariables)h(and)f(their)g(v)m(alues)h(to)e(the)h ! (Readline)i(output)d(stream.)315 293 y(If)16 b(a)g(n)o(umeric)g ! (argumen)o(t)f(is)i(supplied,)h(the)e(output)f(is)i(formatted)d(in)j ! (suc)o(h)f(a)g(w)o(a)o(y)f(that)315 348 y(it)g(can)h(b)q(e)g(made)f ! (part)f(of)h(an)g Fm(inputrc)k Fu(\014le.)i(This)16 b(command)f(is)h ! (un)o(b)q(ound)g(b)o(y)f(default.)75 427 y Ft(dump-macros)f(\(\))315 ! 482 y Fu(Prin)o(t)j(all)h(of)e(the)h(Readline)i(k)o(ey)e(sequences)h(b) ! q(ound)g(to)e(macros)g(and)h(the)g(strings)g(they)315 ! 537 y(ouput.)30 b(If)19 b(a)f(n)o(umeric)i(argumen)o(t)d(is)i ! (supplied,)j(the)c(output)h(is)g(formatted)e(in)i(suc)o(h)g(a)315 ! 592 y(w)o(a)o(y)14 b(that)g(it)i(can)f(b)q(e)g(made)g(part)g(of)f(an)h ! Fm(inputrc)k Fu(\014le.)i(This)15 b(command)g(is)h(un)o(b)q(ound)g(b)o ! (y)315 647 y(default.)75 775 y Fs(1.5)33 b(Readline)23 ! b(vi)h(Mo)r(de)137 871 y Fu(While)13 b(the)f(Readline)j(library)d(do)q ! (es)g(not)g(ha)o(v)o(e)f(a)h(full)h(set)f(of)f Ft(vi)g ! Fu(editing)j(functions,)f(it)f(do)q(es)g(con)o(tain)75 ! 926 y(enough)17 b(to)g(allo)o(w)g(simple)h(editing)h(of)d(the)i(line.) ! 27 b(The)17 b(Readline)i Ft(vi)e Fu(mo)q(de)g(b)q(eha)o(v)o(es)g(as)g ! (sp)q(eci\014ed)i(in)75 981 y(the)c Fp(POSIX)h Fu(1003.2)d(standard.) ! 137 1048 y(In)i(order)g(to)f(switc)o(h)g(in)o(teractiv)o(ely)i(b)q(et)o (w)o(een)f Ft(emacs)e Fu(and)i Ft(vi)f Fu(editing)i(mo)q(des,)f(use)f ! (the)h(command)75 1103 y(M-C-j)g(\(toggle-editing-mo)q(de\).)21 ! b(The)15 b(Readline)j(default)d(is)h Ft(emacs)f Fu(mo)q(de.)137 ! 1170 y(When)h(y)o(ou)e(en)o(ter)h(a)g(line)i(in)e Ft(vi)g Fu(mo)q(de,)g(y)o(ou)g(are)f(already)i(placed)g(in)g(`insertion')f(mo)q ! (de,)g(as)g(if)g(y)o(ou)75 1225 y(had)e(t)o(yp)q(ed)h(an)f(`)p ! Ft(i)p Fu('.)18 b(Pressing)608 1223 y Fo(h)p 620 1197 ! 70 2 v 620 1225 a Fn(ESC)p 620 1233 V 687 1223 a Fo(i)715 ! 1225 y Fu(switc)o(hes)13 b(y)o(ou)g(in)o(to)g(`command')f(mo)q(de,)i ! (where)f(y)o(ou)g(can)g(edit)h(the)75 1280 y(text)i(of)h(the)g(line)h (with)g(the)f(standard)f Ft(vi)h Fu(mo)o(v)o(emen)o(t)f(k)o(eys,)g(mo)o ! (v)o(e)g(to)h(previous)g(history)g(lines)i(with)75 1335 y(`)p Ft(k)p Fu(')14 b(and)i(subsequen)o(t)f(lines)i(with)f(`)p Ft(j)p Fu(',)e(and)h(so)g(forth.)p eop %%Page: 19 21 19 20 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)844 b(19)75 183 y Fq(2)41 b(Programming)28 ! b(with)e(GNU)i(Readline)137 305 y Fu(This)16 b(c)o(hapter)f(describ)q ! (es)i(the)f(in)o(terface)g(b)q(et)o(w)o(een)f(the)h(GNU)f(Readline)j ! (Library)e(and)f(other)g(pro-)75 360 y(grams.)38 b(If)22 ! b(y)o(ou)f(are)g(a)g(programmer,)h(and)f(y)o(ou)g(wish)i(to)d(include)k ! (the)e(features)f(found)h(in)g(GNU)75 414 y(Readline)16 ! b(suc)o(h)e(as)f(completion,)h(line)h(editing,)g(and)f(in)o(teractiv)o ! (e)g(history)f(manipulation)i(in)g(y)o(our)d(o)o(wn)75 ! 469 y(programs,)i(this)h(section)h(is)g(for)e(y)o(ou.)75 ! 602 y Fs(2.1)33 b(Basic)22 b(Beha)n(vior)137 700 y Fu(Man)o(y)15 b(programs)f(pro)o(vide)i(a)f(command)g(line)i(in)o(terface,)e(suc)o(h) h(as)f Ft(mail)p Fu(,)f Ft(ftp)p Fu(,)h(and)g Ft(sh)p ! Fu(.)20 b(F)l(or)15 b(suc)o(h)75 754 y(programs,)e(the)h(default)h(b)q ! (eha)o(viour)g(of)f(Readline)j(is)d(su\016cien)o(t.)21 b(This)14 b(section)h(describ)q(es)h(ho)o(w)e(to)g(use)75 ! 809 y(Readline)19 b(in)g(the)e(simplest)h(w)o(a)o(y)e(p)q(ossible,)j(p) ! q(erhaps)f(to)f(replace)h(calls)g(in)g(y)o(our)f(co)q(de)h(to)e ! Ft(gets\(\))g Fu(or)75 864 y Ft(fgets)e(\(\))p Fu(.)137 ! 933 y(The)j(function)h Ft(readline)c(\(\))j Fu(prin)o(ts)g(a)g(prompt)f ! (and)h(then)g(reads)g(and)g(returns)g(a)g(single)h(line)g(of)75 ! 988 y(text)12 b(from)f(the)i(user.)19 b(The)12 b(line)i ! Ft(readline)d Fu(returns)h(is)h(allo)q(cated)g(with)g ! Ft(malloc)h(\(\))p Fu(;)e(y)o(ou)g(should)i Ft(free)75 ! 1042 y(\(\))h Fu(the)g(line)i(when)f(y)o(ou)f(are)f(done)i(with)g(it.)k (The)15 b(declaration)h(for)f Ft(readline)f Fu(in)i(ANSI)g(C)f(is)195 ! 1108 y Ft(char)23 b(*readline)g(\(char)g(*)p Fm(prompt)q ! Ft(\);)75 1177 y Fu(So,)15 b(one)g(migh)o(t)g(sa)o(y)195 ! 1243 y Ft(char)23 b(*line)g(=)h(readline)f(\("Enter)g(a)h(line:)f("\);) ! 75 1312 y Fu(in)12 b(order)f(to)g(read)h(a)f(line)i(of)e(text)g(from)f (the)i(user.)19 b(The)11 b(line)j(returned)d(has)h(the)f(\014nal)h ! (newline)i(remo)o(v)o(ed,)75 1366 y(so)h(only)h(the)f(text)g(remains.) ! 137 1435 y(If)21 b Ft(readline)e Fu(encoun)o(ters)h(an)g Ft(EOF)g Fu(while)i(reading)f(the)f(line,)j(and)d(the)h(line)g(is)g ! (empt)o(y)f(at)g(that)75 1490 y(p)q(oin)o(t,)15 b(then)g Ft(\(char)f(*\)NULL)g Fu(is)h(returned.)21 b(Otherwise,)15 b(the)g(line)h(is)f(ended)h(just)e(as)h(if)g(a)f(newline)j(had)75 ! 1545 y(b)q(een)f(t)o(yp)q(ed.)137 1614 y(If)d(y)o(ou)g(w)o(an)o(t)f (the)h(user)g(to)f(b)q(e)i(able)g(to)e(get)g(at)h(the)g(line)h(later,)f ! (\(with)1325 1612 y Fo(h)p 1338 1586 57 2 v 1338 1614 ! a Fn(C-p)p 1338 1621 V 1392 1612 a Fo(i)1420 1614 y Fu(for)f ! (example\),)i(y)o(ou)f(m)o(ust)75 1668 y(call)j Ft(add_history)e(\(\))h ! Fu(to)f(sa)o(v)o(e)h(the)g(line)i(a)o(w)o(a)o(y)d(in)i(a)f ! Fm(history)k Fu(list)d(of)e(suc)o(h)i(lines.)195 1734 ! y Ft(add_history)22 b(\(line\);)75 1803 y Fu(F)l(or)15 b(full)h(details)g(on)f(the)h(GNU)f(History)g(Library)l(,)g(see)h(the)f ! (asso)q(ciated)g(man)o(ual.)137 1872 y(It)h(is)g(preferable)h(to)e(a)o (v)o(oid)g(sa)o(ving)h(empt)o(y)f(lines)i(on)f(the)g(history)f(list,)i ! (since)f(users)g(rarely)g(ha)o(v)o(e)f(a)75 1927 y(burning)h(need)g(to) e(reuse)h(a)g(blank)g(line.)22 b(Here)15 b(is)g(a)g(function)g(whic)o ! (h)h(usefully)h(replaces)e(the)g(standard)75 1981 y Ft(gets)g(\(\))f ! Fu(library)i(function,)g(and)g(has)f(the)g(adv)m(an)o(tage)f(of)h(no)g ! (static)g(bu\013er)h(to)e(o)o(v)o(er\015o)o(w:)195 2047 y Ft(/*)24 b(A)f(static)g(variable)g(for)h(holding)e(the)i(line.)f(*/) 195 2099 y(static)g(char)g(*line_read)g(=)h(\(char)f(*\)NULL;)195 --- 1342,2281 ---- %%Page: 3 5 3 4 bop 75 -58 a Fu(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1077 ! b(3)137 149 y(When)12 b(y)o(ou)g(use)g(a)f(kill)i(command,)f(the)g ! (text)f(is)h(sa)o(v)o(ed)f(in)i(a)e Fk(kill-ring)p Fu(.)21 b(An)o(y)12 b(n)o(um)o(b)q(er)g(of)f(consecutiv)o(e)75 ! 204 y(kills)17 b(sa)o(v)o(e)e(all)h(of)f(the)h(killed)i(text)d (together,)f(so)h(that)g(when)h(y)o(ou)f(y)o(ank)g(it)h(bac)o(k,)f(y)o ! (ou)g(get)g(it)h(all.)22 b(The)75 259 y(kill)c(ring)f(is)f(not)g(line)i (sp)q(eci\014c;)g(the)e(text)g(that)f(y)o(ou)h(killed)j(on)d(a)g (previously)h(t)o(yp)q(ed)g(line)h(is)e(a)o(v)m(ailable)75 ! 314 y(to)f(b)q(e)g(y)o(ank)o(ed)g(bac)o(k)h(later,)e(when)i(y)o(ou)f ! (are)g(t)o(yping)g(another)g(line.)137 380 y(Here)h(is)f(the)h(list)g ! (of)e(commands)h(for)g(killing)j(text.)75 458 y Fo(C-k)168 ! b Fu(Kill)17 b(the)f(text)e(from)h(the)g(curren)o(t)g(cursor)g(p)q ! (osition)h(to)f(the)g(end)h(of)f(the)g(line.)75 535 y ! Fo(M-d)168 b Fu(Kill)15 b(from)e(the)g(cursor)g(to)f(the)i(end)g(of)e (the)i(curren)o(t)f(w)o(ord,)f(or,)h(if)g(b)q(et)o(w)o(een)h(w)o(ords,) ! e(to)h(the)315 590 y(end)j(of)f(the)g(next)g(w)o(ord.)k(W)l(ord)c(b)q ! (oundaries)i(are)e(the)g(same)g(as)g(those)f(used)i(b)o(y)f ! Fo(M-f)p Fu(.)75 668 y Fo(M-)123 666 y Fn(h)p 135 640 ! 73 2 v 135 668 a Fm(DEL)p 135 675 V 206 666 a Fn(i)315 ! 668 y Fu(Kill)21 b(from)e(the)g(cursor)f(the)h(start)f(of)h(the)g ! (previous)h(w)o(ord,)f(or,)g(if)g(b)q(et)o(w)o(een)h(w)o(ords,)f(to)315 ! 723 y(the)14 b(start)f(of)g(the)h(previous)g(w)o(ord.)19 b(W)l(ord)14 b(b)q(oundaries)h(are)e(the)h(same)g(as)f(those)h(used)g ! (b)o(y)315 777 y Fo(M-b)p Fu(.)75 855 y Fo(C-w)168 b ! Fu(Kill)18 b(from)d(the)g(cursor)h(to)f(the)g(previous)i(whitespace.)22 ! b(This)16 b(is)g(di\013eren)o(t)g(than)f Fo(M-)1777 853 ! y Fn(h)p 1789 827 V 1789 855 a Fm(DEL)p 1789 863 V 1860 ! 853 a Fn(i)315 910 y Fu(b)q(ecause)h(the)f(w)o(ord)g(b)q(oundaries)h ! (di\013er.)137 987 y(Here)21 b(is)h(ho)o(w)e(to)g Fk(y)o(ank)j ! Fu(the)e(text)f(bac)o(k)h(in)o(to)g(the)f(line.)39 b(Y)l(anking)21 ! b(means)g(to)f(cop)o(y)h(the)g(most-)75 1042 y(recen)o(tly-killed)d ! (text)d(from)f(the)i(kill)h(bu\013er.)75 1120 y Fo(C-y)168 ! b Fu(Y)l(ank)15 b(the)h(most)e(recen)o(tly)i(killed)h(text)e(bac)o(k)g ! (in)o(to)g(the)h(bu\013er)f(at)f(the)i(cursor.)75 1198 ! y Fo(M-y)168 b Fu(Rotate)16 b(the)h(kill-ring,)j(and)d(y)o(ank)g(the)h ! (new)f(top.)26 b(Y)l(ou)17 b(can)h(only)g(do)f(this)h(if)f(the)h(prior) ! 315 1252 y(command)d(is)h Fo(C-y)f Fu(or)f Fo(M-y)p Fu(.)75 ! 1361 y Fj(1.2.4)30 b(Readline)20 b(Argumen)n(ts)137 1457 ! y Fu(Y)l(ou)15 b(can)g(pass)f(n)o(umeric)i(argumen)o(ts)e(to)g ! (Readline)h(commands.)20 b(Sometimes)15 b(the)g(argumen)o(t)e(acts)75 ! 1511 y(as)20 b(a)f(rep)q(eat)i(coun)o(t,)f(other)g(times)g(it)h(is)f ! (the)g Fl(sign)j Fu(of)c(the)h(argumen)o(t)g(that)f(is)i(signi\014can)o ! (t.)35 b(If)20 b(y)o(ou)75 1566 y(pass)d(a)f(negativ)o(e)h(argumen)o(t) ! f(to)g(a)g(command)h(whic)o(h)h(normally)f(acts)f(in)i(a)e(forw)o(ard)g ! (direction,)i(that)75 1621 y(command)g(will)h(act)e(in)i(a)e(bac)o(kw)o ! (ard)g(direction.)28 b(F)l(or)17 b(example,)i(to)e(kill)j(text)d(bac)o ! (k)g(to)g(the)h(start)e(of)75 1676 y(the)f(line,)i(y)o(ou)e(migh)o(t)g ! (t)o(yp)q(e)g(`)p Ft(M--)f(C-k)p Fu('.)137 1742 y(The)h(general)f(w)o ! (a)o(y)f(to)h(pass)g(n)o(umeric)h(argumen)o(ts)e(to)g(a)h(command)g(is) ! h(to)e(t)o(yp)q(e)h(meta)g(digits)h(b)q(efore)75 1797 ! y(the)h(command.)k(If)c(the)f(\014rst)g(`digit')h(t)o(yp)q(ed)f(is)h(a) ! g(min)o(us)g(sign)g(\(`)p Ft(-)p Fu('\),)d(then)j(the)f(sign)h(of)f ! (the)h(argumen)o(t)75 1852 y(will)21 b(b)q(e)f(negativ)o(e.)31 ! b(Once)20 b(y)o(ou)f(ha)o(v)o(e)g(t)o(yp)q(ed)g(one)g(meta)g(digit)h ! (to)e(get)h(the)g(argumen)o(t)f(started,)h(y)o(ou)75 ! 1906 y(can)c(t)o(yp)q(e)f(the)h(remainder)g(of)f(the)g(digits,)h(and)g ! (then)g(the)f(command.)20 b(F)l(or)13 b(example,)i(to)f(giv)o(e)h(the)f ! Fo(C-d)75 1961 y Fu(command)19 b(an)f(argumen)o(t)g(of)g(10,)h(y)o(ou)f ! (could)i(t)o(yp)q(e)f(`)p Ft(M-1)14 b(0)h(C-d)p Fu(',)k(whic)o(h)g ! (will)h(delete)g(the)f(next)g(ten)75 2016 y(c)o(haracters)14 ! b(on)i(the)f(input)h(line.)75 2125 y Fj(1.2.5)30 b(Searc)n(hing)21 ! b(for)f(Commands)h(in)f(the)h(History)137 2220 y Fu(Readline)d(pro)o ! (vides)e(commands)g(for)g(searc)o(hing)g(through)g(the)g(command)g ! (history)g(for)g(lines)i(con-)75 2275 y(taining)e(a)f(sp)q(eci\014ed)i ! (string.)j(There)c(are)e(t)o(w)o(o)g(searc)o(h)h(mo)q(des:)20 ! b Fk(incremen)o(tal)e Fu(and)e Fk(non-incremen)o(tal)p ! Fu(.)137 2341 y(Incremen)o(tal)e(searc)o(hes)f(b)q(egin)h(b)q(efore)f ! (the)g(user)g(has)g(\014nished)h(t)o(yping)f(the)g(searc)o(h)g(string.) ! 19 b(As)13 b(eac)o(h)75 2396 y(c)o(haracter)k(of)g(the)h(searc)o(h)g ! (string)f(is)h(t)o(yp)q(ed,)h(Readline)g(displa)o(ys)f(the)g(next)g(en) ! o(try)f(from)g(the)h(history)75 2451 y(matc)o(hing)12 ! b(the)g(string)g(t)o(yp)q(ed)g(so)g(far.)18 b(An)13 b(incremen)o(tal)g ! (searc)o(h)f(requires)g(only)h(as)f(man)o(y)f(c)o(haracters)g(as)75 ! 2506 y(needed)16 b(to)d(\014nd)j(the)e(desired)i(history)e(en)o(try)l ! (.)19 b(T)l(o)c(searc)o(h)f(bac)o(kw)o(ard)f(in)j(the)e(history)g(for)g ! (a)g(particular)75 2560 y(string,)g(t)o(yp)q(e)h Fo(C-r)p ! Fu(.)k(T)o(yping)d Fo(C-s)e Fu(searc)o(hes)h(forw)o(ard)e(through)h ! (the)h(history)l(.)20 b(The)15 b(c)o(haracters)f(presen)o(t)75 ! 2615 y(in)20 b(the)f(v)m(alue)h(of)f(the)g Ft(isearch-terminators)d Fu(v)m(ariable)k(are)f(used)h(to)e(terminate)h(an)g(incremen)o(tal)75 ! 2670 y(searc)o(h.)31 b(If)19 b(that)f(v)m(ariable)i(has)f(not)f(b)q ! (een)i(assigned)g(a)e(v)m(alue,)j(the)1289 2668 y Fn(h)p ! 1301 2642 70 2 v 1301 2670 a Fm(ESC)p 1301 2678 V 1368 ! 2668 a Fn(i)1402 2670 y Fu(and)e Fo(C-J)f Fu(c)o(haracters)g(will)p ! eop %%Page: 4 6 ! 4 5 bop 75 -58 a Fu(4)1322 b(GNU)15 b(Readline)h(Library)75 ! 149 y(terminate)21 b(an)g(incremen)o(tal)i(searc)o(h.)37 ! b Fo(C-g)21 b Fu(will)i(ab)q(ort)e(an)g(incremen)o(tal)h(searc)o(h)f ! (and)g(restore)g(the)75 204 y(original)16 b(line.)21 b(When)15 b(the)f(searc)o(h)g(is)h(terminated,)g(the)f(history)h(en)o ! (try)f(con)o(taining)h(the)g(searc)o(h)f(string)75 259 ! y(b)q(ecomes)i(the)f(curren)o(t)g(line.)137 324 y(T)l(o)g(\014nd)i ! (other)e(matc)o(hing)g(en)o(tries)h(in)h(the)e(history)h(list,)g(t)o ! (yp)q(e)f Fo(C-r)g Fu(or)g Fo(C-s)g Fu(as)h(appropriate.)k(This)75 ! 379 y(will)15 b(searc)o(h)e(bac)o(kw)o(ard)f(or)g(forw)o(ard)g(in)i ! (the)f(history)g(for)g(the)g(next)g(en)o(try)g(matc)o(hing)g(the)g ! (searc)o(h)g(string)75 434 y(t)o(yp)q(ed)19 b(so)g(far.)30 ! b(An)o(y)19 b(other)f(k)o(ey)h(sequence)h(b)q(ound)g(to)e(a)h(Readline) ! h(command)e(will)j(terminate)e(the)75 489 y(searc)o(h)10 ! b(and)h(execute)g(that)f(command.)18 b(F)l(or)10 b(instance,)i(a)1063 ! 487 y Fn(h)p 1076 461 76 2 v 1076 489 a Fm(RET)p 1076 ! 496 V 1149 487 a Fn(i)1174 489 y Fu(will)g(terminate)f(the)g(searc)o(h) ! f(and)h(accept)75 543 y(the)k(line,)h(thereb)o(y)f(executing)g(the)g ! (command)g(from)f(the)g(history)h(list.)20 b(A)15 b(mo)o(v)o(emen)o(t)f ! (command)g(will)75 598 y(terminate)h(the)g(searc)o(h,)g(mak)o(e)g(the)g ! (last)g(line)i(found)f(the)f(curren)o(t)g(line,)h(and)g(b)q(egin)g ! (editing.)137 664 y(Non-incremen)o(tal)25 b(searc)o(hes)e(read)h(the)f ! (en)o(tire)h(searc)o(h)f(string)g(b)q(efore)h(starting)f(to)f(searc)o ! (h)i(for)75 718 y(matc)o(hing)d(history)h(lines.)39 b(The)22 ! b(searc)o(h)f(string)g(ma)o(y)g(b)q(e)h(t)o(yp)q(ed)f(b)o(y)h(the)f ! (user)h(or)e(b)q(e)i(part)f(of)g(the)75 773 y(con)o(ten)o(ts)15 ! b(of)f(the)i(curren)o(t)f(line.)75 896 y Fs(1.3)33 b(Readline)23 ! b(Init)h(File)137 990 y Fu(Although)f(the)g(Readline)h(library)f(comes) ! g(with)g(a)f(set)g(of)g(Emacs-lik)o(e)i(k)o(eybindings)g(installed)75 ! 1045 y(b)o(y)d(default,)h(it)f(is)h(p)q(ossible)g(to)e(use)i(a)e ! (di\013eren)o(t)h(set)g(of)f(k)o(eybindings.)39 b(An)o(y)20 ! b(user)h(can)g(customize)75 1100 y(programs)15 b(that)h(use)g(Readline) ! i(b)o(y)e(putting)g(commands)g(in)i(an)e Fk(inputrc)k ! Fu(\014le,)d(con)o(v)o(en)o(tionally)g(in)g(his)75 1155 ! y(home)g(directory)l(.)24 b(The)17 b(name)g(of)f(this)h(\014le)g(is)g ! (tak)o(en)g(from)e(the)i(v)m(alue)h(of)e(the)h(en)o(vironmen)o(t)g(v)m ! (ariable)75 1209 y Ft(INPUTRC)p Fu(.)i(If)c(that)g(v)m(ariable)h(is)g ! (unset,)f(the)g(default)h(is)g(`)p Ft(~/.inputrc)p Fu('.)137 ! 1275 y(When)f(a)g(program)f(whic)o(h)h(uses)g(the)g(Readline)h(library) ! g(starts)d(up,)i(the)g(init)h(\014le)g(is)f(read,)g(and)g(the)75 ! 1329 y(k)o(ey)g(bindings)i(are)e(set.)137 1395 y(In)f(addition,)h(the)e Ft(C-x)i(C-r)e Fu(command)g(re-reads)h(this)g(init)g(\014le,)h(th)o(us) ! e(incorp)q(orating)h(an)o(y)f(c)o(hanges)75 1450 y(that)h(y)o(ou)h ! (migh)o(t)g(ha)o(v)o(e)g(made)g(to)g(it.)75 1556 y Fj(1.3.1)30 ! b(Readline)20 b(Init)g(File)h(Syn)n(tax)137 1650 y Fu(There)c(are)g (only)g(a)g(few)f(basic)i(constructs)e(allo)o(w)o(ed)i(in)f(the)g ! (Readline)h(init)g(\014le.)26 b(Blank)18 b(lines)g(are)75 ! 1705 y(ignored.)36 b(Lines)22 b(b)q(eginning)h(with)d(a)h(`)p Ft(#)p Fu(')e(are)h(commen)o(ts.)35 b(Lines)22 b(b)q(eginning)h(with)e ! (a)f(`)p Ft($)p Fu(')f(indicate)75 1760 y(conditional)c(constructs)f (\(see)g(Section)g(1.3.2)f([Conditional)h(Init)h(Constructs],)e(page)h ! (8\).)k(Other)c(lines)75 1814 y(denote)h(v)m(ariable)i(settings)e(and)h ! (k)o(ey)f(bindings.)75 1890 y(V)l(ariable)h(Settings)315 ! 1945 y(Y)l(ou)k(can)h(mo)q(dify)g(the)f(run-time)h(b)q(eha)o(vior)g(of) ! e(Readline)j(b)o(y)e(altering)h(the)f(v)m(alues)h(of)315 ! 2000 y(v)m(ariables)d(in)g(Readline)g(using)f(the)g Ft(set)g ! Fu(command)f(within)i(the)f(init)h(\014le.)26 b(The)17 ! b(syn)o(tax)315 2055 y(is)f(simple:)435 2117 y Ft(set)23 ! b Fk(v)m(ariable)28 b(v)m(alue)315 2182 y Fu(Here,)14 ! b(for)f(example,)h(is)g(ho)o(w)f(to)g(c)o(hange)h(from)f(the)h(default) ! g(Emacs-lik)o(e)h(k)o(ey)e(binding)j(to)315 2237 y(use)g ! Ft(vi)e Fu(line)j(editing)g(commands:)435 2299 y Ft(set)23 ! b(editing-mode)g(vi)315 2365 y Fu(V)l(ariable)c(names)e(and)h(v)m ! (alues,)h(where)e(appropriate,)h(are)f(recognized)i(without)e(regard) ! 315 2419 y(to)e(case.)315 2485 y(A)g(great)g(deal)g(of)g(run-time)h(b)q ! (eha)o(vior)g(is)g(c)o(hangeable)g(with)f(the)h(follo)o(wing)f(v)m ! (ariables.)315 2560 y Ft(bell-style)555 2615 y Fu(Con)o(trols)21 ! b(what)h(happ)q(ens)h(when)f(Readline)h(w)o(an)o(ts)e(to)g(ring)i(the)f ! (termi-)555 2670 y(nal)d(b)q(ell.)32 b(If)19 b(set)f(to)g(`)p ! Ft(none)p Fu(',)g(Readline)i(nev)o(er)f(rings)g(the)f(b)q(ell.)32 ! b(If)19 b(set)g(to)p eop %%Page: 5 7 5 6 bop 75 -58 a Fu(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1077 ! b(5)555 149 y(`)p Ft(visible)p Fu(',)15 b(Readline)i(uses)g(a)f ! (visible)j(b)q(ell)g(if)e(one)f(is)h(a)o(v)m(ailable.)26 ! b(If)16 b(set)h(to)555 204 y(`)p Ft(audible)p Fu(')g(\(the)h ! (default\),)i(Readline)g(attempts)e(to)g(ring)h(the)g(terminal's)555 ! 259 y(b)q(ell.)315 338 y Ft(comment-begin)555 393 y Fu(The)c(string)f ! (to)g(insert)i(at)d(the)i(b)q(eginning)i(of)d(the)h(line)h(when)f(the)g ! Ft(insert-)555 448 y(comment)f Fu(command)h(is)h(executed.)21 ! b(The)15 b(default)h(v)m(alue)g(is)g Ft("#")p Fu(.)315 ! 527 y Ft(completion-ignore-case)555 582 y Fu(If)e(set)f(to)g(`)p ! Ft(on)p Fu(',)g(Readline)i(p)q(erforms)e(\014lename)i(matc)o(hing)f ! (and)g(completion)555 637 y(in)i(a)f(case-insensitiv)o(e)i(fashion.)k ! (The)15 b(default)h(v)m(alue)g(is)g(`)p Ft(off)p Fu('.)315 ! 716 y Ft(completion-query-items)555 770 y Fu(The)d(n)o(um)o(b)q(er)h ! (of)e(p)q(ossible)j(completions)g(that)d(determines)i(when)g(the)f ! (user)555 825 y(is)21 b(ask)o(ed)g(whether)g(he)h(w)o(an)o(ts)d(to)i ! (see)g(the)g(list)h(of)e(p)q(ossibilitie)q(s.)40 b(If)21 ! b(the)555 880 y(n)o(um)o(b)q(er)14 b(of)f(p)q(ossible)i(completions)f ! (is)g(greater)f(than)g(this)h(v)m(alue,)h(Readline)555 ! 935 y(will)g(ask)e(the)g(user)h(whether)f(or)g(not)g(he)g(wishes)h(to)f ! (view)h(them;)f(otherwise,)555 990 y(they)f(are)g(simply)i(listed.)20 ! b(This)13 b(v)m(ariable)g(m)o(ust)f(b)q(e)h(set)f(to)f(an)h(in)o(teger) ! h(v)m(alue)555 1044 y(greater)h(than)h(or)g(equal)h(to)f(0.)k(The)d ! (default)f(limit)i(is)f Ft(100)p Fu(.)315 1124 y Ft(convert-meta)555 ! 1178 y Fu(If)11 b(set)g(to)g(`)p Ft(on)p Fu(',)f(Readline)i(will)h(con) ! o(v)o(ert)d(c)o(haracters)h(with)g(the)g(eigh)o(th)h(bit)f(set)555 ! 1233 y(to)f(an)h Fp(asci)q(i)e Fu(k)o(ey)i(sequence)g(b)o(y)g ! (stripping)h(the)e(eigh)o(th)h(bit)h(and)e(pre\014xing)i(an)555 ! 1286 y Fn(h)p 567 1260 70 2 v 567 1288 a Fm(ESC)p 567 ! 1296 V 634 1286 a Fn(i)666 1288 y Fu(c)o(haracter,)k(con)o(v)o(erting)h ! (them)g(to)f(a)h(meta-pre\014xed)g(k)o(ey)g(sequence.)555 ! 1343 y(The)e(default)h(v)m(alue)h(is)e(`)p Ft(on)p Fu('.)315 ! 1422 y Ft(disable-completion)555 1477 y Fu(If)k(set)f(to)f(`)p ! Ft(On)p Fu(',)h(Readline)i(will)g(inhibit)g(w)o(ord)e(completion.)30 ! b(Completion)555 1531 y(c)o(haracters)12 b(will)j(b)q(e)f(inserted)g ! (in)o(to)f(the)g(line)h(as)f(if)h(they)f(had)g(b)q(een)h(mapp)q(ed)555 ! 1586 y(to)h Ft(self-insert)p Fu(.)j(The)d(default)h(is)g(`)p ! Ft(off)p Fu('.)315 1665 y Ft(editing-mode)555 1720 y ! Fu(The)f Ft(editing-mode)d Fu(v)m(ariable)k(con)o(trols)e(whic)o(h)h ! (default)g(set)f(of)g(k)o(ey)g(bind-)555 1775 y(ings)f(is)g(used.)20 ! b(By)12 b(default,)i(Readline)f(starts)f(up)h(in)g(Emacs)f(editing)i ! (mo)q(de,)555 1830 y(where)h(the)f(k)o(eystrok)o(es)g(are)g(most)g ! (similar)i(to)d(Emacs.)20 b(This)15 b(v)m(ariable)h(can)555 ! 1885 y(b)q(e)g(set)f(to)f(either)i(`)p Ft(emacs)p Fu(')e(or)h(`)p ! Ft(vi)p Fu('.)315 1964 y Ft(enable-keypad)555 2019 y ! Fu(When)d(set)f(to)h(`)p Ft(on)p Fu(',)e(Readline)j(will)h(try)d(to)g ! (enable)i(the)f(application)h(k)o(eypad)555 2073 y(when)h(it)f(is)h ! (called.)21 b(Some)13 b(systems)g(need)h(this)g(to)f(enable)h(the)g ! (arro)o(w)e(k)o(eys.)555 2128 y(The)j(default)h(is)g(`)p ! Ft(off)p Fu('.)315 2207 y Ft(expand-tilde)555 2262 y ! Fu(If)e(set)g(to)f(`)p Ft(on)p Fu(',)f(tilde)k(expansion)e(is)h(p)q ! (erformed)f(when)g(Readline)h(attempts)555 2317 y(w)o(ord)g ! (completion.)21 b(The)15 b(default)h(is)f(`)p Ft(off)p ! Fu('.)315 2396 y Ft(horizontal-scroll-mode)555 2451 y ! Fu(This)k(v)m(ariable)g(can)f(b)q(e)g(set)g(to)f(either)i(`)p ! Ft(on)p Fu(')e(or)g(`)p Ft(off)p Fu('.)27 b(Setting)19 ! b(it)f(to)f(`)p Ft(on)p Fu(')555 2506 y(means)c(that)f(the)i(text)e(of) ! h(the)g(lines)i(b)q(eing)f(edited)g(will)h(scroll)f(horizon)o(tally)555 ! 2560 y(on)i(a)f(single)i(screen)g(line)g(when)g(they)f(are)f(longer)h ! (than)g(the)g(width)g(of)g(the)555 2615 y(screen,)e(instead)f(of)g (wrapping)g(on)o(to)f(a)h(new)g(screen)h(line.)21 b(By)13 ! b(default,)h(this)555 2670 y(v)m(ariable)j(is)e(set)g(to)g(`)p ! Ft(off)p Fu('.)p eop %%Page: 6 8 ! 6 7 bop 75 -58 a Fu(6)1322 b(GNU)15 b(Readline)h(Library)315 ! 149 y Ft(input-meta)555 204 y Fu(If)g(set)f(to)g(`)p ! Ft(on)p Fu(',)f(Readline)j(will)h(enable)e(eigh)o(t-bit)h(input)f(\(it) ! g(will)h(not)e(clear)555 259 y(the)20 b(eigh)o(th)g(bit)g(in)h(the)f(c) ! o(haracters)f(it)h(reads\),)g(regardless)g(of)g(what)f(the)555 ! 314 y(terminal)i(claims)g(it)f(can)g(supp)q(ort.)34 b(The)20 ! b(default)h(v)m(alue)g(is)g(`)p Ft(off)p Fu('.)33 b(The)555 ! 369 y(name)15 b Ft(meta-flag)f Fu(is)i(a)f(synon)o(ym)g(for)f(this)i(v) ! m(ariable.)315 448 y Ft(isearch-terminators)555 503 y ! Fu(The)26 b(string)g(of)f(c)o(haracters)g(that)g(should)i(terminate)f ! (an)g(incremen)o(tal)555 557 y(searc)o(h)12 b(without)h(subsequen)o ! (tly)g(executing)h(the)e(c)o(haracter)g(as)g(a)g(command)555 ! 612 y(\(see)22 b(Section)h(1.2.5)e([Searc)o(hing],)j(page)e(3\).)40 ! b(If)23 b(this)g(v)m(ariable)g(has)f(not)555 667 y(b)q(een)17 ! b(giv)o(en)f(a)g(v)m(alue,)g(the)g(c)o(haracters)1247 ! 665 y Fn(h)p 1259 639 70 2 v 1259 667 a Fm(ESC)p 1259 ! 675 V 1326 665 a Fn(i)1357 667 y Fu(and)g Fo(C-J)f Fu(will)i(terminate) ! f(an)555 722 y(incremen)o(tal)g(searc)o(h.)315 801 y ! Ft(keymap)96 b Fu(Sets)19 b(Readline's)i(idea)f(of)f(the)g(curren)o(t)h ! (k)o(eymap)f(for)f(k)o(ey)i(binding)h(com-)555 856 y(mands.)41 ! b(Acceptable)23 b Ft(keymap)f Fu(names)g(are)f Ft(emacs)p ! Fu(,)i Ft(emacs-standard)p Fu(,)555 910 y Ft(emacs-meta)p ! Fu(,)49 b Ft(emacs-ctlx)p Fu(,)g Ft(vi)p Fu(,)h Ft(vi-move)p ! Fu(,)f Ft(vi-command)p Fu(,)g(and)555 965 y Ft(vi-insert)p ! Fu(.)31 b Ft(vi)20 b Fu(is)g(equiv)m(alen)o(t)h(to)e ! Ft(vi-command)p Fu(;)g Ft(emacs)g Fu(is)h(equiv)m(alen)o(t)555 ! 1020 y(to)15 b Ft(emacs-standard)p Fu(.)20 b(The)d(default)f(v)m(alue)h ! (is)g Ft(emacs)p Fu(.)k(The)16 b(v)m(alue)h(of)f(the)555 ! 1075 y Ft(editing-mode)e Fu(v)m(ariable)i(also)f(a\013ects)g(the)g ! (default)h(k)o(eymap.)315 1154 y Ft(mark-directories)555 ! 1209 y Fu(If)j(set)g(to)g(`)p Ft(on)p Fu(',)f(completed)i(directory)g ! (names)f(ha)o(v)o(e)f(a)h(slash)h(app)q(ended.)555 1264 ! y(The)15 b(default)h(is)g(`)p Ft(on)p Fu('.)315 1343 ! y Ft(mark-modified-lines)555 1398 y Fu(This)j(v)m(ariable,)g(when)g ! (set)e(to)h(`)p Ft(on)p Fu(',)f(causes)h(Readline)h(to)e(displa)o(y)i ! (an)f(as-)555 1452 y(terisk)f(\(`)p Ft(*)p Fu('\))e(at)i(the)f(start)g ! (of)h(history)f(lines)j(whic)o(h)e(ha)o(v)o(e)g(b)q(een)h(mo)q ! (di\014ed.)555 1507 y(This)e(v)m(ariable)g(is)g(`)p Ft(off)p ! Fu(')e(b)o(y)h(default.)315 1586 y Ft(output-meta)555 ! 1641 y Fu(If)j(set)f(to)g(`)p Ft(on)p Fu(',)g(Readline)i(will)h(displa) ! o(y)f(c)o(haracters)d(with)j(the)e(eigh)o(th)h(bit)555 ! 1696 y(set)g(directly)i(rather)d(than)h(as)g(a)g(meta-pre\014xed)h ! (escap)q(e)g(sequence.)30 b(The)555 1751 y(default)16 ! b(is)f(`)p Ft(off)p Fu('.)315 1830 y Ft(print-completions-horizont)o ! (ally)555 1885 y Fu(If)d(set)g(to)f(`)p Ft(on)p Fu(',)h(Readline)h ! (will)g(displa)o(y)h(completions)f(with)f(matc)o(hes)f(sorted)555 ! 1939 y(horizon)o(tally)23 b(in)f(alphab)q(etical)i(order,)f(rather)e ! (than)g(do)o(wn)h(the)g(screen.)555 1994 y(The)15 b(default)h(is)g(`)p ! Ft(off)p Fu('.)315 2073 y Ft(show-all-if-ambiguous)555 ! 2128 y Fu(This)g(alters)e(the)i(default)f(b)q(eha)o(vior)h(of)e(the)h ! (completion)h(functions.)21 b(If)15 b(set)555 2183 y(to)e(`)p ! Ft(on)p Fu(',)g(w)o(ords)g(whic)o(h)h(ha)o(v)o(e)g(more)f(than)g(one)h ! (p)q(ossible)i(completion)f(cause)555 2238 y(the)20 b(matc)o(hes)f(to)f ! (b)q(e)j(listed)f(immediately)h(instead)f(of)f(ringing)i(the)e(b)q ! (ell.)555 2293 y(The)c(default)h(v)m(alue)h(is)e(`)p ! Ft(off)p Fu('.)315 2372 y Ft(visible-stats)555 2426 y ! Fu(If)h(set)g(to)f(`)p Ft(on)p Fu(',)g(a)h(c)o(haracter)f(denoting)h(a) ! g(\014le's)h(t)o(yp)q(e)f(is)g(app)q(ended)i(to)d(the)555 ! 2481 y(\014lename)h(when)g(listing)h(p)q(ossible)g(completions.)j(The)c ! (default)g(is)f(`)p Ft(off)p Fu('.)75 2560 y(Key)h(Bindings)315 ! 2615 y(The)21 b(syn)o(tax)f(for)h(con)o(trolling)h(k)o(ey)f(bindings)h (in)g(the)f(init)h(\014le)g(is)g(simple.)39 b(First)20 ! b(y)o(ou)315 2670 y(need)15 b(to)e(\014nd)h(the)g(name)g(of)g(the)f (command)h(that)f(y)o(ou)h(w)o(an)o(t)f(to)g(c)o(hange.)19 ! b(The)14 b(follo)o(wing)p eop %%Page: 7 9 7 8 bop 75 -58 a Fu(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1077 ! b(7)315 149 y(sections)18 b(con)o(tain)h(tables)f(of)f(the)h(command)g ! (name,)g(the)g(default)h(k)o(eybinding,)h(if)e(an)o(y)l(,)315 ! 204 y(and)d(a)g(short)g(description)i(of)d(what)h(the)g(command)g(do)q ! (es.)315 273 y(Once)k(y)o(ou)f(kno)o(w)f(the)h(name)g(of)g(the)g ! (command,)g(simply)h(place)g(on)f(a)f(line)j(in)f(the)f(init)315 ! 328 y(\014le)g(the)f(name)g(of)f(the)h(k)o(ey)g(y)o(ou)f(wish)i(to)e ! (bind)i(the)f(command)g(to,)f(a)g(colon,)i(and)f(then)315 ! 382 y(the)f(name)g(of)g(the)g(command.)22 b(The)16 b(name)g(of)g(the)g ! (k)o(ey)f(can)i(b)q(e)f(expressed)h(in)g(di\013eren)o(t)315 ! 437 y(w)o(a)o(ys,)d(dep)q(ending)j(on)e(what)g(y)o(ou)g(\014nd)h(most)e ! (comfortable.)315 506 y(In)19 b(addition)g(to)e(command)h(names,)g ! (readline)i(allo)o(ws)e(k)o(eys)g(to)f(b)q(e)i(b)q(ound)g(to)e(a)h ! (string)315 561 y(that)c(is)i(inserted)g(when)g(the)f(k)o(ey)g(is)h ! (pressed)g(\(a)e Fk(macro)r Fu(\).)315 643 y Fk(k)o(eyname)s ! Fu(:)19 b Fk(function-name)g Fu(or)c Fk(macro)555 698 ! y(k)o(eyname)i Fu(is)e(the)f(name)h(of)f(a)g(k)o(ey)g(sp)q(elled)j(out) ! d(in)h(English.)21 b(F)l(or)13 b(example:)675 764 y Ft(Control-u:)22 ! b(universal-argument)675 816 y(Meta-Rubout:)g(backward-kill-word)675 ! 867 y(Control-o:)g(">)i(output")555 936 y Fu(In)c(the)f(ab)q(o)o(v)o(e) ! g(example,)i Fo(C-u)e Fu(is)h(b)q(ound)g(to)f(the)g(function)h ! Ft(universal-)555 991 y(argument)p Fu(,)e Fo(M-DEL)h ! Fu(is)g(b)q(ound)h(to)e(the)h(function)h Ft(backward-kill-word)p ! Fu(,)555 1046 y(and)g Fo(C-o)f Fu(is)h(b)q(ound)g(to)f(run)h(the)f ! (macro)g(expressed)h(on)g(the)f(righ)o(t)h(hand)555 1101 ! y(side)c(\(that)e(is,)i(to)e(insert)i(the)f(text)g(`)p ! Ft(>)f(output)p Fu(')g(in)o(to)i(the)f(line\).)555 1169 ! y(A)k(n)o(um)o(b)q(er)f(of)g(sym)o(b)q(olic)i(c)o(haracter)e(names)g ! (are)g(recognized)i(while)g(pro-)555 1224 y(cessing)13 ! b(this)f(k)o(ey)g(binding)h(syn)o(tax:)18 b Fk(DEL)p ! Fu(,)11 b Fk(ESC)p Fu(,)h Fk(ESCAPE)p Fu(,)f Fk(LFD)p ! Fu(,)g Fk(NEW-)555 1279 y(LINE)p Fu(,)16 b Fk(RET)p Fu(,)e ! Fk(RETURN)p Fu(,)f Fk(R)o(UBOUT)p Fu(,)i Fk(SP)l(A)o(CE)p ! Fu(,)g Fk(SPC)p Fu(,)f(and)i Fk(T)l(AB)p Fu(.)315 1361 ! y Ft(")p Fk(k)o(eyseq)q Ft(")p Fu(:)k Fk(function-name)e ! Fu(or)d Fk(macro)555 1416 y(k)o(eyseq)i Fu(di\013ers)e(from)g ! Fk(k)o(eyname)j Fu(ab)q(o)o(v)o(e)d(in)i(that)d(strings)i(denoting)g ! (an)f(en-)555 1471 y(tire)i(k)o(ey)g(sequence)h(can)f(b)q(e)g(sp)q ! (eci\014ed,)i(b)o(y)e(placing)h(the)f(k)o(ey)g(sequence)h(in)555 ! 1526 y(double)e(quotes.)j(Some)c Fp(gnu)g Fu(Emacs)f(st)o(yle)h(k)o(ey) ! g(escap)q(es)g(can)g(b)q(e)g(used,)g(as)555 1580 y(in)j(the)f(follo)o ! (wing)g(example,)h(but)f(the)g(sp)q(ecial)i(c)o(haracter)d(names)h(are) ! f(not)555 1635 y(recognized.)675 1701 y Ft("\\C-u":)23 ! b(universal-argument)675 1753 y("\\C-x\\C-r":)f(re-read-init-file)675 ! 1805 y("\\e[11~":)h("Function)f(Key)i(1")555 1873 y Fu(In)33 ! b(the)f(ab)q(o)o(v)o(e)g(example,)37 b Fo(C-u)32 b Fu(is)h(again)f(b)q ! (ound)h(to)f(the)g(function)555 1928 y Ft(universal-argument)19 ! b Fu(\(just)j(as)f(it)h(w)o(as)f(in)i(the)f(\014rst)f(example\),)j(`)p ! Fo(C-x)555 1983 y(C-r)p Fu(')c(is)h(b)q(ound)g(to)f(the)h(function)g ! Ft(re-read-init-file)p Fu(,)f(and)g(`)1731 1981 y Fn(h)p ! 1743 1955 70 2 v 1743 1983 a Fm(ESC)p 1743 1991 V 1810 ! 1981 a Fn(i)15 b(h)p 1852 1955 10 2 v 1852 1983 a Fm([)p ! 1852 1991 V 1860 1981 a Fn(i)555 2036 y(h)p 567 2010 ! 18 2 v 567 2038 a Fm(1)p 567 2045 V 583 2036 a Fn(i)g(h)p ! 625 2010 V 625 2038 a Fm(1)p 625 2045 V 640 2036 a Fn(i)g(h)p ! 683 2010 24 2 v 683 2038 a Ft(~)p 683 2045 V 704 2036 ! a Fn(i)719 2038 y Fu(')g(is)h(b)q(ound)g(to)e(insert)i(the)f(text)g(`)p ! Ft(Function)f(Key)g(1)p Fu('.)315 2120 y(The)h(follo)o(wing)h ! Fp(gnu)e Fu(Emacs)h(st)o(yle)g(escap)q(e)h(sequences)g(are)e(a)o(v)m ! (ailable)j(when)e(sp)q(ecifying)315 2175 y(k)o(ey)g(sequences:)315 ! 2258 y Fo(\\C-)168 b Fu(con)o(trol)15 b(pre\014x)315 ! 2340 y Fo(\\M-)168 b Fu(meta)15 b(pre\014x)315 2423 y ! Fo(\\e)192 b Fu(an)15 b(escap)q(e)h(c)o(haracter)315 ! 2505 y Fo(\\\\)192 b Fu(bac)o(kslash)315 2587 y Fo(\\)p ! Ft(")555 2585 y Fn(h)p 567 2559 V 567 2587 a Ft(")p 567 ! 2595 V 589 2585 a Fn(i)604 2587 y Fu(,)15 b(a)f(double)j(quotation)e ! (mark)315 2670 y Fo(\\')555 2668 y Fn(h)p 567 2642 10 ! 2 v 567 2670 a Fm(')p 567 2678 V 575 2668 a Fn(i)590 ! 2670 y Fu(,)g(a)f(single)j(quote)e(or)g(ap)q(ostrophe)p eop %%Page: 8 10 ! 8 9 bop 75 -58 a Fu(8)1322 b(GNU)15 b(Readline)h(Library)315 ! 149 y(In)e(addition)h(to)f(the)f Fp(gnu)h Fu(Emacs)g(st)o(yle)f(escap)q ! (e)i(sequences,)g(a)e(second)i(set)e(of)h(bac)o(kslash)315 ! 204 y(escap)q(es)i(is)g(a)o(v)m(ailable:)315 286 y Ft(\\a)192 ! b Fu(alert)15 b(\(b)q(ell\))315 368 y Ft(\\b)192 b Fu(bac)o(kspace)315 ! 449 y Ft(\\d)g Fu(delete)315 531 y Ft(\\f)g Fu(form)14 ! b(feed)315 613 y Ft(\\n)192 b Fu(newline)315 694 y Ft(\\r)g ! Fu(carriage)15 b(return)315 776 y Ft(\\t)192 b Fu(horizon)o(tal)16 ! b(tab)315 858 y Ft(\\v)192 b Fu(v)o(ertical)16 b(tab)315 ! 940 y Ft(\\)p Fk(nnn)141 b Fu(the)14 b(c)o(haracter)f(whose)h ! Fp(asci)q(i)e Fu(co)q(de)j(is)f(the)g(o)q(ctal)g(v)m(alue)h ! Fk(nnn)f Fu(\(one)g(to)f(three)555 994 y(digits\))315 ! 1076 y Ft(\\x)p Fk(nnn)117 b Fu(the)16 b(c)o(haracter)f(whose)h ! Fp(asci)q(i)f Fu(co)q(de)i(is)f(the)h(hexadecimal)g(v)m(alue)g ! Fk(nnn)g Fu(\(one)555 1131 y(to)e(three)g(digits\))315 ! 1213 y(When)k(en)o(tering)g(the)g(text)f(of)g(a)h(macro,)f(single)i(or) ! e(double)i(quotes)f(m)o(ust)f(b)q(e)h(used)h(to)315 1267 ! y(indicate)12 b(a)f(macro)f(de\014nition.)20 b(Unquoted)11 ! b(text)f(is)i(assumed)e(to)h(b)q(e)g(a)f(function)i(name.)18 ! b(In)315 1322 y(the)11 b(macro)f(b)q(o)q(dy)l(,)i(the)f(bac)o(kslash)g ! (escap)q(es)g(describ)q(ed)i(ab)q(o)o(v)o(e)d(are)g(expanded.)20 ! b(Bac)o(kslash)315 1377 y(will)i(quote)d(an)o(y)h(other)g(c)o(haracter) ! f(in)i(the)f(macro)f(text,)h(including)j(`)p Ft(")p Fu(')c(and)h(`)p ! Ft(')p Fu('.)34 b(F)l(or)315 1432 y(example,)14 b(the)f(follo)o(wing)g ! (binding)i(will)g(mak)o(e)d(`)p Fo(C-x)i Ft(\\)p Fu(')f(insert)g(a)g ! (single)h(`)p Ft(\\)p Fu(')e(in)o(to)h(the)g(line:)435 ! 1497 y Ft("\\C-x\\\\":)23 b("\\\\")75 1613 y Fj(1.3.2)30 ! b(Conditional)20 b(Init)g(Constructs)137 1712 y Fu(Readline)f(implemen) ! o(ts)g(a)f(facilit)o(y)g(similar)h(in)g(spirit)f(to)f(the)h ! (conditional)h(compilation)g(features)75 1766 y(of)e(the)g(C)g(prepro)q ! (cessor)g(whic)o(h)i(allo)o(ws)e(k)o(ey)g(bindings)i(and)f(v)m(ariable) ! g(settings)f(to)g(b)q(e)h(p)q(erformed)f(as)75 1821 y(the)e(result)h ! (of)f(tests.)k(There)c(are)g(four)g(parser)g(directiv)o(es)h(used.)75 ! 1904 y Ft($if)168 b Fu(The)16 b Ft($if)f Fu(construct)g(allo)o(ws)h ! (bindings)i(to)d(b)q(e)h(made)g(based)g(on)f(the)h(editing)h(mo)q(de,)f ! (the)315 1959 y(terminal)k(b)q(eing)g(used,)g(or)f(the)g(application)i ! (using)e(Readline.)33 b(The)19 b(text)g(of)f(the)i(test)315 ! 2013 y(extends)c(to)e(the)h(end)h(of)f(the)g(line;)i(no)e(c)o ! (haracters)f(are)h(required)i(to)d(isolate)i(it.)315 ! 2095 y Ft(mode)144 b Fu(The)11 b Ft(mode=)e Fu(form)h(of)g(the)h ! Ft($if)f Fu(directiv)o(e)h(is)g(used)g(to)f(test)g(whether)h(Readline) ! 555 2150 y(is)k(in)h Ft(emacs)e Fu(or)g Ft(vi)g Fu(mo)q(de.)20 b(This)c(ma)o(y)e(b)q(e)h(used)g(in)h(conjunction)g(with)f(the)555 ! 2205 y(`)p Ft(set)f(keymap)p Fu(')f(command,)g(for)h(instance,)g(to)f ! (set)h(bindings)h(in)g(the)f Ft(emacs-)555 2260 y(standard)d ! Fu(and)i Ft(emacs-ctlx)e Fu(k)o(eymaps)h(only)i(if)f(Readline)g(is)g ! (starting)f(out)555 2314 y(in)k Ft(emacs)f Fu(mo)q(de.)315 ! 2396 y Ft(term)144 b Fu(The)14 b Ft(term=)e Fu(form)h(ma)o(y)g(b)q(e)h (used)g(to)f(include)j(terminal-sp)q(eci\014c)g(k)o(ey)d(bind-)555 ! 2451 y(ings,)19 b(p)q(erhaps)g(to)e(bind)i(the)g(k)o(ey)e(sequences)j ! (output)e(b)o(y)g(the)g(terminal's)555 2506 y(function)13 b(k)o(eys.)18 b(The)13 b(w)o(ord)e(on)h(the)g(righ)o(t)g(side)g(of)g ! (the)g(`)p Ft(=)p Fu(')f(is)h(tested)g(against)555 2560 y(b)q(oth)j(the)g(full)i(name)e(of)f(the)h(terminal)h(and)f(the)g(p)q ! (ortion)h(of)e(the)h(terminal)555 2615 y(name)i(b)q(efore)g(the)g (\014rst)f(`)p Ft(-)p Fu('.)24 b(This)17 b(allo)o(ws)g Ft(sun)f Fu(to)g(matc)o(h)h(b)q(oth)f Ft(sun)h Fu(and)555 ! 2670 y Ft(sun-cmd)p Fu(,)d(for)g(instance.)p eop %%Page: 9 11 9 10 bop 75 -58 a Fu(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1077 ! b(9)315 149 y Ft(application)555 204 y Fu(The)11 b Fk(application)i ! Fu(construct)e(is)g(used)h(to)e(include)j(application-sp)q(eci)q(\014c) ! h(set-)555 259 y(tings.)19 b(Eac)o(h)12 b(program)f(using)j(the)e ! (Readline)i(library)f(sets)f(the)g Fk(application)555 ! 314 y(name)p Fu(,)g(and)g(y)o(ou)f(can)h(test)f(for)g(a)g(particular)h ! (v)m(alue.)20 b(This)12 b(could)h(b)q(e)f(used)h(to)555 ! 369 y(bind)18 b(k)o(ey)e(sequences)i(to)d(functions)j(useful)f(for)f(a) ! g(sp)q(eci\014c)i(program.)23 b(F)l(or)555 423 y(instance,)17 ! b(the)g(follo)o(wing)g(command)g(adds)f(a)g(k)o(ey)h(sequence)g(that)f ! (quotes)555 478 y(the)f(curren)o(t)g(or)g(previous)h(w)o(ord)e(in)j ! (Bash:)675 543 y Ft($if)23 b(Bash)675 594 y(#)h(Quote)f(the)g(current)g ! (or)h(previous)f(word)675 646 y("\\C-xq":)g("\\eb\\"\\ef\\"")675 ! 698 y($endif)75 778 y($endif)96 b Fu(This)16 b(command,)e(as)h(seen)h ! (in)g(the)f(previous)h(example,)g(terminates)f(an)g Ft($if)f ! Fu(command.)75 858 y Ft($else)120 b Fu(Commands)15 b(in)h(this)f(branc) o(h)h(of)e(the)i Ft($if)e Fu(directiv)o(e)j(are)e(executed)h(if)g(the)f ! (test)g(fails.)75 937 y Ft($include)48 b Fu(This)22 b(directiv)o(e)h ! (tak)o(es)e(a)h(single)h(\014lename)g(as)e(an)h(argumen)o(t)f(and)h ! (reads)f(commands)315 992 y(and)e(bindings)j(from)c(that)h(\014le.)33 ! b(F)l(or)19 b(example,)i(the)e(follo)o(wing)h(directiv)o(e)h(reads)e ! (from)315 1047 y(`)p Ft(/etc/inputrc)p Fu(':)435 1111 ! y Ft($include)k(/etc/inputrc)75 1223 y Fj(1.3.3)30 b(Sample)20 ! b(Init)h(File)137 1320 y Fu(Here)16 b(is)g(an)f(example)h(of)f(an)g ! Fk(inputrc)k Fu(\014le.)i(This)16 b(illustrates)g(k)o(ey)f(binding,)i ! (v)m(ariable)f(assignmen)o(t,)75 1374 y(and)f(conditional)i(syn)o(tax.) ! p eop %%Page: 10 12 ! 10 11 bop 75 -58 a Fu(10)1299 b(GNU)15 b(Readline)h(Library)195 ! 201 y Ft(#)24 b(This)f(file)g(controls)g(the)h(behaviour)e(of)i(line)f ! (input)g(editing)g(for)195 253 y(#)h(programs)e(that)i(use)f(the)h(Gnu) f(Readline)g(library.)47 b(Existing)22 b(programs)195 ! 305 y(#)i(include)f(FTP,)g(Bash,)g(and)h(Gdb.)195 357 ! y(#)195 409 y(#)g(You)f(can)h(re-read)f(the)g(inputrc)g(file)g(with)h ! (C-x)f(C-r.)195 461 y(#)h(Lines)f(beginning)g(with)g('#')g(are)h ! (comments.)195 513 y(#)195 565 y(#)g(First,)f(include)g(any)g (systemwide)g(bindings)f(and)i(variable)f(assignments)f(from)195 ! 616 y(#)i(/etc/Inputrc)195 668 y($include)f(/etc/Inputrc)195 ! 772 y(#)195 824 y(#)h(Set)f(various)g(bindings)g(for)g(emacs)g(mode.) ! 195 928 y(set)g(editing-mode)g(emacs)195 1032 y($if)g(mode=emacs)195 ! 1135 y(Meta-Control-h:)46 b(backward-kill-word)21 b(Text)i(after)h(the) ! f(function)g(name)g(is)h(ignored)p 1986 1145 21 38 v ! 195 1239 a(#)195 1291 y(#)g(Arrow)f(keys)g(in)h(keypad)f(mode)195 ! 1343 y(#)195 1395 y(#"\\M-OD":)190 b(backward-char)195 ! 1447 y(#"\\M-OC":)g(forward-char)195 1499 y(#"\\M-OA":)g ! (previous-history)195 1550 y(#"\\M-OB":)g(next-history)195 ! 1602 y(#)195 1654 y(#)24 b(Arrow)f(keys)g(in)h(ANSI)f(mode)195 ! 1706 y(#)195 1758 y("\\M-[D":)190 b(backward-char)195 ! 1810 y("\\M-[C":)g(forward-char)195 1862 y("\\M-[A":)g ! (previous-history)195 1914 y("\\M-[B":)g(next-history)195 ! 1966 y(#)195 2017 y(#)24 b(Arrow)f(keys)g(in)h(8)g(bit)f(keypad)g(mode) ! 195 2069 y(#)195 2121 y(#"\\M-\\C-OD":)165 b(backward-char)195 ! 2173 y(#"\\M-\\C-OC":)g(forward-char)195 2225 y(#"\\M-\\C-OA":)g ! (previous-history)195 2277 y(#"\\M-\\C-OB":)g(next-history)195 ! 2329 y(#)195 2381 y(#)24 b(Arrow)f(keys)g(in)h(8)g(bit)f(ANSI)g(mode) ! 195 2433 y(#)195 2484 y(#"\\M-\\C-[D":)165 b(backward-char)195 ! 2536 y(#"\\M-\\C-[C":)g(forward-char)195 2588 y(#"\\M-\\C-[A":)g ! (previous-history)195 2640 y(#"\\M-\\C-[B":)g(next-history)p ! eop %%Page: 11 13 11 12 bop 75 -58 a Fu(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1055 ! b(11)195 201 y Ft(C-q:)23 b(quoted-insert)195 305 y($endif)195 ! 409 y(#)h(An)f(old-style)g(binding.)47 b(This)23 b(happens)g(to)g(be)h ! (the)f(default.)195 461 y(TAB:)g(complete)195 565 y(#)h(Macros)f(that)g ! (are)h(convenient)e(for)h(shell)h(interaction)195 616 ! y($if)f(Bash)195 668 y(#)h(edit)f(the)g(path)195 720 ! y("\\C-xp":)g("PATH=${PATH}\\e\\C-e\\C-a\\)o(ef\\C-f")195 ! 772 y(#)h(prepare)f(to)g(type)h(a)f(quoted)g(word)h(--)f(insert)g(open) ! h(and)f(close)g(double)g(quotes)195 824 y(#)h(and)f(move)g(to)h(just)f ! (after)h(the)f(open)g(quote)195 876 y("\\C-x\\"":)g("\\"\\"\\C-b")195 ! 928 y(#)h(insert)f(a)g(backslash)g(\(testing)g(backslash)g(escapes)f ! (in)i(sequences)f(and)g(macros\))195 980 y("\\C-x\\\\":)g("\\\\")195 ! 1032 y(#)h(Quote)f(the)g(current)g(or)h(previous)f(word)195 ! 1083 y("\\C-xq":)g("\\eb\\"\\ef\\"")195 1135 y(#)h(Add)f(a)h(binding)f (to)g(refresh)g(the)h(line,)f(which)g(is)h(unbound)195 ! 1187 y("\\C-xr":)f(redraw-current-line)195 1239 y(#)h(Edit)f(variable)g ! (on)g(current)g(line.)195 1291 y("\\M-\\C-v":)f ! ("\\C-a\\C-k$\\C-y\\M-\\C-e\\C-a\\C-y=)o(")195 1343 y($endif)195 ! 1447 y(#)i(use)f(a)h(visible)f(bell)g(if)h(one)f(is)h(available)195 ! 1499 y(set)f(bell-style)g(visible)195 1602 y(#)h(don't)f(strip)g ! (characters)g(to)g(7)h(bits)f(when)h(reading)195 1654 ! y(set)f(input-meta)g(on)195 1758 y(#)h(allow)f(iso-latin1)f(characters) h(to)g(be)h(inserted)f(rather)g(than)g(converted)g(to)195 ! 1810 y(#)h(prefix-meta)e(sequences)195 1862 y(set)h(convert-meta)g(off) ! 195 1966 y(#)h(display)f(characters)f(with)h(the)h(eighth)f(bit)g(set)h ! (directly)f(rather)g(than)195 2017 y(#)h(as)f(meta-prefixed)f ! (characters)195 2069 y(set)h(output-meta)g(on)195 2173 y(#)h(if)f(there)g(are)h(more)f(than)h(150)f(possible)g(completions)f ! (for)i(a)f(word,)h(ask)f(the)195 2225 y(#)h(user)f(if)h(he)f(wants)g ! (to)h(see)f(all)h(of)f(them)195 2277 y(set)g(completion-query-items)e ! (150)195 2381 y(#)j(For)f(FTP)195 2433 y($if)g(Ftp)195 ! 2484 y("\\C-xg":)g("get)g(\\M-?")195 2536 y("\\C-xt":)g("put)g(\\M-?") ! 195 2588 y("\\M-.":)g(yank-last-arg)195 2640 y($endif)p eop %%Page: 12 14 ! 12 13 bop 75 -58 a Fu(12)1299 b(GNU)15 b(Readline)h(Library)75 ! 149 y Fs(1.4)33 b(Bindable)24 b(Readline)f(Commands)137 ! 247 y Fu(This)17 b(section)f(describ)q(es)h(Readline)g(commands)f(that) ! e(ma)o(y)h(b)q(e)i(b)q(ound)f(to)f(k)o(ey)h(sequences.)22 ! b(Com-)75 301 y(mand)15 b(names)g(without)h(an)f(accompan)o(ying)g(k)o ! (ey)g(sequence)i(are)e(un)o(b)q(ound)h(b)o(y)f(default.)137 ! 369 y(In)f(the)f(follo)o(wing)h(descriptions,)h Fk(p)q(oin)o(t)f ! Fu(refers)f(to)g(the)g(curren)o(t)g(cursor)f(p)q(osition,)j(and)e ! Fk(mark)i Fu(refers)75 424 y(to)k(a)g(cursor)g(p)q(osition)h(sa)o(v)o ! (ed)f(b)o(y)h(the)f Ft(set-mark)g Fu(command.)32 b(The)20 ! b(text)f(b)q(et)o(w)o(een)g(the)h(p)q(oin)o(t)g(and)75 ! 479 y(mark)15 b(is)g(referred)h(to)e(as)h(the)g Fk(region)p ! Fu(.)75 593 y Fj(1.4.1)30 b(Commands)21 b(F)-5 b(or)19 ! b(Mo)n(ving)75 716 y Ft(beginning-of-line)13 b(\(C-a\))315 ! 771 y Fu(Mo)o(v)o(e)h(to)h(the)g(start)f(of)h(the)g(curren)o(t)g(line.) ! 75 864 y Ft(end-of-line)f(\(C-e\))315 919 y Fu(Mo)o(v)o(e)g(to)h(the)g ! (end)h(of)f(the)g(line.)75 1012 y Ft(forward-char)f(\(C-f\))315 ! 1067 y Fu(Mo)o(v)o(e)g(forw)o(ard)g(a)h(c)o(haracter.)75 ! 1160 y Ft(backward-char)e(\(C-b\))315 1215 y Fu(Mo)o(v)o(e)h(bac)o(k)h ! (a)g(c)o(haracter.)75 1309 y Ft(forward-word)f(\(M-f\))315 ! 1363 y Fu(Mo)o(v)o(e)g(forw)o(ard)g(to)g(the)i(end)g(of)e(the)h(next)h ! (w)o(ord.)j(W)l(ords)c(are)f(comp)q(osed)i(of)f(letters)g(and)315 ! 1418 y(digits.)75 1512 y Ft(backward-word)e(\(M-b\))315 ! 1566 y Fu(Mo)o(v)o(e)j(bac)o(k)g(to)h(the)f(start)g(of)g(the)h(curren)o ! (t)g(or)f(previous)i(w)o(ord.)24 b(W)l(ords)16 b(are)h(comp)q(osed)315 ! 1621 y(of)e(letters)g(and)g(digits.)75 1715 y Ft(clear-screen)f ! (\(C-l\))315 1769 y Fu(Clear)f(the)h(screen)g(and)f(redra)o(w)g(the)g ! (curren)o(t)g(line,)i(lea)o(ving)g(the)e(curren)o(t)g(line)i(at)e(the)g ! (top)315 1824 y(of)i(the)g(screen.)75 1918 y Ft(redraw-current-line)e ! (\(\))315 1972 y Fu(Refresh)i(the)g(curren)o(t)g(line.)22 ! b(By)15 b(default,)h(this)f(is)h(un)o(b)q(ound.)75 2086 ! y Fj(1.4.2)30 b(Commands)21 b(F)-5 b(or)19 b(Manipulating)i(The)f ! (History)75 2209 y Ft(accept-line)14 b(\(Newline)g(or)h(Return\))315 ! 2264 y Fu(Accept)j(the)g(line)h(regardless)f(of)f(where)h(the)g(cursor) ! f(is.)27 b(If)18 b(this)g(line)h(is)g(non-empt)o(y)l(,)f(it)315 ! 2319 y(ma)o(y)d(b)q(e)i(added)f(to)g(the)g(history)g(list)g(for)g ! (future)g(recall)h(with)f Ft(add_history\(\))p Fu(.)k(If)d(this)315 ! 2374 y(line)g(is)f(a)e(mo)q(di\014ed)j(history)e(line,)i(the)e(history) ! g(line)i(is)f(restored)e(to)h(its)g(original)i(state.)75 ! 2467 y Ft(previous-history)c(\(C-p\))315 2522 y Fu(Mo)o(v)o(e)h(`bac)o ! (k')h(through)f(the)i(history)f(list,)g(fetc)o(hing)h(the)f(previous)h ! (command.)75 2615 y Ft(next-history)e(\(C-n\))315 2670 ! y Fu(Mo)o(v)o(e)g(`forw)o(ard')f(through)i(the)h(history)f(list,)g ! (fetc)o(hing)h(the)f(next)h(command.)p eop %%Page: 13 15 13 14 bop 75 -58 a Fu(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1055 ! b(13)75 149 y Ft(beginning-of-history)12 b(\(M-<\))315 ! 204 y Fu(Mo)o(v)o(e)i(to)h(the)g(\014rst)g(line)i(in)f(the)f(history)l ! (.)75 307 y Ft(end-of-history)e(\(M->\))315 362 y Fu(Mo)o(v)o(e)h(to)h (the)g(end)h(of)f(the)g(input)h(history)l(,)f(i.e.,)g(the)g(line)i ! (curren)o(tly)f(b)q(eing)g(en)o(tered.)75 466 y Ft ! (reverse-search-history)c(\(C-r\))315 520 y Fu(Searc)o(h)k(bac)o(kw)o (ard)e(starting)h(at)g(the)h(curren)o(t)f(line)j(and)d(mo)o(ving)h ! (`up')f(through)g(the)h(his-)315 575 y(tory)e(as)h(necessary)l(.)20 ! b(This)c(is)g(an)f(incremen)o(tal)h(searc)o(h.)75 678 ! y Ft(forward-search-history)c(\(C-s\))315 733 y Fu(Searc)o(h)j(forw)o (ard)e(starting)h(at)h(the)f(curren)o(t)h(line)h(and)f(mo)o(ving)g(`do) ! o(wn')f(through)g(the)h(the)315 788 y(history)g(as)g(necessary)l(.)20 ! b(This)c(is)g(an)f(incremen)o(tal)h(searc)o(h.)75 891 y Ft(non-incremental-reverse-se)o(arch-hi)o(story)c(\(M-p\))315 ! 946 y Fu(Searc)o(h)k(bac)o(kw)o(ard)e(starting)h(at)g(the)h(curren)o(t) f(line)j(and)d(mo)o(ving)h(`up')f(through)g(the)h(his-)315 ! 1001 y(tory)h(as)h(necessary)g(using)h(a)e(non-incremen)o(tal)j(searc)o ! (h)e(for)f(a)h(string)g(supplied)i(b)o(y)e(the)315 1056 ! y(user.)75 1159 y Ft(non-incremental-forward-se)o(arch-hi)o(story)12 ! b(\(M-n\))315 1214 y Fu(Searc)o(h)j(forw)o(ard)e(starting)h(at)h(the)f (curren)o(t)h(line)h(and)f(mo)o(ving)g(`do)o(wn')f(through)g(the)h(the) ! 315 1268 y(history)e(as)g(necessary)h(using)g(a)f(non-incremen)o(tal)i (searc)o(h)e(for)g(a)g(string)g(supplied)j(b)o(y)d(the)315 ! 1323 y(user.)75 1427 y Ft(history-search-forward)f(\(\))315 ! 1481 y Fu(Searc)o(h)21 b(forw)o(ard)e(through)i(the)f(history)h(for)f (the)h(string)g(of)f(c)o(haracters)g(b)q(et)o(w)o(een)h(the)315 ! 1536 y(start)16 b(of)h(the)h(curren)o(t)g(line)h(and)e(the)h(p)q(oin)o (t.)28 b(This)18 b(is)g(a)f(non-incremen)o(tal)i(searc)o(h.)27 ! b(By)315 1591 y(default,)15 b(this)h(command)f(is)h(un)o(b)q(ound.)75 ! 1694 y Ft(history-search-backward)c(\(\))315 1749 y Fu(Searc)o(h)18 b(bac)o(kw)o(ard)e(through)h(the)h(history)f(for)g(the)g(string)h(of)f ! (c)o(haracters)f(b)q(et)o(w)o(een)i(the)315 1804 y(start)e(of)h(the)h (curren)o(t)g(line)h(and)e(the)h(p)q(oin)o(t.)28 b(This)18 b(is)g(a)f(non-incremen)o(tal)i(searc)o(h.)27 b(By)315 ! 1859 y(default,)15 b(this)h(command)f(is)h(un)o(b)q(ound.)75 ! 1962 y Ft(yank-nth-arg)e(\(M-C-y\))315 2017 y Fu(Insert)f(the)g (\014rst)g(argumen)o(t)f(to)g(the)i(previous)f(command)g(\(usually)h ! (the)f(second)h(w)o(ord)e(on)315 2071 y(the)j(previous)h(line\))g(at)e ! (p)q(oin)o(t.)21 b(With)15 b(an)g(argumen)o(t)f Fk(n)p ! Fu(,)h(insert)g(the)g Fk(n)p Fu(th)g(w)o(ord)g(from)f(the)315 ! 2126 y(previous)g(command)g(\(the)f(w)o(ords)f(in)j(the)e(previous)i ! (command)e(b)q(egin)i(with)e(w)o(ord)g(0\).)19 b(A)315 ! 2181 y(negativ)o(e)13 b(argumen)o(t)f(inserts)h(the)g ! Fk(n)p Fu(th)g(w)o(ord)f(from)g(the)h(end)h(of)e(the)h(previous)g ! (command.)75 2284 y Ft(yank-last-arg)g(\(M-.)i(or)g(M-_\))315 ! 2339 y Fu(Insert)j(last)f(argumen)o(t)g(to)g(the)g(previous)i(command)e ! (\(the)g(last)h(w)o(ord)f(of)g(the)g(previous)315 2394 ! y(history)e(en)o(try\).)20 b(With)15 b(an)g(argumen)o(t,)g(b)q(eha)o(v) ! o(e)g(exactly)h(lik)o(e)g Ft(yank-nth-arg)p Fu(.)j(Succes-)315 ! 2449 y(siv)o(e)f(calls)g(to)f Ft(yank-last-arg)e Fu(mo)o(v)o(e)i(bac)o ! (k)g(through)g(the)g(history)g(list,)i(inserting)f(the)315 ! 2503 y(last)d(argumen)o(t)g(of)f(eac)o(h)i(line)g(in)g(turn.)75 ! 2630 y Fj(1.4.3)30 b(Commands)21 b(F)-5 b(or)19 b(Changing)i(T)-5 ! b(ext)p eop %%Page: 14 16 ! 14 15 bop 75 -58 a Fu(14)1299 b(GNU)15 b(Readline)h(Library)75 ! 149 y Ft(delete-char)e(\(C-d\))315 204 y Fu(Delete)20 ! b(the)g(c)o(haracter)e(at)h(p)q(oin)o(t.)33 b(If)20 b(p)q(oin)o(t)g(is) ! g(at)e(the)i(b)q(eginning)i(of)d(the)g(line,)j(there)315 ! 259 y(are)c(no)h(c)o(haracters)e(in)j(the)e(line,)j(and)e(the)f(last)h ! (c)o(haracter)e(t)o(yp)q(ed)i(w)o(as)f(not)g(b)q(ound)i(to)315 ! 314 y Ft(delete-char)p Fu(,)13 b(then)j(return)f Fp(eof)p ! Fu(.)75 406 y Ft(backward-delete-char)d(\(Rubout\))315 ! 460 y Fu(Delete)k(the)f(c)o(haracter)f(b)q(ehind)j(the)f(cursor.)j(A)c ! (n)o(umeric)h(argumen)o(t)e(means)i(to)e(kill)j(the)315 ! 515 y(c)o(haracters)d(instead)i(of)f(deleting)i(them.)75 ! 607 y Ft(forward-backward-delete-ch)o(ar)12 b(\(\))315 ! 662 y Fu(Delete)20 b(the)f(c)o(haracter)f(under)i(the)f(cursor,)h (unless)g(the)f(cursor)g(is)h(at)e(the)h(end)h(of)f(the)315 ! 717 y(line,)e(in)g(whic)o(h)g(case)e(the)h(c)o(haracter)g(b)q(ehind)h (the)f(cursor)g(is)g(deleted.)23 b(By)16 b(default,)h(this)315 ! 771 y(is)f(not)f(b)q(ound)h(to)e(a)h(k)o(ey)l(.)75 863 ! y Ft(quoted-insert)e(\(C-q)i(or)g(C-v\))315 918 y Fu(Add)j(the)f(next)g ! (c)o(haracter)g(t)o(yp)q(ed)g(to)f(the)i(line)g(v)o(erbatim.)26 ! b(This)18 b(is)f(ho)o(w)g(to)g(insert)g(k)o(ey)315 973 ! y(sequences)f(lik)o(e)h Fo(C-q)p Fu(,)d(for)h(example.)75 ! 1065 y Ft(tab-insert)f(\(M-)401 1063 y Fn(h)p 412 1037 ! 74 2 v 412 1065 a Fm(T)m(AB)p 412 1072 V 484 1063 a Fn(i)499 ! 1065 y Ft(\))315 1119 y Fu(Insert)h(a)g(tab)g(c)o(haracter.)75 ! 1211 y Ft(self-insert)f(\(a,)g(b,)h(A,)g(1,)g(!,)g(...)o(\))315 ! 1266 y Fu(Insert)g(y)o(ourself.)75 1358 y Ft(transpose-chars)e(\(C-t\)) ! 315 1413 y Fu(Drag)i(the)h(c)o(haracter)f(b)q(efore)h(the)h(cursor)e ! (forw)o(ard)g(o)o(v)o(er)g(the)h(c)o(haracter)f(at)h(the)g(cursor,)315 ! 1467 y(mo)o(ving)i(the)f(cursor)h(forw)o(ard)e(as)i(w)o(ell.)28 ! b(If)18 b(the)g(insertion)h(p)q(oin)o(t)f(is)g(at)f(the)h(end)h(of)e ! (the)315 1522 y(line,)c(then)e(this)h(transp)q(oses)e(the)h(last)g(t)o ! (w)o(o)f(c)o(haracters)g(of)h(the)g(line.)20 b(Negativ)o(e)11 ! b(argumen)o(ts)315 1577 y(ha)o(v)o(e)k(no)g(e\013ect.)75 ! 1669 y Ft(transpose-words)e(\(M-t\))315 1724 y Fu(Drag)i(the)h(w)o(ord) ! g(b)q(efore)g(p)q(oin)o(t)h(past)f(the)g(w)o(ord)f(after)h(p)q(oin)o ! (t,)g(mo)o(ving)g(p)q(oin)o(t)h(past)f(that)315 1778 ! y(w)o(ord)f(as)f(w)o(ell.)75 1870 y Ft(upcase-word)g(\(M-u\))315 ! 1925 y Fu(Upp)q(ercase)j(the)f(curren)o(t)g(\(or)f(follo)o(wing\))h(w)o ! (ord.)22 b(With)16 b(a)g(negativ)o(e)g(argumen)o(t,)f(upp)q(er-)315 ! 1980 y(case)g(the)g(previous)h(w)o(ord,)f(but)g(do)g(not)g(mo)o(v)o(e)f ! (the)i(cursor.)75 2072 y Ft(downcase-word)d(\(M-l\))315 ! 2126 y Fu(Lo)o(w)o(ercase)d(the)h(curren)o(t)g(\(or)f(follo)o(wing\))h (w)o(ord.)17 b(With)11 b(a)g(negativ)o(e)g(argumen)o(t,)f(lo)o(w)o ! (ercase)315 2181 y(the)15 b(previous)h(w)o(ord,)e(but)i(do)f(not)g(mo)o ! (v)o(e)f(the)h(cursor.)75 2273 y Ft(capitalize-word)e(\(M-c\))315 ! 2328 y Fu(Capitalize)f(the)f(curren)o(t)f(\(or)g(follo)o(wing\))h(w)o (ord.)18 b(With)11 b(a)f(negativ)o(e)h(argumen)o(t,)f(capitalize)315 ! 2383 y(the)15 b(previous)h(w)o(ord,)e(but)i(do)f(not)g(mo)o(v)o(e)f ! (the)h(cursor.)75 2494 y Fj(1.4.4)30 b(Killing)20 b(And)h(Y)-5 ! b(anking)75 2615 y Ft(kill-line)14 b(\(C-k\))315 2670 y Fu(Kill)j(the)f(text)e(from)h(p)q(oin)o(t)h(to)e(the)h(end)h(of)f ! (the)g(line.)p eop %%Page: 15 17 15 16 bop 75 -58 a Fu(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1055 ! b(15)75 149 y Ft(backward-kill-line)13 b(\(C-x)h(Rubout\))315 ! 204 y Fu(Kill)j(bac)o(kw)o(ard)e(to)f(the)i(b)q(eginning)h(of)e(the)g ! (line.)75 295 y Ft(unix-line-discard)e(\(C-u\))315 349 ! y Fu(Kill)k(bac)o(kw)o(ard)e(from)f(the)i(cursor)e(to)h(the)g(b)q ! (eginning)j(of)c(the)i(curren)o(t)f(line.)75 440 y Ft(kill-whole-line)e ! (\(\))315 495 y Fu(Kill)20 b(all)g(c)o(haracters)d(on)h(the)h(curren)o ! (t)f(line,)i(no)e(matter)g(where)g(p)q(oin)o(t)h(is.)29 ! b(By)19 b(default,)315 549 y(this)d(is)f(un)o(b)q(ound.)75 ! 640 y Ft(kill-word)f(\(M-d\))315 695 y Fu(Kill)j(from)d(p)q(oin)o(t)h ! (to)f(the)h(end)g(of)f(the)h(curren)o(t)g(w)o(ord,)e(or)i(if)g(b)q(et)o ! (w)o(een)g(w)o(ords,)e(to)i(the)f(end)315 750 y(of)h(the)g(next)g(w)o ! (ord.)20 b(W)l(ord)14 b(b)q(oundaries)j(are)e(the)g(same)g(as)g ! Ft(forward-word)p Fu(.)75 840 y Ft(backward-kill-word)e(\(M-)592 ! 838 y Fn(h)p 603 812 73 2 v 603 840 a Fm(DEL)p 603 848 ! V 674 838 a Fn(i)689 840 y Ft(\))315 895 y Fu(Kill)k(the)d(w)o(ord)g(b) ! q(ehind)i(p)q(oin)o(t.)21 b(W)l(ord)14 b(b)q(oundaries)h(are)f(the)h ! (same)f(as)g Ft(backward-word)p Fu(.)75 985 y Ft(unix-word-rubout)f ! (\(C-w\))315 1040 y Fu(Kill)18 b(the)e(w)o(ord)f(b)q(ehind)j(p)q(oin)o ! (t,)e(using)h(white)f(space)g(as)g(a)f(w)o(ord)g(b)q(oundary)l(.)23 ! b(The)16 b(killed)315 1095 y(text)f(is)g(sa)o(v)o(ed)g(on)g(the)h ! (kill-ring.)75 1185 y Ft(delete-horizontal-space)c(\(\))315 ! 1240 y Fu(Delete)k(all)g(spaces)f(and)h(tabs)e(around)i(p)q(oin)o(t.)k ! (By)15 b(default,)h(this)f(is)h(un)o(b)q(ound.)75 1330 ! y Ft(kill-region)e(\(\))315 1385 y Fu(Kill)j(the)f(text)e(in)i(the)g (curren)o(t)f(region.)20 b(By)15 b(default,)h(this)f(command)g(is)h(un) ! o(b)q(ound.)75 1476 y Ft(copy-region-as-kill)d(\(\))315 ! 1530 y Fu(Cop)o(y)j(the)i(text)e(in)i(the)f(region)g(to)g(the)g(kill)h (bu\013er,)f(so)g(it)g(can)g(b)q(e)h(y)o(ank)o(ed)f(righ)o(t)g(a)o(w)o ! (a)o(y)l(.)315 1585 y(By)e(default,)h(this)f(command)g(is)h(un)o(b)q ! (ound.)75 1676 y Ft(copy-backward-word)d(\(\))315 1730 y Fu(Cop)o(y)19 b(the)g(w)o(ord)g(b)q(efore)g(p)q(oin)o(t)h(to)e(the)i (kill)h(bu\013er.)32 b(The)19 b(w)o(ord)g(b)q(oundaries)h(are)f(the)315 ! 1785 y(same)c(as)g Ft(backward-word)p Fu(.)j(By)d(default,)g(this)h ! (command)f(is)h(un)o(b)q(ound.)75 1876 y Ft(copy-forward-word)d(\(\)) ! 315 1930 y Fu(Cop)o(y)i(the)h(w)o(ord)e(follo)o(wing)j(p)q(oin)o(t)f (to)f(the)g(kill)j(bu\013er.)i(The)c(w)o(ord)f(b)q(oundaries)i(are)e ! (the)315 1985 y(same)g(as)g Ft(forward-word)p Fu(.)j(By)d(default,)h ! (this)f(command)g(is)h(un)o(b)q(ound.)75 2076 y Ft(yank)f(\(C-y\))315 ! 2131 y Fu(Y)l(ank)g(the)h(top)f(of)f(the)i(kill)h(ring)e(in)o(to)g(the) ! h(bu\013er)f(at)f(p)q(oin)o(t.)75 2221 y Ft(yank-pop)g(\(M-y\))315 ! 2276 y Fu(Rotate)i(the)h(kill-ring,)j(and)d(y)o(ank)g(the)h(new)f(top.) ! 26 b(Y)l(ou)17 b(can)h(only)g(do)f(this)h(if)f(the)h(prior)315 ! 2331 y(command)d(is)h Ft(yank)e Fu(or)h Ft(yank-pop)p ! Fu(.)75 2441 y Fj(1.4.5)30 b(Sp)r(ecifying)20 b(Numeric)h(Argumen)n(ts) ! 75 2560 y Ft(digit-argument)13 b(\()p Fo(M-0)p Ft(,)i ! Fo(M-1)p Ft(,)f(...)h Fo(M--)p Ft(\))315 2615 y Fu(Add)f(this)g(digit)g ! (to)f(the)h(argumen)o(t)e(already)i(accum)o(ulating,)g(or)f(start)f(a)h ! (new)h(argumen)o(t.)315 2670 y Fo(M--)h Fu(starts)f(a)h(negativ)o(e)g ! (argumen)o(t.)p eop ! %%Page: 16 18 ! 16 17 bop 75 -58 a Fu(16)1299 b(GNU)15 b(Readline)h(Library)75 ! 149 y Ft(universal-argument)d(\(\))315 204 y Fu(This)g(is)h(another)e ! (w)o(a)o(y)g(to)g(sp)q(ecify)i(an)f(argumen)o(t.)18 b(If)13 b(this)g(command)g(is)g(follo)o(w)o(ed)g(b)o(y)g(one)315 ! 259 y(or)h(more)h(digits,)g(optionally)h(with)f(a)g(leading)h(min)o(us) ! f(sign,)g(those)g(digits)g(de\014ne)h(the)f(ar-)315 314 ! y(gumen)o(t.)k(If)c(the)g(command)f(is)h(follo)o(w)o(ed)g(b)o(y)g ! (digits,)g(executing)g Ft(universal-argument)315 369 y Fu(again)h(ends)g(the)g(n)o(umeric)h(argumen)o(t,)e(but)h(is)h (otherwise)f(ignored.)22 b(As)16 b(a)g(sp)q(ecial)h(case,)315 ! 423 y(if)g(this)g(command)f(is)h(immediately)h(follo)o(w)o(ed)f(b)o(y)f ! (a)g(c)o(haracter)g(that)g(is)h(neither)g(a)f(digit)315 ! 478 y(or)d(min)o(us)i(sign,)f(the)g(argumen)o(t)g(coun)o(t)f(for)h(the) g(next)g(command)g(is)g(m)o(ultiplied)j(b)o(y)d(four.)315 ! 533 y(The)19 b(argumen)o(t)f(coun)o(t)g(is)h(initially)j(one,)d(so)f (executing)i(this)f(function)h(the)e(\014rst)h(time)315 ! 588 y(mak)o(es)c(the)h(argumen)o(t)f(coun)o(t)h(four,)f(a)h(second)g (time)g(mak)o(es)g(the)g(argumen)o(t)f(coun)o(t)g(six-)315 ! 643 y(teen,)g(and)g(so)g(on.)20 b(By)15 b(default,)h(this)f(is)h(not)f ! (b)q(ound)h(to)f(a)g(k)o(ey)l(.)75 762 y Fj(1.4.6)30 b(Letting)20 b(Readline)g(T)n(yp)r(e)h(F)-5 b(or)19 b(Y)-5 ! b(ou)75 892 y Ft(complete)14 b(\()305 890 y Fn(h)p 317 ! 864 74 2 v 317 892 a Fm(T)m(AB)p 317 900 V 389 890 a ! Fn(i)404 892 y Ft(\))315 947 y Fu(A)o(ttempt)c(to)h(p)q(erform)g ! (completion)i(on)e(the)g(text)g(b)q(efore)h(p)q(oin)o(t.)19 ! b(The)11 b(actual)h(completion)315 1002 y(p)q(erformed)j(is)h ! (application-sp)q(eci\014)q(c.)23 b(The)15 b(default)h(is)g(\014lename) ! g(completion.)75 1099 y Ft(possible-completions)c(\(M-?\))315 ! 1154 y Fu(List)k(the)f(p)q(ossible)i(completions)f(of)f(the)g(text)g(b) ! q(efore)h(p)q(oin)o(t.)75 1251 y Ft(insert-completions)d(\(M-*\))315 ! 1306 y Fu(Insert)j(all)g(completions)g(of)f(the)g(text)g(b)q(efore)h(p) q(oin)o(t)f(that)g(w)o(ould)h(ha)o(v)o(e)f(b)q(een)h(generated)315 ! 1361 y(b)o(y)f Ft(possible-completions)p Fu(.)75 1458 ! y Ft(menu-complete)e(\(\))315 1513 y Fu(Similar)g(to)f Ft(complete)p Fu(,)f(but)h(replaces)h(the)f(w)o(ord)f(to)g(b)q(e)i ! (completed)f(with)h(a)e(single)j(matc)o(h)315 1568 y(from)k(the)h(list) ! h(of)e(p)q(ossible)j(completions.)32 b(Rep)q(eated)19 ! b(execution)h(of)f Ft(menu-complete)315 1623 y Fu(steps)h(through)g (the)g(list)h(of)f(p)q(ossible)i(completions,)g(inserting)f(eac)o(h)f ! (matc)o(h)f(in)i(turn.)315 1678 y(A)o(t)d(the)g(end)h(of)f(the)h(list)g ! (of)f(completions,)i(the)e(b)q(ell)j(is)d(rung)h(\(sub)s(ject)f(to)f ! (the)i(setting)315 1732 y(of)f Ft(bell-style)p Fu(\))e(and)i(the)g ! (original)h(text)f(is)g(restored.)28 b(An)19 b(argumen)o(t)e(of)g ! Fk(n)i Fu(mo)o(v)o(es)e Fk(n)315 1787 y Fu(p)q(ositions)h(forw)o(ard)e ! (in)j(the)e(list)h(of)f(matc)o(hes;)h(a)f(negativ)o(e)g(argumen)o(t)g ! (ma)o(y)g(b)q(e)h(used)g(to)315 1842 y(mo)o(v)o(e)g(bac)o(kw)o(ard)h ! (through)g(the)g(list.)32 b(This)20 b(command)f(is)h(in)o(tended)g(to)f ! (b)q(e)h(b)q(ound)g(to)315 1895 y Fn(h)p 327 1869 V 327 ! 1897 a Fm(T)m(AB)p 327 1905 V 399 1895 a Fn(i)414 1897 ! y Fu(,)15 b(but)g(is)h(un)o(b)q(ound)g(b)o(y)f(default.)75 ! 1994 y Ft(delete-char-or-list)e(\(\))315 2049 y Fu(Deletes)h(the)f(c)o ! (haracter)g(under)h(the)g(cursor)f(if)h(not)f(at)g(the)g(b)q(eginning)j ! (or)d(end)h(of)f(the)g(line)315 2104 y(\(lik)o(e)i Ft(delete-char)p ! Fu(\).)j(If)d(at)f(the)h(end)g(of)f(the)g(line,)i(b)q(eha)o(v)o(es)f ! (iden)o(tically)i(to)d Ft(possible-)315 2159 y(completions)p ! Fu(.)k(This)e(command)f(is)h(un)o(b)q(ound)g(b)o(y)f(default.)75 ! 2278 y Fj(1.4.7)30 b(Keyb)r(oard)20 b(Macros)75 2408 ! y Ft(start-kbd-macro)13 b(\(C-x)i(\(\))315 2463 y Fu(Begin)h(sa)o(ving) ! f(the)h(c)o(haracters)e(t)o(yp)q(ed)i(in)o(to)f(the)g(curren)o(t)g(k)o ! (eyb)q(oard)g(macro.)75 2560 y Ft(end-kbd-macro)e(\(C-x)i(\)\))315 ! 2615 y Fu(Stop)f(sa)o(ving)f(the)h(c)o(haracters)f(t)o(yp)q(ed)h(in)o ! (to)f(the)h(curren)o(t)g(k)o(eyb)q(oard)f(macro)g(and)h(sa)o(v)o(e)f ! (the)315 2670 y(de\014nition.)p eop %%Page: 17 19 17 18 bop 75 -58 a Fu(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1055 ! b(17)75 149 y Ft(call-last-kbd-macro)13 b(\(C-x)h(e\))315 ! 204 y Fu(Re-execute)k(the)g(last)f(k)o(eyb)q(oard)h(macro)f(de\014ned,) ! i(b)o(y)e(making)h(the)g(c)o(haracters)e(in)j(the)315 ! 259 y(macro)14 b(app)q(ear)i(as)f(if)g(t)o(yp)q(ed)h(at)e(the)i(k)o ! (eyb)q(oard.)75 368 y Fj(1.4.8)30 b(Some)20 b(Miscellaneous)h(Commands) ! 75 486 y Ft(re-read-init-file)13 b(\(C-x)h(C-r\))315 ! 541 y Fu(Read)d(in)g(the)g(con)o(ten)o(ts)g(of)f(the)h ! Fk(inputrc)k Fu(\014le,)d(and)g(incorp)q(orate)f(an)o(y)f(bindings)j ! (or)e(v)m(ariable)315 596 y(assignmen)o(ts)k(found)h(there.)75 ! 684 y Ft(abort)e(\(C-g\))315 739 y Fu(Ab)q(ort)f(the)g(curren)o(t)h (editing)g(command)f(and)h(ring)f(the)h(terminal's)f(b)q(ell)i(\(sub)s ! (ject)e(to)g(the)315 794 y(setting)i(of)g Ft(bell-style)p ! Fu(\).)75 883 y Ft(do-uppercase-version)d(\(M-a,)j(M-b,)f(M-)p ! Fk(x)p Ft(,)h(...\))315 938 y Fu(If)f(the)g(meta\014ed)g(c)o(haracter)f ! Fk(x)k Fu(is)d(lo)o(w)o(ercase,)g(run)g(the)g(command)f(that)h(is)g(b)q ! (ound)h(to)e(the)315 993 y(corresp)q(onding)j(upp)q(ercase)g(c)o ! (haracter.)75 1082 y Ft(prefix-meta)e(\()377 1080 y Fn(h)p ! 389 1054 70 2 v 389 1082 a Fm(ESC)p 389 1089 V 456 1080 ! a Fn(i)471 1082 y Ft(\))315 1136 y Fu(Metafy)k(the)h(next)g(c)o ! (haracter)f(t)o(yp)q(ed.)30 b(This)20 b(is)f(for)f(k)o(eyb)q(oards)h ! (without)g(a)f(meta)g(k)o(ey)l(.)315 1191 y(T)o(yping)e(`)485 ! 1189 y Fn(h)p 496 1163 V 496 1191 a Fm(ESC)p 496 1199 ! V 563 1189 a Fn(i)593 1191 y Ft(f)p Fu(')f(is)h(equiv)m(alen)o(t)h(to)d ! (t)o(yping)i Fo(M-f)p Fu(.)75 1280 y Ft(undo)f(\(C-_)f(or)h(C-x)g ! (C-u\))315 1335 y Fu(Incremen)o(tal)h(undo,)f(separately)h(remem)o(b)q ! (ered)g(for)e(eac)o(h)h(line.)75 1424 y Ft(revert-line)f(\(M-r\))315 ! 1479 y Fu(Undo)j(all)g(c)o(hanges)g(made)f(to)g(this)h(line.)26 b(This)17 b(is)g(lik)o(e)h(executing)f(the)g Ft(undo)f ! Fu(command)315 1533 y(enough)g(times)f(to)g(get)f(bac)o(k)h(to)g(the)g ! (b)q(eginning.)75 1622 y Ft(tilde-expand)f(\(M-~\))315 ! 1677 y Fu(P)o(erform)g(tilde)j(expansion)f(on)f(the)g(curren)o(t)g(w)o ! (ord.)75 1766 y Ft(set-mark)f(\(C-@\))315 1821 y Fu(Set)i(the)h(mark)f ! (to)f(the)i(p)q(oin)o(t.)24 b(If)17 b(a)f(n)o(umeric)h(argumen)o(t)f ! (is)g(supplied,)j(the)e(mark)e(is)i(set)315 1876 y(to)e(that)f(p)q ! (osition.)75 1965 y Ft(exchange-point-and-mark)e(\(C-x)j(C-x\))315 ! 2020 y Fu(Sw)o(ap)g(the)h(p)q(oin)o(t)g(with)g(the)g(mark.)k(The)c ! (curren)o(t)f(cursor)h(p)q(osition)g(is)g(set)g(to)f(the)g(sa)o(v)o(ed) ! 315 2074 y(p)q(osition,)h(and)f(the)h(old)f(cursor)g(p)q(osition)h(is)g ! (sa)o(v)o(ed)f(as)g(the)g(mark.)75 2163 y Ft(character-search)e ! (\(C-]\))315 2218 y Fu(A)f(c)o(haracter)g(is)h(read)g(and)f(p)q(oin)o ! (t)h(is)g(mo)o(v)o(ed)f(to)g(the)g(next)h(o)q(ccurrence)g(of)f(that)g ! (c)o(haracter.)315 2273 y(A)j(negativ)o(e)h(coun)o(t)f(searc)o(hes)g ! (for)f(previous)i(o)q(ccurrences.)75 2362 y Ft ! (character-search-backward)c(\(M-C-]\))315 2417 y Fu(A)22 ! b(c)o(haracter)g(is)h(read)f(and)h(p)q(oin)o(t)g(is)g(mo)o(v)o(ed)f(to) ! g(the)g(previous)h(o)q(ccurrence)h(of)e(that)315 2471 ! y(c)o(haracter.)d(A)c(negativ)o(e)h(coun)o(t)f(searc)o(hes)g(for)f ! (subsequen)o(t)i(o)q(ccurrences.)75 2560 y Ft(insert-comment)d(\(M-#\)) ! 315 2615 y Fu(The)19 b(v)m(alue)i(of)e(the)g Ft(comment-begin)e Fu(v)m(ariable)k(is)f(inserted)g(at)e(the)i(b)q(eginning)h(of)e(the)315 ! 2670 y(curren)o(t)c(line,)i(and)e(the)g(line)i(is)f(accepted)g(as)e(if) ! i(a)f(newline)i(had)f(b)q(een)g(t)o(yp)q(ed.)p eop %%Page: 18 20 ! 18 19 bop 75 -58 a Fu(18)1299 b(GNU)15 b(Readline)h(Library)75 ! 149 y Ft(dump-functions)d(\(\))315 204 y Fu(Prin)o(t)g(all)h(of)f(the)g ! (functions)h(and)g(their)g(k)o(ey)f(bindings)i(to)d(the)i(Readline)g ! (output)f(stream.)315 259 y(If)j(a)g(n)o(umeric)g(argumen)o(t)f(is)i ! (supplied,)h(the)e(output)f(is)i(formatted)d(in)j(suc)o(h)f(a)g(w)o(a)o ! (y)f(that)315 314 y(it)g(can)h(b)q(e)g(made)f(part)f(of)h(an)g ! Fk(inputrc)k Fu(\014le.)i(This)16 b(command)f(is)h(un)o(b)q(ound)g(b)o ! (y)f(default.)75 406 y Ft(dump-variables)e(\(\))315 461 ! y Fu(Prin)o(t)e(all)g(of)f(the)h(settable)g(v)m(ariables)h(and)f(their) ! g(v)m(alues)h(to)e(the)h(Readline)h(output)e(stream.)315 ! 516 y(If)16 b(a)g(n)o(umeric)g(argumen)o(t)f(is)i(supplied,)h(the)e ! (output)f(is)i(formatted)d(in)j(suc)o(h)f(a)g(w)o(a)o(y)f(that)315 ! 570 y(it)g(can)h(b)q(e)g(made)f(part)f(of)h(an)g Fk(inputrc)k ! Fu(\014le.)i(This)16 b(command)f(is)h(un)o(b)q(ound)g(b)o(y)f(default.) ! 75 663 y Ft(dump-macros)f(\(\))315 717 y Fu(Prin)o(t)j(all)h(of)e(the)h ! (Readline)h(k)o(ey)f(sequences)h(b)q(ound)g(to)e(macros)g(and)h(the)g ! (strings)g(they)315 772 y(output.)26 b(If)18 b(a)f(n)o(umeric)h ! (argumen)o(t)f(is)h(supplied,)i(the)d(output)g(is)h(formatted)e(in)j ! (suc)o(h)e(a)315 827 y(w)o(a)o(y)d(that)g(it)i(can)f(b)q(e)g(made)g ! (part)g(of)f(an)h Fk(inputrc)k Fu(\014le.)i(This)15 b(command)g(is)h ! (un)o(b)q(ound)g(b)o(y)315 882 y(default.)75 1010 y Fs(1.5)33 ! b(Readline)23 b(vi)h(Mo)r(de)137 1107 y Fu(While)13 b(the)f(Readline)i ! (library)e(do)q(es)g(not)g(ha)o(v)o(e)f(a)h(full)h(set)f(of)f ! Ft(vi)g Fu(editing)j(functions,)f(it)f(do)q(es)g(con)o(tain)75 ! 1161 y(enough)17 b(to)g(allo)o(w)g(simple)h(editing)h(of)d(the)i(line.) ! 27 b(The)17 b(Readline)h Ft(vi)f Fu(mo)q(de)g(b)q(eha)o(v)o(es)g(as)g ! (sp)q(eci\014ed)i(in)75 1216 y(the)c Fp(posix)g Fu(1003.2)f(standard.) ! 137 1284 y(In)h(order)g(to)f(switc)o(h)g(in)o(teractiv)o(ely)i(b)q(et)o (w)o(een)f Ft(emacs)e Fu(and)i Ft(vi)f Fu(editing)i(mo)q(des,)f(use)f ! (the)h(command)75 1338 y Fo(M-C-j)j Fu(\(b)q(ound)i(to)e ! (emacs-editing-mo)q(de)j(when)e(in)h Ft(vi)f Fu(mo)q(de)g(and)g(to)f ! (vi-editing-mo)q(de)k(in)e Ft(emacs)75 1393 y Fu(mo)q(de\).)g(The)15 ! b(Readline)i(default)f(is)f Ft(emacs)g Fu(mo)q(de.)137 ! 1460 y(When)h(y)o(ou)e(en)o(ter)h(a)g(line)i(in)e Ft(vi)g Fu(mo)q(de,)g(y)o(ou)g(are)f(already)i(placed)g(in)g(`insertion')f(mo)q ! (de,)g(as)g(if)g(y)o(ou)75 1515 y(had)e(t)o(yp)q(ed)h(an)f(`)p ! Ft(i)p Fu('.)18 b(Pressing)608 1513 y Fn(h)p 620 1487 ! 70 2 v 620 1515 a Fm(ESC)p 620 1523 V 687 1513 a Fn(i)715 ! 1515 y Fu(switc)o(hes)13 b(y)o(ou)g(in)o(to)g(`command')f(mo)q(de,)i ! (where)f(y)o(ou)g(can)g(edit)h(the)75 1570 y(text)i(of)h(the)g(line)h (with)g(the)f(standard)f Ft(vi)h Fu(mo)o(v)o(emen)o(t)f(k)o(eys,)g(mo)o ! (v)o(e)g(to)h(previous)g(history)g(lines)i(with)75 1625 y(`)p Ft(k)p Fu(')14 b(and)i(subsequen)o(t)f(lines)i(with)f(`)p Ft(j)p Fu(',)e(and)h(so)g(forth.)p eop %%Page: 19 21 19 20 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)843 b(19)75 149 y Fq(2)41 b(Programming)28 ! b(with)e(GNU)i(Readline)137 267 y Fu(This)18 b(c)o(hapter)f(describ)q ! (es)h(the)f(in)o(terface)g(b)q(et)o(w)o(een)h(the)f Fp(gnu)g ! Fu(Readline)h(Library)f(and)g(other)g(pro-)75 322 y(grams.)h(If)11 ! b(y)o(ou)g(are)g(a)g(programmer,)f(and)i(y)o(ou)f(wish)g(to)g(include)j ! (the)d(features)g(found)g(in)i Fp(gnu)e Fu(Readline)75 ! 377 y(suc)o(h)h(as)f(completion,)h(line)h(editing,)g(and)f(in)o ! (teractiv)o(e)g(history)f(manipulation)i(in)f(y)o(our)f(o)o(wn)g ! (programs,)75 432 y(this)16 b(section)f(is)h(for)f(y)o(ou.)75 ! 561 y Fs(2.1)33 b(Basic)22 b(Beha)n(vior)137 658 y Fu(Man)o(y)15 b(programs)f(pro)o(vide)i(a)f(command)g(line)i(in)o(terface,)e(suc)o(h) h(as)f Ft(mail)p Fu(,)f Ft(ftp)p Fu(,)h(and)g Ft(sh)p ! Fu(.)20 b(F)l(or)15 b(suc)o(h)75 713 y(programs,)e(the)h(default)h(b)q ! (eha)o(viour)g(of)f(Readline)i(is)e(su\016cien)o(t.)21 b(This)14 b(section)h(describ)q(es)h(ho)o(w)e(to)g(use)75 ! 768 y(Readline)k(in)h(the)e(simplest)h(w)o(a)o(y)e(p)q(ossible,)j(p)q ! (erhaps)f(to)f(replace)h(calls)g(in)g(y)o(our)f(co)q(de)h(to)e ! Ft(gets\(\))g Fu(or)75 822 y Ft(fgets\(\))p Fu(.)137 ! 890 y(The)h(function)g Ft(readline\(\))e Fu(prin)o(ts)h(a)g(prompt)g ! Fk(prompt)h Fu(and)f(then)h(reads)f(and)h(returns)f(a)g(single)75 ! 945 y(line)i(of)e(text)g(from)f(the)i(user.)23 b(If)17 ! b Fk(prompt)g Fu(is)g Ft(NULL)e Fu(or)h(the)h(empt)o(y)f(string,)g(no)g ! (prompt)g(is)h(displa)o(y)o(ed.)75 1000 y(The)i(line)h ! Ft(readline)d Fu(returns)i(is)g(allo)q(cated)g(with)g ! Ft(malloc\(\))p Fu(;)g(the)g(caller)g(should)h Ft(free\(\))e ! Fu(the)g(line)75 1054 y(when)e(it)f(has)g(\014nished)i(with)f(it.)k (The)15 b(declaration)h(for)f Ft(readline)f Fu(in)i(ANSI)g(C)f(is)195 ! 1119 y Ft(char)23 b(*readline)g(\(const)g(char)g(*)p ! Fk(prompt)q Ft(\);)75 1187 y Fu(So,)15 b(one)g(migh)o(t)g(sa)o(y)195 ! 1251 y Ft(char)23 b(*line)g(=)h(readline)f(\("Enter)g(a)h(line:)f("\);) ! 75 1319 y Fu(in)12 b(order)f(to)g(read)h(a)f(line)i(of)e(text)g(from)f (the)i(user.)19 b(The)11 b(line)j(returned)d(has)h(the)f(\014nal)h ! (newline)i(remo)o(v)o(ed,)75 1374 y(so)h(only)h(the)f(text)g(remains.) ! 137 1441 y(If)21 b Ft(readline)e Fu(encoun)o(ters)h(an)g Ft(EOF)g Fu(while)i(reading)f(the)f(line,)j(and)d(the)h(line)g(is)g ! (empt)o(y)f(at)g(that)75 1496 y(p)q(oin)o(t,)15 b(then)g Ft(\(char)f(*\)NULL)g Fu(is)h(returned.)21 b(Otherwise,)15 b(the)g(line)h(is)f(ended)h(just)e(as)h(if)g(a)f(newline)j(had)75 ! 1551 y(b)q(een)f(t)o(yp)q(ed.)137 1618 y(If)d(y)o(ou)g(w)o(an)o(t)f (the)h(user)g(to)f(b)q(e)i(able)g(to)e(get)g(at)h(the)g(line)h(later,)f ! (\(with)1325 1616 y Fn(h)p 1338 1590 57 2 v 1338 1618 ! a Fm(C-p)p 1338 1626 V 1392 1616 a Fn(i)1420 1618 y Fu(for)f ! (example\),)i(y)o(ou)f(m)o(ust)75 1673 y(call)j Ft(add_history\(\))e ! Fu(to)g(sa)o(v)o(e)h(the)g(line)i(a)o(w)o(a)o(y)d(in)i(a)e ! Fk(history)19 b Fu(list)d(of)f(suc)o(h)h(lines.)195 1738 ! y Ft(add_history)22 b(\(line\);)75 1805 y Fu(F)l(or)15 b(full)h(details)g(on)f(the)h(GNU)f(History)g(Library)l(,)g(see)h(the)f ! (asso)q(ciated)g(man)o(ual.)137 1873 y(It)h(is)g(preferable)h(to)e(a)o (v)o(oid)g(sa)o(ving)h(empt)o(y)f(lines)i(on)f(the)g(history)f(list,)i ! (since)f(users)g(rarely)g(ha)o(v)o(e)f(a)75 1928 y(burning)h(need)g(to) e(reuse)h(a)g(blank)g(line.)22 b(Here)15 b(is)g(a)g(function)g(whic)o ! (h)h(usefully)h(replaces)e(the)g(standard)75 1983 y Ft(gets\(\))f ! Fu(library)i(function,)g(and)f(has)g(the)h(adv)m(an)o(tage)e(of)h(no)g ! (static)g(bu\013er)g(to)g(o)o(v)o(er\015o)o(w:)195 2047 y Ft(/*)24 b(A)f(static)g(variable)g(for)h(holding)e(the)i(line.)f(*/) 195 2099 y(static)g(char)g(*line_read)g(=)h(\(char)f(*\)NULL;)195 *************** *** 2223,4568 **** (\(char)f(*\)NULL;)p eop %%Page: 20 22 ! 20 21 bop 75 -58 a Fu(20)1299 b(GNU)15 b(Readline)i(Library)290 ! 183 y Ft(})243 287 y(/*)23 b(Get)h(a)f(line)h(from)f(the)h(user.)f(*/) ! 243 339 y(line_read)f(=)i(readline)f(\(""\);)243 443 y(/*)g(If)h(the)f(line)h(has)f(any)h(text)f(in)g(it,)h(save)f(it)h(on)f ! (the)h(history.)f(*/)243 495 y(if)g(\(line_read)g(&&)g(*line_read\))290 ! 546 y(add_history)g(\(line_read\);)243 650 y(return)g(\(line_read\);) ! 195 702 y(})137 770 y Fu(This)13 b(function)f(giv)o(es)h(the)e(user)h ! (the)g(default)h(b)q(eha)o(viour)g(of)1169 768 y Fo(h)p ! 1181 742 74 2 v 1181 770 a Fn(T)m(AB)p 1181 777 V 1253 ! 768 a Fo(i)1280 770 y Fu(completion:)19 b(completion)13 ! b(on)f(\014le)75 824 y(names.)20 b(If)c(y)o(ou)f(do)g(not)g(w)o(an)o(t) ! f(Readline)k(to)c(complete)j(on)e(\014lenames,)h(y)o(ou)f(can)g(c)o ! (hange)h(the)f(binding)75 879 y(of)g(the)205 877 y Fo(h)p ! 217 851 V 217 879 a Fn(T)m(AB)p 217 887 V 289 877 a Fo(i)319 ! 879 y Fu(k)o(ey)g(with)h Ft(rl_bind_key)d(\(\))p Fu(.)195 ! 944 y Ft(int)23 b(rl_bind_key)g(\(int)g Fm(k)o(ey)p Ft(,)h(int)f(\(*)p ! Fm(function)p Ft(\)\(\)\);)137 1011 y(rl_bind_key)14 ! b(\(\))h Fu(tak)o(es)g(t)o(w)o(o)g(argumen)o(ts:)20 b ! Fm(k)o(ey)f Fu(is)d(the)g(c)o(haracter)f(that)g(y)o(ou)g(w)o(an)o(t)g ! (to)g(bind,)i(and)75 1066 y Fm(function)i Fu(is)f(the)g(address)g(of)g ! (the)g(function)g(to)g(call)h(when)f Fm(k)o(ey)k Fu(is)c(pressed.)29 ! b(Binding)1628 1064 y Fo(h)p 1641 1038 V 1641 1066 a ! Fn(T)m(AB)p 1641 1074 V 1712 1064 a Fo(i)1745 1066 y ! Fu(to)17 b Ft(rl_)75 1121 y(insert)d(\(\))i Fu(mak)o(es)433 ! 1119 y Fo(h)p 446 1093 V 446 1121 a Fn(T)m(AB)p 446 1129 ! V 517 1119 a Fo(i)548 1121 y Fu(insert)g(itself.)22 b ! Ft(rl_bind_key)13 b(\(\))i Fu(returns)h(non-zero)g(if)g ! Fm(k)o(ey)j Fu(is)d(not)f(a)g(v)m(alid)75 1176 y(ASCI)q(I)h(c)o (haracter)f(co)q(de)h(\(b)q(et)o(w)o(een)f(0)g(and)g(255\).)137 ! 1243 y(Th)o(us,)g(to)g(disable)h(the)g(default)703 1241 ! y Fo(h)p 716 1215 V 716 1243 a Fn(T)m(AB)p 716 1251 V ! 787 1241 a Fo(i)817 1243 y Fu(b)q(eha)o(vior,)g(the)f(follo)o(wing)h ! (su\016ces:)195 1308 y Ft(rl_bind_key)22 b(\('\\t',)h(rl_insert\);)137 ! 1375 y Fu(This)14 b(co)q(de)g(should)g(b)q(e)g(executed)g(once)g(at)e (the)h(start)f(of)h(y)o(our)g(program;)f(y)o(ou)h(migh)o(t)g(write)g(a) ! g(func-)75 1430 y(tion)i(called)h Ft(initialize_readline)d(\(\))h ! Fu(whic)o(h)i(p)q(erforms)e(this)h(and)g(other)g(desired)g ! (initializations,)75 1485 y(suc)o(h)h(as)e(installing)k(custom)c (completers)i(\(see)f(Section)h(2.6)f([Custom)f(Completers],)g(page)h ! (33\).)75 1614 y Fs(2.2)33 b(Custom)21 b(F)-6 b(unctions)137 ! 1711 y Fu(Readline)15 b(pro)o(vides)e(man)o(y)e(functions)i(for)f (manipulating)i(the)e(text)g(of)g(the)g(line,)i(but)e(it)h(isn't)f(p)q ! (ossi-)75 1765 y(ble)i(to)f(an)o(ticipate)h(the)f(needs)h(of)f(all)h (programs.)k(This)13 b(section)h(describ)q(es)h(the)e(v)m(arious)h ! (functions)g(and)75 1820 y(v)m(ariables)g(de\014ned)h(within)f(the)f ! (Readline)j(library)d(whic)o(h)h(allo)o(w)g(a)e(user)h(program)f(to)h ! (add)g(customized)75 1875 y(functionalit)o(y)j(to)f(Readline.)137 ! 1942 y(Before)j(declaring)i(an)o(y)e(functions)h(that)f(customize)g ! (Readline's)i(b)q(eha)o(vior,)g(or)d(using)i(an)o(y)f(func-)75 ! 1997 y(tionalit)o(y)23 b(Readline)i(pro)o(vides)f(in)f(other)g(co)q (de,)h(an)f(application)i(writer)d(should)i(include)h(the)e(\014le)75 ! 2052 y Ft()14 b Fu(in)j(an)o(y)g(\014le)h(that)e ! (uses)h(Readline's)h(features.)24 b(Since)19 b(some)d(of)g(the)h ! (de\014-)75 2107 y(nitions)g(in)f Ft(readline.h)e Fu(use)i(the)g Ft(stdio)f Fu(library)l(,)h(the)g(\014le)g Ft()f ! Fu(should)h(b)q(e)g(included)j(b)q(efore)75 2162 y Ft(readline.h)p ! Fu(.)75 2274 y Fl(2.2.1)30 b(The)20 b(F)-5 b(unction)20 ! b(T)n(yp)r(e)137 2371 y Fu(F)l(or)f(readabilt)o(y)l(,)h(w)o(e)f ! (declare)h(a)f(new)g(t)o(yp)q(e)g(of)g(ob)s(ject,)g(called)i ! Fm(F)l(unction)p Fu(.)32 b(A)19 b Ft(Function)f Fu(is)h(a)g(C)75 ! 2425 y(function)d(whic)o(h)g(returns)f(an)g Ft(int)p ! Fu(.)20 b(The)15 b(t)o(yp)q(e)g(declaration)h(for)f Ft(Function)f ! Fu(is:)75 2493 y Ft(typedef)g(int)h(Function)f(\(\);)137 ! 2560 y Fu(The)21 b(reason)g(for)f(declaring)i(this)g(new)f(t)o(yp)q(e)g ! (is)g(to)g(mak)o(e)f(it)h(easier)g(to)g(write)g(co)q(de)g(describing)75 ! 2615 y(p)q(oin)o(ters)16 b(to)f(C)g(functions.)21 b(Let)16 ! b(us)f(sa)o(y)g(w)o(e)g(had)h(a)f(v)m(ariable)i(called)g ! Fm(func)i Fu(whic)o(h)d(w)o(as)e(a)i(p)q(oin)o(ter)f(to)g(a)75 ! 2670 y(function.)21 b(Instead)15 b(of)g(the)g(classic)i(C)e ! (declaration)p eop %%Page: 21 23 21 22 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)844 b(21)137 183 y Ft(int)15 b(\(*\)\(\)func;)75 ! 250 y Fu(w)o(e)g(ma)o(y)f(write)137 317 y Ft(Function)g(*func;)75 ! 384 y Fu(Similarly)l(,)j(there)e(are)195 449 y Ft(typedef)23 ! b(void)g(VFunction)g(\(\);)195 501 y(typedef)g(char)g(*CPFunction)g ! (\(\);)g Fu(and)195 552 y Ft(typedef)g(char)g(**CPPFunction)f(\(\);)75 ! 620 y Fu(for)17 b(functions)h(returning)g(no)f(v)m(alue,)h ! Ft(pointer)d(to)g(char)p Fu(,)h(and)i Ft(pointer)c(to)h(pointer)f(to)h ! (char)p Fu(,)i(re-)75 674 y(sp)q(ectiv)o(ely)l(.)75 786 ! y Fl(2.2.2)30 b(W)-5 b(riting)20 b(a)h(New)f(F)-5 b(unction)137 ! 882 y Fu(In)17 b(order)f(to)f(write)h(new)h(functions)g(for)e ! (Readline,)j(y)o(ou)e(need)h(to)e(kno)o(w)h(the)g(calling)i(con)o(v)o ! (en)o(tions)75 937 y(for)g(k)o(eyb)q(oard-in)o(v)o(ok)o(ed)h (functions,)g(and)g(the)f(names)h(of)f(the)g(v)m(ariables)i(that)d ! (describ)q(e)k(the)d(curren)o(t)75 992 y(state)c(of)h(the)g(line)i ! (read)e(so)g(far.)137 1059 y(The)h(calling)h(sequence)f(for)f(a)f ! (command)i Ft(foo)e Fu(lo)q(oks)i(lik)o(e)195 1123 y ! Ft(foo)23 b(\(int)h(count,)f(int)g(key\))75 1190 y Fu(where)18 ! b Fm(coun)o(t)h Fu(is)f(the)g(n)o(umeric)h(argumen)o(t)e(\(or)h(1)f(if) ! i(defaulted\))f(and)g Fm(k)o(ey)k Fu(is)d(the)f(k)o(ey)g(that)f(in)o(v) ! o(ok)o(ed)75 1245 y(this)f(function.)137 1312 y(It)c(is)g(completely)h (up)f(to)f(the)g(function)i(as)e(to)g(what)g(should)h(b)q(e)g(done)g ! (with)g(the)g(n)o(umeric)g(argumen)o(t.)75 1367 y(Some)20 b(functions)h(use)f(it)g(as)g(a)g(rep)q(eat)g(coun)o(t,)g(some)g(as)g (a)f(\015ag,)i(and)f(others)g(to)f(c)o(ho)q(ose)h(alternate)75 ! 1421 y(b)q(eha)o(vior)i(\(refreshing)g(the)g(curren)o(t)f(line)j(as)d (opp)q(osed)h(to)f(refreshing)i(the)e(screen,)j(for)d(example\).)75 ! 1476 y(Some)c(c)o(ho)q(ose)f(to)g(ignore)h(it.)24 b(In)18 b(general,)f(if)g(a)f(function)h(uses)g(the)g(n)o(umeric)h(argumen)o(t) ! d(as)i(a)f(rep)q(eat)75 1531 y(coun)o(t,)e(it)g(should)h(b)q(e)f(able)h (to)e(do)h(something)h(useful)g(with)f(b)q(oth)g(negativ)o(e)g(and)g(p) ! q(ositiv)o(e)h(argumen)o(ts.)75 1586 y(A)o(t)g(the)g(v)o(ery)g(least,)g (it)g(should)h(b)q(e)g(a)o(w)o(are)e(that)h(it)g(can)g(b)q(e)h(passed)g ! (a)f(negativ)o(e)g(argumen)o(t.)75 1714 y Fs(2.3)33 b(Readline)23 ! b(V)-6 b(ariables)137 1810 y Fu(These)16 b(v)m(ariables)g(are)f(a)o(v)m ! (ailable)i(to)e(function)h(writers.)1661 1902 y(V)l(ariable)-1749 ! b Fi(char)20 b(*)f Fh(rl)p 286 1902 18 3 v 21 w(line)p ! 395 1902 V 23 w(bu\013er)195 1957 y Fu(This)h(is)f(the)h(line)h ! (gathered)e(so)f(far.)31 b(Y)l(ou)20 b(are)f(w)o(elcome)g(to)g(mo)q ! (dify)h(the)f(con)o(ten)o(ts)f(of)195 2011 y(the)f(line,)h(but)f(see)g ! (Section)g(2.4.5)e([Allo)o(wing)j(Undoing],)f(page)f(26.)24 ! b(The)17 b(function)g Ft(rl_)195 2066 y(extend_line_buffer)8 ! b Fu(is)k(a)o(v)m(ailable)g(to)f(increase)h(the)f(memory)f(allo)q ! (cated)i(to)e Ft(rl_line_)195 2121 y(buffer)p Fu(.)1661 ! 2213 y(V)l(ariable)-1749 b Fi(int)20 b Fh(rl)p 215 2213 ! V 21 w(p)r(oin)n(t)195 2267 y Fu(The)15 b(o\013set)g(of)f(the)i(curren) ! o(t)f(cursor)g(p)q(osition)h(in)g Ft(rl_line_buffer)d ! Fu(\(the)i Fm(p)q(oin)o(t)q Fu(\).)1661 2359 y(V)l(ariable)-1749 ! b Fi(int)20 b Fh(rl)p 215 2359 V 21 w(end)195 2414 y ! Fu(The)e(n)o(um)o(b)q(er)g(of)f(c)o(haracters)g(presen)o(t)h(in)g ! Ft(rl_line_buffer)p Fu(.)26 b(When)18 b Ft(rl_point)e ! Fu(is)j(at)195 2469 y(the)c(end)h(of)f(the)g(line,)i ! Ft(rl_point)d Fu(and)h Ft(rl_end)f Fu(are)h(equal.)1661 ! 2560 y(V)l(ariable)-1749 b Fi(int)20 b Fh(rl)p 215 2560 ! V 21 w(mark)195 2615 y Fu(The)14 b(mark)e(\(sa)o(v)o(ed)h(p)q ! (osition\))h(in)g(the)g(curren)o(t)f(line.)21 b(If)14 ! b(set,)f(the)h(mark)e(and)i(p)q(oin)o(t)g(de\014ne)195 ! 2670 y(a)h Fm(region)p Fu(.)p eop %%Page: 22 24 ! 22 23 bop 75 -58 a Fu(22)1299 b(GNU)15 b(Readline)i(Library)1661 ! 183 y(V)l(ariable)-1749 b Fi(int)20 b Fh(rl)p 215 183 ! 18 3 v 21 w(done)195 238 y Fu(Setting)j(this)g(to)f(a)h(non-zero)g(v)m ! (alue)h(causes)f(Readline)i(to)d(return)h(the)g(curren)o(t)f(line)195 ! 293 y(immediately)l(.)1661 384 y(V)l(ariable)-1749 b ! Fi(int)20 b Fh(rl)p 215 384 V 21 w(p)r(ending)p 436 384 ! V 20 w(input)195 439 y Fu(Setting)15 b(this)h(to)f(a)f(v)m(alue)j(mak)o ! (es)d(it)i(the)f(next)g(k)o(eystrok)o(e)f(read.)20 b(This)c(is)f(a)g(w) ! o(a)o(y)f(to)h(stu\013)195 494 y(a)g(single)h(c)o(haracter)f(in)o(to)g ! (the)g(input)i(stream.)1661 586 y(V)l(ariable)-1749 b ! Fi(int)20 b Fh(rl)p 215 586 V 21 w(erase)p 363 586 V ! 20 w(empt)n(y)p 540 586 V 20 w(line)195 640 y Fu(Setting)13 ! b(this)h(to)e(a)h(non-zero)g(v)m(alue)h(causes)f(Readline)j(to)c ! (completely)i(erase)f(the)g(curren)o(t)195 695 y(line,)19 ! b(including)g(an)o(y)e(prompt,)f(an)o(y)h(time)g(a)f(newline)j(is)f(t)o ! (yp)q(ed)f(as)f(the)h(only)h(c)o(haracter)195 750 y(on)13 ! b(an)f(otherwise-empt)o(y)h(line.)20 b(The)13 b(cursor)g(is)g(mo)o(v)o ! (ed)f(to)g(the)g(b)q(eginning)j(of)d(the)h(newly-)195 ! 805 y(blank)j(line.)1661 896 y(V)l(ariable)-1749 b Fi(char)20 ! b(*)f Fh(rl)p 286 896 V 21 w(prompt)195 951 y Fu(The)14 ! b(prompt)f(Readline)j(uses.)k(This)14 b(is)g(set)g(from)f(the)g ! (argumen)o(t)g(to)g Ft(readline)h(\(\))p Fu(,)g(and)195 ! 1006 y(should)i(not)f(b)q(e)h(assigned)g(to)e(directly)l(.)1661 ! 1097 y(V)l(ariable)-1749 b Fi(int)20 b Fh(rl)p 215 1097 ! V 21 w(already)p 419 1097 V 21 w(prompted)195 1152 y ! Fu(If)14 b(an)g(application)h(wishes)f(to)f(displa)o(y)i(the)f(prompt)f ! (itself,)i(rather)e(than)g(ha)o(v)o(e)h(Readline)195 ! 1207 y(do)j(it)h(the)f(\014rst)g(time)h Ft(readline\(\))e ! Fu(is)i(called,)h(it)f(should)g(set)f(this)h(v)m(ariable)h(to)e(a)g ! (non-)195 1262 y(zero)i(v)m(alue)i(after)e(displa)o(ying)i(the)f ! (prompt.)32 b(The)20 b(prompt)f(m)o(ust)g(also)g(b)q(e)i(passed)e(as) ! 195 1317 y(the)c(argumen)o(t)e(to)h Ft(readline\(\))g ! Fu(so)g(the)g(redispla)o(y)i(functions)f(can)g(up)q(date)g(the)g ! (displa)o(y)195 1371 y(prop)q(erly)l(.)k(The)11 b(calling)h ! (application)f(is)g(resp)q(onsible)h(for)e(managing)g(the)g(v)m(alue;)j ! (Readline)195 1426 y(nev)o(er)i(sets)g(it.)1661 1518 ! y(V)l(ariable)-1749 b Fi(char)20 b(*)f Fh(rl)p 286 1518 ! V 21 w(library)p 475 1518 V 22 w(v)n(ersion)195 1573 ! y Fu(The)c(v)o(ersion)h(n)o(um)o(b)q(er)f(of)g(this)h(revision)g(of)f ! (the)g(library)l(.)1661 1664 y(V)l(ariable)-1749 b Fi(char)20 ! b(*)f Fh(rl)p 286 1664 V 21 w(terminal)p 518 1664 V 21 ! w(name)195 1719 y Fu(The)c(terminal)h(t)o(yp)q(e,)f(used)h(for)f ! (initialization.)1661 1811 y(V)l(ariable)-1749 b Fi(char)20 ! b(*)f Fh(rl)p 286 1811 V 21 w(readline)p 505 1811 V 22 ! w(name)195 1865 y Fu(This)d(v)m(ariable)h(is)f(set)f(to)g(a)g(unique)i ! (name)f(b)o(y)f(eac)o(h)g(application)j(using)e(Readline.)23 ! b(The)195 1920 y(v)m(alue)12 b(allo)o(ws)e(conditional)i(parsing)f(of)f ! (the)g(inputrc)h(\014le)h(\(see)e(Section)h(1.3.2)e([Conditional)195 ! 1975 y(Init)16 b(Constructs],)e(page)h(8\).)1661 2067 ! y(V)l(ariable)-1749 b Fi(FILE)20 b(*)f Fh(rl)p 286 2067 ! V 21 w(instream)195 2121 y Fu(The)c(stdio)h(stream)e(from)h(whic)o(h)h ! (Readline)h(reads)e(input.)1661 2213 y(V)l(ariable)-1749 ! b Fi(FILE)20 b(*)f Fh(rl)p 286 2213 V 21 w(outstream)195 ! 2268 y Fu(The)c(stdio)h(stream)e(to)h(whic)o(h)h(Readline)h(p)q ! (erforms)e(output.)1661 2359 y(V)l(ariable)-1749 b Fi(Function)20 ! b(*)g Fh(rl)p 391 2359 V 21 w(startup)p 595 2359 V 20 ! w(ho)r(ok)195 2414 y Fu(If)15 b(non-zero,)f(this)h(is)g(the)f(address)h ! (of)e(a)h(function)i(to)d(call)j(just)e(b)q(efore)h Ft(readline)e ! Fu(prin)o(ts)195 2469 y(the)i(\014rst)g(prompt.)1661 ! 2560 y(V)l(ariable)-1749 b Fi(Function)20 b(*)g Fh(rl)p ! 391 2560 V 21 w(pre)p 494 2560 V 20 w(input)p 647 2560 ! V 21 w(ho)r(ok)195 2615 y Fu(If)d(non-zero,)h(this)f(is)h(the)f ! (address)g(of)g(a)g(function)h(to)e(call)i(after)f(the)g(\014rst)f ! (prompt)h(has)195 2670 y(b)q(een)f(prin)o(ted)g(and)g(just)f(b)q(efore) ! g Ft(readline)f Fu(starts)g(reading)i(input)g(c)o(haracters.)p ! eop %%Page: 23 25 23 24 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)844 b(23)1661 183 y(V)l(ariable)-1749 b Fi(Function)20 ! b(*)g Fh(rl)p 391 183 18 3 v 21 w(ev)n(en)n(t)p 544 183 ! V 22 w(ho)r(ok)195 238 y Fu(If)d(non-zero,)f(this)h(is)f(the)h(address) ! f(of)g(a)g(function)h(to)f(call)h(p)q(erio)q(dically)j(when)c(readline) ! 195 293 y(is)g(w)o(aiting)f(for)g(terminal)h(input.)1661 ! 409 y(V)l(ariable)-1749 b Fi(Function)20 b(*)g Fh(rl)p ! 391 409 V 21 w(getc)p 514 409 V 21 w(function)195 463 ! y Fu(If)13 b(non-zero,)g Ft(readline)e Fu(will)k(call)e(indirectly)i ! (through)d(this)h(p)q(oin)o(ter)g(to)f(get)g(a)h(c)o(haracter)195 ! 518 y(from)i(the)i(input)g(stream.)22 b(By)16 b(default,)h(it)f(is)h ! (set)f(to)f Ft(rl_getc)p Fu(,)g(the)h(default)h Ft(readline)195 ! 573 y Fu(c)o(haracter)d(input)j(function)f(\(see)f(Section)h(2.4.8)e ! ([Utilit)o(y)h(F)l(unctions],)h(page)f(28\).)1661 689 ! y(V)l(ariable)-1749 b Fi(VFunction)20 b(*)g Fh(rl)p 417 ! 689 V 21 w(redispla)n(y)p 661 689 V 22 w(function)195 ! 744 y Fu(If)g(non-zero,)h Ft(readline)d Fu(will)j(call)g(indirectly)h ! (through)d(this)h(p)q(oin)o(ter)h(to)e(up)q(date)h(the)195 ! 798 y(displa)o(y)h(with)f(the)g(curren)o(t)g(con)o(ten)o(ts)g(of)f(the) ! h(editing)i(bu\013er.)34 b(By)20 b(default,)h(it)g(is)f(set)195 ! 853 y(to)f Ft(rl_redisplay)p Fu(,)f(the)i(default)g Ft(readline)e ! Fu(redispla)o(y)j(function)f(\(see)f(Section)i(2.4.6)195 ! 908 y([Redispla)o(y],)16 b(page)f(27\).)1661 1024 y(V)l(ariable)-1749 ! b Fi(Keymap)20 b Fh(rl)p 293 1024 V 21 w(executing)p ! 551 1024 V 22 w(k)n(eymap)195 1079 y Fu(This)g(v)m(ariable)g(is)f(set)g ! (to)f(the)h(k)o(eymap)g(\(see)g(Section)h(2.4.2)d([Keymaps],)i(page)g ! (24\))f(in)195 1133 y(whic)o(h)e(the)f(curren)o(tly)h(executing)g ! (readline)h(function)f(w)o(as)f(found.)1661 1249 y(V)l(ariable)-1749 ! b Fi(Keymap)20 b Fh(rl)p 293 1249 V 21 w(binding)p 501 ! 1249 V 22 w(k)n(eymap)195 1304 y Fu(This)g(v)m(ariable)g(is)f(set)g(to) ! f(the)h(k)o(eymap)g(\(see)g(Section)h(2.4.2)d([Keymaps],)i(page)g(24\)) ! f(in)195 1359 y(whic)o(h)e(the)f(last)g(k)o(ey)h(binding)h(o)q ! (ccurred.)75 1517 y Fs(2.4)33 b(Readline)23 b(Con)n(v)n(enience)g(F)-6 ! b(unctions)75 1682 y Fl(2.4.1)30 b(Naming)20 b(a)g(F)-5 ! b(unction)137 1790 y Fu(The)20 b(user)g(can)g(dynamically)i(c)o(hange)e ! (the)g(bindings)i(of)d(k)o(eys)h(while)h(using)g(Readline.)36 ! b(This)20 b(is)75 1845 y(done)f(b)o(y)f(represen)o(ting)h(the)g (function)g(with)g(a)f(descriptiv)o(e)i(name.)29 b(The)19 ! b(user)f(is)h(able)h(to)d(t)o(yp)q(e)i(the)75 1900 y(descriptiv)o(e)e (name)e(when)h(referring)f(to)g(the)g(function.)21 b(Th)o(us,)14 b(in)i(an)f(init)i(\014le,)f(one)f(migh)o(t)g(\014nd)195 ! 1976 y Ft(Meta-Rubout:)46 b(backward-kill-word)137 2055 ! y Fu(This)20 b(binds)h(the)f(k)o(eystrok)o(e)659 2053 ! y Fo(h)p 671 2027 209 2 v 671 2055 a Fn(Meta-Rub)q(out)p ! 671 2062 V 878 2053 a Fo(i)912 2055 y Fu(to)f(the)h(function)g ! Fm(descriptiv)o(ely)25 b Fu(named)20 b Ft(backward-)75 ! 2110 y(kill-word)p Fu(.)29 b(Y)l(ou,)19 b(as)f(the)h(programmer,)f ! (should)i(bind)f(the)g(functions)h(y)o(ou)e(write)h(to)e(descriptiv)o ! (e)75 2164 y(names)e(as)g(w)o(ell.)21 b(Readline)c(pro)o(vides)f(a)f ! (function)h(for)e(doing)i(that:)1650 2280 y(F)l(unction)-1749 ! b Fi(int)20 b Fh(rl)p 215 2280 18 3 v 21 w(add)p 328 ! 2280 V 20 w(defun)i Fg(\()p Ft(char)14 b(*name,)g(Function)g ! (*function,)g(int)h(key)p Fg(\))195 2335 y Fu(Add)i Fm(name)h ! Fu(to)e(the)g(list)h(of)e(named)i(functions.)23 b(Mak)o(e)15 ! b Fm(function)i Fu(b)q(e)g(the)f(function)h(that)195 ! 2390 y(gets)e(called.)21 b(If)16 b Fm(k)o(ey)j Fu(is)c(not)g(-1,)g ! (then)g(bind)i(it)e(to)g Fm(function)h Fu(using)g Ft(rl_bind_key)d ! (\(\))p Fu(.)137 2506 y(Using)j(this)f(function)h(alone)g(is)f ! (su\016cien)o(t)h(for)f(most)f(applications.)21 b(It)15 ! b(is)h(the)f(recommended)h(w)o(a)o(y)75 2560 y(to)d(add)h(a)f(few)g ! (functions)h(to)f(the)h(default)g(functions)g(that)f(Readline)j(has)d ! (built)i(in.)20 b(If)14 b(y)o(ou)f(need)h(to)f(do)75 ! 2615 y(something)k(other)g(than)f(adding)i(a)e(function)i(to)e ! (Readline,)j(y)o(ou)e(ma)o(y)f(need)i(to)e(use)h(the)g(underlying)75 ! 2670 y(functions)f(describ)q(ed)h(b)q(elo)o(w.)p eop ! %%Page: 24 26 ! 24 25 bop 75 -58 a Fu(24)1299 b(GNU)15 b(Readline)i(Library)75 ! 183 y Fl(2.4.2)30 b(Selecting)20 b(a)h(Keymap)137 278 ! y Fu(Key)16 b(bindings)i(tak)o(e)c(place)j(on)e(a)g Fm(k)o(eymap)p Fu(.)21 b(The)15 b(k)o(eymap)h(is)f(the)h(asso)q(ciation)g(b)q(et)o(w)o ! (een)g(the)f(k)o(eys)75 333 y(that)f(the)g(user)g(t)o(yp)q(es)g(and)h (the)f(functions)h(that)f(get)g(run.)19 b(Y)l(ou)c(can)f(mak)o(e)g(y)o ! (our)g(o)o(wn)f(k)o(eymaps,)h(cop)o(y)75 388 y(existing)i(k)o(eymaps,)f ! (and)g(tell)h(Readline)i(whic)o(h)e(k)o(eymap)f(to)f(use.)1650 ! 476 y(F)l(unction)-1749 b Fi(Keymap)20 b Fh(rl)p 293 ! 476 18 3 v 21 w(mak)n(e)p 445 476 V 20 w(bare)p 575 476 ! V 20 w(k)n(eymap)j Fg(\(\))195 531 y Fu(Returns)d(a)f(new,)i(empt)o(y)e ! (k)o(eymap.)32 b(The)20 b(space)g(for)e(the)i(k)o(eymap)f(is)h(allo)q ! (cated)h(with)195 586 y Ft(malloc)14 b(\(\))p Fu(;)h(y)o(ou)g(should)h ! Ft(free)e(\(\))h Fu(it)h(when)g(y)o(ou)e(are)h(done.)1650 ! 674 y(F)l(unction)-1749 b Fi(Keymap)20 b Fh(rl)p 293 ! 674 V 21 w(cop)n(y)p 428 674 V 21 w(k)n(eymap)j Fg(\()p ! Ft(Keymap)14 b(map)p Fg(\))195 729 y Fu(Return)i(a)f(new)g(k)o(eymap)g ! (whic)o(h)h(is)g(a)f(cop)o(y)g(of)g Fm(map)p Fu(.)1650 ! 818 y(F)l(unction)-1749 b Fi(Keymap)20 b Fh(rl)p 293 ! 818 V 21 w(mak)n(e)p 445 818 V 20 w(k)n(eymap)j Fg(\(\))195 ! 872 y Fu(Return)15 b(a)f(new)h(k)o(eymap)f(with)h(the)g(prin)o(ting)h ! (c)o(haracters)d(b)q(ound)j(to)e(rl)p 1443 872 14 2 v ! 17 w(insert,)g(the)h(lo)o(w-)195 927 y(ercase)21 b(Meta)f(c)o ! (haracters)g(b)q(ound)i(to)f(run)g(their)g(equiv)m(alen)o(ts,)j(and)d ! (the)g(Meta)f(digits)195 982 y(b)q(ound)c(to)f(pro)q(duce)h(n)o(umeric) ! g(argumen)o(ts.)1650 1070 y(F)l(unction)-1749 b Fi(void)20 ! b Fh(rl)p 241 1070 18 3 v 21 w(discard)p 441 1070 V 21 w(k)n(eymap)i Fg(\()p Ft(Keymap)14 b(keymap)p Fg(\))195 ! 1125 y Fu(F)l(ree)h(the)h(storage)d(asso)q(ciated)j(with)f ! Fm(k)o(eymap)p Fu(.)137 1214 y(Readline)25 b(has)e(sev)o(eral)g(in)o (ternal)g(k)o(eymaps.)42 b(These)23 b(functions)g(allo)o(w)g(y)o(ou)f ! (to)g(c)o(hange)h(whic)o(h)75 1268 y(k)o(eymap)15 b(is)h(activ)o(e.) ! 1650 1357 y(F)l(unction)-1749 b Fi(Keymap)20 b Fh(rl)p ! 293 1357 V 21 w(get)p 391 1357 V 21 w(k)n(eymap)i Fg(\(\))195 ! 1412 y Fu(Returns)16 b(the)f(curren)o(tly)h(activ)o(e)f(k)o(eymap.)1650 ! 1500 y(F)l(unction)-1749 b Fi(void)20 b Fh(rl)p 241 1500 ! V 21 w(set)p 333 1500 V 21 w(k)n(eymap)i Fg(\()p Ft(Keymap)14 ! b(keymap)p Fg(\))195 1555 y Fu(Mak)o(es)g Fm(k)o(eymap)j ! Fu(the)e(curren)o(tly)h(activ)o(e)f(k)o(eymap.)1650 1643 ! y(F)l(unction)-1749 b Fi(Keymap)20 b Fh(rl)p 293 1643 ! V 21 w(get)p 391 1643 V 21 w(k)n(eymap)p 605 1643 V 20 ! w(b)n(y)p 685 1643 V 21 w(name)i Fg(\()p Ft(char)14 b(*name)p ! Fg(\))195 1698 y Fu(Return)h(the)f(k)o(eymap)g(matc)o(hing)h ! Fm(name)p Fu(.)k Fm(name)e Fu(is)e(one)g(whic)o(h)g(w)o(ould)f(b)q(e)h ! (supplied)i(in)e(a)195 1753 y Ft(set)g(keymap)f Fu(inputrc)i(line)h ! (\(see)e(Section)h(1.3)f([Readline)i(Init)f(File],)f(page)g(4\).)1650 ! 1841 y(F)l(unction)-1749 b Fi(char)20 b(*)f Fh(rl)p 286 ! 1841 V 21 w(get)p 384 1841 V 21 w(k)n(eymap)p 598 1841 ! V 20 w(name)i Fg(\()p Ft(Keymap)14 b(keymap)p Fg(\))195 ! 1896 y Fu(Return)h(the)f(name)h(matc)o(hing)f Fm(k)o(eymap)p ! Fu(.)19 b Fm(name)e Fu(is)e(one)g(whic)o(h)g(w)o(ould)f(b)q(e)h ! (supplied)i(in)e(a)195 1951 y Ft(set)g(keymap)f Fu(inputrc)i(line)h ! (\(see)e(Section)h(1.3)f([Readline)i(Init)f(File],)f(page)g(4\).)75 ! 2059 y Fl(2.4.3)30 b(Binding)20 b(Keys)137 2154 y Fu(Y)l(ou)j(asso)q ! (ciate)f(k)o(eys)g(with)h(functions)g(through)f(the)g(k)o(eymap.)41 ! b(Readline)25 b(has)d(sev)o(eral)h(in)o(ter-)75 2209 ! y(nal)h(k)o(eymaps:)35 b Ft(emacs_standard_keymap)p Fu(,)22 ! b Ft(emacs_meta_keymap)p Fu(,)g Ft(emacs_ctlx_keymap)p ! Fu(,)g Ft(vi_)75 2264 y(movement_keymap)p Fu(,)e(and)i Ft(vi_insertion_keymap)p Fu(.)35 b Ft(emacs_standard_keymap)18 ! b Fu(is)k(the)f(default,)75 2319 y(and)15 b(the)h(examples)g(in)g(this) ! f(man)o(ual)h(assume)f(that.)137 2385 y(Since)k Ft(readline)c Fu(installs)j(a)f(set)f(of)h(default)g(k)o(ey)g(bindings)h(the)f ! (\014rst)g(time)g(it)g(is)g(called,)i(there)d(is)75 2440 ! y(alw)o(a)o(ys)f(the)g(danger)g(that)g(a)g(custom)g(binding)i ! (installed)g(b)q(efore)f(the)f(\014rst)g(call)h(to)f ! Ft(readline)f Fu(will)j(b)q(e)75 2494 y(o)o(v)o(erridden.)28 ! b(An)17 b(alternate)h(mec)o(hanism)g(is)g(to)f(install)i(custom)e(k)o ! (ey)h(bindings)h(in)f(an)g(initialization)75 2549 y(function)h ! (assigned)h(to)d(the)i Ft(rl_startup_hook)e Fu(v)m(ariable)j(\(see)e ! (Section)h(2.3)f([Readline)j(V)l(ariables],)75 2604 y(page)15 ! b(21\).)137 2670 y(These)h(functions)g(manage)e(k)o(ey)i(bindings.)p ! eop ! %%Page: 25 27 ! 25 26 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)844 b(25)1650 183 y(F)l(unction)-1749 b Fi(int)20 ! b Fh(rl)p 215 183 18 3 v 21 w(bind)p 347 183 V 21 w(k)n(ey)k ! Fg(\()p Ft(int)14 b(key,)h(Function)f(*function)p Fg(\))195 ! 238 y Fu(Binds)i Fm(k)o(ey)j Fu(to)14 b Fm(function)h ! Fu(in)h(the)f(curren)o(tly)g(activ)o(e)g(k)o(eymap.)20 ! b(Returns)15 b(non-zero)g(in)h(the)195 293 y(case)f(of)g(an)g(in)o(v)m ! (alid)j Fm(k)o(ey)p Fu(.)1650 374 y(F)l(unction)-1749 ! b Fi(int)20 b Fh(rl)p 215 374 V 21 w(bind)p 347 374 V ! 21 w(k)n(ey)p 452 374 V 21 w(in)p 520 374 V 22 w(map)h ! Fg(\()p Ft(int)14 b(key,)h(Function)f(*function,)283 ! 429 y(Keymap)g(map)p Fg(\))195 484 y Fu(Bind)i Fm(k)o(ey)j ! Fu(to)c Fm(function)h Fu(in)g Fm(map)p Fu(.)k(Returns)15 ! b(non-zero)h(in)g(the)f(case)g(of)g(an)g(in)o(v)m(alid)j ! Fm(k)o(ey)p Fu(.)1650 565 y(F)l(unction)-1749 b Fi(int)20 ! b Fh(rl)p 215 565 V 21 w(un)n(bind)p 409 565 V 21 w(k)n(ey)k ! Fg(\()p Ft(int)14 b(key)p Fg(\))195 620 y Fu(Bind)g Fm(k)o(ey)j ! Fu(to)c(the)g(n)o(ull)i(function)f(in)g(the)f(curren)o(tly)h(activ)o(e) ! f(k)o(eymap.)19 b(Returns)14 b(non-zero)195 675 y(in)i(case)f(of)g ! (error.)1650 756 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p ! 215 756 V 21 w(un)n(bind)p 409 756 V 21 w(k)n(ey)p 514 ! 756 V 21 w(in)p 582 756 V 22 w(map)h Fg(\()p Ft(int)14 ! b(key,)h(Keymap)f(map)p Fg(\))195 811 y Fu(Bind)i Fm(k)o(ey)j ! Fu(to)c(the)g(n)o(ull)i(function)f(in)g Fm(map)p Fu(.)k(Returns)15 ! b(non-zero)h(in)g(case)f(of)g(error.)1650 892 y(F)l(unction)-1749 ! b Fi(int)20 b Fh(rl)p 215 892 V 21 w(un)n(bind)p 409 ! 892 V 21 w(function)p 635 892 V 21 w(in)p 703 892 V 21 ! w(map)h Fg(\()p Ft(Function)14 b(*function,)283 947 y(Keymap)g(map)p ! Fg(\))195 1002 y Fu(Un)o(bind)j(all)f(k)o(eys)f(that)f(execute)i ! Fm(function)g Fu(in)g Fm(map)p Fu(.)1650 1083 y(F)l(unction)-1749 ! b Fi(int)20 b Fh(rl)p 215 1083 V 21 w(un)n(bind)p 409 ! 1083 V 21 w(command)p 674 1083 V 17 w(in)p 738 1083 V ! 22 w(map)h Fg(\()p Ft(char)14 b(*command,)g(Keymap)283 ! 1138 y(map)p Fg(\))195 1193 y Fu(Un)o(bind)j(all)f(k)o(eys)f(that)f ! (are)h(b)q(ound)h(to)f Fm(command)i Fu(in)f Fm(map)p ! Fu(.)1650 1274 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p ! 215 1274 V 21 w(generic)p 413 1274 V 21 w(bind)j Fg(\()p ! Ft(int)15 b(type,)f(char)h(*keyseq,)f(char)h(*data,)283 ! 1329 y(Keymap)f(map)p Fg(\))195 1384 y Fu(Bind)g(the)f(k)o(ey)g ! (sequence)i(represen)o(ted)e(b)o(y)g(the)g(string)g Fm(k)o(eyseq)h ! Fu(to)f(the)g(arbitrary)f(p)q(oin)o(ter)195 1438 y Fm(data)p ! Fu(.)19 b Fm(t)o(yp)q(e)e Fu(sa)o(ys)c(what)h(kind)i(of)e(data)f(is)i ! (p)q(oin)o(ted)g(to)f(b)o(y)g Fm(data)p Fu(;)g(this)h(can)f(b)q(e)h(a)f ! (function)195 1493 y(\()p Ft(ISFUNC)p Fu(\),)f(a)h(macro)g(\()p ! Ft(ISMACR)p Fu(\),)f(or)i(a)f(k)o(eymap)h(\()p Ft(ISKMAP)p ! Fu(\).)j(This)d(mak)o(es)f(new)h(k)o(eymaps)195 1548 ! y(as)g(necessary)l(.)20 b(The)c(initial)h(k)o(eymap)e(in)h(whic)o(h)g ! (to)e(do)i(bindings)h(is)e Fm(map)p Fu(.)1650 1629 y(F)l(unction)-1749 ! b Fi(int)20 b Fh(rl)p 215 1629 V 21 w(parse)p 369 1629 ! V 19 w(and)p 480 1629 V 21 w(bind)j Fg(\()p Ft(char)14 ! b(*line)p Fg(\))195 1684 y Fu(P)o(arse)k Fm(line)23 b ! Fu(as)c(if)g(it)g(had)g(b)q(een)h(read)e(from)h(the)f ! Ft(inputrc)g Fu(\014le)i(and)f(p)q(erform)g(an)o(y)f(k)o(ey)195 ! 1739 y(bindings)i(and)e(v)m(ariable)i(assignmen)o(ts)d(found)i(\(see)f ! (Section)h(1.3)e([Readline)j(Init)f(File],)195 1794 y(page)c(4\).)1650 ! 1875 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p 215 1875 ! V 21 w(read)p 346 1875 V 20 w(init)p 450 1875 V 22 w(\014le)k ! Fg(\()p Ft(char)14 b(*filename)p Fg(\))195 1930 y Fu(Read)25 ! b(k)o(eybindings)i(and)e(v)m(ariable)h(assignmen)o(ts)e(from)g ! Fm(\014lename)29 b Fu(\(see)24 b(Section)i(1.3)195 1985 ! y([Readline)17 b(Init)f(File],)g(page)f(4\).)75 2086 ! y Fl(2.4.4)30 b(Asso)r(ciating)20 b(F)-5 b(unction)20 ! b(Names)h(and)f(Bindings)137 2179 y Fu(These)11 b(functions)h(allo)o(w) ! e(y)o(ou)h(to)f(\014nd)h(out)f(what)g(k)o(eys)h(in)o(v)o(ok)o(e)f ! (named)h(functions)h(and)e(the)h(functions)75 2233 y(in)o(v)o(ok)o(ed)k ! (b)o(y)h(a)e(particular)i(k)o(ey)f(sequence.)1650 2315 ! y(F)l(unction)-1749 b Fi(Function)20 b(*)g Fh(rl)p 391 ! 2315 V 21 w(named)p 579 2315 V 19 w(function)j Fg(\()p ! Ft(char)14 b(*name)p Fg(\))195 2369 y Fu(Return)i(the)f(function)h ! (with)g(name)f Fm(name)p Fu(.)1650 2451 y(F)l(unction)-1749 ! b Fi(Function)20 b(*)g Fh(rl)p 391 2451 V 21 w(function)p ! 617 2451 V 21 w(of)p 685 2451 V 19 w(k)n(eyseq)k Fg(\()p ! Ft(char)15 b(*keyseq,)f(Keymap)283 2506 y(map,)g(int)h(*type)p ! Fg(\))195 2560 y Fu(Return)j(the)f(function)g(in)o(v)o(ok)o(ed)g(b)o(y) ! g Fm(k)o(eyseq)h Fu(in)g(k)o(eymap)f Fm(map)p Fu(.)25 ! b(If)17 b Fm(map)h Fu(is)f(NULL,)h(the)195 2615 y(curren)o(t)13 ! b(k)o(eymap)g(is)h(used.)20 b(If)14 b Fm(t)o(yp)q(e)i ! Fu(is)e(not)f(NULL,)h(the)f(t)o(yp)q(e)g(of)g(the)h(ob)s(ject)f(is)h ! (returned)195 2670 y(in)i(it)f(\(one)g(of)g Ft(ISFUNC)p ! Fu(,)f Ft(ISKMAP)p Fu(,)g(or)h Ft(ISMACR)p Fu(\).)p eop ! %%Page: 26 28 ! 26 27 bop 75 -58 a Fu(26)1299 b(GNU)15 b(Readline)i(Library)1650 ! 183 y(F)l(unction)-1749 b Fi(char)20 b(**)f Fh(rl)p 312 ! 183 18 3 v 21 w(in)n(v)n(oking)p 541 183 V 23 w(k)n(eyseqs)k ! Fg(\()p Ft(Function)14 b(*function)p Fg(\))195 238 y ! Fu(Return)i(an)f(arra)o(y)f(of)h(strings)g(represen)o(ting)h(the)g(k)o ! (ey)f(sequences)h(used)g(to)f(in)o(v)o(ok)o(e)g Fm(func-)195 ! 293 y(tion)g Fu(in)h(the)g(curren)o(t)f(k)o(eymap.)1650 ! 387 y(F)l(unction)-1749 b Fi(char)20 b(**)f Fh(rl)p 312 ! 387 V 21 w(in)n(v)n(oking)p 541 387 V 23 w(k)n(eyseqs)p ! 750 387 V 21 w(in)p 818 387 V 22 w(map)i Fg(\()p Ft(Function)14 ! b(*function,)283 442 y(Keymap)g(map)p Fg(\))195 497 y ! Fu(Return)i(an)f(arra)o(y)f(of)h(strings)g(represen)o(ting)h(the)g(k)o ! (ey)f(sequences)h(used)g(to)f(in)o(v)o(ok)o(e)g Fm(func-)195 ! 552 y(tion)g Fu(in)h(the)g(k)o(eymap)f Fm(map)p Fu(.)1650 ! 646 y(F)l(unction)-1749 b Fi(void)20 b Fh(rl)p 241 646 ! V 21 w(function)p 467 646 V 21 w(dump)r(er)g Fg(\()p ! Ft(int)15 b(readable)p Fg(\))195 701 y Fu(Prin)o(t)k(the)h(readline)g ! (function)g(names)g(and)f(the)g(k)o(ey)g(sequences)i(curren)o(tly)e(b)q ! (ound)i(to)195 756 y(them)16 b(to)f Ft(rl_outstream)p ! Fu(.)k(If)d Fm(readable)j Fu(is)d(non-zero,)g(the)g(list)g(is)g ! (formatted)f(in)h(suc)o(h)g(a)195 810 y(w)o(a)o(y)e(that)h(it)g(can)g ! (b)q(e)h(made)g(part)e(of)h(an)g Ft(inputrc)f Fu(\014le)i(and)g ! (re-read.)1650 905 y(F)l(unction)-1749 b Fi(void)20 b ! Fh(rl)p 241 905 V 21 w(list)p 337 905 V 22 w(funmap)p ! 550 905 V 18 w(names)h Fg(\(\))195 960 y Fu(Prin)o(t)15 ! b(the)g(names)h(of)e(all)j(bindable)g(Readline)g(functions)f(to)f ! Ft(rl_outstream)p Fu(.)1650 1054 y(F)l(unction)-1749 ! b Fi(char)20 b(**)f Fh(rl)p 312 1054 V 21 w(funmap)p ! 524 1054 V 18 w(names)i Fg(\(\))195 1109 y Fu(Return)12 ! b(a)e(NULL)i(terminated)g(arra)o(y)d(of)i(kno)o(wn)g(function)h(names.) ! 18 b(The)11 b(arra)o(y)f(is)i(sorted.)195 1163 y(The)k(arra)o(y)f ! (itself)i(is)f(allo)q(cated,)h(but)f(not)f(the)h(strings)g(inside.)24 ! b(Y)l(ou)16 b(should)h(free)f(\(\))f(the)195 1218 y(arra)o(y)f(when)i ! (y)o(ou)e(done,)i(but)f(not)g(the)g(p)q(oin)o(trs.)75 ! 1333 y Fl(2.4.5)30 b(Allo)n(wing)21 b(Undoing)137 1430 ! y Fu(Supp)q(orting)14 b(the)g(undo)f(command)g(is)h(a)f(painless)h ! (thing,)g(and)f(mak)o(es)g(y)o(our)f(functions)i(m)o(uc)o(h)f(more)75 ! 1485 y(useful.)28 b(It)17 b(is)h(certainly)h(easy)e(to)g(try)g ! (something)g(if)h(y)o(ou)f(kno)o(w)g(y)o(ou)h(can)f(undo)h(it.)27 ! b(I)18 b(could)g(use)g(an)75 1540 y(undo)e(function)g(for)e(the)i(sto)q ! (c)o(k)e(mark)o(et.)137 1608 y(If)g(y)o(our)e(function)i(simply)h ! (inserts)f(text)e(once,)i(or)e(deletes)j(text)d(once,)i(and)f(uses)h ! Ft(rl_insert_text)75 1663 y(\(\))h Fu(or)g Ft(rl_delete_text)e(\(\))i ! Fu(to)f(do)h(it,)g(then)h(undoing)g(is)g(already)f(done)h(for)f(y)o(ou) ! f(automatically)l(.)137 1731 y(If)d(y)o(ou)f(do)g(m)o(ultiple)i ! (insertions)f(or)f(m)o(ultiple)i(deletions,)g(or)e(an)o(y)g(com)o ! (bination)h(of)f(these)g(op)q(erations,)75 1786 y(y)o(ou)19 ! b(should)h(group)e(them)h(together)g(in)o(to)g(one)g(op)q(eration.)31 ! b(This)20 b(is)f(done)h(with)f Ft(rl_begin_undo_)75 1841 ! y(group)14 b(\(\))h Fu(and)h Ft(rl_end_undo_group)d(\(\))p ! Fu(.)137 1909 y(The)j(t)o(yp)q(es)f(of)g(ev)o(en)o(ts)g(that)f(can)h(b) ! q(e)h(undone)g(are:)195 1975 y Ft(enum)23 b(undo_code)g({)h ! (UNDO_DELETE,)e(UNDO_INSERT,)g(UNDO_BEGIN,)g(UNDO_END)h(};)137 ! 2043 y Fu(Notice)16 b(that)e Ft(UNDO_DELETE)g Fu(means)h(to)g(insert)g ! (some)g(text,)f(and)i Ft(UNDO_INSERT)d Fu(means)i(to)g(delete)75 ! 2098 y(some)d(text.)18 b(That)12 b(is,)h(the)f(undo)g(co)q(de)h(tells)g ! (undo)g(what)e(to)h(undo,)h(not)f(ho)o(w)f(to)h(undo)g(it.)19 ! b Ft(UNDO_BEGIN)75 2152 y Fu(and)c Ft(UNDO_END)f Fu(are)h(tags)g(added) ! g(b)o(y)h Ft(rl_begin_undo_group)c(\(\))j Fu(and)g Ft ! (rl_end_undo_group)e(\(\))p Fu(.)1650 2247 y(F)l(unction)-1749 ! b Fi(int)20 b Fh(rl)p 215 2247 V 21 w(b)r(egin)p 372 ! 2247 V 20 w(undo)p 517 2247 V 20 w(group)h Fg(\(\))195 ! 2302 y Fu(Begins)e(sa)o(ving)g(undo)g(information)f(in)i(a)e(group)g ! (construct.)29 b(The)19 b(undo)g(information)195 2356 ! y(usually)f(comes)f(from)f(calls)h(to)g Ft(rl_insert_text)c(\(\))j ! Fu(and)h Ft(rl_delete_text)c(\(\))p Fu(,)k(but)195 2411 ! y(could)f(b)q(e)g(the)f(result)h(of)f(calls)h(to)f Ft(rl_add_undo)e ! (\(\))p Fu(.)1650 2506 y(F)l(unction)-1749 b Fi(int)20 ! b Fh(rl)p 215 2506 V 21 w(end)p 326 2506 V 20 w(undo)p ! 471 2506 V 20 w(group)h Fg(\(\))195 2560 y Fu(Closes)c(the)g(curren)o ! (t)g(undo)h(group)e(started)h(with)g Ft(rl_begin_undo_group)c(\(\))p ! Fu(.)25 b(There)195 2615 y(should)17 b(b)q(e)f(one)f(call)i(to)e ! Ft(rl_end_undo_group)e(\(\))i Fu(for)g(eac)o(h)g(call)i(to)e ! Ft(rl_begin_undo_)195 2670 y(group)f(\(\))p Fu(.)p eop ! %%Page: 27 29 ! 27 28 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)844 b(27)1650 183 y(F)l(unction)-1749 b Fi(void)20 ! b Fh(rl)p 241 183 18 3 v 21 w(add)p 354 183 V 20 w(undo)i ! Fg(\()p Ft(enum)14 b(undo_code)g(what,)g(int)h(start,)g(int)f(end,)283 ! 238 y(char)g(*text)p Fg(\))195 293 y Fu(Remem)o(b)q(er)j(ho)o(w)f(to)f ! (undo)i(an)f(ev)o(en)o(t)g(\(according)h(to)e Fm(what)q ! Fu(\).)23 b(The)16 b(a\013ected)g(text)g(runs)195 348 ! y(from)e Fm(start)h Fu(to)g Fm(end)p Fu(,)g(and)h(encompasses)f ! Fm(text)p Fu(.)1650 445 y(F)l(unction)-1749 b Fi(void)20 ! b Fh(free)p 296 445 V 20 w(undo)p 441 445 V 20 w(list)k ! Fg(\(\))195 500 y Fu(F)l(ree)15 b(the)h(existing)g(undo)f(list.)1650 ! 597 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p 215 597 ! V 21 w(do)p 297 597 V 20 w(undo)i Fg(\(\))195 651 y Fu(Undo)16 ! b(the)g(\014rst)f(thing)h(on)g(the)f(undo)h(list.)22 ! b(Returns)17 b Ft(0)e Fu(if)h(there)g(w)o(as)f(nothing)h(to)f(undo,)195 ! 706 y(non-zero)g(if)h(something)g(w)o(as)e(undone.)137 ! 803 y(Finally)l(,)j(if)f(y)o(ou)f(neither)i(insert)f(nor)f(delete)i ! (text,)e(but)g(directly)i(mo)q(dify)f(the)g(existing)g(text)g(\(e.g.,) ! 75 858 y(c)o(hange)i(its)h(case\),)g(call)g Ft(rl_modifying)14 ! b(\(\))k Fu(once,)h(just)f(b)q(efore)h(y)o(ou)f(mo)q(dify)h(the)f ! (text.)29 b(Y)l(ou)19 b(m)o(ust)75 913 y(supply)d(the)g(indices)h(of)e ! (the)g(text)g(range)g(that)f(y)o(ou)h(are)g(going)g(to)g(mo)q(dify)l(.) ! 1650 1010 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p 215 ! 1010 V 21 w(mo)r(difying)h Fg(\()p Ft(int)15 b(start,)f(int)h(end)p ! Fg(\))195 1065 y Fu(T)l(ell)i(Readline)i(to)c(sa)o(v)o(e)g(the)i(text)e ! (b)q(et)o(w)o(een)h Fm(start)g Fu(and)g Fm(end)j Fu(as)c(a)h(single)h ! (undo)g(unit.)23 b(It)195 1120 y(is)16 b(assumed)f(that)g(y)o(ou)f ! (will)j(subsequen)o(tly)g(mo)q(dify)e(that)g(text.)75 ! 1237 y Fl(2.4.6)30 b(Redispla)n(y)1650 1363 y Fu(F)l(unction)-1749 ! b Fi(void)20 b Fh(rl)p 241 1363 V 21 w(redispla)n(y)k ! Fg(\(\))195 1417 y Fu(Change)19 b(what's)f(displa)o(y)o(ed)i(on)f(the)f ! (screen)i(to)e(re\015ect)h(the)g(curren)o(t)g(con)o(ten)o(ts)f(of)g ! Ft(rl_)195 1472 y(line_buffer)p Fu(.)1650 1569 y(F)l(unction)-1749 ! b Fi(int)20 b Fh(rl)p 215 1569 V 21 w(forced)p 390 1569 ! V 20 w(up)r(date)p 584 1569 V 20 w(displa)n(y)k Fg(\(\))195 ! 1624 y Fu(F)l(orce)17 b(the)f(line)j(to)d(b)q(e)i(up)q(dated)f(and)g ! (redispla)o(y)o(ed,)h(whether)f(or)g(not)f(Readline)j(thinks)195 ! 1679 y(the)c(screen)h(displa)o(y)g(is)g(correct.)1650 ! 1776 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p 215 1776 ! V 21 w(on)p 297 1776 V 20 w(new)p 416 1776 V 21 w(line)k ! Fg(\(\))195 1831 y Fu(T)l(ell)15 b(the)f(up)q(date)h(functions)g(that)e ! (w)o(e)g(ha)o(v)o(e)h(mo)o(v)o(ed)f(on)o(to)g(a)h(new)g(\(empt)o(y\))f ! (line,)j(usually)195 1886 y(after)e(ouputting)i(a)f(newline.)1650 ! 1983 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p 215 1983 ! V 21 w(on)p 297 1983 V 20 w(new)p 416 1983 V 21 w(line)p ! 525 1983 V 22 w(with)p 657 1983 V 22 w(prompt)h Fg(\(\))195 ! 2037 y Fu(T)l(ell)c(the)e(up)q(date)h(functions)g(that)f(w)o(e)g(ha)o ! (v)o(e)g(mo)o(v)o(ed)f(on)o(to)h(a)g(new)g(line,)i(with)f ! Fm(rl)p 1595 2037 14 2 v 16 w(prompt)195 2092 y Fu(already)f(displa)o ! (y)o(ed.)22 b(This)15 b(could)h(b)q(e)g(used)g(b)o(y)f(applications)i ! (that)d(w)o(an)o(t)g(to)h(output)g(the)195 2147 y(prompt)j(string)g ! (themselv)o(es,)h(but)g(still)h(need)f(Readline)h(to)e(kno)o(w)g(the)g ! (prompt)g(string)195 2202 y(length)e(for)e(redispla)o(y)l(.)22 ! b(It)15 b(should)h(b)q(e)g(used)g(after)e(setting)h Fm(rl)p ! 1258 2202 V 17 w(already)p 1420 2202 V 17 w(prompted)p ! Fu(.)1650 2299 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p ! 215 2299 18 3 v 21 w(reset)p 357 2299 V 20 w(line)p 465 ! 2299 V 23 w(state)j Fg(\(\))195 2354 y Fu(Reset)17 b(the)f(displa)o(y)h ! (state)f(to)f(a)h(clean)h(state)f(and)g(redispla)o(y)h(the)g(curren)o ! (t)f(line)i(starting)195 2409 y(on)d(a)g(new)g(line.)1650 ! 2506 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p 215 2506 ! V 21 w(message)g Fg(\()p Ft(va_alist)p Fg(\))195 2560 ! y Fu(The)h(argumen)o(ts)f(are)g(a)g(string)h(as)f(w)o(ould)h(b)q(e)g ! (supplied)i(to)d Ft(printf)p Fu(.)35 b(The)21 b(resulting)195 ! 2615 y(string)h(is)g(displa)o(y)o(ed)h(in)g(the)f Fm(ec)o(ho)g(area)p ! Fu(.)39 b(The)23 b(ec)o(ho)f(area)f(is)h(also)g(used)h(to)e(displa)o(y) ! 195 2670 y(n)o(umeric)16 b(argumen)o(ts)e(and)i(searc)o(h)f(strings.)p ! eop %%Page: 28 30 ! 28 29 bop 75 -58 a Fu(28)1299 b(GNU)15 b(Readline)i(Library)1650 ! 183 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p 215 183 ! 18 3 v 21 w(clear)p 354 183 V 21 w(message)h Fg(\(\))195 ! 238 y Fu(Clear)15 b(the)h(message)e(in)i(the)g(ec)o(ho)f(area.)1650 ! 333 y(F)l(unction)-1749 b Fi(void)20 b Fh(rl)p 241 333 ! V 21 w(sa)n(v)n(e)p 365 333 V 21 w(prompt)h Fg(\(\))195 ! 388 y Fu(Sa)o(v)o(e)e(the)h(lo)q(cal)h(Readline)h(prompt)d(displa)o(y)i ! (state)e(in)h(preparation)g(for)f(displa)o(ying)i(a)195 ! 443 y(new)15 b(message)g(in)h(the)f(message)g(area)g(with)g ! Ft(rl_message)p Fu(.)1650 538 y(F)l(unction)-1749 b Fi(void)20 ! b Fh(rl)p 241 538 V 21 w(restore)p 436 538 V 20 w(prompt)g ! Fg(\(\))195 593 y Fu(Restore)c(the)h(lo)q(cal)h(Readline)g(prompt)e ! (displa)o(y)i(state)e(sa)o(v)o(ed)g(b)o(y)g(the)h(most)e(recen)o(t)i ! (call)195 648 y(to)e Ft(rl_save_prompt)p Fu(.)75 763 ! y Fl(2.4.7)30 b(Mo)r(difying)20 b(T)-5 b(ext)1650 887 ! y Fu(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p 215 887 ! V 21 w(insert)p 378 887 V 21 w(text)k Fg(\()p Ft(char)14 ! b(*text)p Fg(\))195 942 y Fu(Insert)h Fm(text)h Fu(in)o(to)f(the)h ! (line)g(at)f(the)g(curren)o(t)g(cursor)g(p)q(osition.)1650 ! 1037 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p 215 1037 ! V 21 w(delete)p 383 1037 V 22 w(text)k Fg(\()p Ft(int)14 ! b(start,)h(int)f(end)p Fg(\))195 1092 y Fu(Delete)i(the)f(text)g(b)q ! (et)o(w)o(een)g Fm(start)g Fu(and)h Fm(end)h Fu(in)f(the)g(curren)o(t)f ! (line.)1650 1187 y(F)l(unction)-1749 b Fi(char)20 b(*)f ! Fh(rl)p 286 1187 V 21 w(cop)n(y)p 421 1187 V 21 w(text)24 ! b Fg(\()p Ft(int)14 b(start,)h(int)g(end)p Fg(\))195 ! 1242 y Fu(Return)h(a)f(cop)o(y)g(of)g(the)g(text)f(b)q(et)o(w)o(een)i ! Fm(start)f Fu(and)g Fm(end)j Fu(in)e(the)f(curren)o(t)g(line.)1650 ! 1337 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p 215 1337 ! V 21 w(kill)p 311 1337 V 23 w(text)k Fg(\()p Ft(int)14 ! b(start,)h(int)g(end)p Fg(\))195 1392 y Fu(Cop)o(y)j(the)h(text)f(b)q ! (et)o(w)o(een)h Fm(start)f Fu(and)h Fm(end)i Fu(in)e(the)g(curren)o(t)f ! (line)i(to)e(the)h(kill)h(ring,)g(ap-)195 1447 y(p)q(ending)15 ! b(or)f(prep)q(ending)h(to)e(the)h(last)f(kill)j(if)e(the)g(last)f ! (command)h(w)o(as)f(a)g(kill)i(command.)195 1502 y(The)j(text)f(is)h ! (deleted.)28 b(If)18 b Fm(start)f Fu(is)h(less)g(than)f ! Fm(end)p Fu(,)i(the)e(text)g(is)h(app)q(ended,)i(otherwise)195 ! 1556 y(prep)q(ended.)i(If)15 b(the)g(last)h(command)f(w)o(as)f(not)h(a) ! g(kill,)h(a)f(new)h(kill)h(ring)e(slot)g(is)h(used.)75 ! 1672 y Fl(2.4.8)30 b(Utilit)n(y)21 b(F)-5 b(unctions)1650 ! 1796 y Fu(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p 215 ! 1796 V 21 w(read)p 346 1796 V 20 w(k)n(ey)k Fg(\(\))195 ! 1851 y Fu(Return)14 b(the)g(next)g(c)o(haracter)e(a)o(v)m(ailable.)22 ! b(This)14 b(handles)h(input)f(inserted)h(in)o(to)e(the)h(input)195 ! 1905 y(stream)k(via)g Fm(p)q(ending)j(input)f Fu(\(see)f(Section)g(2.3) ! f([Readline)i(V)l(ariables],)g(page)e(21\))g(and)195 ! 1960 y Ft(rl_stuff_char)13 b(\(\))p Fu(,)i(macros,)f(and)h(c)o ! (haracters)g(read)g(from)f(the)i(k)o(eyb)q(oard.)1650 ! 2056 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p 215 2056 ! V 21 w(getc)j Fg(\()p Ft(FILE)14 b(*)p Fg(\))195 2110 ! y Fu(Return)i(the)f(next)g(c)o(haracter)g(a)o(v)m(ailable)i(from)d(the) ! h(k)o(eyb)q(oard.)1650 2206 y(F)l(unction)-1749 b Fi(int)20 ! b Fh(rl)p 215 2206 V 21 w(stu\013)p 346 2206 V 20 w(c)n(har)j ! Fg(\()p Ft(int)15 b(c)p Fg(\))195 2260 y Fu(Insert)22 ! b Fm(c)i Fu(in)o(to)e(the)g(Readline)i(input)f(stream.)38 ! b(It)22 b(will)h(b)q(e)f Ft(")p Fu(read)p Ft(")g Fu(b)q(efore)g ! (Readline)195 2315 y(attempts)14 b(to)h(read)g(c)o(haracters)f(from)h ! (the)g(terminal)h(with)f Ft(rl_read_key)f(\(\))p Fu(.)1650 ! 2410 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p 215 2410 ! V 21 w(extend)p 404 2410 V 21 w(line)p 513 2410 V 22 ! w(bu\013er)j Fg(\()p Ft(int)15 b(len)p Fg(\))195 2465 ! y Fu(Ensure)f(that)e Ft(rl_line_buffer)g Fu(has)h(enough)h(space)f(to)g ! (hold)h Fm(len)h Fu(c)o(haracters,)d(p)q(ossibly)195 ! 2520 y(reallo)q(cating)k(it)g(if)f(necessary)l(.)1650 ! 2615 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p 215 2615 ! V 21 w(initiali)q(z)q(e)26 b Fg(\(\))195 2670 y Fu(Initialize)18 ! b(or)d(re-initialize)j(Readline's)f(in)o(ternal)f(state.)p ! eop %%Page: 29 31 29 30 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)844 b(29)1650 183 y(F)l(unction)-1749 b Fi(int)20 ! b Fh(rl)p 215 183 18 3 v 21 w(reset)p 357 183 V 20 w(terminal)j ! Fg(\()p Ft(char)15 b(*terminal_name)p Fg(\))195 238 y ! Fu(Reinitializ)q(e)h(Readline's)g(idea)e(of)f(the)h(terminal)g ! (settings)g(using)g Fm(terminal)p 1501 238 14 2 v 17 ! w(name)j Fu(as)c(the)195 293 y(terminal)k(t)o(yp)q(e)g(\(e.g.,)e ! Ft(vt100)p Fu(\).)24 b(If)16 b Fm(terminal)p 987 293 ! V 18 w(name)j Fu(is)e(NULL,)g(the)g(v)m(alue)h(of)e(the)h ! Ft(TERM)195 348 y Fu(en)o(vironmen)o(t)e(v)m(ariable)i(is)f(used.)1650 ! 431 y(F)l(unction)-1749 b Fi(int)20 b Fh(alphab)r(etic)k ! Fg(\()p Ft(int)14 b(c)p Fg(\))195 486 y Fu(Return)i(1)f(if)g ! Fm(c)j Fu(is)e(an)f(alphab)q(etic)i(c)o(haracter.)1650 ! 570 y(F)l(unction)-1749 b Fi(int)20 b Fh(n)n(umeric)i ! Fg(\()p Ft(int)15 b(c)p Fg(\))195 624 y Fu(Return)h(1)f(if)g ! Fm(c)j Fu(is)e(a)f(n)o(umeric)h(c)o(haracter.)1650 708 ! y(F)l(unction)-1749 b Fi(int)20 b Fh(ding)i Fg(\(\))195 ! 763 y Fu(Ring)16 b(the)f(terminal)h(b)q(ell,)h(ob)q(eying)f(the)g ! (setting)f(of)g Ft(bell-style)p Fu(.)1650 847 y(F)l(unction)-1749 ! b Fi(void)20 b Fh(rl)p 241 847 18 3 v 21 w(displa)n(y)p ! 435 847 V 22 w(matc)n(h)p 611 847 V 20 w(list)25 b Fg(\()p ! Ft(char)14 b(**matches,)g(int)g(len,)h(int)283 901 y(max)p ! Fg(\))195 956 y Fu(A)j(con)o(v)o(enience)i(function)g(for)d(displa)o ! (ying)j(a)e(list)i(of)e(strings)g(in)h(columnar)g(format)e(on)195 ! 1011 y(Readline's)e(output)e(stream.)18 b Ft(matches)12 ! b Fu(is)h(the)g(list)h(of)f(strings,)f(in)i(argv)e(format,)g(suc)o(h)h ! (as)195 1066 y(a)h(list)h(of)e(completion)j(matc)o(hes.)j ! Ft(len)13 b Fu(is)i(the)f(n)o(um)o(b)q(er)h(of)e(strings)h(in)h ! Ft(matches)p Fu(,)e(and)h Ft(max)195 1120 y Fu(is)k(the)g(length)h(of)e ! (the)h(longest)g(string)g(in)h Ft(matches)p Fu(.)27 b(This)18 ! b(function)h(uses)f(the)g(setting)195 1175 y(of)13 b ! Ft(print-completions-horizontally)d Fu(to)k(select)g(ho)o(w)g(the)g ! (matc)o(hes)f(are)h(displa)o(y)o(ed)195 1230 y(\(see)h(Section)h(1.3.1) ! e([Readline)j(Init)f(File)g(Syn)o(tax],)e(page)h(4\).)137 ! 1314 y(The)h(follo)o(wing)g(are)f(implemen)o(ted)h(as)f(macros,)f ! (de\014ned)j(in)f Ft(chartypes.h)p Fu(.)1650 1397 y(F)l(unction)-1749 ! b Fi(int)20 b Fh(upp)r(ercase)p 426 1397 V 19 w(p)j Fg(\()p ! Ft(int)14 b(c)p Fg(\))195 1452 y Fu(Return)i(1)f(if)g ! Fm(c)j Fu(is)e(an)f(upp)q(ercase)i(alphab)q(etic)f(c)o(haracter.)1650 ! 1536 y(F)l(unction)-1749 b Fi(int)20 b Fh(lo)n(w)n(ercase)p ! 409 1536 V 22 w(p)i Fg(\()p Ft(int)15 b(c)p Fg(\))195 ! 1591 y Fu(Return)h(1)f(if)g Fm(c)j Fu(is)e(a)f(lo)o(w)o(ercase)g ! (alphab)q(etic)i(c)o(haracter.)1650 1674 y(F)l(unction)-1749 ! b Fi(int)20 b Fh(digit)p 289 1674 V 22 w(p)i Fg(\()p ! Ft(int)15 b(c)p Fg(\))195 1729 y Fu(Return)h(1)f(if)g ! Fm(c)j Fu(is)e(a)f(n)o(umeric)h(c)o(haracter.)1650 1813 ! y(F)l(unction)-1749 b Fi(int)20 b Fh(to)p 227 1813 V ! 20 w(upp)r(er)i Fg(\()p Ft(int)14 b(c)p Fg(\))195 1867 ! y Fu(If)21 b Fm(c)i Fu(is)e(a)g(lo)o(w)o(ercase)f(alphab)q(etic)i(c)o ! (haracter,)f(return)g(the)f(corresp)q(onding)i(upp)q(ercase)195 ! 1922 y(c)o(haracter.)1650 2006 y(F)l(unction)-1749 b ! Fi(int)20 b Fh(to)p 227 2006 V 20 w(lo)n(w)n(er)k Fg(\()p ! Ft(int)15 b(c)p Fg(\))195 2061 y Fu(If)j Fm(c)j Fu(is)e(an)f(upp)q ! (ercase)h(alphab)q(etic)h(c)o(haracter,)e(return)g(the)g(corresp)q ! (onding)h(lo)o(w)o(ercase)195 2115 y(c)o(haracter.)1650 ! 2199 y(F)l(unction)-1749 b Fi(int)20 b Fh(digit)p 289 ! 2199 V 22 w(v)m(alue)j Fg(\()p Ft(int)15 b(c)p Fg(\))195 ! 2254 y Fu(If)g Fm(c)k Fu(is)c(a)g(n)o(um)o(b)q(er,)g(return)g(the)h(v)m ! (alue)g(it)g(represen)o(ts.)75 2357 y Fl(2.4.9)30 b(Alternate)20 ! b(In)n(terface)137 2451 y Fu(An)j(alternate)f(in)o(terface)h(is)g(a)o ! (v)m(ailable)h(to)d(plain)j Ft(readline\(\))p Fu(.)40 ! b(Some)22 b(applications)i(need)g(to)75 2506 y(in)o(terlea)o(v)o(e)15 b(k)o(eyb)q(oard)f(I/O)h(with)g(\014le,)h(device,)f(or)f(windo)o(w)h (system)f(I/O,)h(t)o(ypically)h(b)o(y)e(using)h(a)g(main)75 ! 2560 y(lo)q(op)f(to)g Ft(select\(\))e Fu(on)i(v)m(arious)g(\014le)h (descriptors.)20 b(T)l(o)14 b(accomo)q(date)f(this)h(need,)h(readline)g ! (can)f(also)g(b)q(e)75 2615 y(in)o(v)o(ok)o(ed)i(as)f(a)g(`callbac)o ! (k')h(function)h(from)d(an)i(ev)o(en)o(t)f(lo)q(op.)22 ! b(There)16 b(are)f(functions)h(a)o(v)m(ailable)i(to)c(mak)o(e)75 ! 2670 y(this)i(easy)l(.)p eop ! %%Page: 30 32 ! 30 31 bop 75 -58 a Fu(30)1299 b(GNU)15 b(Readline)i(Library)1650 ! 183 y(F)l(unction)-1749 b Fi(void)20 b Fh(rl)p 241 183 ! 18 3 v 21 w(callbac)n(k)p 458 183 V 23 w(handler)p 670 ! 183 V 21 w(install)25 b Fg(\()p Ft(char)14 b(*prompt,)g(Vfunction)283 ! 238 y(*lhandler)p Fg(\))195 293 y Fu(Set)i(up)h(the)g(terminal)g(for)f ! (readline)i(I/O)e(and)h(displa)o(y)g(the)g(initial)h(expanded)g(v)m ! (alue)f(of)195 348 y Fm(prompt)p Fu(.)24 b(Sa)o(v)o(e)17 ! b(the)g(v)m(alue)h(of)e Fm(lhandler)22 b Fu(to)17 b(use)g(as)f(a)h ! (callbac)o(k)h(when)f(a)g(complete)g(line)195 402 y(of)e(input)h(has)f ! (b)q(een)h(en)o(tered.)1650 498 y(F)l(unction)-1749 b ! Fi(void)20 b Fh(rl)p 241 498 V 21 w(callbac)n(k)p 458 ! 498 V 23 w(read)p 591 498 V 20 w(c)n(har)j Fg(\(\))195 ! 553 y Fu(Whenev)o(er)14 b(an)f(application)i(determines)f(that)f(k)o ! (eyb)q(oard)g(input)h(is)g(a)o(v)m(ailable,)h(it)f(should)195 ! 608 y(call)20 b Ft(rl_callback_read_char\(\))p Fu(,)c(whic)o(h)k(will)g ! (read)f(the)g(next)g(c)o(haracter)f(from)g(the)195 663 ! y(curren)o(t)25 b(input)h(source.)48 b(If)25 b(that)g(c)o(haracter)f ! (completes)h(the)g(line,)k Ft(rl_callback_)195 717 y(read_char)14 ! b Fu(will)k(in)o(v)o(ok)o(e)e(the)f Fm(lhandler)21 b ! Fu(function)c(sa)o(v)o(ed)e(b)o(y)h Ft(rl_callback_handler_)195 ! 772 y(install)g Fu(to)h(pro)q(cess)g(the)g(line.)27 b ! Ft(EOF)17 b Fu(is)h(indicated)g(b)o(y)f(calling)i Fm(lhandler)j ! Fu(with)c(a)f Ft(NULL)195 827 y Fu(line.)1650 923 y(F)l(unction)-1749 ! b Fi(void)20 b Fh(rl)p 241 923 V 21 w(callbac)n(k)p 458 ! 923 V 23 w(handler)p 670 923 V 21 w(remo)n(v)n(e)i Fg(\(\))195 ! 977 y Fu(Restore)15 b(the)g(terminal)g(to)g(its)g(initial)i(state)d ! (and)h(remo)o(v)o(e)f(the)h(line)h(handler.)21 b(This)16 ! b(ma)o(y)195 1032 y(b)q(e)g(called)h(from)d(within)j(a)d(callbac)o(k)j ! (as)d(w)o(ell)j(as)d(indep)q(enden)o(tly)m(.)75 1148 ! y Fl(2.4.10)29 b(An)21 b(Example)137 1246 y Fu(Here)f(is)g(a)f ! (function)i(whic)o(h)f(c)o(hanges)f(lo)o(w)o(ercase)h(c)o(haracters)e ! (to)h(their)h(upp)q(ercase)h(equiv)m(alen)o(ts,)75 1301 ! y(and)e(upp)q(ercase)i(c)o(haracters)d(to)h(lo)o(w)o(ercase.)31 ! b(If)20 b(this)f(function)h(w)o(as)f(b)q(ound)h(to)f(`)p ! Ft(M-c)p Fu(',)f(then)i(t)o(yping)75 1356 y(`)p Ft(M-c)p Fu(')12 b(w)o(ould)h(c)o(hange)h(the)f(case)g(of)g(the)g(c)o(haracter)g (under)g(p)q(oin)o(t.)20 b(T)o(yping)14 b(`)p Ft(M-1)g(0)h(M-c)p ! Fu(')d(w)o(ould)i(c)o(hange)75 1410 y(the)h(case)g(of)g(the)h(follo)o (wing)f(10)g(c)o(haracters,)f(lea)o(ving)i(the)f(cursor)g(on)g(the)h ! (last)f(c)o(haracter)f(c)o(hanged.)195 1477 y Ft(/*)24 b(Invert)f(the)g(case)g(of)h(the)f(COUNT)h(following)e(characters.)h ! (*/)195 1528 y(int)195 1580 y(invert_case_line)f(\(count,)h(key\))314 ! 1632 y(int)h(count,)f(key;)195 1684 y({)243 1736 y(register)f(int)i ! (start,)f(end,)g(i;)243 1840 y(start)g(=)h(rl_point;)243 ! 1944 y(if)f(\(rl_point)g(>=)h(rl_end\))290 1995 y(return)f(\(0\);)243 ! 2099 y(if)g(\(count)g(<)h(0\))290 2151 y({)338 2203 y(direction)f(=)h ! (-1;)338 2255 y(count)f(=)h(-count;)290 2307 y(})243 ! 2359 y(else)290 2411 y(direction)f(=)h(1;)243 2514 y(/*)f(Find)h(the)f ! (end)h(of)f(the)h(range)f(to)g(modify.)g(*/)243 2566 ! y(end)g(=)h(start)f(+)h(\(count)f(*)h(direction\);)243 ! 2670 y(/*)f(Force)g(it)h(to)g(be)f(within)g(range.)g(*/)p ! eop ! %%Page: 31 33 ! 31 32 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)844 b(31)243 183 y Ft(if)23 b(\(end)h(>)f(rl_end\))290 ! 235 y(end)h(=)g(rl_end;)243 287 y(else)f(if)h(\(end)f(<)h(0\))290 ! 339 y(end)g(=)g(0;)243 443 y(if)f(\(start)g(==)h(end\))290 ! 495 y(return)f(\(0\);)243 598 y(if)g(\(start)g(>)h(end\))290 ! 650 y({)338 702 y(int)g(temp)f(=)h(start;)338 754 y(start)f(=)h(end;) ! 338 806 y(end)g(=)f(temp;)290 858 y(})243 962 y(/*)g(Tell)h(readline)e ! (that)i(we)f(are)h(modifying)e(the)i(line,)f(so)h(it)f(will)h(save)314 ! 1013 y(the)g(undo)f(information.)f(*/)243 1065 y(rl_modifying)g ! (\(start,)h(end\);)243 1169 y(for)g(\(i)h(=)f(start;)h(i)f(!=)h(end;)f ! (i++\))290 1221 y({)338 1273 y(if)h(\(uppercase_p)e ! (\(rl_line_buffer[i]\)\))386 1325 y(rl_line_buffer[i])f(=)j(to_lower)f ! (\(rl_line_buffer[i]\);)338 1377 y(else)g(if)h(\(lowercase_p)e ! (\(rl_line_buffer[i]\)\))386 1429 y(rl_line_buffer[i])f(=)j(to_upper)f ! (\(rl_line_buffer[i]\);)290 1480 y(})243 1532 y(/*)g(Move)h(point)f(to) ! g(on)h(top)f(of)h(the)f(last)h(character)e(changed.)h(*/)243 ! 1584 y(rl_point)f(=)i(\(direction)f(==)g(1\))h(?)g(end)f(-)h(1)g(:)f ! (start;)243 1636 y(return)g(\(0\);)195 1688 y(})75 1835 ! y Fs(2.5)33 b(Readline)23 b(Signal)h(Handling)137 1938 ! y Fu(Signals)e(are)f(async)o(hronous)f(ev)o(en)o(ts)h(sen)o(t)f(to)h(a) ! f(pro)q(cess)h(b)o(y)g(the)g(Unix)h(k)o(ernel,)g(sometimes)f(on)75 ! 1993 y(b)q(ehalf)g(of)e(another)h(pro)q(cess.)34 b(They)20 ! b(are)g(in)o(tended)h(to)e(indicate)j(exceptional)f(ev)o(en)o(ts,)f ! (lik)o(e)h(a)f(user)75 2048 y(pressing)c(the)f(in)o(terrupt)g(k)o(ey)g ! (on)g(his)h(terminal,)f(or)g(a)f(net)o(w)o(ork)g(connection)i(b)q(eing) ! g(brok)o(en.)k(There)15 b(is)75 2102 y(a)e(class)g(of)g(signals)h(that) ! f(can)g(b)q(e)h(sen)o(t)f(to)f(the)i(pro)q(cess)f(curren)o(tly)h ! (reading)f(input)i(from)d(the)h(k)o(eyb)q(oard.)75 2157 ! y(Since)i(Readline)g(c)o(hanges)f(the)f(terminal)h(attributes)f(when)h (it)g(is)g(called,)h(it)e(needs)h(to)f(p)q(erform)g(sp)q(ecial)75 ! 2212 y(pro)q(cessing)22 b(when)f(a)g(signal)h(is)g(receiv)o(ed)g(to)e ! (restore)g(the)i(terminal)f(to)g(a)g(sane)g(state,)g(or)f(pro)o(vide)75 ! 2267 y(application)d(writers)e(with)g(functions)h(to)f(do)g(so)g(man)o ! (ually)l(.)137 2341 y(Readline)23 b(con)o(tains)d(an)g(in)o(ternal)h ! (signal)g(handler)g(that)f(is)h(installed)h(for)d(a)h(n)o(um)o(b)q(er)g ! (of)g(signals)75 2396 y(\()p Ft(SIGINT)p Fu(,)h Ft(SIGQUIT)p ! Fu(,)g Ft(SIGTERM)p Fu(,)g Ft(SIGALRM)p Fu(,)g Ft(SIGTSTP)p ! Fu(,)g Ft(SIGTTIN)p Fu(,)h(and)f Ft(SIGTTOU)p Fu(\).)36 ! b(When)21 b(one)g(of)75 2451 y(these)16 b(signals)h(is)f(receiv)o(ed,)h ! (the)f(signal)h(handler)f(will)i(reset)e(the)g(terminal)g(attributes)g ! (to)f(those)h(that)75 2506 y(w)o(ere)22 b(in)h(e\013ect)f(b)q(efore)g ! Ft(readline)14 b(\(\))22 b Fu(w)o(as)f(called,)k(reset)d(the)g(signal)h ! (handling)h(to)d(what)g(it)i(w)o(as)75 2560 y(b)q(efore)e ! Ft(readline)14 b(\(\))20 b Fu(w)o(as)f(called,)k(and)e(resend)g(the)f ! (signal)i(to)d(the)i(calling)h(application.)37 b(If)21 ! b(and)75 2615 y(when)15 b(the)f(calling)i(application's)g(signal)f ! (handler)g(returns,)f(Readline)j(will)e(reinitialize)j(the)c(terminal) ! 75 2670 y(and)21 b(con)o(tin)o(ue)h(to)e(accept)h(input.)39 ! b(When)21 b(a)g Ft(SIGINT)f Fu(is)h(receiv)o(ed,)j(the)d(Readline)i ! (signal)f(handler)p eop ! %%Page: 32 34 ! 32 33 bop 75 -58 a Fu(32)1299 b(GNU)15 b(Readline)i(Library)75 ! 183 y(p)q(erforms)h(some)f(additional)j(w)o(ork,)d(whic)o(h)i(will)h ! (cause)e(an)o(y)g(partially-en)o(tered)h(line)h(to)d(b)q(e)i(ab)q ! (orted)75 238 y(\(see)c(the)g(description)i(of)e Ft(rl_free_line_state) ! e(\(\))p Fu(\).)137 307 y(There)i(is)h(an)f(additional)h(Readline)h ! (signal)f(handler,)g(for)e Ft(SIGWINCH)p Fu(,)g(whic)o(h)h(the)g(k)o ! (ernel)h(sends)g(to)75 362 y(a)i(pro)q(cess)h(whenev)o(er)h(the)e ! (terminal's)h(size)h(c)o(hanges)f(\(for)f(example,)i(if)f(a)f(user)h ! (resizes)h(an)e Ft(xterm)p Fu(\).)75 417 y(The)k(Readline)h ! Ft(SIGWINCH)d Fu(handler)j(up)q(dates)e(Readline's)i(in)o(ternal)g ! (screen)e(size)i(state,)e(and)h(then)75 472 y(calls)c(an)o(y)f ! Ft(SIGWINCH)e Fu(signal)j(handler)g(the)f(calling)i(application)f(has)f ! (installed.)27 b(Readline)19 b(calls)f(the)75 527 y(application's)h ! Ft(SIGWINCH)d Fu(signal)j(handler)f(without)g(resetting)g(the)f ! (terminal)i(to)e(its)g(original)i(state.)75 581 y(If)d(the)g ! (application's)h(signal)g(handler)g(do)q(es)g(more)e(than)h(up)q(date)h ! (its)f(idea)h(of)e(the)h(terminal)h(size)g(and)75 636 ! y(return)e(\(for)f(example,)h(a)g Ft(longjmp)f Fu(bac)o(k)g(to)h(a)f ! (main)h(pro)q(cessing)h(lo)q(op\),)f(it)g Fm(m)o(ust)g ! Fu(call)i Ft(rl_cleanup_)75 691 y(after_signal)d(\(\))g ! Fu(\(describ)q(ed)j(b)q(elo)o(w\),)e(to)g(restore)f(the)i(terminal)g ! (state.)137 760 y(Readline)h(pro)o(vides)e(t)o(w)o(o)e(v)m(ariables)i (that)f(allo)o(w)g(application)i(writers)e(to)g(con)o(trol)g(whether)h ! (or)e(not)75 815 y(it)k(will)h(catc)o(h)e(certain)h(signals)h(and)f (act)f(on)g(them)h(when)g(they)f(are)h(receiv)o(ed.)25 ! b(It)16 b(is)i(imp)q(ortan)o(t)e(that)75 870 y(applications)j(c)o ! (hange)e(the)g(v)m(alues)i(of)d(these)i(v)m(ariables)g(only)g(when)g ! (calling)g Ft(readline)d(\(\))p Fu(,)h(not)h(in)h(a)75 ! 925 y(signal)e(handler,)g(so)f(Readline's)i(in)o(ternal)f(signal)g ! (state)e(is)i(not)f(corrupted.)1661 1021 y(V)l(ariable)-1749 ! b Fi(int)20 b Fh(rl)p 215 1021 18 3 v 21 w(catc)n(h)p ! 366 1021 V 22 w(signals)195 1076 y Fu(If)h(this)h(v)m(ariable)g(is)g ! (non-zero,)g(Readline)i(will)e(install)h(signal)f(handlers)g(for)e ! Ft(SIGINT)p Fu(,)195 1131 y Ft(SIGQUIT)p Fu(,)14 b Ft(SIGTERM)p ! Fu(,)g Ft(SIGALRM)p Fu(,)f Ft(SIGTSTP)p Fu(,)h Ft(SIGTTIN)p ! Fu(,)g(and)h Ft(SIGTTOU)p Fu(.)195 1200 y(The)g(default)h(v)m(alue)h ! (of)d Ft(rl_catch_signals)f Fu(is)j(1.)1661 1297 y(V)l(ariable)-1749 ! b Fi(int)20 b Fh(rl)p 215 1297 V 21 w(catc)n(h)p 366 ! 1297 V 22 w(sigwinc)n(h)195 1351 y Fu(If)15 b(this)h(v)m(ariable)g(is)g ! (non-zero,)f(Readline)i(will)g(install)f(a)f(signal)h(handler)g(for)e ! Ft(SIGWINCH)p Fu(.)195 1421 y(The)h(default)h(v)m(alue)h(of)d ! Ft(rl_catch_sigwinch)f Fu(is)j(1.)137 1517 y(If)g(an)f(application)j ! (do)q(es)d(not)g(wish)i(to)d(ha)o(v)o(e)h(Readline)j(catc)o(h)e(an)o(y) ! f(signals,)h(or)f(to)f(handle)j(signals)75 1572 y(other)i(than)g(those) ! g(Readline)j(catc)o(hes)d(\()p Ft(SIGHUP)p Fu(,)g(for)g(example\),)h ! (Readline)i(pro)o(vides)d(con)o(v)o(enience)75 1627 y(functions)d(to)f (do)g(the)g(necessary)g(terminal)h(and)g(in)o(ternal)g(state)e(clean)o ! (up)i(up)q(on)g(receipt)g(of)f(a)g(signal.)1650 1723 ! y(F)l(unction)-1749 b Fi(void)20 b Fh(rl)p 241 1723 V ! 21 w(clean)n(up)p 450 1723 V 22 w(after)p 590 1723 V ! 20 w(signal)j Fg(\()p Ft(void)p Fg(\))195 1778 y Fu(This)12 ! b(function)h(will)g(reset)f(the)g(state)f(of)g(the)h(terminal)h(to)e ! (what)g(it)h(w)o(as)f(b)q(efore)h Ft(readline)195 1833 ! y(\(\))f Fu(w)o(as)f(called,)j(and)e(remo)o(v)o(e)g(the)g(Readline)i ! (signal)f(handlers)g(for)e(all)i(signals,)h(dep)q(ending)195 ! 1888 y(on)i(the)g(v)m(alues)i(of)e Ft(rl_catch_signals)d ! Fu(and)k Ft(rl_catch_sigwinch)p Fu(.)1650 1984 y(F)l(unction)-1749 ! b Fi(void)20 b Fh(rl)p 241 1984 V 21 w(free)p 356 1984 ! V 20 w(line)p 464 1984 V 23 w(state)j Fg(\()p Ft(void)p ! Fg(\))195 2039 y Fu(This)e(will)h(free)e(an)o(y)g(partial)g(state)g ! (asso)q(ciated)g(with)g(the)h(curren)o(t)f(input)h(line)h(\(undo)195 ! 2094 y(information,)d(an)o(y)f(partial)h(history)f(en)o(try)l(,)h(an)o ! (y)f(partially-en)o(tered)i(k)o(eyb)q(oard)e(macro,)195 ! 2148 y(and)c(an)o(y)f(partially-en)o(tered)i(n)o(umeric)f(argumen)o ! (t\).)k(This)c(should)h(b)q(e)f(called)h(b)q(efore)e ! Ft(rl_)195 2203 y(cleanup_after_signal)f(\(\))p Fu(.)23 ! b(The)16 b(Readline)j(signal)e(handler)g(for)f Ft(SIGINT)f ! Fu(calls)j(this)195 2258 y(to)d(ab)q(ort)f(the)h(curren)o(t)h(input)g ! (line.)1650 2354 y(F)l(unction)-1749 b Fi(void)20 b Fh(rl)p ! 241 2354 V 21 w(reset)p 383 2354 V 20 w(after)p 521 2354 ! V 21 w(signal)j Fg(\()p Ft(void)p Fg(\))195 2409 y Fu(This)d(will)h ! (reinitialize)i(the)c(terminal)i(and)e(reinstall)i(an)o(y)e(Readline)j ! (signal)e(handlers,)195 2464 y(dep)q(ending)d(on)f(the)f(v)m(alues)h ! (of)f Ft(rl_catch_signals)e Fu(and)i Ft(rl_catch_sigwinch)p ! Fu(.)137 2560 y(If)20 b(an)g(application)h(do)q(es)f(not)g(wish)g ! (Readline)i(to)d(catc)o(h)g Ft(SIGWINCH)p Fu(,)h(it)g(ma)o(y)f(call)h ! Ft(rl_resize_)75 2615 y(terminal)14 b(\(\))i Fu(to)g(force)g(Readline)j ! (to)d(up)q(date)h(its)g(idea)g(of)f(the)g(terminal)i(size)f(when)g(a)f ! Ft(SIGWINCH)f Fu(is)75 2670 y(receiv)o(ed.)p eop ! %%Page: 33 35 ! 33 34 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)844 b(33)1650 183 y(F)l(unction)-1749 b Fi(void)20 ! b Fh(rl)p 241 183 18 3 v 21 w(resize)p 401 183 V 22 w(terminal)j ! Fg(\()p Ft(void)p Fg(\))195 238 y Fu(Up)q(date)16 b(Readline's)h(in)o ! (ternal)f(screen)f(size.)137 319 y(The)h(follo)o(wing)g(functions)g ! (install)g(and)g(remo)o(v)o(e)e(Readline's)j(signal)f(handlers.)1650 ! 399 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p 215 399 ! V 21 w(set)p 307 399 V 20 w(signals)j Fg(\()p Ft(void)p ! Fg(\))195 454 y Fu(Install)28 b(Readline's)g(signal)f(handler)h(for)e ! Ft(SIGINT)p Fu(,)i Ft(SIGQUIT)p Fu(,)f Ft(SIGTERM)p Fu(,)h ! Ft(SIGALRM)p Fu(,)195 509 y Ft(SIGTSTP)p Fu(,)19 b Ft(SIGTTIN)p ! Fu(,)h Ft(SIGTTOU)p Fu(,)f(and)h Ft(SIGWINCH)p Fu(,)g(dep)q(ending)i ! (on)d(the)h(v)m(alues)h(of)e Ft(rl_)195 564 y(catch_signals)13 ! b Fu(and)j Ft(rl_catch_sigwinch)p Fu(.)1650 644 y(F)l(unction)-1749 ! b Fi(int)20 b Fh(rl)p 215 644 V 21 w(clear)p 354 644 ! V 21 w(signals)j Fg(\()p Ft(void)p Fg(\))195 699 y Fu(Remo)o(v)o(e)15 ! b(all)h(of)f(the)g(Readline)j(signal)e(handlers)g(installed)h(b)o(y)e ! Ft(rl_set_signals)e(\(\))p Fu(.)75 816 y Fs(2.6)33 b(Custom)21 ! b(Completers)137 908 y Fu(T)o(ypically)l(,)e(a)d(program)f(that)h (reads)h(commands)f(from)g(the)h(user)f(has)h(a)f(w)o(a)o(y)g(of)g ! (disam)o(biguating)75 963 y(commands)i(and)f(data.)27 b(If)18 b(y)o(our)f(program)g(is)h(one)g(of)f(these,)i(then)f(it)g(can) ! f(pro)o(vide)i(completion)g(for)75 1018 y(commands,)14 b(data,)g(or)g(b)q(oth.)20 b(The)15 b(follo)o(wing)g(sections)g (describ)q(e)h(ho)o(w)e(y)o(our)g(program)g(and)h(Readline)75 ! 1073 y(co)q(op)q(erate)g(to)g(pro)o(vide)g(this)h(service.)75 ! 1173 y Fl(2.6.1)30 b(Ho)n(w)21 b(Completing)f(W)-5 b(orks)137 ! 1266 y Fu(In)18 b(order)f(to)f(complete)i(some)f(text,)g(the)g(full)i (list)e(of)g(p)q(ossible)i(completions)f(m)o(ust)f(b)q(e)h(a)o(v)m ! (ailable.)75 1321 y(That)e(is,)i(it)f(is)h(not)f(p)q(ossible)h(to)f (accurately)g(expand)h(a)e(partial)i(w)o(ord)e(without)h(kno)o(wing)g ! (all)h(of)f(the)75 1375 y(p)q(ossible)i(w)o(ords)e(whic)o(h)h(mak)o(e)f ! (sense)h(in)h(that)d(con)o(text.)26 b(The)18 b(Readline)i(library)e ! (pro)o(vides)g(the)g(user)75 1430 y(in)o(terface)f(to)f(completion,)i (and)e(t)o(w)o(o)g(of)g(the)h(most)f(common)g(completion)i(functions:) ! 23 b(\014lename)18 b(and)75 1485 y(username.)h(F)l(or)10 b(completing)i(other)e(t)o(yp)q(es)h(of)f(text,)h(y)o(ou)g(m)o(ust)f (write)h(y)o(our)f(o)o(wn)h(completion)g(function.)75 ! 1540 y(This)16 b(section)g(describ)q(es)g(exactly)g(what)f(suc)o(h)g (functions)h(m)o(ust)f(do,)f(and)i(pro)o(vides)f(an)h(example.)137 ! 1603 y(There)g(are)f(three)g(ma)s(jor)f(functions)i(used)f(to)g(p)q ! (erform)g(completion:)100 1667 y(1.)29 b(The)21 b(user-in)o(terface)g ! (function)g Ft(rl_complete)14 b(\(\))p Fu(.)35 b(This)21 ! b(function)g(is)g(called)h(with)f(the)f(same)165 1721 ! y(argumen)o(ts)c(as)g(other)h(Readline)i(functions)f(in)o(tended)g(for) ! e(in)o(teractiv)o(e)i(use:)23 b Fm(coun)o(t)18 b Fu(and)f ! Fm(in)o(v)o(ok-)165 1776 y(ing)p 228 1776 14 2 v 17 w(k)o(ey)p ! Fu(.)34 b(It)20 b(isolates)g(the)g(w)o(ord)f(to)h(b)q(e)g(completed)h ! (and)f(calls)h Ft(completion_matches)13 b(\(\))20 b Fu(to)165 ! 1831 y(generate)f(a)f(list)i(of)e(p)q(ossible)j(completions.)32 ! b(It)18 b(then)i(either)f(lists)h(the)f(p)q(ossible)h(completions,)165 ! 1886 y(inserts)g(the)f(p)q(ossible)j(completions,)f(or)e(actually)h(p)q ! (erforms)f(the)h(completion,)h(dep)q(ending)h(on)165 ! 1940 y(whic)o(h)16 b(b)q(eha)o(vior)g(is)f(desired.)100 ! 2004 y(2.)29 b(The)11 b(in)o(ternal)g(function)g Ft(completion_matches) ! i(\(\))d Fu(uses)h(y)o(our)e Fm(generator)k Fu(function)e(to)f ! (generate)165 2059 y(the)16 b(list)h(of)f(p)q(ossible)i(matc)o(hes,)d ! (and)h(then)h(returns)f(the)g(arra)o(y)f(of)g(these)i(matc)o(hes.)22 ! b(Y)l(ou)16 b(should)165 2113 y(place)g(the)f(address)h(of)e(y)o(our)h ! (generator)f(function)i(in)g Ft(rl_completion_entry_function)p ! Fu(.)100 2177 y(3.)29 b(The)19 b(generator)e(function)j(is)f(called)h ! (rep)q(eatedly)f(from)f Ft(completion_matches)13 b(\(\))p ! Fu(,)18 b(returning)165 2232 y(a)e(string)g(eac)o(h)h(time.)24 ! b(The)17 b(argumen)o(ts)e(to)h(the)g(generator)g(function)h(are)f ! Fm(text)h Fu(and)g Fm(state)p Fu(.)22 b Fm(text)165 2286 ! y Fu(is)17 b(the)f(partial)g(w)o(ord)f(to)h(b)q(e)h(completed.)23 ! b Fm(state)18 b Fu(is)e(zero)g(the)g(\014rst)g(time)g(the)g(function)h ! (is)g(called,)165 2341 y(allo)o(wing)f(the)e(generator)g(to)g(p)q ! (erform)h(an)o(y)f(necessary)h(initialization,)j(and)d(a)f(p)q(ositiv)o ! (e)i(non-zero)165 2396 y(in)o(teger)i(for)f(eac)o(h)g(subsequen)o(t)h ! (call.)28 b(When)18 b(the)g(generator)f(function)h(returns)f ! Ft(\(char)e(*\)NULL)165 2451 y Fu(this)h(signals)h Ft ! (completion_matches)c(\(\))i Fu(that)g(there)h(are)g(no)g(more)f(p)q ! (ossibilitie)q(s)j(left.)23 b(Usually)165 2506 y(the)c(generator)g ! (function)h(computes)g(the)f(list)h(of)f(p)q(ossible)i(completions)g ! (when)e Fm(state)j Fu(is)d(zero,)165 2560 y(and)13 b(returns)g(them)f ! (one)h(at)f(a)h(time)g(on)g(subsequen)o(t)g(calls.)20 ! b(Eac)o(h)13 b(string)f(the)h(generator)f(function)165 ! 2615 y(returns)k(as)f(a)h(matc)o(h)f(m)o(ust)h(b)q(e)g(allo)q(cated)h ! (with)g Ft(malloc\(\))p Fu(;)d(Readline)19 b(frees)d(the)g(strings)f ! (when)165 2670 y(it)g(has)h(\014nished)g(with)g(them.)p ! eop ! %%Page: 34 36 ! 34 35 bop 75 -58 a Fu(34)1299 b(GNU)15 b(Readline)i(Library)1650 ! 183 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p 215 183 ! 18 3 v 21 w(complete)j Fg(\()p Ft(int)14 b(ignore,)g(int)h ! (invoking_key)p Fg(\))195 238 y Fu(Complete)20 b(the)g(w)o(ord)f(at)g ! (or)g(b)q(efore)h(p)q(oin)o(t.)34 b(Y)l(ou)20 b(ha)o(v)o(e)f(supplied)j ! (the)e(function)h(that)195 293 y(do)q(es)15 b(the)g(initial)h(simple)h ! (matc)o(hing)d(selection)i(algorithm)f(\(see)f Ft(completion_matches) ! 195 348 y(\(\))p Fu(\).)19 b(The)d(default)f(is)h(to)f(do)g(\014lename) ! h(completion.)1661 448 y(V)l(ariable)-1749 b Fi(Function)20 ! b(*)g Fh(rl)p 391 448 V 21 w(completion)p 686 448 V 21 ! w(en)n(try)p 839 448 V 21 w(function)195 503 y Fu(This)c(is)f(a)g(p)q ! (oin)o(ter)g(to)g(the)g(generator)f(function)i(for)e ! Ft(completion_matches)f(\(\))p Fu(.)20 b(If)15 b(the)195 ! 558 y(v)m(alue)21 b(of)e Ft(rl_completion_entry_functio)o(n)e ! Fu(is)j Ft(\(Function)14 b(*\)NULL)19 b Fu(then)h(the)f(de-)195 ! 613 y(fault)11 b(\014lename)h(generator)d(function,)j ! Ft(filename_completion_function)g(\(\))p Fu(,)f(is)g(used.)75 ! 734 y Fl(2.6.2)30 b(Completion)20 b(F)-5 b(unctions)137 ! 834 y Fu(Here)16 b(is)f(the)h(complete)g(list)g(of)e(callable)k ! (completion)e(functions)g(presen)o(t)f(in)h(Readline.)1650 ! 935 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p 215 935 ! V 21 w(complete)p 460 935 V 21 w(in)n(ternal)k Fg(\()p ! Ft(int)15 b(what_to_do)p Fg(\))195 990 y Fu(Complete)k(the)f(w)o(ord)g ! (at)g(or)g(b)q(efore)g(p)q(oin)o(t.)30 b Fm(what)p 1105 ! 990 14 2 v 16 w(to)p 1162 990 V 16 w(do)21 b Fu(sa)o(ys)c(what)h(to)g ! (do)g(with)h(the)195 1045 y(completion.)33 b(A)19 b(v)m(alue)h(of)f(`)p ! Ft(?)p Fu(')f(means)h(list)h(the)f(p)q(ossible)i(completions.)33 ! b(`)p Ft(TAB)p Fu(')18 b(means)195 1099 y(do)g(standard)g(completion.) ! 30 b(`)p Ft(*)p Fu(')18 b(means)g(insert)g(all)i(of)d(the)i(p)q ! (ossible)h(completions.)30 b(`)p Ft(!)p Fu(')195 1154 ! y(means)17 b(to)f(displa)o(y)i(all)g(of)e(the)h(p)q(ossible)i ! (completions,)f(if)f(there)g(is)g(more)g(than)f(one,)h(as)195 ! 1209 y(w)o(ell)f(as)f(p)q(erforming)h(partial)f(completion.)1650 ! 1310 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p 215 1310 ! 18 3 v 21 w(complete)j Fg(\()p Ft(int)14 b(ignore,)g(int)h ! (invoking_key)p Fg(\))195 1365 y Fu(Complete)20 b(the)g(w)o(ord)f(at)g ! (or)g(b)q(efore)h(p)q(oin)o(t.)34 b(Y)l(ou)20 b(ha)o(v)o(e)f(supplied)j ! (the)e(function)h(that)195 1419 y(do)q(es)15 b(the)g(initial)h(simple)h ! (matc)o(hing)d(selection)i(algorithm)f(\(see)f Ft(completion_matches) ! 195 1474 y(\(\))h Fu(and)h Ft(rl_completion_entry_functi)o(on)p ! Fu(\).)i(The)e(default)g(is)g(to)f(do)g(\014lename)i(com-)195 ! 1529 y(pletion.)k(This)15 b(calls)g Ft(rl_complete_internal)e(\(\))h ! Fu(with)h(an)f(argumen)o(t)f(dep)q(ending)k(on)195 1584 ! y Fm(in)o(v)o(oking)p 364 1584 14 2 v 17 w(k)o(ey)p Fu(.)1650 ! 1685 y(F)l(unction)-1749 b Fi(int)19 b Fh(rl)p 214 1685 ! 18 3 v 21 w(p)r(ossible)p 432 1685 V 20 w(completions)k ! Fg(\()p Ft(int)15 b(count,)f(int)h(invoking_key)p Fg(\)\))195 ! 1739 y Fu(List)k(the)f(p)q(ossible)i(completions.)29 ! b(See)19 b(description)h(of)d Ft(rl_complete)d(\(\))p ! Fu(.)28 b(This)19 b(calls)195 1794 y Ft(rl_complete_internal)12 ! b(\(\))j Fu(with)h(an)f(argumen)o(t)f(of)h(`)p Ft(?)p ! Fu('.)1650 1895 y(F)l(unction)-1749 b Fi(int)20 b Fh(rl)p ! 215 1895 V 21 w(insert)p 378 1895 V 21 w(completions)j ! Fg(\()p Ft(int)14 b(count,)g(int)h(invoking_key)p Fg(\)\))195 ! 1950 y Fu(Insert)24 b(the)h(list)f(of)g(p)q(ossible)i(completions)f(in) ! o(to)f(the)g(line,)k(deleting)e(the)e(partially-)195 ! 2004 y(completed)16 b(w)o(ord.)j(See)c(description)i(of)d ! Ft(rl_complete)g(\(\))p Fu(.)19 b(This)d(calls)g Ft(rl_complete_)195 ! 2059 y(internal)e(\(\))h Fu(with)g(an)h(argumen)o(t)e(of)h(`)p ! Ft(*)p Fu('.)1650 2160 y(F)l(unction)-1749 b Fi(char)20 ! b(**)f Fh(completion)p 547 2160 V 21 w(matc)n(hes)j Fg(\()p ! Ft(char)15 b(*text,)f(CPFunction)283 2215 y(*entry_func)p ! Fg(\))195 2270 y Fu(Returns)f(an)f(arra)o(y)f(of)h Ft(\(char)j(*\))d ! Fu(whic)o(h)h(is)g(a)f(list)h(of)f(completions)i(for)e ! Fm(text)p Fu(.)18 b(If)13 b(there)f(are)195 2324 y(no)17 ! b(completions,)g(returns)g Ft(\(char)d(**\)NULL)p Fu(.)23 ! b(The)17 b(\014rst)f(en)o(try)g(in)i(the)e(returned)h(arra)o(y)195 ! 2379 y(is)c(the)h(substitution)f(for)g Fm(text)p Fu(.)18 ! b(The)13 b(remaining)i(en)o(tries)e(are)f(the)i(p)q(ossible)g ! (completions.)195 2434 y(The)h(arra)o(y)f(is)i(terminated)g(with)f(a)g ! Ft(NULL)g Fu(p)q(oin)o(ter.)195 2506 y Fm(en)o(try)p ! 302 2506 14 2 v 16 w(func)g Fu(is)d(a)f(function)h(of)g(t)o(w)o(o)e ! (args,)h(and)g(returns)h(a)f Ft(\(char)k(*\))p Fu(.)j(The)12 ! b(\014rst)f(argumen)o(t)195 2560 y(is)j Fm(text)p Fu(.)19 ! b(The)14 b(second)g(is)g(a)f(state)f(argumen)o(t;)h(it)h(is)g(zero)f ! (on)h(the)f(\014rst)g(call,)i(and)f(non-zero)195 2615 ! y(on)g(subsequen)o(t)g(calls.)21 b Fm(en)o(try)p 714 ! 2615 V 16 w(func)c Fu(returns)d(a)f Ft(NULL)h Fu(p)q(oin)o(ter)g(to)f ! (the)h(caller)h(when)g(there)195 2670 y(are)g(no)g(more)g(matc)o(hes.)p ! eop ! %%Page: 35 37 ! 35 36 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)844 b(35)1650 183 y(F)l(unction)-1749 b Fi(char)20 ! b(*)f Fh(\014lename)p 455 183 18 3 v 20 w(completion)p ! 749 183 V 21 w(function)k Fg(\()p Ft(char)15 b(*text,)f(int)283 ! 238 y(state)p Fg(\))195 293 y Fu(A)19 b(generator)g(function)h(for)f ! (\014lename)h(completion)h(in)f(the)f(general)h(case.)33 ! b(Note)19 b(that)195 348 y(completion)e(in)f(Bash)f(is)h(a)f(little)i ! (di\013eren)o(t)f(b)q(ecause)g(of)f(all)h(the)g(pathnames)f(that)g(m)o ! (ust)195 402 y(b)q(e)i(follo)o(w)o(ed)g(when)g(lo)q(oking)h(up)f ! (completions)h(for)e(a)g(command.)24 b(The)17 b(Bash)g(source)f(is)195 ! 457 y(a)f(useful)h(reference)g(for)f(writing)g(custom)g(completion)h ! (functions.)1650 539 y(F)l(unction)-1749 b Fi(char)20 ! b(*)f Fh(username)p 487 539 V 19 w(completion)p 780 539 ! V 21 w(function)k Fg(\()p Ft(char)14 b(*text,)g(int)283 ! 594 y(state)p Fg(\))195 649 y Fu(A)k(completion)g(generator)f(for)g ! (usernames.)28 b Fm(text)18 b Fu(con)o(tains)f(a)h(partial)g(username)g ! (pre-)195 704 y(ceded)f(b)o(y)f(a)g(random)f(c)o(haracter)h(\(usually)h ! (`)p Ft(~)p Fu('\).)k(As)16 b(with)g(all)h(completion)g(generators,)195 ! 759 y Fm(state)g Fu(is)f(zero)f(on)g(the)g(\014rst)g(call)h(and)g ! (non-zero)f(for)g(subsequen)o(t)h(calls.)75 861 y Fl(2.6.3)30 ! b(Completion)20 b(V)-5 b(ariables)1661 972 y Fu(V)l(ariable)-1749 ! b Fi(Function)20 b(*)g Fh(rl)p 391 972 V 21 w(completion)p ! 686 972 V 21 w(en)n(try)p 839 972 V 21 w(function)195 ! 1026 y Fu(A)c(p)q(oin)o(ter)h(to)e(the)i(generator)e(function)i(for)e ! Ft(completion_matches)e(\(\))p Fu(.)22 b Ft(NULL)16 b ! Fu(means)195 1081 y(to)f(use)g Ft(filename_completion_functio)o(n)d ! (\(\))p Fu(,)j(the)g(default)h(\014lename)g(completer.)1661 ! 1163 y(V)l(ariable)-1749 b Fi(CPPFunction)21 b(*)e Fh(rl)p ! 469 1163 V 21 w(attempted)p 749 1163 V 20 w(completion)p ! 1043 1163 V 21 w(function)195 1218 y Fu(A)d(p)q(oin)o(ter)h(to)f(an)g ! (alternativ)o(e)h(function)g(to)f(create)g(matc)o(hes.)23 ! b(The)16 b(function)i(is)e(called)195 1273 y(with)f Fm(text)p ! Fu(,)g Fm(start)p Fu(,)e(and)i Fm(end)p Fu(.)21 b Fm(start)15 ! b Fu(and)g Fm(end)i Fu(are)e(indices)i(in)f Ft(rl_line_buffer)d ! Fu(sa)o(ying)195 1328 y(what)22 b(the)h(b)q(oundaries)h(of)e ! Fm(text)h Fu(are.)42 b(If)23 b(this)g(function)h(exists)f(and)f ! (returns)h Ft(NULL)p Fu(,)195 1383 y(or)c(if)h(this)g(v)m(ariable)h(is) ! f(set)g(to)e Ft(NULL)p Fu(,)i(then)g Ft(rl_complete)14 ! b(\(\))19 b Fu(will)i(call)g(the)f(v)m(alue)g(of)195 ! 1437 y Ft(rl_completion_entry_functi)o(on)14 b Fu(to)j(generate)g(matc) ! o(hes,)g(otherwise)g(the)g(arra)o(y)f(of)195 1492 y(strings)f(returned) ! h(will)h(b)q(e)e(used.)1661 1574 y(V)l(ariable)-1749 ! b Fi(CPFunction)21 b(*)e Fh(rl)p 443 1574 V 21 w(\014lename)p ! 672 1574 V 20 w(quoting)p 881 1574 V 21 w(function)195 ! 1629 y Fu(A)g(p)q(oin)o(ter)g(to)f(a)h(function)g(that)g(will)h(quote)f ! (a)f(\014lename)i(in)g(an)e(application-)j(sp)q(eci\014c)195 ! 1684 y(fashion.)33 b(This)20 b(is)g(called)h(if)f(\014lename)g ! (completion)h(is)f(b)q(eing)g(attempted)f(and)h(one)f(of)195 ! 1739 y(the)13 b(c)o(haracters)f(in)h Ft(rl_filename_quote_characte)o ! (rs)d Fu(app)q(ears)i(in)i(a)e(completed)i(\014le-)195 ! 1793 y(name.)29 b(The)18 b(function)h(is)g(called)h(with)e ! Fm(text)p Fu(,)g Fm(matc)o(h)p 1144 1793 14 2 v 16 w(t)o(yp)q(e)p ! Fu(,)h(and)f Fm(quote)p 1480 1793 V 16 w(p)q(oin)o(ter)p ! Fu(.)30 b(The)195 1848 y Fm(text)17 b Fu(is)h(the)f(\014lename)h(to)e ! (b)q(e)h(quoted.)25 b(The)17 b Fm(matc)o(h)p 1115 1848 ! V 16 w(t)o(yp)q(e)i Fu(is)f(either)f Ft(SINGLE_MATCH)p ! Fu(,)e(if)195 1903 y(there)j(is)g(only)h(one)f(completion)h(matc)o(h,)f ! (or)f Ft(MULT_MATCH)p Fu(.)27 b(Some)18 b(functions)g(use)h(this)195 ! 1958 y(to)13 b(decide)i(whether)f(or)g(not)f(to)g(insert)h(a)f(closing) ! i(quote)f(c)o(haracter.)k(The)c Fm(quote)p 1600 1958 ! V 16 w(p)q(oin)o(ter)195 2013 y Fu(is)20 b(a)g(p)q(oin)o(ter)g(to)f(an) ! o(y)g(op)q(ening)i(quote)e(c)o(haracter)g(the)h(user)g(t)o(yp)q(ed.)34 ! b(Some)19 b(functions)195 2067 y(c)o(ho)q(ose)c(to)g(reset)g(this)g(c)o ! (haracter.)1661 2150 y(V)l(ariable)-1749 b Fi(CPFunction)21 ! b(*)e Fh(rl)p 443 2150 18 3 v 21 w(\014lename)p 672 2150 ! V 20 w(dequoting)p 939 2150 V 21 w(function)195 2204 ! y Fu(A)14 b(p)q(oin)o(ter)g(to)e(a)i(function)g(that)f(will)i(remo)o(v) ! o(e)e(application-sp)q(eci\014c)k(quoting)d(c)o(haracters)195 ! 2259 y(from)21 b(a)g(\014lename)h(b)q(efore)f(completion)i(is)f ! (attempted,)g(so)f(those)g(c)o(haracters)f(do)h(not)195 ! 2314 y(in)o(terfere)e(with)f(matc)o(hing)h(the)f(text)g(against)g ! (names)g(in)h(the)f(\014lesystem.)30 b(It)19 b(is)f(called)195 ! 2369 y(with)g Fm(text)p Fu(,)g(the)g(text)g(of)g(the)g(w)o(ord)f(to)g ! (b)q(e)i(dequoted,)g(and)f Fm(quote)p 1381 2369 14 2 ! v 16 w(c)o(har)p Fu(,)g(whic)o(h)h(is)g(the)195 2424 ! y(quoting)e(c)o(haracter)f(that)g(delimits)i(the)f(\014lename)h ! (\(usually)f(`)p Ft(')p Fu(')f(or)g(`)p Ft(")p Fu('\).)23 ! b(If)17 b Fm(quote)p 1657 2424 V 16 w(c)o(har)195 2478 ! y Fu(is)f(zero,)e(the)i(\014lename)g(w)o(as)e(not)h(in)h(an)f(em)o(b)q ! (edded)i(string.)1661 2560 y(V)l(ariable)-1749 b Fi(Function)20 ! b(*)g Fh(rl)p 391 2560 18 3 v 21 w(c)n(har)p 519 2560 ! V 20 w(is)p 577 2560 V 22 w(quoted)p 770 2560 V 20 w(p)195 ! 2615 y Fu(A)c(p)q(oin)o(ter)g(to)f(a)h(function)g(to)g(call)g(that)g ! (determines)g(whether)g(or)g(not)f(a)g(sp)q(eci\014c)j(c)o(har-)195 ! 2670 y(acter)12 b(in)i(the)f(line)i(bu\013er)e(is)g(quoted,)g ! (according)h(to)e(whatev)o(er)g(quoting)h(mec)o(hanism)h(the)p ! eop ! %%Page: 36 38 ! 36 37 bop 75 -58 a Fu(36)1299 b(GNU)15 b(Readline)i(Library)195 ! 183 y(program)12 b(calling)j(readline)g(uses.)20 b(The)13 ! b(function)h(is)g(called)h(with)f(t)o(w)o(o)e(argumen)o(ts:)18 ! b Fm(text)p Fu(,)195 238 y(the)11 b(text)g(of)g(the)g(line,)i(and)f ! Fm(index)p Fu(,)g(the)g(index)g(of)f(the)g(c)o(haracter)g(in)h(the)f ! (line.)20 b(It)11 b(is)h(used)g(to)195 293 y(decide)20 ! b(whether)e(a)g(c)o(haracter)g(found)h(in)g Ft ! (rl_completer_word_break_)o(charact)o(ers)195 348 y Fu(should)d(b)q(e)g ! (used)g(to)e(break)i(w)o(ords)e(for)h(the)g(completer.)1661 ! 447 y(V)l(ariable)-1749 b Fi(int)20 b Fh(rl)p 215 447 ! 18 3 v 21 w(completion)p 510 447 V 21 w(query)p 673 447 ! V 21 w(items)195 502 y Fu(Up)d(to)e(this)i(man)o(y)f(items)h(will)h(b)q ! (e)f(displa)o(y)o(ed)g(in)g(resp)q(onse)g(to)f(a)g(p)q ! (ossible-completions)195 557 y(call.)26 b(After)16 b(that,)g(w)o(e)h ! (ask)f(the)h(user)g(if)g(she)g(is)h(sure)e(she)i(w)o(an)o(ts)d(to)h ! (see)h(them)g(all.)26 b(The)195 612 y(default)16 b(v)m(alue)g(is)g ! (100.)1661 712 y(V)l(ariable)-1749 b Fi(char)20 b(*)f ! Fh(rl)p 286 712 V 21 w(basic)p 430 712 V 21 w(w)n(ord)p ! 575 712 V 21 w(break)p 736 712 V 20 w(c)n(haracters)195 ! 766 y Fu(The)13 b(basic)h(list)f(of)g(c)o(haracters)f(that)g(signal)i ! (a)e(break)h(b)q(et)o(w)o(een)g(w)o(ords)f(for)g(the)h(completer)195 ! 821 y(routine.)20 b(The)c(default)g(v)m(alue)g(of)f(this)g(v)m(ariable) ! i(is)f(the)f(c)o(haracters)g(whic)o(h)h(break)f(w)o(ords)195 ! 876 y(for)g(completion)h(in)g(Bash,)f(i.e.,)g Ft(")g ! (\\t\\n\\"\\\\'`@$><=;|&{\(")p Fu(.)1661 976 y(V)l(ariable)-1749 ! b Fi(char)20 b(*)f Fh(rl)p 286 976 V 21 w(basic)p 430 ! 976 V 21 w(quote)p 590 976 V 21 w(c)n(haracters)195 1030 ! y Fu(List)d(of)f(quote)g(c)o(haracters)f(whic)o(h)i(can)f(cause)h(a)f ! (w)o(ord)f(break.)1661 1130 y(V)l(ariable)-1749 b Fi(char)20 ! b(*)f Fh(rl)p 286 1130 V 21 w(completer)p 555 1130 V ! 21 w(w)n(ord)p 700 1130 V 20 w(break)p 860 1130 V 20 ! w(c)n(haracters)195 1185 y Fu(The)j(list)g(of)f(c)o(haracters)g(that)g ! (signal)h(a)g(break)f(b)q(et)o(w)o(een)h(w)o(ords)f(for)g ! Ft(rl_complete_)195 1240 y(internal)14 b(\(\))p Fu(.)k(The)10 ! b(default)h(list)g(is)g(the)f(v)m(alue)h(of)f Ft ! (rl_basic_word_break_charac)o(ters)p Fu(.)p 1909 1244 ! 21 36 v 1661 1340 a(V)l(ariable)-1749 b Fi(char)20 b(*)f ! Fh(rl)p 286 1340 18 3 v 21 w(completer)p 555 1340 V 21 ! w(quote)p 715 1340 V 21 w(c)n(haracters)195 1394 y Fu(List)11 ! b(of)g(c)o(haracters)f(whic)o(h)h(can)g(b)q(e)h(used)f(to)g(quote)f(a)h ! (substring)g(of)f(the)h(line.)20 b(Completion)195 1449 ! y(o)q(ccurs)c(on)g(the)g(en)o(tire)g(substring,)g(and)g(within)h(the)e ! (substring)h Ft(rl_completer_word_)195 1504 y(break_characters)d ! Fu(are)h(treated)g(as)h(an)o(y)f(other)g(c)o(haracter,)g(unless)i(they) ! f(also)g(app)q(ear)195 1559 y(within)h(this)g(list.)1661 ! 1658 y(V)l(ariable)-1749 b Fi(char)20 b(*)f Fh(rl)p 286 ! 1658 V 21 w(\014lename)p 515 1658 V 20 w(quote)p 674 ! 1658 V 21 w(c)n(haracters)195 1713 y Fu(A)d(list)g(of)g(c)o(haracters)e ! (that)h(cause)h(a)g(\014lename)h(to)e(b)q(e)h(quoted)g(b)o(y)f(the)h ! (completer)g(when)195 1768 y(they)f(app)q(ear)h(in)g(a)f(completed)h ! (\014lename.)21 b(The)15 b(default)h(is)g(the)f(n)o(ull)i(string.)1661 ! 1868 y(V)l(ariable)-1749 b Fi(char)20 b(*)f Fh(rl)p 286 ! 1868 V 21 w(sp)r(ecial)p 473 1868 V 22 w(pre\014xes)195 ! 1923 y Fu(The)14 b(list)h(of)e(c)o(haracters)g(that)g(are)g(w)o(ord)g ! (break)h(c)o(haracters,)f(but)h(should)g(b)q(e)h(left)f(in)g ! Fm(text)195 1977 y Fu(when)19 b(it)g(is)g(passed)f(to)g(the)h ! (completion)g(function.)31 b(Programs)17 b(can)h(use)h(this)g(to)f ! (help)195 2032 y(determine)e(what)e(kind)i(of)e(completing)i(to)e(do.) ! 19 b(F)l(or)14 b(instance,)h(Bash)g(sets)f(this)i(v)m(ariable)195 ! 2087 y(to)f Ft(")p Fu($)p Ft(@")f Fu(so)h(that)f(it)i(can)f(complete)h ! (shell)h(v)m(ariables)f(and)g(hostnames.)1661 2187 y(V)l(ariable)-1749 ! b Fi(int)20 b Fh(rl)p 215 2187 V 21 w(completion)p 510 ! 2187 V 21 w(app)r(end)p 715 2187 V 19 w(c)n(haracter)195 ! 2241 y Fu(When)15 b(a)e(single)j(completion)f(alternativ)o(e)f(matc)o ! (hes)g(at)g(the)g(end)h(of)e(the)i(command)f(line,)195 ! 2296 y(this)20 b(c)o(haracter)e(is)i(app)q(ended)h(to)d(the)i(inserted) ! g(completion)g(text.)31 b(The)20 b(default)g(is)f(a)195 ! 2351 y(space)14 b(c)o(haracter)f(\(`)i('\).)j(Setting)c(this)h(to)e ! (the)h(n)o(ull)h(c)o(haracter)e(\(`)p Ft(\\0)p Fu('\))f(prev)o(en)o(ts) ! i(an)o(ything)195 2406 y(b)q(eing)24 b(app)q(ended)g(automatically)l(.) ! 42 b(This)23 b(can)g(b)q(e)g(c)o(hanged)f(in)i(custom)e(completion)195 ! 2461 y(functions)15 b(to)e(pro)o(vide)i(the)f(\\most)f(sensible)j(w)o ! (ord)d(separator)g(c)o(haracter")g(according)i(to)195 ! 2515 y(an)g(application-sp)q(eci\014)q(c)j(command)d(line)i(syn)o(tax)d ! (sp)q(eci\014cation.)1661 2615 y(V)l(ariable)-1749 b ! Fi(int)20 b Fh(rl)p 215 2615 V 21 w(ignore)p 391 2615 ! V 20 w(completion)p 685 2615 V 21 w(duplicates)195 2670 ! y Fu(If)15 b(non-zero,)h(then)f(disallo)o(w)h(duplicates)h(in)f(the)g ! (matc)o(hes.)j(Default)c(is)h(1.)p eop ! %%Page: 37 39 ! 37 38 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)844 b(37)1661 183 y(V)l(ariable)-1749 b Fi(int)20 ! b Fh(rl)p 215 183 18 3 v 21 w(\014lename)p 444 183 V ! 20 w(completion)p 738 183 V 21 w(desired)195 238 y Fu(Non-zero)15 ! b(means)g(that)g(the)g(results)h(of)f(the)g(matc)o(hes)g(are)f(to)h(b)q ! (e)h(treated)f(as)f(\014lenames.)195 293 y(This)e(is)h ! Fm(alw)o(a)o(ys)f Fu(zero)g(on)g(en)o(try)l(,)g(and)g(can)f(only)i(b)q ! (e)f(c)o(hanged)g(within)h(a)e(completion)i(en)o(try)195 ! 348 y(generator)f(function.)20 b(If)14 b(it)f(is)h(set)f(to)g(a)g ! (non-zero)g(v)m(alue,)i(directory)e(names)h(ha)o(v)o(e)f(a)g(slash)195 ! 402 y(app)q(ended)k(and)f(Readline)h(attempts)e(to)f(quote)i(completed) ! g(\014lenames)g(if)g(they)g(con)o(tain)195 457 y(an)o(y)f(em)o(b)q ! (edded)i(w)o(ord)d(break)h(c)o(haracters.)1661 541 y(V)l(ariable)-1749 ! b Fi(int)20 b Fh(rl)p 215 541 V 21 w(\014lename)p 444 ! 541 V 20 w(quoting)p 653 541 V 21 w(desired)195 596 y ! Fu(Non-zero)c(means)f(that)g(the)h(results)g(of)g(the)f(matc)o(hes)h ! (are)f(to)g(b)q(e)h(quoted)g(using)h(double)195 650 y(quotes)12 ! b(\(or)f(an)g(application-sp)q(eci)q(\014c)k(quoting)d(mec)o(hanism\))g ! (if)g(the)g(completed)h(\014lename)195 705 y(con)o(tains)f(an)o(y)g(c)o ! (haracters)g(in)h Ft(rl_filename_quote_chars)p Fu(.)j(This)c(is)h ! Fm(alw)o(a)o(ys)h Fu(non-zero)195 760 y(on)d(en)o(try)l(,)g(and)h(can)f ! (only)h(b)q(e)g(c)o(hanged)f(within)h(a)f(completion)i(en)o(try)d ! (generator)g(function.)195 815 y(The)16 b(quoting)h(is)g(e\013ected)f ! (via)h(a)e(call)j(to)d(the)i(function)g(p)q(oin)o(ted)g(to)e(b)o(y)i ! Ft(rl_filename_)195 870 y(quoting_function)p Fu(.)1661 ! 953 y(V)l(ariable)-1749 b Fi(int)20 b Fh(rl)p 215 953 ! V 21 w(inhibit)p 399 953 V 23 w(completion)195 1008 y ! Fu(If)15 b(this)f(v)m(ariable)i(is)f(non-zero,)f(completion)i(is)f ! (inhibit)p Ft(<)p Fu(ed.)22 b(The)14 b(completion)i(c)o(haracter)195 ! 1063 y(will)h(b)q(e)f(inserted)g(as)f(an)o(y)f(other)h(b)q(ound)h(to)f ! Ft(self-insert)p Fu(.)1661 1146 y(V)l(ariable)-1749 b ! Fi(Function)20 b(*)g Fh(rl)p 391 1146 V 21 w(ignore)p ! 567 1146 V 20 w(some)p 714 1146 V 19 w(completions)p ! 1030 1146 V 21 w(function)195 1201 y Fu(This)15 b(function,)g(if)f ! (de\014ned,)i(is)e(called)i(b)o(y)e(the)h(completer)f(when)h(real)g ! (\014lename)g(comple-)195 1256 y(tion)k(is)g(done,)g(after)f(all)i(the) ! f(matc)o(hing)f(names)h(ha)o(v)o(e)f(b)q(een)i(generated.)30 ! b(It)19 b(is)g(passed)195 1311 y(a)h Ft(NULL)f Fu(terminated)h(arra)o ! (y)f(of)g(matc)o(hes.)34 b(The)20 b(\014rst)g(elemen)o(t)h(\()p ! Ft(matches[0])p Fu(\))c(is)k(the)195 1366 y(maximal)e(substring)f ! (common)g(to)g(all)h(matc)o(hes.)29 b(This)19 b(function)g(can)f ! (re-arrange)g(the)195 1420 y(list)h(of)e(matc)o(hes)h(as)f(required,)i ! (but)f(eac)o(h)g(elemen)o(t)h(deleted)g(from)e(the)h(arra)o(y)f(m)o ! (ust)g(b)q(e)195 1475 y(freed.)1661 1559 y(V)l(ariable)-1749 ! b Fi(Function)20 b(*)g Fh(rl)p 391 1559 V 21 w(directory)p ! 639 1559 V 21 w(completion)p 934 1559 V 21 w(ho)r(ok)195 ! 1613 y Fu(This)13 b(function,)h(if)g(de\014ned,)g(is)f(allo)o(w)o(ed)h ! (to)e(mo)q(dify)h(the)g(directory)g(p)q(ortion)g(of)g(\014lenames)195 ! 1668 y(Readline)k(completes.)j(It)15 b(is)g(called)h(with)f(the)g ! (address)g(of)f(a)g(string)h(\(the)f(curren)o(t)h(direc-)195 ! 1723 y(tory)f(name\))g(as)h(an)f(argumen)o(t.)19 b(It)c(could)h(b)q(e)f ! (used)h(to)e(expand)h(sym)o(b)q(olic)h(links)g(or)e(shell)195 ! 1778 y(v)m(ariables)j(in)f(pathnames.)1661 1861 y(V)l(ariable)-1749 ! b Fi(VFunction)20 b(*)g Fh(rl)p 417 1861 V 21 w(completion)p ! 712 1861 V 21 w(displa)n(y)p 906 1861 V 22 w(matc)n(hes)p ! 1131 1861 V 20 w(ho)r(ok)195 1916 y Fu(If)g(non-zero,)g(then)f(this)h ! (is)g(the)f(address)h(of)f(a)g(function)h(to)f(call)h(when)g ! (completing)g(a)195 1971 y(w)o(ord)h(w)o(ould)h(normally)h(displa)o(y)g ! (the)f(list)h(of)e(p)q(ossible)j(matc)o(hes.)39 b(This)23 ! b(function)f(is)195 2026 y(called)d(in)f(lieu)h(of)e(Readline)j(displa) ! o(ying)f(the)e(list.)27 b(It)18 b(tak)o(es)e(three)i(argumen)o(ts:)23 ! b(\()p Ft(char)195 2081 y(**)p Fm(matc)o(hes)p Fu(,)g ! Ft(int)e Fm(n)o(um)p 623 2081 14 2 v 17 w(matc)o(hes)p ! Fu(,)h Ft(int)g Fm(max)p 1015 2081 V 16 w(length)p Fu(\))g(where)g ! Fm(matc)o(hes)i Fu(is)e(the)g(arra)o(y)195 2135 y(of)17 ! b(matc)o(hing)h(strings,)f Fm(n)o(um)p 702 2135 V 17 ! w(matc)o(hes)h Fu(is)g(the)g(n)o(um)o(b)q(er)g(of)f(strings)g(in)h ! (that)f(arra)o(y)l(,)g(and)195 2190 y Fm(max)p 283 2190 ! V 16 w(length)f Fu(is)h(the)e(length)i(of)e(the)h(longest)g(string)f ! (in)i(that)e(arra)o(y)l(.)20 b(Readline)e(pro)o(vides)195 ! 2245 y(a)d(con)o(v)o(enience)i(function,)g Ft(rl_display_match_list)p ! Fu(,)12 b(that)j(tak)o(es)g(care)g(of)h(doing)g(the)195 ! 2300 y(displa)o(y)k(to)f(Readline's)i(output)f(stream.)31 ! b(That)19 b(function)h(ma)o(y)f(b)q(e)h(called)h(from)e(this)195 ! 2355 y(ho)q(ok.)75 2458 y Fl(2.6.4)30 b(A)21 b(Short)f(Completion)g ! (Example)137 2552 y Fu(Here)11 b(is)f(a)g(small)h(application)h ! (demonstrating)e(the)g(use)h(of)e(the)i(GNU)f(Readline)i(library)l(.)19 ! b(It)11 b(is)f(called)75 2606 y Ft(fileman)p Fu(,)17 ! b(and)h(the)g(source)g(co)q(de)g(resides)h(in)f(`)p Ft ! (examples/fileman.c)p Fu('.)25 b(This)18 b(sample)g(application)75 ! 2661 y(pro)o(vides)c(completion)g(of)e(command)h(names,)g(line)i ! (editing)g(features,)d(and)i(access)f(to)f(the)h(history)h(list.)p ! eop ! %%Page: 38 40 ! 38 39 bop 75 -58 a Fu(38)1299 b(GNU)15 b(Readline)i(Library)195 ! 183 y Ft(/*)24 b(fileman.c)e(--)i(A)g(tiny)f(application)f(which)h ! (demonstrates)g(how)g(to)h(use)f(the)267 235 y(GNU)g(Readline)g ! (library.)46 b(This)24 b(application)e(interactively)g(allows)h(users) ! 267 287 y(to)g(manipulate)g(files)g(and)g(their)g(modes.)h(*/)195 ! 391 y(#include)f()195 443 y(#include)g()195 ! 495 y(#include)g()195 546 y(#include)g()195 ! 598 y(#include)g()195 702 y(#include)g ! ()195 754 y(#include)g()195 ! 858 y(extern)g(char)g(*getwd)g(\(\);)195 910 y(extern)g(char)g ! (*xmalloc)g(\(\);)195 1013 y(/*)h(The)f(names)g(of)h(functions)e(that)i ! (actually)f(do)g(the)h(manipulation.)e(*/)195 1065 y(int)h(com_list)g ! (\(\),)h(com_view)e(\(\),)i(com_rename)e(\(\),)i(com_stat)f(\(\),)g ! (com_pwd)g(\(\);)195 1117 y(int)g(com_delete)g(\(\),)g(com_help)g ! (\(\),)h(com_cd)f(\(\),)g(com_quit)g(\(\);)195 1221 y(/*)h(A)f ! (structure)g(which)g(contains)g(information)f(on)i(the)f(commands)g ! (this)g(program)267 1273 y(can)g(understand.)f(*/)195 ! 1377 y(typedef)h(struct)g({)243 1429 y(char)g(*name;)g(/*)h(User)f ! (printable)g(name)g(of)h(the)f(function.)g(*/)243 1480 ! y(Function)f(*func;)i(/*)f(Function)g(to)g(call)h(to)f(do)h(the)f(job.) ! h(*/)243 1532 y(char)f(*doc;)g(/*)h(Documentation)e(for)h(this)h ! (function.)46 b(*/)195 1584 y(})24 b(COMMAND;)195 1688 ! y(COMMAND)f(commands[])f(=)i({)243 1740 y({)f("cd",)h(com_cd,)f ! ("Change)f(to)i(directory)f(DIR")g(},)243 1792 y({)g("delete",)g ! (com_delete,)f("Delete)h(FILE")h(},)243 1844 y({)f("help",)g(com_help,) ! g("Display)g(this)g(text")g(},)243 1896 y({)g("?",)h(com_help,)e ! ("Synonym)h(for)h(`help'")f(},)243 1947 y({)g("list",)g(com_list,)g ! ("List)g(files)g(in)h(DIR")f(},)243 1999 y({)g("ls",)h(com_list,)e ! ("Synonym)h(for)g(`list'")g(},)243 2051 y({)g("pwd",)g(com_pwd,)g ! ("Print)g(the)h(current)f(working)g(directory")f(},)243 ! 2103 y({)h("quit",)g(com_quit,)g("Quit)g(using)g(Fileman")g(},)243 ! 2155 y({)g("rename",)g(com_rename,)f("Rename)h(FILE)h(to)f(NEWNAME")g ! (},)243 2207 y({)g("stat",)g(com_stat,)g("Print)g(out)g(statistics)g ! (on)h(FILE")f(},)243 2259 y({)g("view",)g(com_view,)g("View)g(the)h ! (contents)e(of)i(FILE")f(},)243 2311 y({)g(\(char)h(*\)NULL,)f ! (\(Function)f(*\)NULL,)h(\(char)g(*\)NULL)g(})195 2363 ! y(};)195 2466 y(/*)h(Forward)e(declarations.)h(*/)195 ! 2518 y(char)g(*stripwhite)g(\(\);)195 2570 y(COMMAND)g(*find_command)f ! (\(\);)p eop %%Page: 39 41 39 40 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)844 b(39)195 183 y Ft(/*)24 b(The)f(name)g(of)h(this)f ! (program,)g(as)h(taken)f(from)g(argv[0].)g(*/)195 235 ! y(char)g(*progname;)195 339 y(/*)h(When)f(non-zero,)g(this)g(global)g ! (means)g(the)h(user)f(is)g(done)h(using)f(this)g(program.)g(*/)p ! 1985 349 21 42 v 195 391 a(int)g(done;)195 495 y(char)g(*)195 ! 546 y(dupstr)g(\(s\))314 598 y(int)h(s;)195 650 y({)243 ! 702 y(char)f(*r;)243 806 y(r)g(=)h(xmalloc)f(\(strlen)g(\(s\))g(+)h ! (1\);)243 858 y(strcpy)f(\(r,)g(s\);)243 910 y(return)g(\(r\);)195 ! 962 y(})195 1065 y(main)g(\(argc,)g(argv\))314 1117 y(int)h(argc;)314 ! 1169 y(char)g(**argv;)195 1221 y({)243 1273 y(char)f(*line,)g(*s;)243 ! 1377 y(progname)f(=)i(argv[0];)243 1480 y(initialize_readline)d(\(\);)i ! (/*)h(Bind)f(our)h(completer.)e(*/)243 1584 y(/*)h(Loop)h(reading)f ! (and)g(executing)g(lines)g(until)g(the)g(user)h(quits.)f(*/)243 ! 1636 y(for)g(\()h(;)g(done)f(==)h(0;)f(\))290 1688 y({)338 ! 1740 y(line)g(=)h(readline)f(\("FileMan:)f("\);)338 1844 ! y(if)i(\(!line\))386 1896 y(break;)338 1999 y(/*)g(Remove)f(leading)g ! (and)g(trailing)g(whitespace)f(from)i(the)f(line.)410 ! 2051 y(Then,)g(if)h(there)f(is)g(anything)g(left,)g(add)h(it)f(to)h ! (the)f(history)g(list)410 2103 y(and)g(execute)g(it.)h(*/)338 ! 2155 y(s)g(=)g(stripwhite)e(\(line\);)338 2259 y(if)i(\(*s\))386 ! 2311 y({)434 2363 y(add_history)e(\(s\);)434 2414 y(execute_line)g ! (\(s\);)386 2466 y(})338 2570 y(free)h(\(line\);)290 ! 2622 y(})p eop %%Page: 40 42 ! 40 41 bop 75 -58 a Fu(40)1299 b(GNU)15 b(Readline)i(Library)243 ! 183 y Ft(exit)23 b(\(0\);)195 235 y(})195 339 y(/*)h(Execute)e(a)i ! (command)f(line.)g(*/)195 391 y(int)195 443 y(execute_line)f(\(line\)) ! 314 495 y(char)i(*line;)195 546 y({)243 598 y(register)e(int)i(i;)243 ! 650 y(COMMAND)f(*command;)243 702 y(char)g(*word;)243 ! 806 y(/*)g(Isolate)g(the)h(command)f(word.)g(*/)243 858 ! y(i)g(=)h(0;)243 910 y(while)f(\(line[i])g(&&)g(whitespace)g ! (\(line[i]\)\))290 962 y(i++;)243 1013 y(word)g(=)h(line)f(+)h(i;)243 ! 1117 y(while)f(\(line[i])g(&&)g(!whitespace)g(\(line[i]\)\))290 ! 1169 y(i++;)243 1273 y(if)g(\(line[i]\))290 1325 y(line[i++])g(=)h ! ('\\0';)243 1429 y(command)f(=)g(find_command)g(\(word\);)243 ! 1532 y(if)g(\(!command\))290 1584 y({)338 1636 y(fprintf)g(\(stderr,)g ! ("\045s:)g(No)h(such)f(command)g(for)g(FileMan.\\n",)g(word\);)338 ! 1688 y(return)g(\(-1\);)290 1740 y(})243 1844 y(/*)g(Get)h(argument)f ! (to)g(command,)g(if)g(any.)h(*/)243 1896 y(while)f(\(whitespace)f ! (\(line[i]\)\))290 1947 y(i++;)243 2051 y(word)h(=)h(line)f(+)h(i;)243 ! 2155 y(/*)f(Call)h(the)f(function.)g(*/)243 2207 y(return)g ! (\(\(*\(command->func\)\))e(\(word\)\);)195 2259 y(})195 ! 2363 y(/*)j(Look)f(up)g(NAME)h(as)f(the)h(name)f(of)h(a)f(command,)g ! (and)h(return)f(a)g(pointer)g(to)h(that)267 2414 y(command.)46 ! b(Return)23 b(a)h(NULL)f(pointer)g(if)h(NAME)f(isn't)g(a)h(command)f ! (name.)g(*/)195 2466 y(COMMAND)g(*)195 2518 y(find_command)f(\(name\)) ! 314 2570 y(char)i(*name;)195 2622 y({)p eop %%Page: 41 43 41 42 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)844 b(41)243 183 y Ft(register)22 b(int)i(i;)243 ! 287 y(for)f(\(i)h(=)f(0;)h(commands[i].name;)e(i++\))290 ! 339 y(if)i(\(strcmp)f(\(name,)g(commands[i].name\))f(==)h(0\))338 ! 391 y(return)g(\(&commands[i]\);)243 495 y(return)g(\(\(COMMAND)f ! (*\)NULL\);)195 546 y(})195 650 y(/*)i(Strip)f(whitespace)f(from)i(the) ! f(start)g(and)h(end)f(of)h(STRING.)46 b(Return)24 b(a)f(pointer)267 ! 702 y(into)g(STRING.)g(*/)195 754 y(char)g(*)195 806 ! y(stripwhite)f(\(string\))314 858 y(char)i(*string;)195 ! 910 y({)243 962 y(register)e(char)i(*s,)f(*t;)243 1065 ! y(for)g(\(s)h(=)f(string;)g(whitespace)g(\(*s\);)g(s++\))290 ! 1117 y(;)243 1221 y(if)g(\(*s)h(==)f(0\))290 1273 y(return)g(\(s\);)243 ! 1377 y(t)g(=)h(s)g(+)g(strlen)f(\(s\))g(-)h(1;)243 1429 ! y(while)f(\(t)g(>)h(s)g(&&)g(whitespace)e(\(*t\)\))290 ! 1480 y(t--;)243 1532 y(*++t)h(=)h('\\0';)243 1636 y(return)f(s;)195 ! 1688 y(})195 1792 y(/*)h(***********************)o(*******)o(********)o ! (*******)o(*******)o(********)o(****)d(*/)195 1844 y(/*)1575 ! b(*/)195 1896 y(/*)429 b(Interface)23 b(to)g(Readline)g(Completion)381 ! b(*/)195 1947 y(/*)1575 b(*/)195 1999 y(/*)24 b ! (***********************)o(*******)o(********)o(*******)o(*******)o ! (********)o(****)d(*/)195 2103 y(char)i(*command_generator)f(\(\);)195 ! 2155 y(char)h(**fileman_completion)e(\(\);)195 2259 y(/*)j(Tell)f(the)g ! (GNU)h(Readline)f(library)f(how)i(to)g(complete.)46 b(We)24 ! b(want)f(to)h(try)f(to)h(complete)p 2034 2269 21 42 v ! 267 2311 a(on)f(command)g(names)g(if)h(this)f(is)h(the)f(first)g(word)h ! (in)f(the)h(line,)f(or)h(on)f(filenames)p 1962 2317 21 ! 35 v 267 2363 a(if)g(not.)g(*/)195 2414 y(initialize_readline)e(\(\)) ! 195 2466 y({)243 2518 y(/*)i(Allow)g(conditional)g(parsing)g(of)g(the)h ! (~/.inputrc)e(file.)h(*/)243 2570 y(rl_readline_name)e(=)j("FileMan";)p ! eop %%Page: 42 44 ! 42 43 bop 75 -58 a Fu(42)1299 b(GNU)15 b(Readline)i(Library)243 ! 183 y Ft(/*)23 b(Tell)h(the)f(completer)g(that)g(we)h(want)f(a)h(crack) ! f(first.)g(*/)243 235 y(rl_attempted_completion_)o(functio)o(n)e(=)j ! (\(CPPFunction)e(*\)fileman_completion;)195 287 y(})195 ! 391 y(/*)i(Attempt)e(to)i(complete)f(on)g(the)h(contents)f(of)g(TEXT.) ! 47 b(START)23 b(and)h(END)f(bound)h(the)267 443 y(region)f(of)g ! (rl_line_buffer)f(that)h(contains)g(the)h(word)f(to)h(complete.)46 ! b(TEXT)23 b(is)267 495 y(the)g(word)g(to)h(complete.)46 ! b(We)24 b(can)f(use)h(the)f(entire)g(contents)g(of)h(rl_line_buffer)p ! 1963 505 21 38 v 267 546 a(in)f(case)g(we)h(want)f(to)h(do)g(some)f ! (simple)g(parsing.)47 b(Return)23 b(the)g(array)g(of)h(matches,)p ! 1986 557 V 267 598 a(or)f(NULL)g(if)h(there)f(aren't)g(any.)h(*/)195 ! 650 y(char)f(**)195 702 y(fileman_completion)e(\(text,)i(start,)g ! (end\))314 754 y(char)h(*text;)314 806 y(int)g(start,)f(end;)195 ! 858 y({)243 910 y(char)g(**matches;)243 1013 y(matches)g(=)g(\(char)h ! (**\)NULL;)243 1117 y(/*)f(If)h(this)f(word)h(is)f(at)h(the)f(start)g ! (of)h(the)f(line,)h(then)f(it)g(is)h(a)g(command)314 ! 1169 y(to)g(complete.)46 b(Otherwise)23 b(it)h(is)f(the)h(name)f(of)h ! (a)f(file)h(in)f(the)h(current)314 1221 y(directory.)f(*/)243 ! 1273 y(if)g(\(start)g(==)h(0\))290 1325 y(matches)f(=)h ! (completion_matches)d(\(text,)j(command_generator\);)243 ! 1429 y(return)f(\(matches\);)195 1480 y(})195 1584 y(/*)h(Generator)e ! (function)h(for)g(command)g(completion.)47 b(STATE)23 ! b(lets)g(us)h(know)f(whether)p 1938 1594 21 42 v 267 ! 1636 a(to)g(start)g(from)h(scratch;)e(without)h(any)h(state)f(\(i.e.)g ! (STATE)g(==)h(0\),)f(then)h(we)267 1688 y(start)f(at)g(the)h(top)f(of)h ! (the)f(list.)g(*/)195 1740 y(char)g(*)195 1792 y(command_generator)f ! (\(text,)h(state\))314 1844 y(char)h(*text;)314 1896 ! y(int)g(state;)195 1947 y({)243 1999 y(static)f(int)g(list_index,)g ! (len;)243 2051 y(char)g(*name;)243 2155 y(/*)g(If)h(this)f(is)h(a)g ! (new)f(word)g(to)h(complete,)f(initialize)f(now.)47 b(This)24 ! b(includes)314 2207 y(saving)f(the)h(length)f(of)g(TEXT)h(for)f ! (efficiency,)g(and)g(initializing)f(the)i(index)p 1938 ! 2217 21 38 v 314 2259 a(variable)f(to)h(0.)f(*/)243 2311 ! y(if)g(\(!state\))290 2363 y({)338 2414 y(list_index)g(=)g(0;)338 ! 2466 y(len)h(=)f(strlen)g(\(text\);)290 2518 y(})243 ! 2622 y(/*)g(Return)g(the)h(next)f(name)g(which)h(partially)e(matches)h ! (from)g(the)h(command)f(list.)g(*/)p 1985 2632 21 42 ! v eop %%Page: 43 45 43 44 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)844 b(43)243 183 y Ft(while)23 b(\(name)g(=)h ! (commands[list_index].name)o(\))290 235 y({)338 287 y(list_index++;)338 ! 391 y(if)g(\(strncmp)f(\(name,)g(text,)g(len\))g(==)h(0\))386 ! 443 y(return)f(\(dupstr\(name\)\);)290 495 y(})243 598 ! y(/*)g(If)h(no)f(names)h(matched,)e(then)i(return)f(NULL.)g(*/)243 ! 650 y(return)g(\(\(char)g(*\)NULL\);)195 702 y(})195 ! 806 y(/*)h(***********************)o(*******)o(********)o(*******)o ! (*******)o(********)o(****)d(*/)195 858 y(/*)1575 b(*/)195 ! 910 y(/*)549 b(FileMan)22 b(Commands)644 b(*/)195 962 ! y(/*)1575 b(*/)195 1013 y(/*)24 b(***********************)o(*******)o ! (********)o(*******)o(*******)o(********)o(****)d(*/)195 ! 1117 y(/*)j(String)f(to)g(pass)h(to)f(system)g(\(\).)47 ! b(This)24 b(is)f(for)h(the)f(LIST,)g(VIEW)h(and)f(RENAME)267 ! 1169 y(commands.)f(*/)195 1221 y(static)h(char)g(syscom[1024];)195 ! 1325 y(/*)h(List)f(the)g(file\(s\))g(named)g(in)h(arg.)f(*/)195 ! 1377 y(com_list)g(\(arg\))314 1429 y(char)h(*arg;)195 ! 1480 y({)243 1532 y(if)f(\(!arg\))290 1584 y(arg)h(=)g("";)243 ! 1688 y(sprintf)f(\(syscom,)f("ls)i(-FClg)f(\045s",)g(arg\);)243 ! 1740 y(return)g(\(system)g(\(syscom\)\);)195 1792 y(})195 ! 1896 y(com_view)g(\(arg\))314 1947 y(char)h(*arg;)195 ! 1999 y({)243 2051 y(if)f(\(!valid_argument)f(\("view",)h(arg\)\))290 ! 2103 y(return)g(1;)243 2207 y(sprintf)g(\(syscom,)f("more)i(\045s",)f ! (arg\);)243 2259 y(return)g(\(system)g(\(syscom\)\);)195 ! 2311 y(})195 2414 y(com_rename)f(\(arg\))314 2466 y(char)i(*arg;)195 ! 2518 y({)243 2570 y(too_dangerous)e(\("rename"\);)243 ! 2622 y(return)h(\(1\);)p eop %%Page: 44 46 ! 44 45 bop 75 -58 a Fu(44)1299 b(GNU)15 b(Readline)i(Library)195 ! 183 y Ft(})195 287 y(com_stat)23 b(\(arg\))314 339 y(char)h(*arg;)195 ! 391 y({)243 443 y(struct)f(stat)g(finfo;)243 546 y(if)g ! (\(!valid_argument)f(\("stat",)h(arg\)\))290 598 y(return)g(\(1\);)243 ! 702 y(if)g(\(stat)g(\(arg,)h(&finfo\))f(==)g(-1\))290 ! 754 y({)338 806 y(perror)g(\(arg\);)338 858 y(return)g(\(1\);)290 ! 910 y(})243 1013 y(printf)g(\("Statistics)f(for)h(`\045s':\\n",)g ! (arg\);)243 1117 y(printf)g(\("\045s)g(has)h(\045d)f(link\045s,)g(and)g ! (is)h(\045d)g(byte\045s)f(in)g(length.\\n",)g(arg,)434 ! 1169 y(finfo.st_nlink,)434 1221 y(\(finfo.st_nlink)e(==)j(1\))g(?)f("") ! h(:)g("s",)434 1273 y(finfo.st_size,)434 1325 y(\(finfo.st_size)e(==)h ! (1\))h(?)f("")h(:)g("s"\);)243 1377 y(printf)f(\("Inode)g(Last)g ! (Change)g(at:)g(\045s",)h(ctime)f(\(&finfo.st_ctime\)\);)243 ! 1429 y(printf)g(\(")143 b(Last)23 b(access)g(at:)g(\045s",)h(ctime)f ! (\(&finfo.st_atime\)\);)243 1480 y(printf)g(\(")95 b(Last)23 ! b(modified)g(at:)g(\045s",)h(ctime)f(\(&finfo.st_mtime\)\);)243 ! 1532 y(return)g(\(0\);)195 1584 y(})195 1688 y(com_delete)f(\(arg\))314 ! 1740 y(char)i(*arg;)195 1792 y({)243 1844 y(too_dangerous)e ! (\("delete"\);)243 1896 y(return)h(\(1\);)195 1947 y(})195 ! 2051 y(/*)h(Print)f(out)g(help)h(for)f(ARG,)g(or)h(for)f(all)h(of)f ! (the)h(commands)f(if)g(ARG)h(is)267 2103 y(not)f(present.)g(*/)195 ! 2155 y(com_help)g(\(arg\))314 2207 y(char)h(*arg;)195 ! 2259 y({)243 2311 y(register)e(int)i(i;)243 2363 y(int)f(printed)g(=)h ! (0;)243 2466 y(for)f(\(i)h(=)f(0;)h(commands[i].name;)e(i++\))290 ! 2518 y({)338 2570 y(if)i(\(!*arg)f(||)g(\(strcmp)g(\(arg,)g ! (commands[i].name\))f(==)i(0\)\))386 2622 y({)p eop %%Page: 45 47 45 46 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)844 b(45)434 183 y Ft(printf)23 b(\("\045s\\t\\t\045s.\\n",)e ! (commands[i].name,)h(commands[i].doc\);)434 235 y(printed++;)386 ! 287 y(})290 339 y(})243 443 y(if)h(\(!printed\))290 495 ! y({)338 546 y(printf)g(\("No)h(commands)e(match)h(`\045s'.)48 ! b(Possibilties)22 b(are:\\n",)h(arg\);)338 650 y(for)h(\(i)f(=)h(0;)g ! (commands[i].name;)d(i++\))386 702 y({)434 754 y(/*)i(Print)g(in)h(six) ! f(columns.)g(*/)434 806 y(if)g(\(printed)g(==)h(6\))481 ! 858 y({)529 910 y(printed)f(=)h(0;)529 962 y(printf)f(\("\\n"\);)481 ! 1013 y(})434 1117 y(printf)g(\("\045s\\t",)f(commands[i].name\);)434 ! 1169 y(printed++;)386 1221 y(})338 1325 y(if)i(\(printed\))386 ! 1377 y(printf)f(\("\\n"\);)290 1429 y(})243 1480 y(return)g(\(0\);)195 ! 1532 y(})195 1636 y(/*)h(Change)f(to)g(the)h(directory)e(ARG.)i(*/)195 ! 1688 y(com_cd)f(\(arg\))314 1740 y(char)h(*arg;)195 1792 ! y({)243 1844 y(if)f(\(chdir)g(\(arg\))h(==)f(-1\))290 ! 1896 y({)338 1947 y(perror)g(\(arg\);)338 1999 y(return)g(1;)290 ! 2051 y(})243 2155 y(com_pwd)g(\(""\);)243 2207 y(return)g(\(0\);)195 ! 2259 y(})195 2363 y(/*)h(Print)f(out)g(the)h(current)f(working)f ! (directory.)h(*/)195 2414 y(com_pwd)g(\(ignore\))314 ! 2466 y(char)h(*ignore;)195 2518 y({)243 2570 y(char)f(dir[1024],)g(*s;) ! p eop %%Page: 46 48 ! 46 47 bop 75 -58 a Fu(46)1299 b(GNU)15 b(Readline)i(Library)243 ! 183 y Ft(s)23 b(=)h(getwd)f(\(dir\);)243 235 y(if)g(\(s)h(==)f(0\))290 ! 287 y({)338 339 y(printf)g(\("Error)g(getting)g(pwd:)g(\045s\\n",)g ! (dir\);)338 391 y(return)g(1;)290 443 y(})243 546 y(printf)g ! (\("Current)f(directory)h(is)h(\045s\\n",)f(dir\);)243 ! 598 y(return)g(0;)195 650 y(})195 754 y(/*)h(The)f(user)g(wishes)g(to)h ! (quit)f(using)g(this)h(program.)46 b(Just)24 b(set)f(DONE)h(non-zero.)e ! (*/)p 1961 764 21 42 v 195 806 a(com_quit)h(\(arg\))314 ! 858 y(char)h(*arg;)195 910 y({)243 962 y(done)f(=)h(1;)243 ! 1013 y(return)f(\(0\);)195 1065 y(})195 1169 y(/*)h(Function)e(which)i ! (tells)f(you)g(that)g(you)h(can't)f(do)h(this.)f(*/)195 ! 1221 y(too_dangerous)f(\(caller\))314 1273 y(char)i(*caller;)195 ! 1325 y({)243 1377 y(fprintf)f(\(stderr,)457 1429 y("\045s:)h(Too)f ! (dangerous)g(for)g(me)h(to)g(distribute.)46 b(Write)23 ! b(it)h(yourself.\\n",)p 1987 1439 V 457 1480 a(caller\);)195 ! 1532 y(})195 1636 y(/*)g(Return)f(non-zero)f(if)i(ARG)f(is)h(a)g(valid) ! f(argument)g(for)g(CALLER,)g(else)g(print)267 1688 y(an)g(error)g ! (message)g(and)h(return)f(zero.)g(*/)195 1740 y(int)195 ! 1792 y(valid_argument)f(\(caller,)h(arg\))314 1844 y(char)h(*caller,)e ! (*arg;)195 1896 y({)243 1947 y(if)h(\(!arg)g(||)h(!*arg\))290 ! 1999 y({)338 2051 y(fprintf)f(\(stderr,)g("\045s:)g(Argument)g ! (required.\\n",)f(caller\);)338 2103 y(return)h(\(0\);)290 ! 2155 y(})243 2259 y(return)g(\(1\);)195 2311 y(})p eop %%Page: 47 49 ! 47 48 bop 75 -58 a Fu(Concept)15 b(Index)1466 b(47)75 ! 183 y Fq(Concept)27 b(Index)75 359 y Fs(C)75 417 y Ff(command)14 ! b(editing)9 b Fe(.)f(.)e(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)21 ! b Ff(1)75 517 y Fs(E)75 575 y Ff(editing)15 b(command)f(lines)8 ! b Fe(.)f(.)f(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)20 b Ff(1)75 675 ! y Fs(I)75 733 y Ff(initiali)q(zati)q(on)c(\014le,)e(readline)8 ! b Fe(.)g(.)e(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)g(.)20 b Ff(4)75 782 y(in)o(teraction,)15 ! b(readline)e Fe(.)7 b(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)24 ! b Ff(1)75 882 y Fs(K)75 940 y Ff(kill)15 b(ring)e Fe(.)6 ! b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)24 b Ff(3)1012 359 y(killin)q(g)16 b(text)11 ! b Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)24 b Ff(2)1012 495 y Fs(N)1012 553 y Ff(notation,)15 ! b(readline)5 b Fe(.)k(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! 19 b Ff(1)1012 688 y Fs(R)1012 747 y Ff(readline,)c(function)6 ! b Fe(.)i(.)e(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)19 ! b Ff(19)1012 882 y Fs(Y)1012 940 y Ff(y)o(anking)c(text)6 ! b Fe(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)19 b Ff(2)p eop %%Page: 48 50 ! 48 49 bop 75 -58 a Fu(48)1299 b(GNU)15 b(Readline)i(Library)p eop %%Page: 49 51 ! 49 50 bop 75 -58 a Fu(F)l(unction)16 b(and)f(V)l(ariable)i(Index)1187 ! b(49)75 183 y Fq(F)-7 b(unction)26 b(and)h(V)-7 b(ariable)26 ! b(Index)75 345 y Fs(A)75 403 y Fd(abort)11 b(\(C-g\))6 ! b Fe(.)t(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)18 b Ff(17)75 453 y Fd(accept-lin)o(e)10 b(\(Newline)o(,)g(Return\)) ! s Fe(.)s(.)c(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)16 ! b Ff(12)75 503 y Fd(alphabetic)r Fe(.)t(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)16 b Ff(29)75 ! 652 y Fs(B)75 711 y Fd(backward-c)o(ha)o(r)10 b(\(C-b\))t ! Fe(.)t(.)c(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)17 b Ff(12)75 760 ! y Fd(backward-d)o(el)o(ete)o(-c)o(har)9 b(\(Rubout\))f ! Fe(.)s(.)e(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)21 ! b Ff(14)75 810 y Fd(backward-k)o(il)o(l-l)o(in)o(e)10 ! b(\(C-x)h(Rubout\))e Fe(.)t(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! 22 b Ff(14)75 860 y Fd(backward-k)o(il)o(l-w)o(or)o(d)10 ! b(\(M-DEL\))t Fe(.)s(.)c(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)16 b Ff(15)75 910 y Fd(backward-w)o(or)o(d)10 ! b(\(M-b\))t Fe(.)t(.)c(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)17 b Ff(12)75 ! 960 y Fd(beginning-)o(of)o(-hi)o(st)o(ory)9 b(\(M-<\))t ! Fe(.)t(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)16 b Ff(13)75 1009 y Fd(beginning-)o(of)o(-li)o(ne)9 ! b(\(C-a\))e Fe(.)e(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)g(.)g(.)20 b Ff(12)75 1059 y(b)q(ell-st)o(yle)13 ! b Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)23 b Ff(4)75 1209 y Fs(C)75 1267 ! y Fd(call-last-)o(kb)o(d-m)o(ac)o(ro)9 b(\(C-x)j(e\))6 ! b Fe(.)f(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! 18 b Ff(16)75 1317 y Fd(capitalize)o(-w)o(ord)9 b(\(M-c\))f ! Fe(.)e(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)23 b Ff(14)75 1366 y Fd(character-)o(se)o(arc)o ! (h)10 b(\(C-]\))f Fe(.)s(.)d(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)21 b Ff(17)75 1416 ! y Fd(character-)o(se)o(arc)o(h-)o(bac)o(kwa)o(rd)9 b(\(M-C-]\))s ! Fe(.)t(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)16 b Ff(17)75 ! 1466 y Fd(clear-scre)o(en)9 b(\(C-l\))c Fe(.)g(.)h(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)18 b Ff(12)75 1516 y(commen)o(t-b)q(egin)9 b ! Fe(.)f(.)e(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)21 ! b Ff(4)75 1566 y Fd(complete)10 b(\(TAB\))e Fe(.)e(.)g(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)23 b Ff(16)75 1616 y(completion-query-i)q ! (tems)9 b Fe(.)f(.)f(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)21 b Ff(5)75 ! 1665 y Fd(completion)p 276 1665 12 2 v 10 w(matches)5 ! b Fe(.)s(.)h(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)17 b Ff(34)75 ! 1715 y(con)o(v)o(ert-meta)11 b Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)23 b Ff(5)75 1765 y Fd(copy-backw)o(ar) ! o(d-w)o(or)o(d)10 b(\(\))f Fe(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)23 ! b Ff(15)75 1815 y Fd(copy-forwa)o(rd)o(-wo)o(rd)9 b(\(\))i ! Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)24 b Ff(15)75 1865 y Fd(copy-regio)o(n-)o ! (as-)o(ki)o(ll)9 b(\(\))g Fe(.)c(.)h(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)21 b Ff(15)75 ! 2014 y Fs(D)75 2072 y Fd(delete-cha)o(r)10 b(\(C-d\))c ! Fe(.)t(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)19 b Ff(13)75 ! 2122 y Fd(delete-cha)o(r-)o(or-)o(li)o(st)9 b(\(\))g ! Fe(.)c(.)h(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)21 b Ff(16)75 2172 y Fd(delete-hor)o(iz)o(ont)o(al)o ! (-sp)o(ace)9 b(\(\))t Fe(.)c(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)16 b Ff(15)75 2222 y Fd(digit-argu)o(me)o(nt)9 ! b(\(M-0,)i(M-1,)h(...)f(M--\))t Fe(.)t(.)6 b(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)16 b Ff(15)75 2271 y Fd(digit)p 177 2271 V 12 w(p)10 ! b Fe(.)c(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)23 b Ff(29)75 2321 y Fd(digit)p 177 ! 2321 V 12 w(value)5 b Fe(.)t(.)h(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)18 b Ff(29)75 2371 y Fd(ding)10 ! b Fe(.)c(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)24 b Ff(29)75 2421 y(disable-comple)q ! (tion)7 b Fe(.)i(.)d(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)19 ! b Ff(5)75 2471 y Fd(do-upperca)o(se)o(-ve)o(rs)o(ion)9 ! b(\(M-a,)i(M-b,)g(M-)p Fe(x)p Fd(,)h Fc(:)6 b(:)g(:)p ! Fd(\))j Fe(.)d(.)23 b Ff(17)75 2521 y Fd(downcase-w)o(or)o(d)10 ! b(\(M-l\))t Fe(.)t(.)c(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)17 b Ff(14)75 ! 2570 y Fd(dump-funct)o(io)o(ns)9 b(\(\))d Fe(.)g(.)g(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)19 b Ff(17)75 2620 y Fd(dump-macro)o(s)10 ! b(\(\))f Fe(.)d(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)23 ! b Ff(18)75 2670 y Fd(dump-varia)o(bl)o(es)9 b(\(\))d ! Fe(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)19 b Ff(18)1012 ! 345 y Fs(E)1012 403 y Ff(editing-mo)q(de)13 b Fe(.)6 ! b(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)23 ! b Ff(5)1012 453 y(enable-k)o(eypad)13 b Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)22 b Ff(5)1012 ! 503 y Fd(end-kbd-mac)o(ro)9 b(\(C-x)i(\)\))5 b Fe(.)h(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! g(.)18 b Ff(16)1012 553 y Fd(end-of-hist)o(or)o(y)10 ! b(\(M->\))f Fe(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)24 b Ff(13)1012 ! 603 y Fd(end-of-line)9 b(\(C-e\))d Fe(.)f(.)h(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)20 b Ff(12)1012 652 y Fd(exchange-po)o(in)o(t-a)o(nd)o(-ma)o ! (rk)9 b(\(C-x)j(C-x\))7 b Fe(.)t(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)20 ! b Ff(17)1012 702 y(expand-tilde)8 b Fe(.)h(.)d(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)20 b Ff(5)1012 ! 811 y Fs(F)1012 869 y Fd(filename)p 1174 869 V 11 w(completion)p ! 1385 869 V 11 w(function)s Fe(.)s(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)16 b Ff(35)1012 919 y Fd(forward-bac)o(kw)o(ard) ! o(-d)o(ele)o(te)o(-ch)o(ar)9 b(\(\))d Fe(.)f(.)h(.)h(.)f(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)19 b Ff(14)1012 969 y Fd(forward-cha)o(r)10 ! b(\(C-f\))5 b Fe(.)t(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)18 ! b Ff(12)1012 1019 y Fd(forward-sea)o(rc)o(h-h)o(is)o(tor)o(y)10 ! b(\(C-s\))d Fe(.)f(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)23 b Ff(13)1012 1069 y Fd(forward-wor)o(d)10 b(\(M-f\))5 ! b Fe(.)t(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)18 b Ff(12)1012 ! 1118 y Fd(free)p 1094 1118 V 13 w(undo)p 1187 1118 V ! 13 w(list)t Fe(.)t(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)17 b Ff(27)1012 1228 y Fs(H)1012 1286 y Fd(history-sea)o(rc)o(h-b)o ! (ac)o(kwa)o(rd)9 b(\(\))t Fe(.)c(.)h(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)17 b Ff(13)1012 1336 y Fd(history-sea)o(rc) ! o(h-f)o(or)o(war)o(d)10 b(\(\))5 b Fe(.)g(.)h(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)18 b Ff(13)1012 ! 1385 y(horizon)o(tal-scrol)q(l-mo)r(de)c Fe(.)6 b(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)24 b Ff(5)1012 1495 y Fs(I)1012 1553 y Ff(input-meta)12 ! b Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)23 b Ff(5)1012 1602 y Fd(insert-comm)o(en)o(t)10 ! b(\(M-#\))f Fe(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)24 b Ff(17)1012 ! 1652 y Fd(insert-comp)o(le)o(tio)o(ns)9 b(\(M-*\))d Fe(.)t(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)19 ! b Ff(16)1012 1702 y(isearc)o(h-terminators)13 b Fe(.)6 ! b(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)23 b Ff(6)1012 ! 1811 y Fs(K)1012 1869 y Ff(k)o(eymap)t Fe(.)7 b(.)g(.)f(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)17 ! b Ff(6)1012 1919 y Fd(kill-line)10 b(\(C-k\))f Fe(.)t(.)d(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)g(.)22 b Ff(14)1012 1969 y Fd(kill-region)9 ! b(\(\))g Fe(.)e(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)24 ! b Ff(15)1012 2019 y Fd(kill-whole-)o(li)o(ne)9 b(\(\))c ! Fe(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)18 b Ff(15)1012 ! 2069 y Fd(kill-word)10 b(\(M-d\))f Fe(.)t(.)d(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)22 b Ff(15)1012 2178 y Fs(L)1012 2236 ! y Fd(lowercase)p 1194 2236 V 11 w(p)5 b Fe(.)h(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)18 b Ff(29)1012 ! 2345 y Fs(M)1012 2403 y Ff(mark-mo)q(di\014ed-li)q(nes)6 ! b Fe(.)j(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)18 b ! Ff(6)1012 2453 y Fd(menu-comple)o(te)9 b(\(\))f Fe(.)d(.)h(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)g(.)g(.)21 b Ff(16)1012 2503 y(meta-\015ag)8 ! b Fe(.)f(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)21 b Ff(5)1012 2612 y Fs(N)1012 2670 ! y Fd(next-histor)o(y)10 b(\(C-n\))5 b Fe(.)t(.)h(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)h(.)18 b Ff(12)p eop %%Page: 50 52 ! 50 51 bop 75 -58 a Fu(50)1299 b(GNU)15 b(Readline)i(Library)75 ! 183 y Fd(non-increm)o(en)o(tal)o(-f)o(orw)o(ard)o(-s)o(ear)o(ch)o(-hi)o ! (st)o(ory)9 b(\(M-n\))155 233 y Fe(.)d(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)16 ! b Ff(13)75 283 y Fd(non-increm)o(en)o(tal)o(-r)o(eve)o(rse)o(-s)o(ear)o ! (ch)o(-hi)o(st)o(ory)9 b(\(M-p\))155 333 y Fe(.)d(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)g(.)16 b Ff(13)75 382 y Fd(numeric)7 b Fe(.)t(.)f(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)20 ! b Ff(29)75 485 y Fs(O)75 543 y Ff(output-meta)7 b Fe(.)g(.)f(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)19 ! b Ff(6)75 646 y Fs(P)75 704 y Fd(possible-c)o(om)o(ple)o(ti)o(ons)9 ! b(\(M-?\))t Fe(.)t(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)16 b Ff(16)75 754 y Fd(prefix-met)o(a)10 ! b(\(ESC\))c Fe(.)t(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)19 ! b Ff(17)75 804 y Fd(previous-h)o(is)o(tor)o(y)10 b(\(C-p\))f ! Fe(.)s(.)d(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)21 b Ff(12)75 907 y Fs(Q)75 965 y ! Fd(quoted-ins)o(er)o(t)10 b(\(C-q,)h(C-v\))d Fe(.)e(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)22 ! b Ff(14)75 1068 y Fs(R)75 1126 y Fd(re-read-in)o(it)o(-fi)o(le)9 ! b(\(C-x)i(C-r\))6 b Fe(.)f(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)18 b Ff(17)75 1176 y Fd(readline)6 ! b Fe(.)s(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)19 b Ff(19)75 1225 y Fd(redraw-cur)o(re)o(nt-)o(li)o(ne) ! 9 b(\(\))g Fe(.)c(.)h(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)21 b Ff(12)75 1275 y Fd(reverse-se)o(ar) ! o(ch-)o(hi)o(sto)o(ry)9 b(\(C-r\))f Fe(.)e(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)22 b Ff(13)75 1325 y Fd(revert-lin)o(e)10 ! b(\(M-r\))c Fe(.)t(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)19 ! b Ff(17)75 1375 y Fd(rl)p 117 1375 12 2 v 13 w(add)p ! 190 1375 V 13 w(defun)6 b Fe(.)f(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)g(.)19 b Ff(23)75 1425 y Fd(rl)p 117 ! 1425 V 13 w(add)p 190 1425 V 13 w(undo)8 b Fe(.)d(.)h(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)20 b Ff(27)75 ! 1474 y Fd(rl)p 117 1474 V 13 w(already)p 270 1474 V 12 ! w(prompted)e Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)21 b Ff(22)75 ! 1524 y Fd(rl)p 117 1524 V 13 w(attempted)p 310 1524 V ! 11 w(completion)p 520 1524 V 10 w(function)g Fe(.)6 b(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)24 b Ff(35)75 1574 y Fd(rl)p 117 1574 ! V 13 w(basic)p 230 1574 V 13 w(quote)p 343 1574 V 12 ! w(character)o(s)13 b Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)16 b Ff(36)75 1624 y Fd(rl)p ! 117 1624 V 13 w(basic)p 230 1624 V 13 w(word)p 323 1624 ! V 12 w(break)p 435 1624 V 12 w(characters)h Fe(.)6 b(.)h(.)f(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)21 b Ff(36)75 1674 y Fd(rl)p ! 117 1674 V 13 w(begin)p 230 1674 V 13 w(undo)p 323 1674 ! V 12 w(group)9 b Fe(.)t(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)21 ! b Ff(26)75 1724 y Fd(rl)p 117 1724 V 13 w(bind)p 210 ! 1724 V 13 w(key)8 b Fe(.)d(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)20 b Ff(25)75 1773 y Fd(rl)p 117 ! 1773 V 13 w(bind)p 210 1773 V 13 w(key)p 283 1773 V 13 ! w(in)p 336 1773 V 13 w(map)t Fe(.)5 b(.)h(.)h(.)f(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)17 b Ff(25)75 1823 y Fd(rl)p 117 1823 V 13 w(binding)p ! 270 1823 V 12 w(keymap)k Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)23 ! b Ff(23)75 1873 y Fd(rl_callbac)o(k_)o(han)o(dl)o(er_)o(ins)o(ta)o(ll)7 ! b Fe(.)s(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)20 ! b Ff(30)75 1923 y Fd(rl_callbac)o(k_)o(han)o(dl)o(er_)o(rem)o(ov)o(e)9 ! b Fe(.)s(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! 21 b Ff(30)75 1973 y Fd(rl_callbac)o(k_)o(rea)o(d_)o(cha)o(r)6 ! b Fe(.)s(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)19 b Ff(30)75 2022 y Fd(rl)p ! 117 2022 V 13 w(catch)p 230 2022 V 13 w(signals)13 b ! Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)16 b ! Ff(32)75 2072 y Fd(rl)p 117 2072 V 13 w(catch)p 230 2072 ! V 13 w(sigwinch)k Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)23 ! b Ff(32)75 2122 y Fd(rl)p 117 2122 V 13 w(char)p 210 ! 2122 V 13 w(is)p 263 2122 V 13 w(quoted)p 396 2122 V ! 12 w(p)18 b Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)18 b ! Ff(35)75 2172 y Fd(rl)p 117 2172 V 13 w(cleanup)p 270 ! 2172 V 12 w(after)p 382 2172 V 12 w(signal)t Fe(.)s(.)6 ! b(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)16 b Ff(32)75 2222 y Fd(rl)p 117 2222 V 13 ! w(clear)p 230 2222 V 13 w(message)7 b Fe(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)h(.)22 b Ff(28)75 2271 y Fd(rl)p 117 2271 ! V 13 w(clear)p 230 2271 V 13 w(signals)7 b Fe(.)f(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)h(.)22 b Ff(33)75 2321 y Fd(rl)p 117 ! 2321 V 13 w(complete)5 b Fe(.)s(.)h(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)18 b Ff(34)75 2371 y Fd(rl)p ! 117 2371 V 13 w(complete)p 290 2371 V 11 w(internal)5 ! b Fe(.)s(.)h(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)17 b Ff(34)75 2421 y ! Fd(rl)p 117 2421 V 13 w(completer)p 310 2421 V 11 w(quote)p ! 421 2421 V 12 w(characters)f Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)19 b Ff(36)75 2471 y Fd(rl)p 117 2471 ! V 13 w(completer)p 310 2471 V 11 w(word)p 401 2471 V ! 13 w(break)p 514 2471 V 12 w(character)o(s)13 b Fe(.)6 ! b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)16 b Ff(36)75 2521 y ! Fd(rl)p 117 2521 V 13 w(completion)p 329 2521 V 11 w(append)p ! 461 2521 V 11 w(character)f Fe(.)6 b(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)g(.)18 b Ff(36)75 2570 y Fd(rl)p 117 2570 V 13 ! w(completion)p 329 2570 V 11 w(display)p 481 2570 V 11 ! w(matches)p 632 2570 V 11 w(hook)d Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)16 b Ff(37)75 2620 y Fd(rl)p 117 2620 V 13 w(completion)p ! 329 2620 V 11 w(entry)p 441 2620 V 12 w(function)21 b ! Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)24 b Ff(34,)13 ! b(35)75 2670 y Fd(rl)p 117 2670 V 13 w(completion)p 329 ! 2670 V 11 w(query)p 441 2670 V 12 w(items)h Fe(.)6 b(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)16 ! b Ff(36)1012 183 y Fd(rl)p 1054 183 V 14 w(copy)p 1148 ! 183 V 12 w(keymap)t Fe(.)t(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)17 b Ff(24)1012 233 y Fd(rl)p 1054 233 V 14 ! w(copy)p 1148 233 V 12 w(text)6 b Fe(.)f(.)h(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)20 b Ff(28)1012 283 y ! Fd(rl)p 1054 283 V 14 w(delete)p 1188 283 V 12 w(text)t ! Fe(.)t(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)17 ! b Ff(28)1012 333 y Fd(rl)p 1054 333 V 14 w(directory)p ! 1247 333 V 10 w(completion)p 1458 333 V 11 w(hook)i Fe(.)6 ! b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)21 ! b Ff(37)1012 382 y Fd(rl)p 1054 382 V 14 w(discard)p ! 1208 382 V 11 w(keymap)9 b Fe(.)s(.)e(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! 22 b Ff(24)1012 432 y Fd(rl)p 1054 432 V 14 w(display)p ! 1208 432 V 11 w(match)p 1319 432 V 12 w(list)6 b Fe(.)f(.)h(.)g(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! h(.)19 b Ff(29)1012 482 y Fd(rl)p 1054 482 V 14 w(do)p ! 1108 482 V 13 w(undo)9 b Fe(.)c(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)22 b Ff(27)1012 532 y Fd(rl)p ! 1054 532 V 14 w(done)15 b Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)17 b Ff(22)1012 ! 582 y Fd(rl)p 1054 582 V 14 w(end)f Fe(.)6 b(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)18 ! b Ff(21)1012 632 y Fd(rl)p 1054 632 V 14 w(end)p 1128 ! 632 V 13 w(undo)p 1221 632 V 12 w(group)10 b Fe(.)c(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)25 b Ff(26)1012 681 y Fd(rl)p 1054 681 ! V 14 w(erase)p 1168 681 V 12 w(empty)p 1280 681 V 12 ! w(line)d Fe(.)6 b(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)24 b Ff(22)1012 ! 731 y Fd(rl)p 1054 731 V 14 w(event)p 1168 731 V 12 w(hook)18 ! b Fe(.)7 b(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)21 ! b Ff(23)1012 781 y Fd(rl)p 1054 781 V 14 w(executing)p ! 1247 781 V 10 w(keymap)e Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)21 ! b Ff(23)1012 831 y Fd(rl)p 1054 831 V 14 w(extend)p 1188 ! 831 V 12 w(line)p 1280 831 V 12 w(buffer)6 b Fe(.)t(.)g(.)g(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.) ! 19 b Ff(28)1012 881 y Fd(rl)p 1054 881 V 14 w(filename)p ! 1228 881 V 11 w(completio)o(n)p 1438 881 V 11 w(desired)d ! Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)19 ! b Ff(37)1012 930 y Fd(rl)p 1054 930 V 14 w(filename)p ! 1228 930 V 11 w(dequoting)p 1418 930 V 10 w(function)d ! Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)19 ! b Ff(35)1012 980 y Fd(rl)p 1054 980 V 14 w(filename)p ! 1228 980 V 11 w(quote)p 1339 980 V 12 w(character)o(s)f ! Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)21 ! b Ff(36)1012 1030 y Fd(rl)p 1054 1030 V 14 w(filename)p ! 1228 1030 V 11 w(quoting)p 1379 1030 V 11 w(desired)f ! Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)23 ! b Ff(37)1012 1080 y Fd(rl)p 1054 1080 V 14 w(filename)p ! 1228 1080 V 11 w(quoting)p 1379 1080 V 11 w(function)18 ! b Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)21 ! b Ff(35)1012 1130 y Fd(rl)p 1054 1130 V 14 w(forced)p ! 1188 1130 V 12 w(update)p 1320 1130 V 11 w(display)9 ! b Fe(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)24 b Ff(27)1012 1180 y Fd(rl)p 1054 1180 ! V 14 w(free)p 1148 1180 V 12 w(line)p 1240 1180 V 13 ! w(state)8 b Fe(.)e(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)23 ! b Ff(32)1012 1229 y Fd(rl)p 1054 1229 V 14 w(function)p ! 1228 1229 V 11 w(dumper)7 b Fe(.)t(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)21 ! b Ff(26)1012 1279 y Fd(rl)p 1054 1279 V 14 w(function)p ! 1228 1279 V 11 w(of)p 1279 1279 V 13 w(keyseq)6 b Fe(.)t(.)g(.)g(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)h(.)19 b Ff(25)1012 1329 y Fd(rl)p 1054 1329 V 14 ! w(funmap)p 1188 1329 V 12 w(names)9 b Fe(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)h(.)f(.)24 b Ff(26)1012 1379 y Fd(rl)p 1054 ! 1379 V 14 w(generic)p 1208 1379 V 11 w(bind)10 b Fe(.)c(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)h(.)f(.)24 b Ff(25)1012 1429 y Fd(rl)p ! 1054 1429 V 14 w(get)p 1128 1429 V 13 w(keymap)5 b Fe(.)t(.)h(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)18 b Ff(24)1012 ! 1478 y Fd(rl)p 1054 1478 V 14 w(get)p 1128 1478 V 13 ! w(keymap)p 1261 1478 V 11 w(by)p 1312 1478 V 14 w(name)9 ! b Fe(.)t(.)d(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)22 b Ff(24)1012 1528 y Fd(rl)p ! 1054 1528 V 14 w(get)p 1128 1528 V 13 w(keymap)p 1261 ! 1528 V 11 w(name)9 b Fe(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)23 ! b Ff(24)1012 1578 y Fd(rl)p 1054 1578 V 14 w(getc)8 b ! Fe(.)e(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)23 b Ff(28)1012 1628 y Fd(rl)p 1054 1628 ! V 14 w(getc)p 1148 1628 V 12 w(function)13 b Fe(.)7 b(.)f(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)17 b Ff(23)1012 1678 y Fd(rl)p ! 1054 1678 V 14 w(ignore)p 1188 1678 V 12 w(completi)o(on)p ! 1399 1678 V 11 w(duplicate)o(s)d Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)h(.)f(.)17 b Ff(36)1012 1727 y Fd(rl)p 1054 1727 ! V 14 w(ignore)p 1188 1727 V 12 w(some)p 1280 1727 V 12 ! w(completion)o(s)p 1511 1727 V 11 w(function)j Fe(.)6 ! b(.)g(.)g(.)g(.)g(.)g(.)24 b Ff(37)1012 1777 y Fd(rl)p ! 1054 1777 V 14 w(inhibit)p 1208 1777 V 11 w(completion)15 ! b Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)19 b Ff(37)1012 1827 y Fd(rl)p ! 1054 1827 V 14 w(initializ)o(e)8 b Fe(.)e(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)24 b Ff(28)1012 1877 y Fd(rl)p ! 1054 1877 V 14 w(insert)p 1188 1877 V 12 w(completi)o(ons)r ! Fe(.)t(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)17 b Ff(34)1012 1927 y Fd(rl)p ! 1054 1927 V 14 w(insert)p 1188 1927 V 12 w(text)t Fe(.)t(.)6 ! b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)17 ! b Ff(28)1012 1977 y Fd(rl)p 1054 1977 V 14 w(instream)g ! Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)20 ! b Ff(22)1012 2026 y Fd(rl)p 1054 2026 V 14 w(invoking)p ! 1228 2026 V 11 w(keyseqs)6 b Fe(.)s(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)19 ! b Ff(26)1012 2076 y Fd(rl)p 1054 2076 V 14 w(invoking)p ! 1228 2076 V 11 w(keyseqs)p 1379 2076 V 11 w(in)p 1430 ! 2076 V 14 w(map)9 b Fe(.)e(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)h(.)f(.)24 b Ff(26)1012 2126 y Fd(rl)p ! 1054 2126 V 14 w(kill)p 1148 2126 V 12 w(text)6 b Fe(.)f(.)h(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)20 b Ff(28)1012 ! 2176 y Fd(rl)p 1054 2176 V 14 w(library)p 1208 2176 V ! 11 w(version)g Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)23 ! b Ff(22)1012 2226 y Fd(rl)p 1054 2226 V 14 w(line)p 1148 ! 2226 V 12 w(buffer)17 b Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)19 b Ff(21)1012 2275 y Fd(rl)p 1054 2275 V ! 14 w(list)p 1148 2275 V 12 w(funmap)p 1280 2275 V 12 ! w(names)7 b Fe(.)e(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)21 b Ff(26)1012 ! 2325 y Fd(rl)p 1054 2325 V 14 w(make)p 1148 2325 V 12 ! w(bare)p 1240 2325 V 13 w(keymap)9 b Fe(.)s(.)d(.)h(.)f(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.) ! 22 b Ff(24)1012 2375 y Fd(rl)p 1054 2375 V 14 w(make)p ! 1148 2375 V 12 w(keymap)t Fe(.)t(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)17 b Ff(24)1012 2425 y Fd(rl)p 1054 2425 ! V 14 w(mark)e Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)17 b Ff(21)1012 2475 ! y Fd(rl)p 1054 2475 V 14 w(message)6 b Fe(.)s(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)19 b Ff(27)1012 ! 2524 y Fd(rl)p 1054 2524 V 14 w(modifying)s Fe(.)s(.)6 ! b(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)17 ! b Ff(27)1012 2574 y Fd(rl)p 1054 2574 V 14 w(named)p ! 1168 2574 V 12 w(function)8 b Fe(.)s(.)f(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)22 b Ff(25)1012 2624 y Fd(rl)p 1054 2624 V 14 w(on)p ! 1108 2624 V 13 w(new)p 1181 2624 V 13 w(line)7 b Fe(.)t(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)20 b Ff(27)p eop %%Page: 51 53 ! 51 52 bop 75 -58 a Fu(F)l(unction)16 b(and)f(V)l(ariable)i(Index)1187 ! b(51)75 183 y Fd(rl)p 117 183 12 2 v 13 w(on)p 170 183 ! V 14 w(new)p 244 183 V 13 w(line)p 337 183 V 12 w(with)p ! 429 183 V 13 w(prompt)5 b Fe(.)t(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)18 b Ff(27)75 233 y Fd(rl)p ! 117 233 V 13 w(outstream)d Fe(.)7 b(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)h(.)18 b Ff(22)75 283 y Fd(rl)p 117 283 ! V 13 w(parse)p 230 283 V 13 w(and)p 303 283 V 13 w(bind)9 ! b Fe(.)d(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)24 b Ff(25)75 ! 333 y Fd(rl)p 117 333 V 13 w(pending)p 270 333 V 12 w(input)14 ! b Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)16 ! b Ff(22)75 382 y Fd(rl)p 117 382 V 13 w(point)22 b Fe(.)6 ! b(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)24 b Ff(21)75 432 y Fd(rl)p 117 432 V 13 w(possible)p ! 290 432 V 11 w(completions)6 b Fe(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)22 b Ff(34)75 ! 482 y Fd(rl)p 117 482 V 13 w(pre)p 190 482 V 13 w(input)p ! 303 482 V 13 w(hook)16 b Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! 18 b Ff(22)75 532 y Fd(rl)p 117 532 V 13 w(prompt)i Fe(.)7 ! b(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! 22 b Ff(22)75 582 y Fd(rl)p 117 582 V 13 w(read)p 210 ! 582 V 13 w(init)p 303 582 V 13 w(file)9 b Fe(.)d(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)24 b Ff(25)75 632 y Fd(rl)p 117 632 V ! 13 w(read)p 210 632 V 13 w(key)8 b Fe(.)d(.)h(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)20 b Ff(28)75 681 ! y Fd(rl)p 117 681 V 13 w(readline)p 290 681 V 11 w(name)15 ! b Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)16 ! b Ff(22)75 731 y Fd(rl)p 117 731 V 13 w(redisplay)t Fe(.)s(.)6 ! b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)16 ! b Ff(27)75 781 y Fd(rl)p 117 781 V 13 w(redisplay)p 310 ! 781 V 11 w(function)f Fe(.)6 b(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)18 b Ff(23)75 ! 831 y Fd(rl)p 117 831 V 13 w(reset)p 230 831 V 13 w(after)p ! 343 831 V 12 w(signal)6 b Fe(.)t(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)19 ! b Ff(32)75 881 y Fd(rl)p 117 881 V 13 w(reset)p 230 881 ! V 13 w(line)p 323 881 V 12 w(state)9 b Fe(.)t(.)d(.)g(.)g(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.) ! f(.)21 b Ff(27)75 930 y Fd(rl)p 117 930 V 13 w(reset)p ! 230 930 V 13 w(terminal)8 b Fe(.)s(.)e(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! 21 b Ff(29)75 980 y Fd(rl)p 117 980 V 13 w(resize)p 250 ! 980 V 12 w(terminal)7 b Fe(.)s(.)f(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)20 ! b Ff(33)75 1030 y Fd(rl)p 117 1030 V 13 w(restore)p 270 ! 1030 V 12 w(prompt)9 b Fe(.)s(.)d(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)21 ! b Ff(28)75 1080 y Fd(rl)p 117 1080 V 13 w(save)p 210 ! 1080 V 13 w(prompt)t Fe(.)t(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)17 b Ff(28)75 1130 y Fd(rl)p 117 1130 V 13 ! w(set)p 190 1130 V 13 w(keymap)5 b Fe(.)t(.)h(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)18 b Ff(24)75 1180 y Fd(rl)p ! 117 1180 V 13 w(set)p 190 1180 V 13 w(signals)t Fe(.)t(.)6 ! b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)17 ! b Ff(33)75 1229 y Fd(rl)p 117 1229 V 13 w(special)p 270 ! 1229 V 12 w(prefixes)h Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)21 ! b Ff(36)75 1279 y Fd(rl)p 117 1279 V 13 w(startup)p 270 ! 1279 V 12 w(hook)16 b Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)17 b Ff(22)75 1329 y Fd(rl)p 117 1329 V 13 w(stuff)p ! 230 1329 V 13 w(char)5 b Fe(.)t(.)h(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)18 b Ff(28)75 1379 y Fd(rl)p 117 1379 ! V 13 w(terminal)p 290 1379 V 11 w(name)d Fe(.)6 b(.)g(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)g(.)16 b Ff(22)75 1429 y Fd(rl)p 117 ! 1429 V 13 w(unbind)p 250 1429 V 12 w(command)p 402 1429 ! V 12 w(in)p 454 1429 V 13 w(map)5 b Fe(.)g(.)h(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)18 ! b Ff(25)75 1478 y Fd(rl)p 117 1478 V 13 w(unbind)p 250 ! 1478 V 12 w(function)p 422 1478 V 11 w(in)p 473 1478 ! V 14 w(map)t Fe(.)t(.)6 b(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)17 b Ff(25)75 1528 y Fd(rl)p ! 117 1528 V 13 w(unbind)p 250 1528 V 12 w(key)5 b Fe(.)g(.)h(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)18 b Ff(25)75 ! 1578 y Fd(rl)p 117 1578 V 13 w(unbind)p 250 1578 V 12 ! w(key)p 322 1578 V 13 w(in)p 375 1578 V 13 w(map)10 b ! Fe(.)c(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)23 b Ff(25)1012 183 y ! Fs(S)1012 241 y Fd(self-insert)9 b(\(a,)j(b,)g(A,)g(1,)g(!,)g(...\))t ! Fe(.)5 b(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)18 ! b Ff(14)1012 291 y Fd(set-mark)10 b(\(C-@\))e Fe(.)f(.)f(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)24 b Ff(17)1012 341 y(sho)o(w-all-if-am) ! o(bigu)q(ous)8 b Fe(.)g(.)e(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)20 ! b Ff(6)1012 391 y Fd(start-kbd-m)o(ac)o(ro)9 b(\(C-x)j(\(\))e ! Fe(.)c(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)g(.)24 b Ff(16)1012 490 y Fs(T)1012 549 y ! Fd(tab-insert)9 b(\(M-TAB\))c Fe(.)t(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)18 ! b Ff(14)1012 598 y Fd(tilde-expan)o(d)10 b(\(M-~\))5 ! b Fe(.)t(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)18 b Ff(17)1012 ! 648 y Fd(to)p 1054 648 V 14 w(lower)9 b Fe(.)t(.)d(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)22 ! b Ff(29)1012 698 y Fd(to)p 1054 698 V 14 w(upper)9 b ! Fe(.)t(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)g(.)g(.)22 b Ff(29)1012 748 y Fd(transpose-c)o(ha)o(rs)9 ! b(\(C-t\))f Fe(.)e(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)23 b Ff(14)1012 798 ! y Fd(transpose-w)o(or)o(ds)9 b(\(M-t\))f Fe(.)e(.)h(.)f(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)23 ! b Ff(14)1012 897 y Fs(U)1012 955 y Fd(undo)12 b(\(C-)p ! 1166 955 V 13 w(,)g(C-x)g(C-u\))5 b Fe(.)t(.)h(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)18 b Ff(17)1012 1005 y Fd(universal-a)o(rg)o(ume)o(nt)9 ! b(\(\))g Fe(.)d(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)23 b Ff(15)1012 1055 y ! Fd(unix-line-d)o(is)o(car)o(d)10 b(\(C-u\))d Fe(.)t(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)21 ! b Ff(14)1012 1105 y Fd(unix-word-r)o(ub)o(out)9 b(\(C-w\))g ! Fe(.)t(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)22 b Ff(15)1012 1155 y Fd(upcase-word)9 ! b(\(M-u\))d Fe(.)f(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)20 ! b Ff(14)1012 1204 y Fd(uppercase)p 1194 1204 V 11 w(p)5 ! b Fe(.)h(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)18 b Ff(29)1012 1254 y Fd(username)p 1174 1254 V 11 ! w(completion)p 1385 1254 V 11 w(function)s Fe(.)s(.)6 ! b(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)16 ! b Ff(35)1012 1354 y Fs(V)1012 1412 y Ff(visible-stats)t ! Fe(.)9 b(.)d(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)17 b Ff(6)1012 1512 y Fs(Y)1012 1570 y Fd(yank)12 ! b(\(C-y\))7 b Fe(.)t(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)20 b Ff(15)1012 1620 y Fd(yank-last-a)o(rg)9 ! b(\(M-.,)i(M-)p 1433 1620 V 13 w(\))t Fe(.)6 b(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)17 ! b Ff(13)1012 1669 y Fd(yank-nth-ar)o(g)10 b(\(M-C-y\))e ! Fe(.)e(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)g(.)g(.)g(.)g(.)h(.)24 b Ff(13)1012 1719 y Fd(yank-pop)10 ! b(\(M-y\))e Fe(.)f(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)24 ! b Ff(15)p eop %%Page: 52 54 ! 52 53 bop 75 -58 a Fu(52)1299 b(GNU)15 b(Readline)i(Library)p eop ! %%Page: -1 55 ! -1 54 bop 1862 -58 a Fu(i)75 183 y Fq(T)-7 b(able)27 ! b(of)f(Con)n(ten)n(ts)75 354 y Fs(1)67 b(Command)22 b(Line)i(Editing)d ! Fb(.)10 b(.)h(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)h ! (.)f(.)g(.)g(.)42 b Fs(1)224 423 y Fu(1.1)j(In)o(tro)q(duction)16 ! b(to)f(Line)h(Editing)e Fa(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)27 b Fu(1)224 478 y(1.2)45 b(Readline)17 b(In)o(teraction)8 ! b Fa(.)g(.)g(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)23 b Fu(1)374 532 y(1.2.1)44 b(Readline)17 ! b(Bare)e(Essen)o(tials)f Fa(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h (.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)27 ! b Fu(1)374 587 y(1.2.2)44 b(Readline)17 b(Mo)o(v)o(emen)o(t)d(Commands) ! 7 b Fa(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f ! (.)h(.)21 b Fu(2)374 642 y(1.2.3)44 b(Readline)17 b(Killing)h(Commands) ! 11 b Fa(.)c(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h ! (.)f(.)h(.)f(.)h(.)25 b Fu(2)374 697 y(1.2.4)44 b(Readline)17 ! b(Argumen)o(ts)12 b Fa(.)c(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)27 ! b Fu(3)374 752 y(1.2.5)44 b(Searc)o(hing)16 b(for)e(Commands)h(in)h ! (the)f(History)e Fa(.)8 b(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)27 ! b Fu(3)224 806 y(1.3)45 b(Readline)17 b(Init)g(File)e ! Fa(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)f(.)29 b Fu(4)374 861 y(1.3.1)44 b(Readline)17 ! b(Init)f(File)h(Syn)o(tax)7 b Fa(.)g(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)21 ! b Fu(4)374 916 y(1.3.2)44 b(Conditional)16 b(Init)g(Constructs)5 ! b Fa(.)i(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)g(.)f(.)19 b Fu(8)374 971 y(1.3.3)44 b(Sample)16 ! b(Init)g(File)11 b Fa(.)e(.)e(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)26 b Fu(9)224 1026 y(1.4)45 b(Bindable)17 b(Readline)h ! (Commands)6 b Fa(.)h(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)21 ! b Fu(12)374 1080 y(1.4.1)44 b(Commands)14 b(F)l(or)h(Mo)o(ving)e ! Fa(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)h(.)28 b Fu(12)374 1135 y(1.4.2)44 b(Commands)14 b(F)l(or)h(Manipulating)i(The)e(History)9 ! b Fa(.)e(.)h(.)f(.)h(.)f(.)h(.)24 b Fu(12)374 1190 y(1.4.3)44 ! b(Commands)14 b(F)l(or)h(Changing)h(T)l(ext)e Fa(.)8 b(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)30 ! b Fu(13)374 1245 y(1.4.4)44 b(Killing)18 b(And)e(Y)l(anking)9 ! b Fa(.)e(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)24 b Fu(14)374 ! 1299 y(1.4.5)44 b(Sp)q(ecifying)17 b(Numeric)f(Argumen)o(ts)c ! Fa(.)c(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)27 ! b Fu(15)374 1354 y(1.4.6)44 b(Letting)15 b(Readline)j(T)o(yp)q(e)d(F)l ! (or)g(Y)l(ou)10 b Fa(.)d(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)25 b Fu(16)374 1409 y(1.4.7)44 b(Keyb)q(oard)15 ! b(Macros)6 b Fa(.)h(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f (.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)21 ! b Fu(16)374 1464 y(1.4.8)44 b(Some)15 b(Miscellaneous)i(Commands)7 ! b Fa(.)g(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! 22 b Fu(17)224 1519 y(1.5)45 b(Readline)17 b(vi)f(Mo)q(de)e ! Fa(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)28 b Fu(18)75 1640 y Fs(2)67 b(Programming)23 ! b(with)g(GNU)f(Readline)12 b Fb(.)f(.)g(.)f(.)g(.)g(.)g(.)h(.)f(.)35 ! b Fs(19)224 1708 y Fu(2.1)45 b(Basic)16 b(Beha)o(vior)8 ! b Fa(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)f(.)h(.)f(.)23 b Fu(19)224 1763 y(2.2)45 ! b(Custom)14 b(F)l(unctions)7 b Fa(.)i(.)f(.)f(.)h(.)f(.)h(.)f(.)h(.)f (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)22 b Fu(20)374 ! 1818 y(2.2.1)44 b(The)15 b(F)l(unction)h(T)o(yp)q(e)11 ! b Fa(.)d(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)26 b Fu(20)374 ! 1873 y(2.2.2)44 b(W)l(riting)16 b(a)e(New)i(F)l(unction)6 ! b Fa(.)i(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.) ! f(.)h(.)f(.)h(.)f(.)h(.)f(.)21 b Fu(21)224 1928 y(2.3)45 ! b(Readline)17 b(V)l(ariables)f Fa(.)8 b(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h ! (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)29 b Fu(21)224 ! 1982 y(2.4)45 b(Readline)17 b(Con)o(v)o(enience)g(F)l(unctions)7 ! b Fa(.)i(.)e(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)23 b Fu(23)374 2037 y(2.4.1)44 ! b(Naming)15 b(a)g(F)l(unction)e Fa(.)7 b(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)27 b Fu(23)374 2092 y(2.4.2)44 b(Selecting)17 ! b(a)e(Keymap)6 b Fa(.)h(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h ! (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)21 ! b Fu(24)374 2147 y(2.4.3)44 b(Binding)17 b(Keys)5 b Fa(.)j(.)f(.)h(.)f (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) ! f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)20 b ! Fu(24)374 2202 y(2.4.4)44 b(Asso)q(ciating)16 b(F)l(unction)g(Names)f ! (and)g(Bindings)8 b Fa(.)h(.)f(.)f(.)h(.)f(.)h(.)23 b ! Fu(25)374 2256 y(2.4.5)44 b(Allo)o(wing)16 b(Undoing)f ! Fa(.)8 b(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)29 b ! Fu(26)374 2311 y(2.4.6)44 b(Redispla)o(y)10 b Fa(.)f(.)f(.)g(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)26 ! b Fu(27)374 2366 y(2.4.7)44 b(Mo)q(difying)16 b(T)l(ext)7 ! b Fa(.)g(.)g(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)22 ! b Fu(28)374 2421 y(2.4.8)44 b(Utilit)o(y)16 b(F)l(unctions)e ! Fa(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)28 ! b Fu(28)374 2475 y(2.4.9)44 b(Alternate)15 b(In)o(terface)5 ! b Fa(.)i(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)20 b ! Fu(29)374 2530 y(2.4.10)43 b(An)16 b(Example)f Fa(.)8 ! b(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)30 ! b Fu(30)224 2585 y(2.5)45 b(Readline)17 b(Signal)g(Handling)12 ! b Fa(.)c(.)g(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)27 ! b Fu(31)224 2640 y(2.6)45 b(Custom)14 b(Completers)f ! Fa(.)8 b(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h ! (.)f(.)28 b Fu(33)p eop ! %%Page: -2 56 ! -2 55 bop 75 -58 a Fu(ii)1321 b(GNU)15 b(Readline)i(Library)374 ! 42 y(2.6.1)44 b(Ho)o(w)14 b(Completing)i(W)l(orks)10 ! b Fa(.)d(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.) ! f(.)h(.)f(.)h(.)f(.)h(.)f(.)25 b Fu(33)374 96 y(2.6.2)44 ! b(Completion)16 b(F)l(unctions)6 b Fa(.)i(.)g(.)f(.)h(.)f(.)h(.)f(.)h (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) ! 21 b Fu(34)374 151 y(2.6.3)44 b(Completion)16 b(V)l(ariables)c ! Fa(.)c(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)27 b Fu(35)374 206 y(2.6.4)44 b(A)15 b(Short)g(Completion)h(Example)5 b ! Fa(.)j(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h ! (.)f(.)20 b Fu(37)75 327 y Fs(Concept)i(Index)10 b Fb(.)i(.)e(.)g(.)g (.)g(.)h(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)h(.)f(.)g(.)g(.)h(.)f(.)33 b Fs(47)75 462 y(F)-6 b(unction)25 b(and)d(V)-6 b(ariable)24 b(Index)9 ! b Fb(.)i(.)f(.)g(.)h(.)f(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)32 b Fs(49)p eop %%Trailer end --- 2288,4986 ---- (\(char)f(*\)NULL;)p eop %%Page: 20 22 ! 20 21 bop 75 -58 a Fu(20)1299 b(GNU)15 b(Readline)h(Library)290 ! 149 y Ft(})243 253 y(/*)23 b(Get)h(a)f(line)h(from)f(the)h(user.)f(*/) ! 243 305 y(line_read)f(=)i(readline)f(\(""\);)243 409 y(/*)g(If)h(the)f(line)h(has)f(any)h(text)f(in)g(it,)h(save)f(it)h(on)f ! (the)h(history.)f(*/)243 461 y(if)g(\(line_read)g(&&)g(*line_read\))290 ! 513 y(add_history)g(\(line_read\);)243 616 y(return)g(\(line_read\);) ! 195 668 y(})137 738 y Fu(This)13 b(function)f(giv)o(es)h(the)e(user)h ! (the)g(default)h(b)q(eha)o(viour)g(of)1169 736 y Fn(h)p ! 1181 710 74 2 v 1181 738 a Fm(T)m(AB)p 1181 746 V 1253 ! 736 a Fn(i)1280 738 y Fu(completion:)19 b(completion)13 ! b(on)f(\014le)75 793 y(names.)20 b(If)c(y)o(ou)f(do)g(not)g(w)o(an)o(t) ! f(Readline)j(to)d(complete)j(on)e(\014lenames,)h(y)o(ou)f(can)g(c)o ! (hange)h(the)f(binding)75 848 y(of)g(the)205 846 y Fn(h)p ! 217 820 V 217 848 a Fm(T)m(AB)p 217 855 V 289 846 a Fn(i)319 ! 848 y Fu(k)o(ey)g(with)h Ft(rl_bind_key\(\))p Fu(.)195 ! 914 y Ft(int)23 b(rl_bind_key)g(\(int)g Fk(k)o(ey)p Ft(,)h ! (rl_command_func_t)d(*)p Fk(function)p Ft(\);)137 984 ! y(rl_bind_key\(\))15 b Fu(tak)o(es)h(t)o(w)o(o)g(argumen)o(ts:)22 ! b Fk(k)o(ey)e Fu(is)e(the)e(c)o(haracter)g(that)g(y)o(ou)h(w)o(an)o(t)f ! (to)g(bind,)i(and)75 1039 y Fk(function)h Fu(is)f(the)g(address)g(of)g ! (the)g(function)g(to)g(call)h(when)f Fk(k)o(ey)k Fu(is)c(pressed.)29 ! b(Binding)1628 1037 y Fn(h)p 1641 1011 V 1641 1039 a ! Fm(T)m(AB)p 1641 1046 V 1712 1037 a Fn(i)1745 1039 y ! Fu(to)17 b Ft(rl_)75 1094 y(insert\(\))f Fu(mak)o(es)422 ! 1092 y Fn(h)p 434 1066 V 434 1094 a Fm(T)m(AB)p 434 1101 ! V 506 1092 a Fn(i)539 1094 y Fu(insert)i(itself.)28 b ! Ft(rl_bind_key\(\))15 b Fu(returns)j(non-zero)g(if)g ! Fk(k)o(ey)j Fu(is)d(not)f(a)g(v)m(alid)75 1148 y(ASCI)q(I)f(c)o (haracter)f(co)q(de)h(\(b)q(et)o(w)o(een)f(0)g(and)g(255\).)137 ! 1218 y(Th)o(us,)g(to)g(disable)h(the)g(default)703 1216 ! y Fn(h)p 716 1190 V 716 1218 a Fm(T)m(AB)p 716 1226 V ! 787 1216 a Fn(i)817 1218 y Fu(b)q(eha)o(vior,)g(the)f(follo)o(wing)h ! (su\016ces:)195 1285 y Ft(rl_bind_key)22 b(\('\\t',)h(rl_insert\);)137 ! 1354 y Fu(This)14 b(co)q(de)g(should)g(b)q(e)g(executed)g(once)g(at)e (the)h(start)f(of)h(y)o(our)g(program;)f(y)o(ou)h(migh)o(t)g(write)g(a) ! g(func-)75 1409 y(tion)k(called)h Ft(initialize_readline\(\))13 ! b Fu(whic)o(h)k(p)q(erforms)f(this)h(and)g(other)f(desired)h ! (initializations,)75 1464 y(suc)o(h)f(as)e(installing)k(custom)c (completers)i(\(see)f(Section)h(2.6)f([Custom)f(Completers],)g(page)h ! (38\).)75 1599 y Fs(2.2)33 b(Custom)21 b(F)-6 b(unctions)137 ! 1697 y Fu(Readline)14 b(pro)o(vides)f(man)o(y)e(functions)i(for)f (manipulating)i(the)e(text)g(of)g(the)g(line,)i(but)e(it)h(isn't)f(p)q ! (ossi-)75 1752 y(ble)i(to)f(an)o(ticipate)h(the)f(needs)h(of)f(all)h (programs.)k(This)13 b(section)h(describ)q(es)h(the)e(v)m(arious)h ! (functions)g(and)75 1807 y(v)m(ariables)g(de\014ned)h(within)f(the)f ! (Readline)i(library)e(whic)o(h)h(allo)o(w)g(a)e(user)h(program)f(to)h ! (add)g(customized)75 1862 y(functionalit)o(y)j(to)f(Readline.)137 ! 1931 y(Before)j(declaring)i(an)o(y)e(functions)h(that)f(customize)g ! (Readline's)h(b)q(eha)o(vior,)h(or)d(using)i(an)o(y)f(func-)75 ! 1986 y(tionalit)o(y)23 b(Readline)h(pro)o(vides)g(in)f(other)g(co)q (de,)h(an)f(application)i(writer)d(should)i(include)h(the)e(\014le)75 ! 2041 y Ft()14 b Fu(in)j(an)o(y)g(\014le)h(that)e ! (uses)h(Readline's)g(features.)24 b(Since)19 b(some)d(of)g(the)h ! (de\014-)75 2096 y(nitions)g(in)f Ft(readline.h)e Fu(use)i(the)g Ft(stdio)f Fu(library)l(,)h(the)g(\014le)g Ft()f ! Fu(should)h(b)q(e)g(included)j(b)q(efore)75 2151 y Ft(readline.h)p ! Fu(.)75 2268 y Fj(2.2.1)30 b(Readline)20 b(T)n(yp)r(edefs)137 ! 2366 y Fu(F)l(or)15 b(readabilt)o(y)l(,)g(w)o(e)g(declare)i(a)d(n)o(um) ! o(b)q(er)i(of)f(new)g(ob)s(ject)g(t)o(yp)q(es,)g(all)h(p)q(oin)o(ters)f ! (to)g(functions.)137 2436 y(The)j(reason)g(for)f(declaring)i(these)f ! (new)g(t)o(yp)q(es)g(is)h(to)e(mak)o(e)g(it)h(easier)h(to)e(write)h(co) ! q(de)g(describing)75 2491 y(p)q(oin)o(ters)e(to)e(C)h(functions)h(with) ! g(appropriately)f(protot)o(yp)q(ed)g(argumen)o(ts)g(and)g(return)g(v)m ! (alues.)137 2560 y(F)l(or)j(instance,)i(sa)o(y)e(w)o(e)g(w)o(an)o(t)f ! (to)h(declare)h(a)f(v)m(ariable)i Fk(func)i Fu(as)c(a)g(p)q(oin)o(ter)h ! (to)f(a)g(function)h(whic)o(h)75 2615 y(tak)o(es)12 b(t)o(w)o(o)g ! Ft(int)g Fu(argumen)o(ts)g(and)h(returns)g(an)g Ft(int)f ! Fu(\(this)h(is)g(the)g(t)o(yp)q(e)g(of)g(all)g(of)g(the)g(Readline)h ! (bindable)75 2670 y(functions\).)20 b(Instead)c(of)f(the)g(classic)h(C) ! f(declaration)p eop %%Page: 21 23 21 22 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)843 b(21)137 149 y Ft(int)15 b(\(*func\)\(\);)75 ! 220 y Fu(or)g(the)g(ANSI-C)h(st)o(yle)f(declaration)137 ! 290 y Ft(int)g(\(*func\)\(int,)f(int\);)75 360 y Fu(w)o(e)h(ma)o(y)f ! (write)137 430 y Ft(rl_command_func_t)f(*func;)137 500 ! y Fu(The)j(full)g(list)g(of)f(function)h(p)q(oin)o(ter)g(t)o(yp)q(es)f ! (a)o(v)m(ailable)i(is)75 584 y Ft(typedef)d(int)h(rl_command_func_t)e ! (\(int,)h(int\);)75 652 y(typedef)g(char)h(*rl_compentry_func_t)d ! (\(const)j(char)f(*,)h(int\);)75 721 y(typedef)f(char)h ! (**rl_completion_func_t)d(\(const)i(char)h(*,)g(int,)f(int\);)75 ! 790 y(typedef)g(char)h(*rl_quote_func_t)e(\(char)h(*,)h(int,)g(char)f ! (*\);)75 858 y(typedef)g(char)h(*rl_dequote_func_t)d(\(char)j(*,)g ! (int\);)75 927 y(typedef)f(int)h(rl_compignore_func_t)d(\(char)j(**\);) ! 75 996 y(typedef)f(void)h(rl_compdisp_func_t)d(\(char)j(**,)g(int,)f ! (int\);)75 1064 y(typedef)g(int)h(rl_hook_func_t)e(\(void\);)75 ! 1133 y(typedef)h(int)h(rl_getc_func_t)e(\(FILE)i(*\);)75 ! 1202 y(typedef)f(int)h(rl_linebuf_func_t)e(\(char)h(*,)h(int\);)75 ! 1270 y(typedef)f(int)h(rl_intfunc_t)e(\(int\);)75 1339 ! y(#define)h(rl_ivoidfunc_t)f(rl_hook_func_t)75 1408 y(typedef)h(int)h ! (rl_icpfunc_t)e(\(char)i(*\);)75 1476 y(typedef)f(int)h(rl_icppfunc_t)e ! (\(char)i(**\);)75 1545 y(typedef)f(void)h(rl_voidfunc_t)e(\(void\);)75 ! 1614 y(typedef)h(void)h(rl_vintfunc_t)e(\(int\);)75 1682 ! y(typedef)h(void)h(rl_vcpfunc_t)e(\(char)i(*\);)75 1751 ! y(typedef)f(void)h(rl_vcppfunc_t)e(\(char)i(**\);)75 ! 1855 y Fj(2.2.2)30 b(W)-5 b(riting)20 b(a)h(New)f(F)-5 ! b(unction)137 1954 y Fu(In)17 b(order)f(to)f(write)h(new)h(functions)g ! (for)e(Readline,)i(y)o(ou)f(need)h(to)e(kno)o(w)h(the)g(calling)i(con)o ! (v)o(en)o(tions)75 2009 y(for)g(k)o(eyb)q(oard-in)o(v)o(ok)o(ed)h (functions,)g(and)g(the)f(names)h(of)f(the)g(v)m(ariables)i(that)d ! (describ)q(e)k(the)d(curren)o(t)75 2064 y(state)c(of)h(the)g(line)i ! (read)e(so)g(far.)137 2134 y(The)h(calling)h(sequence)f(for)f(a)f ! (command)i Ft(foo)e Fu(lo)q(oks)i(lik)o(e)195 2201 y ! Ft(foo)23 b(\(int)h(count,)f(int)g(key\))75 2271 y Fu(where)18 ! b Fk(coun)o(t)h Fu(is)f(the)g(n)o(umeric)h(argumen)o(t)e(\(or)h(1)f(if) ! i(defaulted\))f(and)g Fk(k)o(ey)k Fu(is)d(the)f(k)o(ey)g(that)f(in)o(v) ! o(ok)o(ed)75 2326 y(this)f(function.)137 2396 y(It)c(is)g(completely)h (up)f(to)f(the)g(function)i(as)e(to)g(what)g(should)h(b)q(e)g(done)g ! (with)g(the)g(n)o(umeric)g(argumen)o(t.)75 2451 y(Some)20 b(functions)h(use)f(it)g(as)g(a)g(rep)q(eat)g(coun)o(t,)g(some)g(as)g (a)f(\015ag,)i(and)f(others)g(to)f(c)o(ho)q(ose)h(alternate)75 ! 2506 y(b)q(eha)o(vior)i(\(refreshing)g(the)g(curren)o(t)f(line)j(as)d (opp)q(osed)h(to)f(refreshing)i(the)e(screen,)j(for)d(example\).)75 ! 2560 y(Some)c(c)o(ho)q(ose)f(to)g(ignore)h(it.)24 b(In)18 b(general,)f(if)g(a)f(function)h(uses)g(the)g(n)o(umeric)h(argumen)o(t) ! d(as)i(a)f(rep)q(eat)75 2615 y(coun)o(t,)e(it)g(should)h(b)q(e)f(able)h (to)e(do)h(something)h(useful)g(with)f(b)q(oth)g(negativ)o(e)g(and)g(p) ! q(ositiv)o(e)h(argumen)o(ts.)75 2670 y(A)o(t)g(the)g(v)o(ery)g(least,)g (it)g(should)h(b)q(e)g(a)o(w)o(are)e(that)h(it)g(can)g(b)q(e)h(passed)g ! (a)f(negativ)o(e)g(argumen)o(t.)p eop %%Page: 22 24 ! 22 23 bop 75 -58 a Fu(22)1299 b(GNU)15 b(Readline)h(Library)75 ! 149 y Fs(2.3)33 b(Readline)23 b(V)-6 b(ariables)137 245 ! y Fu(These)16 b(v)m(ariables)g(are)f(a)o(v)m(ailable)i(to)e(function)h ! (writers.)1773 356 y(V)l(ariable)-1861 b Fi(char)20 b(*)f ! Fh(rl)p 286 356 18 3 v 21 w(line)p 395 356 V 23 w(bu\013er)195 ! 410 y Fu(This)d(is)g(the)g(line)h(gathered)f(so)f(far.)20 ! b(Y)l(ou)c(are)f(w)o(elcome)h(to)f(mo)q(dify)h(the)g(con)o(ten)o(ts)f ! (of)g(the)h(line,)195 465 y(but)i(see)g(Section)h(2.4.5)d([Allo)o(wing) ! i(Undoing],)h(page)e(29.)27 b(The)18 b(function)h Ft(rl_extend_line_) ! 195 520 y(buffer)14 b Fu(is)i(a)o(v)m(ailable)h(to)d(increase)j(the)e ! (memory)f(allo)q(cated)j(to)d Ft(rl_line_buffer)p Fu(.)1773 ! 631 y(V)l(ariable)-1861 b Fi(int)20 b Fh(rl)p 215 631 ! V 21 w(p)r(oin)n(t)195 686 y Fu(The)15 b(o\013set)g(of)f(the)i(curren)o ! (t)f(cursor)g(p)q(osition)h(in)g Ft(rl_line_buffer)d ! Fu(\(the)i Fl(p)n(oint)t Fu(\).)1773 797 y(V)l(ariable)-1861 ! b Fi(int)20 b Fh(rl)p 215 797 V 21 w(end)195 852 y Fu(The)14 ! b(n)o(um)o(b)q(er)g(of)g(c)o(haracters)f(presen)o(t)h(in)h ! Ft(rl_line_buffer)p Fu(.)i(When)e Ft(rl_point)e Fu(is)h(at)f(the)h(end) ! 195 906 y(of)h(the)g(line,)i Ft(rl_point)d Fu(and)h Ft(rl_end)f ! Fu(are)h(equal.)1773 1017 y(V)l(ariable)-1861 b Fi(int)20 ! b Fh(rl)p 215 1017 V 21 w(mark)195 1072 y Fu(The)f Fk(mark)h ! Fu(\(sa)o(v)o(ed)e(p)q(osition\))h(in)g(the)g(curren)o(t)f(line.)31 ! b(If)19 b(set,)g(the)f(mark)g(and)h(p)q(oin)o(t)g(de\014ne)g(a)195 ! 1127 y Fl(r)n(e)n(gion)p Fu(.)1773 1238 y(V)l(ariable)-1861 ! b Fi(int)20 b Fh(rl)p 215 1238 V 21 w(done)195 1293 y ! Fu(Setting)11 b(this)g(to)g(a)f(non-zero)h(v)m(alue)h(causes)f ! (Readline)h(to)f(return)f(the)h(curren)o(t)g(line)h(immediately)l(.) ! 1773 1404 y(V)l(ariable)-1861 b Fi(int)20 b Fh(rl)p 215 ! 1404 V 21 w(n)n(um)p 347 1404 V 19 w(c)n(hars)p 496 1404 ! V 20 w(to)p 567 1404 V 21 w(read)195 1459 y Fu(Setting)d(this)g(to)f(a) ! g(p)q(ositiv)o(e)h(v)m(alue)h(b)q(efore)f(calling)h Ft(readline\(\))d ! Fu(causes)h(Readline)i(to)e(return)195 1514 y(after)h(accepting)i(that) ! e(man)o(y)g(c)o(haracters,)h(rather)f(than)h(reading)g(up)g(to)f(a)h(c) ! o(haracter)f(b)q(ound)195 1568 y(to)e Ft(accept-line)p ! Fu(.)1773 1679 y(V)l(ariable)-1861 b Fi(int)20 b Fh(rl)p ! 215 1679 V 21 w(p)r(ending)p 436 1679 V 20 w(input)195 ! 1734 y Fu(Setting)13 b(this)g(to)f(a)g(v)m(alue)i(mak)o(es)e(it)h(the)f ! (next)h(k)o(eystrok)o(e)f(read.)19 b(This)13 b(is)g(a)f(w)o(a)o(y)g(to) ! f(stu\013)h(a)h(single)195 1789 y(c)o(haracter)h(in)o(to)i(the)f(input) ! h(stream.)1773 1900 y(V)l(ariable)-1861 b Fi(int)20 b ! Fh(rl)p 215 1900 V 21 w(dispatc)n(hing)195 1955 y Fu(Set)12 ! b(to)g(a)f(non-zero)i(v)m(alue)g(if)g(a)f(function)h(is)f(b)q(eing)i ! (called)f(from)f(a)f(k)o(ey)h(binding;)j(zero)d(otherwise.)195 ! 2010 y(Application)20 b(functions)e(can)g(test)g(this)g(to)f(disco)o(v) ! o(er)h(whether)g(they)g(w)o(ere)g(called)h(directly)g(or)195 ! 2064 y(b)o(y)c(Readline's)h(dispatc)o(hing)h(mec)o(hanism.)1773 ! 2175 y(V)l(ariable)-1861 b Fi(int)20 b Fh(rl)p 215 2175 ! V 21 w(erase)p 363 2175 V 20 w(empt)n(y)p 540 2175 V ! 20 w(line)195 2230 y Fu(Setting)j(this)h(to)e(a)h(non-zero)g(v)m(alue)h ! (causes)f(Readline)i(to)d(completely)i(erase)f(the)g(curren)o(t)195 ! 2285 y(line,)g(including)h(an)o(y)c(prompt,)h(an)o(y)g(time)g(a)f ! (newline)j(is)e(t)o(yp)q(ed)g(as)f(the)h(only)g(c)o(haracter)f(on)195 ! 2340 y(an)e(otherwise-empt)o(y)g(line.)31 b(The)18 b(cursor)g(is)h(mo)o ! (v)o(ed)e(to)h(the)g(b)q(eginning)i(of)e(the)g(newly-blank)195 ! 2395 y(line.)1773 2506 y(V)l(ariable)-1861 b Fi(char)20 ! b(*)f Fh(rl)p 286 2506 V 21 w(prompt)195 2560 y Fu(The)13 ! b(prompt)g(Readline)h(uses.)20 b(This)13 b(is)h(set)f(from)f(the)h ! (argumen)o(t)g(to)f Ft(readline\(\))p Fu(,)g(and)h(should)195 ! 2615 y(not)g(b)q(e)h(assigned)g(to)f(directly)l(.)21 ! b(The)14 b Ft(rl_set_prompt\(\))d Fu(function)j(\(see)g(Section)g ! (2.4.6)e([Redis-)195 2670 y(pla)o(y],)j(page)g(30\))f(ma)o(y)h(b)q(e)g ! (used)h(to)f(mo)q(dify)h(the)f(prompt)g(string)g(after)f(calling)j ! Ft(readline\(\))p Fu(.)p eop %%Page: 23 25 23 24 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)843 b(23)1773 149 y(V)l(ariable)-1861 b Fi(int)20 ! b Fh(rl)p 215 149 18 3 v 21 w(already)p 419 149 V 21 ! w(prompted)195 204 y Fu(If)e(an)g(application)i(wishes)f(to)f(displa)o ! (y)h(the)f(prompt)g(itself,)h(rather)f(than)g(ha)o(v)o(e)g(Readline)h ! (do)195 259 y(it)e(the)f(\014rst)g(time)h Ft(readline\(\))e ! Fu(is)i(called,)h(it)e(should)i(set)e(this)h(v)m(ariable)g(to)f(a)g ! (non-zero)h(v)m(alue)195 314 y(after)h(displa)o(ying)j(the)e(prompt.)31 ! b(The)19 b(prompt)g(m)o(ust)f(also)h(b)q(e)h(passed)f(as)f(the)h ! (argumen)o(t)g(to)195 369 y Ft(readline\(\))c Fu(so)h(the)h(redispla)o ! (y)g(functions)h(can)e(up)q(date)h(the)g(displa)o(y)h(prop)q(erly)l(.) ! 24 b(The)17 b(calling)195 423 y(application)g(is)f(resp)q(onsible)h ! (for)d(managing)h(the)h(v)m(alue;)g(Readline)g(nev)o(er)g(sets)e(it.) ! 1773 549 y(V)l(ariable)-1861 b Fi(const)20 b(char)g(*)f ! Fh(rl)p 436 549 V 21 w(library)p 625 549 V 21 w(v)n(ersion)195 ! 604 y Fu(The)c(v)o(ersion)h(n)o(um)o(b)q(er)f(of)g(this)h(revision)g ! (of)f(the)g(library)l(.)1773 730 y(V)l(ariable)-1861 ! b Fi(int)20 b Fh(rl)p 215 730 V 21 w(gn)n(u)p 327 730 ! V 20 w(readline)p 545 730 V 22 w(p)195 785 y Fu(Alw)o(a)o(ys)15 ! b(set)g(to)f(1,)h(denoting)h(that)e(this)i(is)g Fp(gnu)f ! Fu(readline)h(rather)f(than)g(some)g(em)o(ulation.)1773 ! 911 y(V)l(ariable)-1861 b Fi(const)20 b(char)g(*)f Fh(rl)p ! 436 911 V 21 w(terminal)p 668 911 V 21 w(name)195 966 ! y Fu(The)14 b(terminal)h(t)o(yp)q(e,)f(used)h(for)e(initialization.)23 ! b(If)14 b(not)f(set)h(b)o(y)g(the)g(application,)i(Readline)f(sets)195 ! 1021 y(this)h(to)e(the)h(v)m(alue)i(of)e(the)g Ft(TERM)g ! Fu(en)o(vironmen)o(t)g(v)m(ariable)i(the)e(\014rst)g(time)g(it)h(is)f ! (called.)1773 1147 y(V)l(ariable)-1861 b Fi(const)20 ! b(char)g(*)f Fh(rl)p 436 1147 V 21 w(readline)p 655 1147 ! V 22 w(name)195 1201 y Fu(This)d(v)m(ariable)h(is)f(set)g(to)f(a)g ! (unique)i(name)f(b)o(y)f(eac)o(h)h(application)h(using)f(Readline.)23 ! b(The)16 b(v)m(alue)195 1256 y(allo)o(ws)e(conditional)i(parsing)e(of)g ! (the)g(inputrc)h(\014le)g(\(see)f(Section)h(1.3.2)d([Conditional)j ! (Init)g(Con-)195 1311 y(structs],)f(page)h(8\).)1773 ! 1437 y(V)l(ariable)-1861 b Fi(FILE)20 b(*)f Fh(rl)p 286 ! 1437 V 21 w(instream)195 1492 y Fu(The)c(stdio)h(stream)e(from)h(whic)o ! (h)h(Readline)g(reads)f(input.)1773 1618 y(V)l(ariable)-1861 ! b Fi(FILE)20 b(*)f Fh(rl)p 286 1618 V 21 w(outstream)195 ! 1673 y Fu(The)c(stdio)h(stream)e(to)h(whic)o(h)h(Readline)g(p)q ! (erforms)f(output.)1773 1799 y(V)l(ariable)-1861 b Fi ! (rl_command_func_t)22 b(*)d Fh(rl)p 626 1799 V 21 w(last)p ! 735 1799 V 21 w(func)195 1854 y Fu(The)f(address)f(of)g(the)g(last)h ! (command)f(function)h(Readline)h(executed.)27 b(Ma)o(y)17 ! b(b)q(e)h(used)g(to)f(test)195 1908 y(whether)e(or)g(not)g(a)g ! (function)h(is)f(b)q(eing)i(executed)f(t)o(wice)g(in)g(succession,)g ! (for)e(example.)1773 2034 y(V)l(ariable)-1861 b Fi(rl_hook_func_t)21 ! b(*)e Fh(rl)p 547 2034 V 22 w(startup)p 752 2034 V 19 ! w(ho)r(ok)195 2089 y Fu(If)e(non-zero,)h(this)g(is)f(the)h(address)f ! (of)f(a)h(function)h(to)f(call)h(just)f(b)q(efore)g Ft(readline)f ! Fu(prin)o(ts)i(the)195 2144 y(\014rst)d(prompt.)1773 ! 2270 y(V)l(ariable)-1861 b Fi(rl_hook_func_t)21 b(*)e ! Fh(rl)p 547 2270 V 22 w(pre)p 651 2270 V 20 w(input)p ! 804 2270 V 21 w(ho)r(ok)195 2325 y Fu(If)f(non-zero,)g(this)g(is)h(the) ! f(address)f(of)h(a)f(function)i(to)e(call)i(after)e(the)h(\014rst)f ! (prompt)g(has)h(b)q(een)195 2380 y(prin)o(ted)e(and)f(just)g(b)q(efore) ! h Ft(readline)e Fu(starts)g(reading)h(input)i(c)o(haracters.)1773 ! 2506 y(V)l(ariable)-1861 b Fi(rl_hook_func_t)21 b(*)e ! Fh(rl)p 547 2506 V 22 w(ev)n(en)n(t)p 701 2506 V 22 w(ho)r(ok)195 ! 2560 y Fu(If)i(non-zero,)g(this)g(is)g(the)f(address)g(of)g(a)g ! (function)h(to)f(call)i(p)q(erio)q(dically)h(when)e(Readline)g(is)195 ! 2615 y(w)o(aiting)15 b(for)f(terminal)h(input.)21 b(By)14 ! b(default,)h(this)g(will)i(b)q(e)e(called)h(at)e(most)g(ten)g(times)h ! (a)f(second)195 2670 y(if)i(there)f(is)h(no)f(k)o(eyb)q(oard)g(input.)p ! eop ! %%Page: 24 26 ! 24 25 bop 75 -58 a Fu(24)1299 b(GNU)15 b(Readline)h(Library)1773 ! 149 y(V)l(ariable)-1861 b Fi(rl_getc_func_t)21 b(*)e ! Fh(rl)p 547 149 18 3 v 22 w(getc)p 671 149 V 21 w(function)195 ! 204 y Fu(If)c(non-zero,)h(Readline)g(will)h(call)f(indirectly)i ! (through)d(this)g(p)q(oin)o(ter)h(to)f(get)f(a)h(c)o(haracter)g(from) ! 195 259 y(the)k(input)i(stream.)31 b(By)19 b(default,)h(it)g(is)g(set)f ! (to)f Ft(rl_getc)p Fu(,)h(the)g(default)h(Readline)h(c)o(haracter)195 ! 314 y(input)16 b(function)g(\(see)f(Section)h(2.4.8)e([Character)g ! (Input],)h(page)g(32\).)1773 442 y(V)l(ariable)-1861 ! b Fi(rl_voidfunc_t)21 b(*)e Fh(rl)p 521 442 V 21 w(redispla)n(y)p ! 765 442 V 22 w(function)195 497 y Fu(If)f(non-zero,)h(Readline)g(will)h ! (call)f(indirectly)h(through)e(this)g(p)q(oin)o(ter)h(to)e(up)q(date)i ! (the)f(displa)o(y)195 552 y(with)c(the)f(curren)o(t)h(con)o(ten)o(ts)f ! (of)g(the)g(editing)i(bu\013er.)k(By)14 b(default,)g(it)g(is)g(set)f ! (to)g Ft(rl_redisplay)p Fu(,)195 607 y(the)i(default)h(Readline)h ! (redispla)o(y)f(function)g(\(see)f(Section)h(2.4.6)e([Redispla)o(y],)h ! (page)g(30\).)1773 735 y(V)l(ariable)-1861 b Fi(rl_vintfunc_t)21 ! b(*)e Fh(rl)p 521 735 V 21 w(prep)p 656 735 V 21 w(term)p ! 798 735 V 19 w(function)195 790 y Fu(If)12 b(non-zero,)h(Readline)g ! (will)h(call)f(indirectly)h(through)e(this)g(p)q(oin)o(ter)h(to)e ! (initialize)k(the)e(terminal.)195 844 y(The)19 b(function)g(tak)o(es)f ! (a)g(single)i(argumen)o(t,)e(an)h Ft(int)f Fu(\015ag)g(that)g(sa)o(ys)g ! (whether)g(or)h(not)f(to)g(use)195 899 y(eigh)o(t-bit)g(c)o(haracters.) ! 25 b(By)17 b(default,)h(this)f(is)h(set)e(to)h Ft(rl_prep_terminal)e ! Fu(\(see)i(Section)h(2.4.9)195 954 y([T)l(erminal)e(Managemen)o(t],)d ! (page)i(32\).)1773 1082 y(V)l(ariable)-1861 b Fi(rl_voidfunc_t)21 ! b(*)e Fh(rl)p 521 1082 V 21 w(deprep)p 714 1082 V 21 ! w(term)p 856 1082 V 19 w(function)195 1137 y Fu(If)g(non-zero,)g ! (Readline)g(will)h(call)g(indirectly)g(through)e(this)h(p)q(oin)o(ter)f ! (to)g(reset)g(the)h(terminal.)195 1192 y(This)f(function)g(should)h ! (undo)f(the)f(e\013ects)h(of)f Ft(rl_prep_term_function)p ! Fu(.)24 b(By)17 b(default,)i(this)195 1247 y(is)d(set)f(to)f ! Ft(rl_deprep_terminal)f Fu(\(see)i(Section)h(2.4.9)e([T)l(erminal)i ! (Managemen)o(t],)d(page)i(32\).)1773 1375 y(V)l(ariable)-1861 ! b Fi(Keymap)20 b Fh(rl)p 293 1375 V 21 w(executing)p ! 551 1375 V 22 w(k)n(eymap)195 1430 y Fu(This)f(v)m(ariable)g(is)f(set)g ! (to)g(the)g(k)o(eymap)f(\(see)h(Section)h(2.4.2)e([Keymaps],)g(page)h ! (26\))f(in)i(whic)o(h)195 1485 y(the)c(curren)o(tly)h(executing)g ! (readline)h(function)f(w)o(as)f(found.)1773 1613 y(V)l(ariable)-1861 ! b Fi(Keymap)20 b Fh(rl)p 293 1613 V 21 w(binding)p 501 ! 1613 V 22 w(k)n(eymap)195 1668 y Fu(This)f(v)m(ariable)g(is)f(set)g(to) ! g(the)g(k)o(eymap)f(\(see)h(Section)h(2.4.2)e([Keymaps],)g(page)h(26\)) ! f(in)i(whic)o(h)195 1723 y(the)c(last)g(k)o(ey)g(binding)j(o)q ! (ccurred.)1773 1851 y(V)l(ariable)-1861 b Fi(char)20 ! b(*)f Fh(rl)p 286 1851 V 21 w(executing)p 544 1851 V ! 22 w(macro)195 1906 y Fu(This)d(v)m(ariable)g(is)g(set)f(to)g(the)g ! (text)g(of)f(an)o(y)h(curren)o(tly-executing)i(macro.)1773 ! 2034 y(V)l(ariable)-1861 b Fi(int)20 b Fh(rl)p 215 2034 ! V 21 w(readline)p 434 2034 V 22 w(state)195 2089 y Fu(A)d(v)m(ariable)i ! (with)e(bit)h(v)m(alues)h(that)d(encapsulate)i(the)g(curren)o(t)f ! (Readline)h(state.)25 b(A)18 b(bit)f(is)h(set)195 2144 ! y(with)h(the)g Ft(RL_SETSTATE)f Fu(macro,)h(and)g(unset)g(with)g(the)g ! Ft(RL_UNSETSTATE)e Fu(macro.)31 b(Use)19 b(the)195 2199 ! y Ft(RL_ISSTATE)e Fu(macro)h(to)g(test)g(whether)h(a)f(particular)i ! (state)d(bit)j(is)f(set.)30 b(Curren)o(t)18 b(state)g(bits)195 ! 2253 y(include:)195 2339 y Ft(RL_STATE_NONE)435 2393 ! y Fu(Readline)e(has)g(not)e(y)o(et)h(b)q(een)h(called,)h(nor)e(has)g ! (it)g(b)q(egun)h(to)f(in)o(tialize.)195 2477 y Ft ! (RL_STATE_INITIALIZING)435 2532 y Fu(Readline)h(is)g(initializi)q(ng)i ! (its)d(in)o(ternal)h(data)f(structures.)195 2615 y Ft ! (RL_STATE_INITIALIZED)435 2670 y Fu(Readline)h(has)g(completed)g(its)f ! (initialization.)p eop ! %%Page: 25 27 ! 25 26 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)843 b(25)195 149 y Ft(RL_STATE_TERMPREPPED)435 ! 204 y Fu(Readline)16 b(has)e(mo)q(di\014ed)i(the)e(terminal)h(mo)q(des) ! g(to)e(do)i(its)f(o)o(wn)g(input)h(and)g(redis-)435 259 ! y(pla)o(y)l(.)195 342 y Ft(RL_STATE_READCMD)435 397 y ! Fu(Readline)h(is)g(reading)g(a)f(command)g(from)f(the)i(k)o(eyb)q ! (oard.)195 480 y Ft(RL_STATE_METANEXT)435 534 y Fu(Readline)g(is)g ! (reading)g(more)f(input)h(after)e(reading)i(the)f(meta-pre\014x)h(c)o ! (haracter.)195 617 y Ft(RL_STATE_DISPATCHING)435 672 ! y Fu(Readline)g(is)g(dispatc)o(hing)h(to)d(a)h(command.)195 ! 755 y Ft(RL_STATE_MOREINPUT)435 810 y Fu(Readline)h(is)g(reading)g ! (more)f(input)h(while)h(executing)f(an)f(editing)i(command.)195 ! 893 y Ft(RL_STATE_ISEARCH)435 947 y Fu(Readline)f(is)g(p)q(erforming)g ! (an)f(incremen)o(tal)h(history)f(searc)o(h.)195 1030 ! y Ft(RL_STATE_NSEARCH)435 1085 y Fu(Readline)h(is)g(p)q(erforming)g(a)f ! (non-incremen)o(tal)h(history)g(searc)o(h.)195 1168 y ! Ft(RL_STATE_SEARCH)435 1223 y Fu(Readline)11 b(is)g(searc)o(hing)g(bac) ! o(kw)o(ard)e(or)h(forw)o(ard)f(through)h(the)g(history)g(for)f(a)h ! (string.)195 1306 y Ft(RL_STATE_NUMERICARG)435 1360 y ! Fu(Readline)16 b(is)g(reading)g(a)f(n)o(umeric)h(argumen)o(t.)195 ! 1443 y Ft(RL_STATE_MACROINPUT)435 1498 y Fu(Readline)d(is)g(curren)o ! (tly)g(getting)f(its)g(input)h(from)e(a)h(previously-de\014ned)j(k)o ! (eyb)q(oard)435 1553 y(macro.)195 1636 y Ft(RL_STATE_MACRODEF)435 ! 1691 y Fu(Readline)h(is)g(curren)o(tly)g(reading)g(c)o(haracters)e ! (de\014ning)j(a)e(k)o(eyb)q(oard)g(macro.)195 1773 y ! Ft(RL_STATE_OVERWRITE)435 1828 y Fu(Readline)h(is)g(in)g(o)o(v)o ! (erwrite)f(mo)q(de.)195 1911 y Ft(RL_STATE_COMPLETING)435 ! 1966 y Fu(Readline)h(is)g(p)q(erforming)g(w)o(ord)e(completion.)195 ! 2049 y Ft(RL_STATE_SIGHANDLER)435 2104 y Fu(Readline)i(is)g(curren)o ! (tly)g(executing)g(the)f(readline)i(signal)f(handler.)195 ! 2187 y Ft(RL_STATE_UNDOING)435 2241 y Fu(Readline)g(is)g(p)q(erforming) ! g(an)f(undo.)195 2324 y Ft(RL_STATE_DONE)435 2379 y Fu(Readline)g(has)f ! (read)g(a)f(k)o(ey)h(sequence)h(b)q(ound)g(to)e Ft(accept-line)f ! Fu(and)i(is)h(ab)q(out)f(to)435 2434 y(return)h(the)g(line)i(to)e(the)g ! (caller.)1773 2560 y(V)l(ariable)-1861 b Fi(int)20 b ! Fh(rl)p 215 2560 18 3 v 21 w(explicit)p 417 2560 V 24 ! w(arg)195 2615 y Fu(Set)f(to)g(a)g(non-zero)h(v)m(alue)h(if)e(an)h ! (explicit)h(n)o(umeric)g(argumen)o(t)d(w)o(as)h(sp)q(eci\014ed)i(b)o(y) ! f(the)f(user.)195 2670 y(Only)d(v)m(alid)h(in)f(a)f(bindable)i(command) ! f(function.)p eop ! %%Page: 26 28 ! 26 27 bop 75 -58 a Fu(26)1299 b(GNU)15 b(Readline)h(Library)1773 ! 149 y(V)l(ariable)-1861 b Fi(int)20 b Fh(rl)p 215 149 ! 18 3 v 21 w(n)n(umeric)p 437 149 V 20 w(arg)195 204 y ! Fu(Set)j(to)f(the)g(v)m(alue)i(of)f(an)o(y)f(n)o(umeric)h(argumen)o(t)f ! (explicitly)k(sp)q(eci\014ed)f(b)o(y)d(the)h(user)g(b)q(efore)195 ! 259 y(executing)14 b(the)f(curren)o(t)g(Readline)h(function.)20 ! b(Only)14 b(v)m(alid)h(in)f(a)f(bindable)i(command)d(function.)1773 ! 368 y(V)l(ariable)-1861 b Fi(int)20 b Fh(rl)p 215 368 ! V 21 w(editing)p 407 368 V 22 w(mo)r(de)195 423 y Fu(Set)13 ! b(to)f(a)g(v)m(alue)i(denoting)f(Readline's)g(curren)o(t)g(editing)h ! (mo)q(de.)19 b(A)12 b(v)m(alue)i(of)e Fk(1)k Fu(means)d(Readline)195 ! 477 y(is)j(curren)o(tly)f(in)h(emacs)g(mo)q(de;)f Fk(0)j ! Fu(means)d(that)g(vi)h(mo)q(de)f(is)h(activ)o(e.)75 601 ! y Fs(2.4)33 b(Readline)23 b(Con)n(v)n(enience)g(F)-6 ! b(unctions)75 737 y Fj(2.4.1)30 b(Naming)20 b(a)g(F)-5 ! b(unction)137 832 y Fu(The)20 b(user)g(can)g(dynamically)i(c)o(hange)e ! (the)g(bindings)i(of)d(k)o(eys)h(while)h(using)g(Readline.)35 ! b(This)20 b(is)75 887 y(done)f(b)o(y)f(represen)o(ting)h(the)g (function)g(with)g(a)f(descriptiv)o(e)i(name.)29 b(The)19 ! b(user)f(is)h(able)h(to)d(t)o(yp)q(e)i(the)75 941 y(descriptiv)o(e)e (name)e(when)h(referring)f(to)g(the)g(function.)21 b(Th)o(us,)14 b(in)i(an)f(init)i(\014le,)f(one)f(migh)o(t)g(\014nd)195 ! 1004 y Ft(Meta-Rubout:)46 b(backward-kill-word)137 1070 ! y Fu(This)21 b(binds)g(the)f(k)o(eystrok)o(e)661 1068 ! y Fn(h)p 673 1042 209 2 v 673 1070 a Fm(Meta-Rub)q(out)p ! 673 1077 V 879 1068 a Fn(i)914 1070 y Fu(to)g(the)g(function)g ! Fl(descriptively)k Fu(named)c Ft(backward-)75 1124 y(kill-word)p ! Fu(.)29 b(Y)l(ou,)19 b(as)f(the)h(programmer,)f(should)i(bind)f(the)g ! (functions)h(y)o(ou)e(write)h(to)e(descriptiv)o(e)75 ! 1179 y(names)e(as)g(w)o(ell.)21 b(Readline)16 b(pro)o(vides)g(a)f ! (function)h(for)e(doing)i(that:)1762 1288 y(F)l(unction)-1861 ! b Fi(int)20 b Fh(rl)p 215 1288 18 3 v 21 w(add)p 328 ! 1288 V 20 w(defun)i Fg(\()p Ft(const)14 b(char)h(*name,)f ! (rl_command_func_t)283 1343 y(*function,)f(int)i(key)p ! Fg(\))195 1397 y Fu(Add)j Fk(name)i Fu(to)d(the)h(list)h(of)e(named)h ! (functions.)28 b(Mak)o(e)17 b Fk(function)h Fu(b)q(e)g(the)g(function)h ! (that)d(gets)195 1452 y(called.)21 b(If)16 b Fk(k)o(ey)j ! Fu(is)d(not)e(-1,)h(then)h(bind)g(it)g(to)e Fk(function)i ! Fu(using)g Ft(rl_bind_key\(\))p Fu(.)137 1539 y(Using)g(this)f ! (function)h(alone)g(is)f(su\016cien)o(t)h(for)f(most)f(applications.)21 ! b(It)15 b(is)h(the)f(recommended)h(w)o(a)o(y)75 1594 ! y(to)d(add)h(a)f(few)g(functions)h(to)f(the)h(default)g(functions)g ! (that)f(Readline)i(has)e(built)i(in.)20 b(If)14 b(y)o(ou)f(need)h(to)f ! (do)75 1649 y(something)k(other)g(than)f(adding)i(a)e(function)i(to)e ! (Readline,)i(y)o(ou)f(ma)o(y)f(need)i(to)e(use)h(the)g(underlying)75 ! 1704 y(functions)f(describ)q(ed)h(b)q(elo)o(w.)75 1811 ! y Fj(2.4.2)30 b(Selecting)20 b(a)h(Keymap)137 1906 y ! Fu(Key)16 b(bindings)i(tak)o(e)c(place)j(on)e(a)g Fk(k)o(eymap)p Fu(.)21 b(The)15 b(k)o(eymap)h(is)f(the)h(asso)q(ciation)g(b)q(et)o(w)o ! (een)g(the)f(k)o(eys)75 1960 y(that)f(the)g(user)g(t)o(yp)q(es)g(and)h (the)f(functions)h(that)f(get)g(run.)19 b(Y)l(ou)c(can)f(mak)o(e)g(y)o ! (our)g(o)o(wn)f(k)o(eymaps,)h(cop)o(y)75 2015 y(existing)i(k)o(eymaps,) ! f(and)g(tell)h(Readline)h(whic)o(h)f(k)o(eymap)f(to)f(use.)1762 ! 2124 y(F)l(unction)-1861 b Fi(Keymap)20 b Fh(rl)p 293 ! 2124 V 21 w(mak)n(e)p 445 2124 V 20 w(bare)p 575 2124 ! V 20 w(k)n(eymap)j Fg(\()p Ft(void)p Fg(\))195 2179 y ! Fu(Returns)12 b(a)f(new,)i(empt)o(y)f(k)o(eymap.)18 b(The)13 ! b(space)f(for)f(the)i(k)o(eymap)e(is)i(allo)q(cated)g(with)f ! Ft(malloc\(\))p Fu(;)195 2233 y(the)j(caller)i(should)f(free)f(it)h(b)o ! (y)f(calling)i Ft(rl_discard_keymap\(\))12 b Fu(when)k(done.)1762 ! 2342 y(F)l(unction)-1861 b Fi(Keymap)20 b Fh(rl)p 293 ! 2342 V 21 w(cop)n(y)p 428 2342 V 21 w(k)n(eymap)j Fg(\()p ! Ft(Keymap)14 b(map)p Fg(\))195 2397 y Fu(Return)h(a)g(new)g(k)o(eymap)g ! (whic)o(h)h(is)g(a)f(cop)o(y)g(of)g Fk(map)p Fu(.)1762 ! 2506 y(F)l(unction)-1861 b Fi(Keymap)20 b Fh(rl)p 293 ! 2506 V 21 w(mak)n(e)p 445 2506 V 20 w(k)n(eymap)j Fg(\()p ! Ft(void)p Fg(\))195 2560 y Fu(Return)16 b(a)f(new)i(k)o(eymap)e(with)i ! (the)f(prin)o(ting)h(c)o(haracters)e(b)q(ound)i(to)e(rl)p ! 1457 2560 14 2 v 17 w(insert,)h(the)g(lo)o(w)o(ercase)195 ! 2615 y(Meta)11 b(c)o(haracters)f(b)q(ound)i(to)f(run)h(their)f(equiv)m ! (alen)o(ts,)j(and)d(the)h(Meta)e(digits)i(b)q(ound)g(to)f(pro)q(duce) ! 195 2670 y(n)o(umeric)16 b(argumen)o(ts.)p eop ! %%Page: 27 29 ! 27 28 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)843 b(27)1762 149 y(F)l(unction)-1861 b Fi(void)20 ! b Fh(rl)p 241 149 18 3 v 21 w(discard)p 441 149 V 21 w(k)n(eymap)i Fg(\()p Ft(Keymap)14 b(keymap)p Fg(\))195 ! 204 y Fu(F)l(ree)h(the)h(storage)d(asso)q(ciated)j(with)f ! Fk(k)o(eymap)p Fu(.)137 293 y(Readline)24 b(has)f(sev)o(eral)g(in)o (ternal)g(k)o(eymaps.)42 b(These)23 b(functions)g(allo)o(w)g(y)o(ou)f ! (to)g(c)o(hange)h(whic)o(h)75 348 y(k)o(eymap)15 b(is)h(activ)o(e.)1762 ! 459 y(F)l(unction)-1861 b Fi(Keymap)20 b Fh(rl)p 293 ! 459 V 21 w(get)p 391 459 V 21 w(k)n(eymap)i Fg(\()p Ft(void)p ! Fg(\))195 514 y Fu(Returns)15 b(the)g(curren)o(tly)h(activ)o(e)f(k)o ! (eymap.)1762 625 y(F)l(unction)-1861 b Fi(void)20 b Fh(rl)p ! 241 625 V 21 w(set)p 333 625 V 21 w(k)n(eymap)i Fg(\()p ! Ft(Keymap)14 b(keymap)p Fg(\))195 680 y Fu(Mak)o(es)g ! Fk(k)o(eymap)j Fu(the)e(curren)o(tly)h(activ)o(e)f(k)o(eymap.)1762 ! 791 y(F)l(unction)-1861 b Fi(Keymap)20 b Fh(rl)p 293 ! 791 V 21 w(get)p 391 791 V 21 w(k)n(eymap)p 605 791 V ! 20 w(b)n(y)p 685 791 V 21 w(name)i Fg(\()p Ft(const)14 ! b(char)g(*name)p Fg(\))195 846 y Fu(Return)i(the)h(k)o(eymap)f(matc)o ! (hing)h Fk(name)p Fu(.)24 b Fk(name)19 b Fu(is)e(one)g(whic)o(h)g(w)o ! (ould)g(b)q(e)h(supplied)h(in)e(a)f Ft(set)195 901 y(keymap)e ! Fu(inputrc)j(line)f(\(see)g(Section)g(1.3)e([Readline)i(Init)g(File],)g ! (page)f(4\).)1762 1012 y(F)l(unction)-1861 b Fi(char)20 ! b(*)f Fh(rl)p 286 1012 V 21 w(get)p 384 1012 V 21 w(k)n(eymap)p ! 598 1012 V 20 w(name)i Fg(\()p Ft(Keymap)14 b(keymap)p ! Fg(\))195 1067 y Fu(Return)i(the)h(name)g(matc)o(hing)f ! Fk(k)o(eymap)p Fu(.)24 b Fk(name)19 b Fu(is)e(one)g(whic)o(h)g(w)o ! (ould)g(b)q(e)h(supplied)h(in)e(a)f Ft(set)195 1122 y(keymap)e ! Fu(inputrc)j(line)f(\(see)g(Section)g(1.3)e([Readline)i(Init)g(File],)g ! (page)f(4\).)75 1230 y Fj(2.4.3)30 b(Binding)20 b(Keys)137 ! 1325 y Fu(Key)13 b(sequences)g(are)e(asso)q(ciate)h(with)h(functions)f ! (through)g(the)g(k)o(eymap.)19 b(Readline)13 b(has)f(sev)o(eral)g(in-) ! 75 1380 y(ternal)j(k)o(eymaps:)k Ft(emacs_standard_keymap)p ! Fu(,)11 b Ft(emacs_meta_keymap)p Fu(,)h Ft(emacs_ctlx_keymap)p ! Fu(,)g Ft(vi_)75 1435 y(movement_keymap)p Fu(,)20 b(and)i Ft(vi_insertion_keymap)p Fu(.)35 b Ft(emacs_standard_keymap)18 ! b Fu(is)k(the)f(default,)75 1490 y(and)15 b(the)h(examples)g(in)g(this) ! f(man)o(ual)h(assume)f(that.)137 1556 y(Since)h Ft(readline\(\))c Fu(installs)j(a)f(set)f(of)h(default)g(k)o(ey)g(bindings)h(the)f ! (\014rst)g(time)g(it)g(is)g(called,)i(there)d(is)75 1611 ! y(alw)o(a)o(ys)j(the)g(danger)g(that)g(a)g(custom)g(binding)i ! (installed)g(b)q(efore)f(the)f(\014rst)g(call)i(to)d ! Ft(readline\(\))g Fu(will)75 1666 y(b)q(e)f(o)o(v)o(erridden.)19 ! b(An)13 b(alternate)g(mec)o(hanism)h(is)f(to)f(install)i(custom)f(k)o ! (ey)g(bindings)h(in)g(an)f(initialization)75 1720 y(function)19 ! b(assigned)h(to)d(the)i Ft(rl_startup_hook)e Fu(v)m(ariable)j(\(see)e ! (Section)h(2.3)f([Readline)i(V)l(ariables],)75 1775 y(page)15 ! b(22\).)137 1841 y(These)h(functions)g(manage)e(k)o(ey)i(bindings.)1762 ! 1953 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 1953 ! V 21 w(bind)p 347 1953 V 21 w(k)n(ey)k Fg(\()p Ft(int)14 ! b(key,)h(rl_command_func_t)d(*function)p Fg(\))195 2007 ! y Fu(Binds)18 b Fk(k)o(ey)i Fu(to)c Fk(function)h Fu(in)h(the)e(curren) ! o(tly)h(activ)o(e)g(k)o(eymap.)23 b(Returns)16 b(non-zero)h(in)g(the)g ! (case)195 2062 y(of)e(an)g(in)o(v)m(alid)i Fk(k)o(ey)p ! Fu(.)1762 2173 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p ! 215 2173 V 21 w(bind)p 347 2173 V 21 w(k)n(ey)p 452 2173 ! V 21 w(in)p 520 2173 V 22 w(map)h Fg(\()p Ft(int)14 b(key,)h ! (rl_command_func_t)e(*function,)283 2228 y(Keymap)h(map)p ! Fg(\))195 2283 y Fu(Bind)i Fk(k)o(ey)j Fu(to)c Fk(function)h ! Fu(in)g Fk(map)p Fu(.)k(Returns)14 b(non-zero)i(in)g(the)f(case)g(of)g ! (an)g(in)o(v)m(alid)j Fk(k)o(ey)p Fu(.)1762 2394 y(F)l(unction)-1861 ! b Fi(int)20 b Fh(rl)p 215 2394 V 21 w(un)n(bind)p 409 ! 2394 V 21 w(k)n(ey)k Fg(\()p Ft(int)14 b(key)p Fg(\))195 ! 2449 y Fu(Bind)19 b Fk(k)o(ey)j Fu(to)c(the)g(n)o(ull)i(function)f(in)g ! (the)f(curren)o(tly)g(activ)o(e)h(k)o(eymap.)28 b(Returns)18 ! b(non-zero)g(in)195 2504 y(case)d(of)g(error.)1762 2615 ! y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 2615 V ! 21 w(un)n(bind)p 409 2615 V 21 w(k)n(ey)p 514 2615 V ! 21 w(in)p 582 2615 V 22 w(map)h Fg(\()p Ft(int)14 b(key,)h(Keymap)f ! (map)p Fg(\))195 2670 y Fu(Bind)i Fk(k)o(ey)j Fu(to)c(the)g(n)o(ull)i ! (function)f(in)g Fk(map)p Fu(.)k(Returns)14 b(non-zero)i(in)g(case)f ! (of)g(error.)p eop %%Page: 28 30 ! 28 29 bop 75 -58 a Fu(28)1299 b(GNU)15 b(Readline)h(Library)1762 ! 149 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 149 ! 18 3 v 21 w(un)n(bind)p 409 149 V 21 w(function)p 635 ! 149 V 21 w(in)p 703 149 V 21 w(map)h Fg(\()p Ft(rl_command_func_t)13 ! b(*function,)283 204 y(Keymap)h(map)p Fg(\))195 259 y ! Fu(Un)o(bind)j(all)f(k)o(eys)f(that)f(execute)i Fk(function)g ! Fu(in)g Fk(map)p Fu(.)1762 377 y(F)l(unction)-1861 b ! Fi(int)20 b Fh(rl)p 215 377 V 21 w(un)n(bind)p 409 377 ! V 21 w(command)p 674 377 V 17 w(in)p 738 377 V 22 w(map)h ! Fg(\()p Ft(const)14 b(char)h(*command,)f(Keymap)283 432 ! y(map)p Fg(\))195 486 y Fu(Un)o(bind)j(all)f(k)o(eys)f(that)f(are)h(b)q ! (ound)h(to)f Fk(command)i Fu(in)f Fk(map)p Fu(.)1762 ! 604 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 604 ! V 21 w(set)p 307 604 V 20 w(k)n(ey)k Fg(\()p Ft(const)14 ! b(char)h(*keyseq,)f(rl_command_func_t)f(*function,)283 ! 659 y(Keymap)h(map)p Fg(\))195 714 y Fu(Bind)g(the)e(k)o(ey)h(sequence) ! h(represen)o(ted)f(b)o(y)f(the)h(string)f Fk(k)o(eyseq)i ! Fu(to)e(the)g(function)i Fk(function)p Fu(.)19 b(This)195 ! 768 y(mak)o(es)13 b(new)g(k)o(eymaps)g(as)f(necessary)l(.)20 ! b(The)13 b(initial)j(k)o(eymap)c(in)i(whic)o(h)g(to)f(do)g(bindings)i ! (is)f Fk(map)p Fu(.)1762 886 y(F)l(unction)-1861 b Fi(int)20 ! b Fh(rl)p 215 886 V 21 w(generic)p 413 886 V 21 w(bind)j ! Fg(\()p Ft(int)15 b(type,)f(const)h(char)f(*keyseq,)g(char)h(*data,)283 ! 941 y(Keymap)f(map)p Fg(\))195 996 y Fu(Bind)h(the)e(k)o(ey)h(sequence) ! h(represen)o(ted)e(b)o(y)h(the)g(string)f Fk(k)o(eyseq)i ! Fu(to)d(the)i(arbitrary)f(p)q(oin)o(ter)h Fk(data)p Fu(.)195 ! 1051 y Fk(t)o(yp)q(e)j Fu(sa)o(ys)c(what)h(kind)h(of)f(data)g(is)g(p)q ! (oin)o(ted)i(to)d(b)o(y)h Fk(data)p Fu(;)g(this)h(can)f(b)q(e)h(a)f ! (function)h(\()p Ft(ISFUNC)p Fu(\),)d(a)195 1105 y(macro)i(\()p ! Ft(ISMACR)p Fu(\),)f(or)h(a)h(k)o(eymap)f(\()p Ft(ISKMAP)p ! Fu(\).)k(This)e(mak)o(es)e(new)h(k)o(eymaps)f(as)h(necessary)l(.)20 ! b(The)195 1160 y(initial)d(k)o(eymap)e(in)h(whic)o(h)g(to)f(do)g ! (bindings)i(is)f Fk(map)p Fu(.)1762 1278 y(F)l(unction)-1861 ! b Fi(int)20 b Fh(rl)p 215 1278 V 21 w(parse)p 369 1278 ! V 19 w(and)p 480 1278 V 21 w(bind)j Fg(\()p Ft(char)14 ! b(*line)p Fg(\))195 1333 y Fu(P)o(arse)g Fk(line)19 b ! Fu(as)14 b(if)h(it)g(had)g(b)q(een)h(read)f(from)f(the)g ! Ft(inputrc)g Fu(\014le)i(and)f(p)q(erform)f(an)o(y)h(k)o(ey)f(bindings) ! 195 1387 y(and)h(v)m(ariable)i(assignmen)o(ts)e(found)h(\(see)f ! (Section)h(1.3)e([Readline)i(Init)g(File],)g(page)f(4\).)1762 ! 1505 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 1505 ! V 21 w(read)p 346 1505 V 20 w(init)p 450 1505 V 22 w(\014le)k ! Fg(\()p Ft(const)14 b(char)h(*filename)p Fg(\))195 1560 ! y Fu(Read)g(k)o(eybindings)j(and)e(v)m(ariable)h(assignmen)o(ts)f(from) ! f Fk(\014lename)k Fu(\(see)d(Section)g(1.3)f([Readline)195 ! 1615 y(Init)h(File],)g(page)f(4\).)75 1727 y Fj(2.4.4)30 ! b(Asso)r(ciating)20 b(F)-5 b(unction)20 b(Names)h(and)f(Bindings)137 ! 1824 y Fu(These)11 b(functions)h(allo)o(w)e(y)o(ou)h(to)f(\014nd)h(out) ! f(what)g(k)o(eys)h(in)o(v)o(ok)o(e)f(named)h(functions)h(and)e(the)h ! (functions)75 1879 y(in)o(v)o(ok)o(ed)j(b)o(y)g(a)f(particular)h(k)o ! (ey)g(sequence.)21 b(Y)l(ou)14 b(ma)o(y)f(also)g(asso)q(ciate)h(a)g ! (new)g(function)g(name)g(with)g(an)75 1933 y(arbitrary)h(function.)1762 ! 2051 y(F)l(unction)-1861 b Fi(rl_command_func_t)22 b(*)d ! Fh(rl)p 626 2051 V 21 w(named)p 814 2051 V 19 w(function)k ! Fg(\()p Ft(const)14 b(char)h(*name)p Fg(\))195 2106 y ! Fu(Return)g(the)g(function)h(with)g(name)f Fk(name)p ! Fu(.)1762 2224 y(F)l(unction)-1861 b Fi(rl_command_func_t)22 ! b(*)d Fh(rl)p 626 2224 V 21 w(function)p 852 2224 V 21 ! w(of)p 920 2224 V 20 w(k)n(eyseq)24 b Fg(\()p Ft(const)14 ! b(char)283 2278 y(*keyseq,)g(Keymap)g(map,)h(int)f(*type)p ! Fg(\))195 2333 y Fu(Return)i(the)g(function)h(in)o(v)o(ok)o(ed)g(b)o(y) ! f Fk(k)o(eyseq)h Fu(in)g(k)o(eymap)f Fk(map)p Fu(.)23 ! b(If)17 b Fk(map)g Fu(is)g Ft(NULL)p Fu(,)f(the)g(curren)o(t)195 ! 2388 y(k)o(eymap)i(is)h(used.)31 b(If)18 b Fk(t)o(yp)q(e)j ! Fu(is)e(not)g Ft(NULL)p Fu(,)f(the)g(t)o(yp)q(e)h(of)f(the)h(ob)s(ject) ! f(is)h(returned)g(in)g(the)f Ft(int)195 2443 y Fu(v)m(ariable)f(it)e(p) ! q(oin)o(ts)h(to)e(\(one)h(of)g Ft(ISFUNC)p Fu(,)f Ft(ISKMAP)p ! Fu(,)g(or)h Ft(ISMACR)p Fu(\).)1762 2560 y(F)l(unction)-1861 ! b Fi(char)20 b(**)f Fh(rl)p 312 2560 V 21 w(in)n(v)n(oking)p ! 541 2560 V 23 w(k)n(eyseqs)k Fg(\()p Ft(rl_command_func_t)13 ! b(*function)p Fg(\))195 2615 y Fu(Return)i(an)h(arra)o(y)e(of)h ! (strings)h(represen)o(ting)g(the)g(k)o(ey)f(sequences)i(used)f(to)f(in) ! o(v)o(ok)o(e)h Fk(function)g Fu(in)195 2670 y(the)f(curren)o(t)g(k)o ! (eymap.)p eop %%Page: 29 31 29 30 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)843 b(29)1762 149 y(F)l(unction)-1861 b Fi(char)20 ! b(**)f Fh(rl)p 312 149 18 3 v 21 w(in)n(v)n(oking)p 541 ! 149 V 23 w(k)n(eyseqs)p 750 149 V 21 w(in)p 818 149 V ! 22 w(map)i Fg(\()p Ft(rl_command_func_t)283 204 y(*function,)13 ! b(Keymap)i(map)p Fg(\))195 259 y Fu(Return)g(an)h(arra)o(y)e(of)h ! (strings)h(represen)o(ting)g(the)g(k)o(ey)f(sequences)i(used)f(to)f(in) ! o(v)o(ok)o(e)h Fk(function)g Fu(in)195 314 y(the)f(k)o(eymap)g ! Fk(map)p Fu(.)1762 426 y(F)l(unction)-1861 b Fi(void)20 ! b Fh(rl)p 241 426 V 21 w(function)p 467 426 V 21 w(dump)r(er)g ! Fg(\()p Ft(int)15 b(readable)p Fg(\))195 481 y Fu(Prin)o(t)g(the)f ! (readline)j(function)e(names)g(and)f(the)h(k)o(ey)g(sequences)g(curren) ! o(tly)g(b)q(ound)h(to)e(them)h(to)195 536 y Ft(rl_outstream)p ! Fu(.)j(If)c Fk(readable)j Fu(is)d(non-zero,)g(the)g(list)g(is)h ! (formatted)d(in)j(suc)o(h)f(a)f(w)o(a)o(y)g(that)g(it)h(can)195 ! 590 y(b)q(e)i(made)f(part)g(of)f(an)i Ft(inputrc)e Fu(\014le)i(and)f ! (re-read.)1762 702 y(F)l(unction)-1861 b Fi(void)20 b ! Fh(rl)p 241 702 V 21 w(list)p 337 702 V 22 w(funmap)p ! 550 702 V 18 w(names)h Fg(\()p Ft(void)p Fg(\))195 757 ! y Fu(Prin)o(t)15 b(the)g(names)h(of)e(all)j(bindable)g(Readline)f ! (functions)g(to)f Ft(rl_outstream)p Fu(.)1762 869 y(F)l(unction)-1861 ! b Fi(const)20 b(char)g(**)f Fh(rl)p 462 869 V 21 w(funmap)p ! 674 869 V 18 w(names)i Fg(\()p Ft(void)p Fg(\))195 924 ! y Fu(Return)13 b(a)f(NULL)i(terminated)g(arra)o(y)d(of)i(kno)o(wn)g ! (function)g(names.)20 b(The)13 b(arra)o(y)f(is)h(sorted.)19 ! b(The)195 979 y(arra)o(y)11 b(itself)j(is)f(allo)q(cated,)h(but)f(not)f ! (the)h(strings)f(inside.)21 b(Y)l(ou)13 b(should)h Ft(free\(\))d ! Fu(the)i(arra)o(y)e(when)195 1034 y(y)o(ou)k(are)g(done,)g(but)g(not)g ! (the)g(p)q(oin)o(ters.)1762 1146 y(F)l(unction)-1861 ! b Fi(int)20 b Fh(rl)p 215 1146 V 21 w(add)p 328 1146 ! V 20 w(funmap)p 539 1146 V 18 w(en)n(try)j Fg(\()p Ft(const)14 ! b(char)h(*name,)f(rl_command_func_t)283 1201 y(*function)p ! Fg(\))195 1255 y Fu(Add)j Fk(name)i Fu(to)d(the)g(list)h(of)f(bindable) ! j(Readline)f(command)e(names,)g(and)h(mak)o(e)f Fk(function)h ! Fu(the)195 1310 y(function)f(to)f(b)q(e)g(called)i(when)f ! Fk(name)i Fu(is)d(in)o(v)o(ok)o(ed.)75 1419 y Fj(2.4.5)30 ! b(Allo)n(wing)21 b(Undoing)137 1515 y Fu(Supp)q(orting)14 ! b(the)g(undo)f(command)g(is)h(a)f(painless)h(thing,)g(and)f(mak)o(es)g ! (y)o(our)f(functions)i(m)o(uc)o(h)f(more)75 1569 y(useful.)21 ! b(It)15 b(is)h(certainly)g(easy)f(to)g(try)f(something)i(if)f(y)o(ou)g ! (kno)o(w)g(y)o(ou)g(can)g(undo)h(it.)137 1636 y(If)21 ! b(y)o(our)f(function)h(simply)h(inserts)f(text)e(once,)j(or)e(deletes)h ! (text)f(once,)i(and)f(uses)f Ft(rl_insert_)75 1690 y(text\(\))13 ! b Fu(or)h Ft(rl_delete_text\(\))d Fu(to)j(do)f(it,)h(then)h(undoing)g ! (is)f(already)g(done)h(for)e(y)o(ou)h(automatically)l(.)137 ! 1757 y(If)d(y)o(ou)f(do)g(m)o(ultiple)i(insertions)f(or)f(m)o(ultiple)i ! (deletions,)g(or)e(an)o(y)g(com)o(bination)h(of)f(these)g(op)q ! (erations,)75 1812 y(y)o(ou)19 b(should)h(group)e(them)h(together)g(in) ! o(to)g(one)g(op)q(eration.)31 b(This)20 b(is)f(done)h(with)f ! Ft(rl_begin_undo_)75 1866 y(group\(\))14 b Fu(and)i Ft ! (rl_end_undo_group\(\))p Fu(.)137 1933 y(The)g(t)o(yp)q(es)f(of)g(ev)o ! (en)o(ts)g(that)f(can)h(b)q(e)h(undone)g(are:)195 1996 ! y Ft(enum)23 b(undo_code)g({)h(UNDO_DELETE,)e(UNDO_INSERT,)g ! (UNDO_BEGIN,)g(UNDO_END)h(};)137 2062 y Fu(Notice)16 ! b(that)e Ft(UNDO_DELETE)g Fu(means)h(to)g(insert)g(some)g(text,)f(and)i ! Ft(UNDO_INSERT)d Fu(means)i(to)g(delete)75 2117 y(some)e(text.)19 ! b(That)14 b(is,)g(the)g(undo)g(co)q(de)g(tells)h(what)e(to)h(undo,)g ! (not)f(ho)o(w)g(to)g(undo)i(it.)k Ft(UNDO_BEGIN)13 b ! Fu(and)75 2172 y Ft(UNDO_END)h Fu(are)h(tags)f(added)i(b)o(y)f ! Ft(rl_begin_undo_group\(\))d Fu(and)k Ft(rl_end_undo_group\(\))p ! Fu(.)1762 2284 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p ! 215 2284 V 21 w(b)r(egin)p 372 2284 V 20 w(undo)p 517 ! 2284 V 20 w(group)h Fg(\()p Ft(void)p Fg(\))195 2339 ! y Fu(Begins)16 b(sa)o(ving)g(undo)g(information)f(in)i(a)e(group)g ! (construct.)20 b(The)c(undo)g(information)g(usually)195 ! 2393 y(comes)21 b(from)f(calls)i(to)e Ft(rl_insert_text\(\))e ! Fu(and)j Ft(rl_delete_text\(\))p Fu(,)f(but)h(could)g(b)q(e)h(the)195 ! 2448 y(result)16 b(of)e(calls)j(to)d Ft(rl_add_undo\(\))p ! Fu(.)1762 2560 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p ! 215 2560 V 21 w(end)p 326 2560 V 20 w(undo)p 471 2560 ! V 20 w(group)h Fg(\()p Ft(void)p Fg(\))195 2615 y Fu(Closes)15 ! b(the)f(curren)o(t)h(undo)g(group)f(started)g(with)g ! Ft(rl_begin_undo_group)f(\(\))p Fu(.)19 b(There)c(should)195 ! 2670 y(b)q(e)h(one)f(call)i(to)d Ft(rl_end_undo_group\(\))f ! Fu(for)h(eac)o(h)h(call)i(to)d Ft(rl_begin_undo_group\(\))p ! Fu(.)p eop ! %%Page: 30 32 ! 30 31 bop 75 -58 a Fu(30)1299 b(GNU)15 b(Readline)h(Library)1762 ! 149 y(F)l(unction)-1861 b Fi(void)20 b Fh(rl)p 241 149 ! 18 3 v 21 w(add)p 354 149 V 20 w(undo)i Fg(\()p Ft(enum)14 ! b(undo_code)g(what,)g(int)h(start,)g(int)f(end,)h(char)283 ! 204 y(*text)p Fg(\))195 259 y Fu(Remem)o(b)q(er)i(ho)o(w)f(to)h(undo)g ! (an)g(ev)o(en)o(t)g(\(according)g(to)g Fk(what)q Fu(\).)24 ! b(The)17 b(a\013ected)g(text)f(runs)i(from)195 314 y ! Fk(start)d Fu(to)g Fk(end)p Fu(,)g(and)g(encompasses)h ! Fk(text)p Fu(.)1762 428 y(F)l(unction)-1861 b Fi(void)20 ! b Fh(rl)p 241 428 V 21 w(free)p 356 428 V 20 w(undo)p ! 501 428 V 20 w(list)k Fg(\()p Ft(void)p Fg(\))195 483 ! y Fu(F)l(ree)15 b(the)h(existing)g(undo)f(list.)1762 ! 598 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 598 ! V 21 w(do)p 297 598 V 20 w(undo)i Fg(\()p Ft(void)p Fg(\))195 ! 652 y Fu(Undo)12 b(the)f(\014rst)g(thing)h(on)g(the)f(undo)h(list.)19 ! b(Returns)11 b Ft(0)h Fu(if)g(there)f(w)o(as)g(nothing)h(to)e(undo,)j ! (non-zero)195 707 y(if)j(something)f(w)o(as)f(undone.)137 ! 798 y(Finally)l(,)j(if)f(y)o(ou)f(neither)i(insert)f(nor)f(delete)i ! (text,)e(but)g(directly)i(mo)q(dify)f(the)g(existing)g(text)g(\(e.g.,) ! 75 853 y(c)o(hange)j(its)h(case\),)g(call)g Ft(rl_modifying\(\))e ! Fu(once,)i(just)f(b)q(efore)h(y)o(ou)f(mo)q(dify)h(the)f(text.)32 ! b(Y)l(ou)20 b(m)o(ust)75 907 y(supply)c(the)g(indices)h(of)e(the)g ! (text)g(range)g(that)f(y)o(ou)h(are)g(going)g(to)g(mo)q(dify)l(.)1762 ! 1022 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 1022 ! V 21 w(mo)r(difying)h Fg(\()p Ft(int)15 b(start,)f(int)h(end)p ! Fg(\))195 1077 y Fu(T)l(ell)22 b(Readline)f(to)e(sa)o(v)o(e)h(the)g ! (text)g(b)q(et)o(w)o(een)g Fk(start)g Fu(and)g Fk(end)j ! Fu(as)c(a)h(single)h(undo)g(unit.)35 b(It)20 b(is)195 ! 1131 y(assumed)15 b(that)g(y)o(ou)g(will)i(subsequen)o(tly)f(mo)q(dify) ! g(that)e(text.)75 1242 y Fj(2.4.6)30 b(Redispla)n(y)1762 ! 1385 y Fu(F)l(unction)-1861 b Fi(void)20 b Fh(rl)p 241 ! 1385 V 21 w(redispla)n(y)k Fg(\()p Ft(void)p Fg(\))195 ! 1440 y Fu(Change)19 b(what's)f(displa)o(y)o(ed)i(on)f(the)g(screen)g ! (to)f(re\015ect)i(the)f(curren)o(t)f(con)o(ten)o(ts)h(of)f ! Ft(rl_line_)195 1495 y(buffer)p Fu(.)1762 1609 y(F)l(unction)-1861 ! b Fi(int)20 b Fh(rl)p 215 1609 V 21 w(forced)p 390 1609 ! V 20 w(up)r(date)p 584 1609 V 20 w(displa)n(y)k Fg(\()p ! Ft(void)p Fg(\))195 1664 y Fu(F)l(orce)c(the)g(line)h(to)e(b)q(e)i(up)q ! (dated)f(and)g(redispla)o(y)o(ed,)i(whether)e(or)g(not)f(Readline)i ! (thinks)g(the)195 1719 y(screen)16 b(displa)o(y)g(is)g(correct.)1762 ! 1833 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 1833 ! V 21 w(on)p 297 1833 V 20 w(new)p 416 1833 V 21 w(line)k ! Fg(\()p Ft(void)p Fg(\))195 1888 y Fu(T)l(ell)16 b(the)f(up)q(date)h ! (functions)g(that)e(w)o(e)g(ha)o(v)o(e)h(mo)o(v)o(ed)f(on)o(to)g(a)h ! (new)g(\(empt)o(y\))f(line,)i(usually)h(after)195 1943 ! y(ouputting)f(a)e(newline.)1762 2058 y(F)l(unction)-1861 ! b Fi(int)20 b Fh(rl)p 215 2058 V 21 w(on)p 297 2058 V ! 20 w(new)p 416 2058 V 21 w(line)p 525 2058 V 22 w(with)p ! 657 2058 V 22 w(prompt)h Fg(\()p Ft(void)p Fg(\))195 ! 2112 y Fu(T)l(ell)14 b(the)e(up)q(date)h(functions)g(that)f(w)o(e)g(ha) ! o(v)o(e)g(mo)o(v)o(ed)f(on)o(to)h(a)g(new)g(line,)i(with)f ! Fk(rl)p 1556 2112 14 2 v 17 w(prompt)g Fu(already)195 ! 2167 y(displa)o(y)o(ed.)21 b(This)15 b(could)g(b)q(e)g(used)g(b)o(y)f ! (applications)i(that)e(w)o(an)o(t)f(to)h(output)g(the)g(prompt)g ! (string)195 2222 y(themselv)o(es,)g(but)g(still)h(need)g(Readline)g(to) ! e(kno)o(w)g(the)h(prompt)f(string)h(length)g(for)f(redispla)o(y)l(.)21 ! b(It)195 2277 y(should)16 b(b)q(e)g(used)g(after)e(setting)i ! Fk(rl)p 795 2277 V 16 w(already)p 956 2277 V 17 w(prompted)p ! Fu(.)1762 2391 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p ! 215 2391 18 3 v 21 w(reset)p 357 2391 V 20 w(line)p 465 ! 2391 V 23 w(state)j Fg(\()p Ft(void)p Fg(\))195 2446 ! y Fu(Reset)17 b(the)g(displa)o(y)i(state)d(to)h(a)g(clean)h(state)f ! (and)g(redispla)o(y)i(the)e(curren)o(t)g(line)i(starting)e(on)g(a)195 ! 2501 y(new)e(line.)1762 2615 y(F)l(unction)-1861 b Fi(int)20 ! b Fh(rl)p 215 2615 V 21 w(crlf)j Fg(\()p Ft(void)p Fg(\))195 ! 2670 y Fu(Mo)o(v)o(e)14 b(the)h(cursor)g(to)g(the)g(start)f(of)h(the)g ! (next)g(screen)h(line.)p eop ! %%Page: 31 33 ! 31 32 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)843 b(31)1762 149 y(F)l(unction)-1861 b Fi(int)20 ! b Fh(rl)p 215 149 18 3 v 21 w(sho)n(w)p 359 149 V 20 ! w(c)n(har)j Fg(\()p Ft(int)14 b(c)p Fg(\))195 204 y Fu(Displa)o(y)j(c)o ! (haracter)e Fk(c)20 b Fu(on)c Ft(rl_outstream)p Fu(.)21 ! b(If)c(Readline)g(has)f(not)g(b)q(een)i(set)e(to)f(displa)o(y)j(meta) ! 195 259 y(c)o(haracters)12 b(directly)l(,)j(this)e(will)i(con)o(v)o ! (ert)d(meta)h(c)o(haracters)f(to)g(a)h(meta-pre\014xed)g(k)o(ey)g ! (sequence.)195 314 y(This)j(is)f(in)o(tended)i(for)e(use)g(b)o(y)g ! (applications)i(whic)o(h)f(wish)g(to)f(do)g(their)g(o)o(wn)g(redispla)o ! (y)l(.)1762 443 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p ! 215 443 V 21 w(message)g Fg(\()p Ft(const)14 b(char)h(*,)g(...)p ! Fg(\))195 498 y Fu(The)c(argumen)o(ts)e(are)h(a)g(format)f(string)h(as) ! g(w)o(ould)h(b)q(e)g(supplied)i(to)c Ft(printf)p Fu(,)h(p)q(ossibly)i ! (con)o(taining)195 553 y(con)o(v)o(ersion)22 b(sp)q(eci\014cations)i ! (suc)o(h)f(as)e(`)p Ft(\045d)p Fu(',)i(and)f(an)o(y)g(additional)h ! (argumen)o(ts)e(necessary)i(to)195 608 y(satisfy)d(the)h(con)o(v)o ! (ersion)g(sp)q(eci\014cations.)38 b(The)21 b(resulting)h(string)e(is)i ! (displa)o(y)o(ed)g(in)f(the)g Fk(ec)o(ho)195 663 y(area)p ! Fu(.)e(The)d(ec)o(ho)f(area)g(is)g(also)g(used)h(to)f(displa)o(y)h(n)o ! (umeric)g(argumen)o(ts)f(and)g(searc)o(h)g(strings.)1762 ! 792 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 792 ! V 21 w(clear)p 354 792 V 21 w(message)h Fg(\()p Ft(void)p ! Fg(\))195 847 y Fu(Clear)15 b(the)h(message)e(in)i(the)g(ec)o(ho)f ! (area.)1762 976 y(F)l(unction)-1861 b Fi(void)20 b Fh(rl)p ! 241 976 V 21 w(sa)n(v)n(e)p 365 976 V 21 w(prompt)h Fg(\()p ! Ft(void)p Fg(\))195 1031 y Fu(Sa)o(v)o(e)g(the)h(lo)q(cal)g(Readline)h ! (prompt)e(displa)o(y)i(state)e(in)h(preparation)f(for)g(displa)o(ying)j ! (a)d(new)195 1086 y(message)15 b(in)h(the)f(message)g(area)f(with)i ! Ft(rl_message\(\))p Fu(.)1762 1215 y(F)l(unction)-1861 ! b Fi(void)20 b Fh(rl)p 241 1215 V 21 w(restore)p 436 ! 1215 V 20 w(prompt)g Fg(\()p Ft(void)p Fg(\))195 1270 ! y Fu(Restore)g(the)i(lo)q(cal)g(Readline)h(prompt)e(displa)o(y)h(state) ! f(sa)o(v)o(ed)g(b)o(y)g(the)g(most)g(recen)o(t)g(call)i(to)195 ! 1325 y Ft(rl_save_prompt)p Fu(.)1762 1455 y(F)l(unction)-1861 ! b Fi(int)20 b Fh(rl)p 215 1455 V 21 w(expand)p 416 1455 ! V 20 w(prompt)h Fg(\()p Ft(char)14 b(*prompt)p Fg(\))195 ! 1509 y Fu(Expand)22 b(an)o(y)f(sp)q(ecial)i(c)o(haracter)e(sequences)h ! (in)g Fk(prompt)g Fu(and)g(set)f(up)h(the)f(lo)q(cal)i(Readline)195 ! 1564 y(prompt)17 b(redispla)o(y)i(v)m(ariables.)30 b(This)18 ! b(function)h(is)f(called)i(b)o(y)e Ft(readline\(\))p ! Fu(.)26 b(It)18 b(ma)o(y)f(also)h(b)q(e)195 1619 y(called)12 ! b(to)e(expand)h(the)g(primary)g(prompt)f(if)h(the)f Ft ! (rl_on_new_line_with_prompt\(\))d Fu(function)195 1674 ! y(or)12 b Ft(rl_already_prompted)e Fu(v)m(ariable)k(is)g(used.)19 ! b(It)13 b(returns)g(the)f(n)o(um)o(b)q(er)i(of)e(visible)j(c)o ! (haracters)195 1729 y(on)g(the)g(last)h(line)g(of)f(the)g(\(p)q ! (ossibly)i(m)o(ulti-line\))g(prompt.)1762 1858 y(F)l(unction)-1861 ! b Fi(int)20 b Fh(rl)p 215 1858 V 21 w(set)p 307 1858 ! V 20 w(prompt)h Fg(\()p Ft(const)14 b(char)h(*prompt)p ! Fg(\))195 1913 y Fu(Mak)o(e)e(Readline)i(use)e Fk(prompt)h ! Fu(for)f(subsequen)o(t)h(redispla)o(y)l(.)21 b(This)14 ! b(calls)g Ft(rl_expand_prompt\(\))195 1968 y Fu(to)h(expand)g(the)h ! (prompt)e(and)i(sets)f Ft(rl_prompt)f Fu(to)g(the)h(result.)75 ! 2088 y Fj(2.4.7)30 b(Mo)r(difying)20 b(T)-5 b(ext)1762 ! 2247 y Fu(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 ! 2247 V 21 w(insert)p 378 2247 V 21 w(text)k Fg(\()p Ft(const)14 ! b(char)g(*text)p Fg(\))195 2301 y Fu(Insert)h Fk(text)h ! Fu(in)o(to)f(the)h(line)g(at)f(the)g(curren)o(t)g(cursor)g(p)q ! (osition.)1762 2431 y(F)l(unction)-1861 b Fi(int)20 b ! Fh(rl)p 215 2431 V 21 w(delete)p 383 2431 V 22 w(text)k ! Fg(\()p Ft(int)14 b(start,)h(int)f(end)p Fg(\))195 2486 ! y Fu(Delete)i(the)f(text)g(b)q(et)o(w)o(een)g Fk(start)g ! Fu(and)h Fk(end)h Fu(in)f(the)g(curren)o(t)f(line.)1762 ! 2615 y(F)l(unction)-1861 b Fi(char)20 b(*)f Fh(rl)p 286 ! 2615 V 21 w(cop)n(y)p 421 2615 V 21 w(text)24 b Fg(\()p ! Ft(int)14 b(start,)h(int)g(end)p Fg(\))195 2670 y Fu(Return)g(a)g(cop)o ! (y)g(of)g(the)g(text)f(b)q(et)o(w)o(een)i Fk(start)f ! Fu(and)g Fk(end)j Fu(in)e(the)f(curren)o(t)g(line.)p ! eop ! %%Page: 32 34 ! 32 33 bop 75 -58 a Fu(32)1299 b(GNU)15 b(Readline)h(Library)1762 ! 149 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 149 ! 18 3 v 21 w(kill)p 311 149 V 23 w(text)k Fg(\()p Ft(int)14 ! b(start,)h(int)g(end)p Fg(\))195 204 y Fu(Cop)o(y)i(the)g(text)f(b)q ! (et)o(w)o(een)i Fk(start)f Fu(and)g Fk(end)i Fu(in)f(the)f(curren)o(t)g ! (line)i(to)e(the)g(kill)i(ring,)e(app)q(ending)195 259 ! y(or)f(prep)q(ending)k(to)c(the)h(last)g(kill)i(if)e(the)g(last)g ! (command)g(w)o(as)f(a)h(kill)i(command.)25 b(The)17 b(text)f(is)195 ! 314 y(deleted.)26 b(If)17 b Fk(start)g Fu(is)g(less)g(than)g ! Fk(end)p Fu(,)g(the)g(text)g(is)g(app)q(ended,)h(otherwise)f(prep)q ! (ended.)27 b(If)17 b(the)195 369 y(last)e(command)g(w)o(as)g(not)f(a)h ! (kill,)i(a)e(new)g(kill)i(ring)f(slot)f(is)h(used.)1762 ! 478 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 478 ! V 21 w(push)p 355 478 V 19 w(macro)p 529 478 V 19 w(input)k ! Fg(\()p Ft(char)14 b(*macro)p Fg(\))195 533 y Fu(Cause)g ! Fk(macro)i Fu(to)d(b)q(e)i(inserted)g(in)o(to)f(the)g(line,)i(as)e(if)g ! (it)h(had)f(b)q(een)h(in)o(v)o(ok)o(ed)g(b)o(y)f(a)g(k)o(ey)g(b)q(ound) ! h(to)195 588 y(a)g(macro.)k(Not)c(esp)q(ecially)i(useful;)f(use)g ! Ft(rl_insert_text\(\))d Fu(instead.)75 696 y Fj(2.4.8)30 ! b(Character)21 b(Input)1762 834 y Fu(F)l(unction)-1861 ! b Fi(int)20 b Fh(rl)p 215 834 V 21 w(read)p 346 834 V ! 20 w(k)n(ey)k Fg(\()p Ft(void)p Fg(\))195 889 y Fu(Return)14 ! b(the)h(next)g(c)o(haracter)f(a)o(v)m(ailable)i(from)e(Readline's)i ! (curren)o(t)f(input)g(stream.)k(This)d(han-)195 944 y(dles)f(input)g ! (inserted)f(in)o(to)g(the)g(input)h(stream)e(via)h Fk(rl)p ! 1117 944 14 2 v 17 w(p)q(ending)p 1290 944 V 18 w(input)i ! Fu(\(see)e(Section)h(2.3)e([Read-)195 999 y(line)21 b(V)l(ariables],)g ! (page)f(22\))f(and)h Ft(rl_stuff_char\(\))p Fu(,)e(macros,)h(and)h(c)o ! (haracters)f(read)h(from)195 1053 y(the)d(k)o(eyb)q(oard.)25 ! b(While)19 b(w)o(aiting)e(for)f(input,)j(this)e(function)h(will)h(call) ! f(an)o(y)e(function)i(assigned)195 1108 y(to)d(the)g ! Ft(rl_event_hook)e Fu(v)m(ariable.)1762 1218 y(F)l(unction)-1861 ! b Fi(int)20 b Fh(rl)p 215 1218 18 3 v 21 w(getc)j Fg(\()p ! Ft(FILE)14 b(*stream)p Fg(\))195 1273 y Fu(Return)c(the)h(next)g(c)o ! (haracter)f(a)o(v)m(ailable)i(from)e Fk(stream)p Fu(,)g(whic)o(h)i(is)f ! (assumed)f(to)g(b)q(e)i(the)e(k)o(eyb)q(oard.)1762 1382 ! y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 1382 V ! 21 w(stu\013)p 346 1382 V 20 w(c)n(har)j Fg(\()p Ft(int)15 ! b(c)p Fg(\))195 1437 y Fu(Insert)i Fk(c)i Fu(in)o(to)d(the)h(Readline)h ! (input)f(stream.)23 b(It)16 b(will)i(b)q(e)f Ft(")p Fu(read)p ! Ft(")g Fu(b)q(efore)f(Readline)i(attempts)195 1492 y(to)d(read)g(c)o ! (haracters)f(from)h(the)g(terminal)h(with)f Ft(rl_read_key\(\))p ! Fu(.)1762 1602 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p ! 215 1602 V 21 w(execute)p 423 1602 V 22 w(next)j Fg(\()p ! Ft(int)15 b(c)p Fg(\))195 1656 y Fu(Mak)o(e)i Fk(c)k ! Fu(b)q(e)d(the)g(next)g(command)g(to)f(b)q(e)i(executed)f(when)h ! Ft(rl_read_key\(\))d Fu(is)i(called.)29 b(This)195 1711 ! y(sets)15 b Fk(rl)p 317 1711 14 2 v 17 w(p)q(ending)p ! 490 1711 V 18 w(input)p Fu(.)1762 1821 y(F)l(unction)-1861 ! b Fi(int)20 b Fh(rl)p 215 1821 18 3 v 21 w(clear)p 354 ! 1821 V 21 w(p)r(ending)p 575 1821 V 21 w(input)j Fg(\()p ! Ft(void)p Fg(\))195 1876 y Fu(Unset)f Fk(rl)p 365 1876 ! 14 2 v 16 w(p)q(ending)p 537 1876 V 19 w(input)p Fu(,)h(e\013ectiv)o ! (ely)g(negating)e(the)h(e\013ect)f(of)g(an)o(y)h(previous)g(call)h(to)d ! Ft(rl_)195 1930 y(execute_next\(\))p Fu(.)29 b(This)19 ! b(w)o(orks)f(only)h(if)h(the)e(p)q(ending)j(input)f(has)f(not)f ! (already)h(b)q(een)h(read)195 1985 y(with)c Ft(rl_read_key\(\))p ! Fu(.)1762 2095 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p ! 215 2095 18 3 v 21 w(set)p 307 2095 V 20 w(k)n(eyb)r(oard)p ! 558 2095 V 21 w(input)p 712 2095 V 21 w(timeout)i Fg(\()p ! Ft(int)15 b(u)p Fg(\))195 2150 y Fu(While)21 b(w)o(aiting)g(for)e(k)o ! (eyb)q(oard)h(input)h(in)g Ft(rl_read_key\(\))p Fu(,)e(Readline)i(will) ! h(w)o(ait)e(for)f Fk(u)h Fu(mi-)195 2204 y(croseconds)h(for)e(input)j ! (b)q(efore)f(calling)h(an)o(y)e(function)h(assigned)g(to)f ! Ft(rl_event_hook)p Fu(.)34 b(The)195 2259 y(default)16 ! b(w)o(aiting)f(p)q(erio)q(d)i(is)e(one-ten)o(th)h(of)e(a)h(second.)21 ! b(Returns)14 b(the)i(old)f(timeout)h(v)m(alue.)75 2367 ! y Fj(2.4.9)30 b(T)-5 b(erminal)20 b(Managemen)n(t)1762 ! 2506 y Fu(F)l(unction)-1861 b Fi(void)20 b Fh(rl)p 241 ! 2506 V 21 w(prep)p 376 2506 V 20 w(terminal)j Fg(\()p ! Ft(int)14 b(meta_flag)p Fg(\))195 2560 y Fu(Mo)q(dify)22 ! b(the)f(terminal)h(settings)f(for)g(Readline's)h(use,)h(so)d ! Ft(readline\(\))g Fu(can)i(read)f(a)g(single)195 2615 ! y(c)o(haracter)15 b(at)g(a)g(time)i(from)d(the)i(k)o(eyb)q(oard.)22 ! b(The)16 b Fk(meta)p 1192 2615 14 2 v 15 w(\015ag)k Fu(argumen)o(t)15 ! b(should)h(b)q(e)h(non-zero)195 2670 y(if)f(Readline)g(should)g(read)f ! (eigh)o(t-bit)i(input.)p eop ! %%Page: 33 35 ! 33 34 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)843 b(33)1762 149 y(F)l(unction)-1861 b Fi(void)20 ! b Fh(rl)p 241 149 18 3 v 21 w(deprep)p 434 149 V 20 w(terminal)j ! Fg(\()p Ft(void)p Fg(\))195 204 y Fu(Undo)16 b(the)g(e\013ects)f(of)h ! Ft(rl_prep_terminal\(\))p Fu(,)d(lea)o(ving)k(the)e(terminal)i(in)g ! (the)e(state)g(in)i(whic)o(h)195 259 y(it)e(w)o(as)g(b)q(efore)g(the)h ! (most)e(recen)o(t)h(call)i(to)d Ft(rl_prep_terminal\(\))p ! Fu(.)1762 379 y(F)l(unction)-1861 b Fi(void)20 b Fh(rl)p ! 241 379 V 21 w(tt)n(y)p 334 379 V 22 w(set)p 427 379 ! V 20 w(default)p 620 379 V 21 w(bindings)k Fg(\()p Ft(Keymap)14 ! b(kmap)p Fg(\))195 434 y Fu(Read)k(the)h(op)q(erating)f(system's)g ! (terminal)h(editing)h(c)o(haracters)e(\(as)f(w)o(ould)i(b)q(e)g(displa) ! o(y)o(ed)h(b)o(y)195 488 y Ft(stty)p Fu(\))14 b(to)h(their)h(Readline)g ! (equiv)m(alen)o(ts.)22 b(The)15 b(bindings)i(are)e(p)q(erformed)g(in)h ! Fk(kmap)p Fu(.)1762 608 y(F)l(unction)-1861 b Fi(int)20 ! b Fh(rl)p 215 608 V 21 w(reset)p 357 608 V 20 w(terminal)j ! Fg(\()p Ft(const)15 b(char)f(*terminal_name)p Fg(\))195 ! 663 y Fu(Reinitialize)h(Readline's)e(idea)g(of)f(the)g(terminal)h ! (settings)g(using)g Fk(terminal)p 1491 663 14 2 v 17 ! w(name)h Fu(as)e(the)h(termi-)195 718 y(nal)k(t)o(yp)q(e)f(\(e.g.,)f ! Ft(vt100)p Fu(\).)21 b(If)c Fk(terminal)p 878 718 V 17 ! w(name)i Fu(is)d Ft(NULL)p Fu(,)g(the)g(v)m(alue)h(of)f(the)g ! Ft(TERM)g Fu(en)o(vironmen)o(t)195 773 y(v)m(ariable)h(is)e(used.)75 ! 886 y Fj(2.4.10)29 b(Utilit)n(y)22 b(F)-5 b(unctions)1762 ! 1035 y Fu(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 ! 1035 18 3 v 21 w(extend)p 404 1035 V 21 w(line)p 513 ! 1035 V 22 w(bu\013er)j Fg(\()p Ft(int)15 b(len)p Fg(\))195 ! 1090 y Fu(Ensure)g(that)g Ft(rl_line_buffer)e Fu(has)i(enough)g(space)h ! (to)e(hold)i Fk(len)g Fu(c)o(haracters,)e(p)q(ossibly)i(real-)195 ! 1145 y(lo)q(cating)g(it)f(if)h(necessary)l(.)1762 1265 ! y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 1265 V ! 21 w(initiali)q(z)q(e)26 b Fg(\()p Ft(void)p Fg(\))195 ! 1320 y Fu(Initialize)21 b(or)d(re-initialize)k(Readline's)d(in)o ! (ternal)h(state.)28 b(It's)18 b(not)g(strictly)h(necessary)g(to)f(call) ! 195 1374 y(this;)d Ft(readline\(\))f Fu(calls)i(it)g(b)q(efore)f ! (reading)h(an)o(y)f(input.)1762 1494 y(F)l(unction)-1861 ! b Fi(int)20 b Fh(rl)p 215 1494 V 21 w(ding)j Fg(\()p ! Ft(void)p Fg(\))195 1549 y Fu(Ring)15 b(the)g(terminal)h(b)q(ell,)h(ob) ! q(eying)f(the)g(setting)f(of)g Ft(bell-style)p Fu(.)1762 ! 1669 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 1669 ! V 21 w(alphab)r(etic)k Fg(\()p Ft(int)14 b(c)p Fg(\))195 ! 1723 y Fu(Return)h(1)g(if)g Fk(c)j Fu(is)e(an)f(alphab)q(etic)i(c)o ! (haracter.)1762 1843 y(F)l(unction)-1861 b Fi(void)20 ! b Fh(rl)p 241 1843 V 21 w(displa)n(y)p 435 1843 V 22 ! w(matc)n(h)p 611 1843 V 20 w(list)25 b Fg(\()p Ft(char)14 ! b(**matches,)g(int)g(len,)h(int)g(max)p Fg(\))195 1898 ! y Fu(A)i(con)o(v)o(enience)i(function)f(for)f(displa)o(ying)i(a)e(list) ! h(of)e(strings)h(in)i(columnar)e(format)f(on)h(Read-)195 ! 1953 y(line's)h(output)f(stream.)23 b Ft(matches)16 b ! Fu(is)h(the)g(list)h(of)e(strings,)h(in)g(argv)f(format,)g(suc)o(h)h ! (as)f(a)h(list)g(of)195 2008 y(completion)c(matc)o(hes.)19 ! b Ft(len)11 b Fu(is)i(the)f(n)o(um)o(b)q(er)h(of)e(strings)h(in)h ! Ft(matches)p Fu(,)f(and)g Ft(max)g Fu(is)g(the)h(length)f(of)195 ! 2062 y(the)h(longest)g(string)g(in)h Ft(matches)p Fu(.)19 ! b(This)13 b(function)h(uses)f(the)h(setting)f(of)f Ft ! (print-completions-)195 2117 y(horizontally)k Fu(to)i(select)h(ho)o(w)e ! (the)i(matc)o(hes)e(are)h(displa)o(y)o(ed)h(\(see)g(Section)g(1.3.1)d ! ([Readline)195 2172 y(Init)g(File)g(Syn)o(tax],)e(page)h(4\).)137 ! 2266 y(The)i(follo)o(wing)f(are)g(implemen)o(ted)i(as)e(macros,)f ! (de\014ned)i(in)g Ft(chardefs.h)p Fu(.)k(Applications)d(should)75 ! 2321 y(refrain)d(from)g(using)h(them.)1762 2441 y(F)l(unction)-1861 ! b Fi(int)p 176 2441 V 40 w Fh(rl)p 235 2441 V 21 w(upp)r(ercase)p ! 506 2441 V 20 w(p)23 b Fg(\()p Ft(int)14 b(c)p Fg(\))195 ! 2495 y Fu(Return)h(1)g(if)g Fk(c)j Fu(is)e(an)f(upp)q(ercase)i(alphab)q ! (etic)f(c)o(haracter.)1762 2615 y(F)l(unction)-1861 b ! Fi(int)p 176 2615 V 40 w Fh(rl)p 235 2615 V 21 w(lo)n(w)n(ercase)p ! 489 2615 V 23 w(p)22 b Fg(\()p Ft(int)15 b(c)p Fg(\))195 ! 2670 y Fu(Return)g(1)g(if)g Fk(c)j Fu(is)e(a)f(lo)o(w)o(ercase)g ! (alphab)q(etic)i(c)o(haracter.)p eop ! %%Page: 34 36 ! 34 35 bop 75 -58 a Fu(34)1299 b(GNU)15 b(Readline)h(Library)1762 ! 149 y(F)l(unction)-1861 b Fi(int)p 176 149 18 3 v 40 ! w Fh(rl)p 235 149 V 21 w(digit)p 369 149 V 22 w(p)23 ! b Fg(\()p Ft(int)14 b(c)p Fg(\))195 204 y Fu(Return)h(1)g(if)g ! Fk(c)j Fu(is)e(a)f(n)o(umeric)h(c)o(haracter.)1762 360 ! y(F)l(unction)-1861 b Fi(int)p 176 360 V 40 w Fh(rl)p ! 235 360 V 21 w(to)p 307 360 V 21 w(upp)r(er)21 b Fg(\()p ! Ft(int)15 b(c)p Fg(\))195 415 y Fu(If)d Fk(c)j Fu(is)d(a)g(lo)o(w)o ! (ercase)f(alphab)q(etic)j(c)o(haracter,)d(return)h(the)g(corresp)q ! (onding)h(upp)q(ercase)g(c)o(haracter.)1762 571 y(F)l(unction)-1861 ! b Fi(int)p 176 571 V 40 w Fh(rl)p 235 571 V 21 w(to)p ! 307 571 V 21 w(lo)n(w)n(er)24 b Fg(\()p Ft(int)15 b(c)p ! Fg(\))195 626 y Fu(If)g Fk(c)i Fu(is)e(an)f(upp)q(ercase)i(alphab)q ! (etic)g(c)o(haracter,)e(return)g(the)h(corresp)q(onding)g(lo)o(w)o ! (ercase)f(c)o(harac-)195 680 y(ter.)1762 836 y(F)l(unction)-1861 ! b Fi(int)p 176 836 V 40 w Fh(rl)p 235 836 V 21 w(digit)p ! 369 836 V 22 w(v)m(alue)24 b Fg(\()p Ft(int)15 b(c)p ! Fg(\))195 891 y Fu(If)g Fk(c)k Fu(is)c(a)g(n)o(um)o(b)q(er,)g(return)g ! (the)h(v)m(alue)g(it)g(represen)o(ts.)75 1029 y Fj(2.4.11)29 ! b(Miscellaneous)22 b(F)-5 b(unctions)1762 1214 y Fu(F)l(unction)-1861 ! b Fi(int)20 b Fh(rl)p 215 1214 V 21 w(macro)p 391 1214 ! V 19 w(bind)j Fg(\()p Ft(const)14 b(char)g(*keyseq,)h(const)f(char)h ! (*macro,)283 1269 y(Keymap)f(map)p Fg(\))195 1324 y Fu(Bind)f(the)f(k)o ! (ey)f(sequence)i Fk(k)o(eyseq)g Fu(to)e(in)o(v)o(ok)o(e)g(the)h(macro)f ! Fk(macro)p Fu(.)18 b(The)12 b(binding)h(is)f(p)q(erformed)g(in)195 ! 1379 y Fk(map)p Fu(.)19 b(When)14 b Fk(k)o(eyseq)h Fu(is)f(in)o(v)o(ok) ! o(ed,)g(the)g Fk(macro)i Fu(will)f(b)q(e)f(inserted)h(in)o(to)f(the)g ! (line.)21 b(This)14 b(function)195 1433 y(is)i(deprecated;)f(use)h ! Ft(rl_generic_bind\(\))d Fu(instead.)1762 1589 y(F)l(unction)-1861 ! b Fi(void)20 b Fh(rl)p 241 1589 V 21 w(macro)p 417 1589 ! V 19 w(dump)r(er)g Fg(\()p Ft(int)15 b(readable)p Fg(\))195 ! 1644 y Fu(Prin)o(t)f(the)f(k)o(ey)h(sequences)g(b)q(ound)h(to)e(macros) ! g(and)g(their)h(v)m(alues,)h(using)f(the)g(curren)o(t)g(k)o(eymap,)195 ! 1699 y(to)h Ft(rl_outstream)p Fu(.)k(If)d Fk(readable)j ! Fu(is)d(non-zero,)g(the)g(list)g(is)g(formatted)f(in)h(suc)o(h)g(a)f(w) ! o(a)o(y)g(that)g(it)195 1754 y(can)g(b)q(e)h(made)f(part)g(of)g(an)g ! Ft(inputrc)f Fu(\014le)i(and)g(re-read.)1762 1910 y(F)l(unction)-1861 ! b Fi(int)20 b Fh(rl)p 215 1910 V 21 w(v)m(ariable)p 431 ! 1910 V 22 w(bind)j Fg(\()p Ft(const)14 b(char)g(*variable,)g(const)h ! (char)f(*value)p Fg(\))195 1964 y Fu(Mak)o(e)22 b(the)g(Readline)i(v)m ! (ariable)g Fk(v)m(ariable)j Fu(ha)o(v)o(e)22 b Fk(v)m(alue)p ! Fu(.)43 b(This)23 b(b)q(eha)o(v)o(es)g(as)f(if)h(the)f(readline)195 ! 2019 y(command)12 b(`)p Ft(set)j Fk(v)m(ariable)k(v)m(alue)s ! Fu(')12 b(had)h(b)q(een)g(executed)h(in)f(an)f Ft(inputrc)g ! Fu(\014le)h(\(see)f(Section)i(1.3.1)195 2074 y([Readline)i(Init)g(File) ! h(Syn)o(tax],)d(page)h(4\).)1762 2230 y(F)l(unction)-1861 ! b Fi(void)20 b Fh(rl)p 241 2230 V 21 w(v)m(ariable)p ! 457 2230 V 22 w(dump)r(er)g Fg(\()p Ft(int)14 b(readable)p ! Fg(\))195 2285 y Fu(Prin)o(t)g(the)h(readline)h(v)m(ariable)f(names)g ! (and)f(their)h(curren)o(t)f(v)m(alues)i(to)d Ft(rl_outstream)p ! Fu(.)18 b(If)d Fk(read-)195 2340 y(able)20 b Fu(is)e(non-zero,)f(the)g ! (list)h(is)g(formatted)e(in)h(suc)o(h)h(a)e(w)o(a)o(y)g(that)h(it)g ! (can)g(b)q(e)h(made)f(part)f(of)h(an)195 2394 y Ft(inputrc)d ! Fu(\014le)i(and)g(re-read.)1762 2550 y(F)l(unction)-1861 ! b Fi(int)20 b Fh(rl)p 215 2550 V 21 w(set)p 307 2550 ! V 20 w(paren)p 469 2550 V 20 w(blink)p 613 2550 V 23 ! w(timeout)i Fg(\()p Ft(int)15 b(u)p Fg(\))195 2605 y ! Fu(Set)e(the)f(time)h(in)o(terv)m(al)h(\(in)f(microseconds\))g(that)f ! (Readline)i(w)o(aits)e(when)h(sho)o(wing)f(a)h(balancing)195 ! 2660 y(c)o(haracter)h(when)i Ft(blink-matching-paren)d ! Fu(has)i(b)q(een)h(enabled.)p eop ! %%Page: 35 37 ! 35 36 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)843 b(35)75 149 y Fj(2.4.12)29 b(Alternate)21 ! b(In)n(terface)137 245 y Fu(An)i(alternate)f(in)o(terface)h(is)g(a)o(v) ! m(ailable)h(to)d(plain)j Ft(readline\(\))p Fu(.)40 b(Some)22 ! b(applications)i(need)g(to)75 300 y(in)o(terlea)o(v)o(e)15 b(k)o(eyb)q(oard)f(I/O)h(with)g(\014le,)h(device,)f(or)f(windo)o(w)h (system)f(I/O,)h(t)o(ypically)h(b)o(y)e(using)h(a)g(main)75 ! 355 y(lo)q(op)f(to)g Ft(select\(\))e Fu(on)i(v)m(arious)g(\014le)h (descriptors.)20 b(T)l(o)14 b(accomo)q(date)f(this)h(need,)h(readline)g ! (can)f(also)g(b)q(e)75 409 y(in)o(v)o(ok)o(ed)i(as)f(a)g(`callbac)o(k') ! h(function)h(from)d(an)i(ev)o(en)o(t)f(lo)q(op.)22 b(There)16 ! b(are)f(functions)h(a)o(v)m(ailable)i(to)c(mak)o(e)75 ! 464 y(this)i(easy)l(.)1762 577 y(F)l(unction)-1861 b ! Fi(void)20 b Fh(rl)p 241 577 18 3 v 21 w(callbac)n(k)p ! 458 577 V 23 w(handler)p 670 577 V 21 w(install)25 b ! Fg(\()p Ft(const)14 b(char)h(*prompt,)283 632 y(rl_vcpfunc_t)e ! (*lhandler)p Fg(\))195 687 y Fu(Set)f(up)h(the)g(terminal)g(for)f ! (readline)i(I/O)f(and)f(displa)o(y)i(the)e(initial)j(expanded)e(v)m ! (alue)h(of)e Fk(prompt)p Fu(.)195 742 y(Sa)o(v)o(e)j(the)h(v)m(alue)h ! (of)f Fk(lhandler)21 b Fu(to)15 b(use)h(as)f(a)h(function)h(to)e(call)i ! (when)f(a)g(complete)g(line)i(of)d(input)195 797 y(has)g(b)q(een)h(en)o ! (tered.)21 b(The)15 b(function)h(tak)o(es)e(the)i(text)e(of)h(the)g ! (line)i(as)e(an)g(argumen)o(t.)1762 910 y(F)l(unction)-1861 ! b Fi(void)20 b Fh(rl)p 241 910 V 21 w(callbac)n(k)p 458 ! 910 V 23 w(read)p 591 910 V 20 w(c)n(har)j Fg(\()p Ft(void)p ! Fg(\))195 965 y Fu(Whenev)o(er)17 b(an)g(application)h(determines)g ! (that)e(k)o(eyb)q(oard)h(input)h(is)f(a)o(v)m(ailable,)i(it)e(should)h ! (call)195 1019 y Ft(rl_callback_read_char\(\))p Fu(,)8 ! b(whic)o(h)k(will)g(read)f(the)g(next)g(c)o(haracter)f(from)g(the)h ! (curren)o(t)g(input)195 1074 y(source.)20 b(If)14 b(that)f(c)o ! (haracter)g(completes)i(the)f(line,)h Ft(rl_callback_read_char)c ! Fu(will)16 b(in)o(v)o(ok)o(e)e(the)195 1129 y Fk(lhandler)21 ! b Fu(function)c(sa)o(v)o(ed)e(b)o(y)h Ft(rl_callback_handler_install)d ! Fu(to)i(pro)q(cess)h(the)g(line.)24 b Ft(EOF)195 1184 ! y Fu(is)16 b(indicated)h(b)o(y)e(calling)i Fk(lhandler)j ! Fu(with)15 b(a)g Ft(NULL)g Fu(line.)1762 1297 y(F)l(unction)-1861 ! b Fi(void)20 b Fh(rl)p 241 1297 V 21 w(callbac)n(k)p ! 458 1297 V 23 w(handler)p 670 1297 V 21 w(remo)n(v)n(e)i ! Fg(\()p Ft(void)p Fg(\))195 1352 y Fu(Restore)c(the)g(terminal)i(to)d ! (its)i(initial)i(state)d(and)g(remo)o(v)o(e)g(the)h(line)h(handler.)31 ! b(This)19 b(ma)o(y)f(b)q(e)195 1407 y(called)f(from)d(within)j(a)e ! (callbac)o(k)h(as)f(w)o(ell)h(as)f(indep)q(enden)o(tly)l(.)75 ! 1516 y Fj(2.4.13)29 b(A)21 b(Readline)g(Example)137 1612 ! y Fu(Here)f(is)g(a)f(function)i(whic)o(h)f(c)o(hanges)f(lo)o(w)o ! (ercase)h(c)o(haracters)e(to)h(their)h(upp)q(ercase)h(equiv)m(alen)o ! (ts,)75 1667 y(and)e(upp)q(ercase)i(c)o(haracters)d(to)h(lo)o(w)o ! (ercase.)31 b(If)20 b(this)f(function)h(w)o(as)f(b)q(ound)h(to)f(`)p ! Ft(M-c)p Fu(',)f(then)i(t)o(yping)75 1721 y(`)p Ft(M-c)p Fu(')12 b(w)o(ould)h(c)o(hange)h(the)f(case)g(of)g(the)g(c)o(haracter)g (under)g(p)q(oin)o(t.)20 b(T)o(yping)14 b(`)p Ft(M-1)g(0)h(M-c)p ! Fu(')d(w)o(ould)i(c)o(hange)75 1776 y(the)h(case)g(of)g(the)h(follo)o (wing)f(10)g(c)o(haracters,)f(lea)o(ving)i(the)f(cursor)g(on)g(the)h ! (last)f(c)o(haracter)f(c)o(hanged.)195 1840 y Ft(/*)24 b(Invert)f(the)g(case)g(of)h(the)f(COUNT)h(following)e(characters.)h ! (*/)195 1892 y(int)195 1944 y(invert_case_line)f(\(count,)h(key\))314 ! 1995 y(int)h(count,)f(key;)195 2047 y({)243 2099 y(register)f(int)i ! (start,)f(end,)g(i;)243 2203 y(start)g(=)h(rl_point;)243 ! 2307 y(if)f(\(rl_point)g(>=)h(rl_end\))290 2359 y(return)f(\(0\);)243 ! 2462 y(if)g(\(count)g(<)h(0\))290 2514 y({)338 2566 y(direction)f(=)h ! (-1;)338 2618 y(count)f(=)h(-count;)290 2670 y(})p eop ! %%Page: 36 38 ! 36 37 bop 75 -58 a Fu(36)1299 b(GNU)15 b(Readline)h(Library)243 ! 149 y Ft(else)290 201 y(direction)23 b(=)h(1;)243 305 ! y(/*)f(Find)h(the)f(end)h(of)f(the)h(range)f(to)g(modify.)g(*/)243 ! 357 y(end)g(=)h(start)f(+)h(\(count)f(*)h(direction\);)243 ! 461 y(/*)f(Force)g(it)h(to)g(be)f(within)g(range.)g(*/)243 ! 513 y(if)g(\(end)h(>)f(rl_end\))290 565 y(end)h(=)g(rl_end;)243 ! 616 y(else)f(if)h(\(end)f(<)h(0\))290 668 y(end)g(=)g(0;)243 ! 772 y(if)f(\(start)g(==)h(end\))290 824 y(return)f(\(0\);)243 ! 928 y(if)g(\(start)g(>)h(end\))290 980 y({)338 1032 y(int)g(temp)f(=)h ! (start;)338 1083 y(start)f(=)h(end;)338 1135 y(end)g(=)f(temp;)290 ! 1187 y(})243 1291 y(/*)g(Tell)h(readline)e(that)i(we)f(are)h(modifying) ! e(the)i(line,)f(so)h(it)f(will)h(save)314 1343 y(the)g(undo)f ! (information.)f(*/)243 1395 y(rl_modifying)g(\(start,)h(end\);)243 ! 1499 y(for)g(\(i)h(=)f(start;)h(i)f(!=)h(end;)f(i++\))290 ! 1550 y({)338 1602 y(if)h(\(_rl_uppercase_p)d(\(rl_line_buffer[i]\)\)) ! 386 1654 y(rl_line_buffer[i])g(=)j(_rl_to_lower)e ! (\(rl_line_buffer[i]\);)338 1706 y(else)h(if)h(\(_rl_lowercase_p)e ! (\(rl_line_buffer[i]\)\))386 1758 y(rl_line_buffer[i])f(=)j ! (_rl_to_upper)e(\(rl_line_buffer[i]\);)290 1810 y(})243 ! 1862 y(/*)h(Move)h(point)f(to)g(on)h(top)f(of)h(the)f(last)h(character) ! e(changed.)h(*/)243 1914 y(rl_point)f(=)i(\(direction)f(==)g(1\))h(?)g ! (end)f(-)h(1)g(:)f(start;)243 1966 y(return)g(\(0\);)195 ! 2017 y(})75 2217 y Fs(2.5)33 b(Readline)23 b(Signal)h(Handling)137 ! 2341 y Fu(Signals)e(are)f(async)o(hronous)f(ev)o(en)o(ts)h(sen)o(t)f ! (to)h(a)f(pro)q(cess)h(b)o(y)g(the)g(Unix)h(k)o(ernel,)g(sometimes)f ! (on)75 2396 y(b)q(ehalf)g(of)e(another)h(pro)q(cess.)34 ! b(They)20 b(are)g(in)o(tended)h(to)e(indicate)j(exceptional)f(ev)o(en)o ! (ts,)f(lik)o(e)h(a)f(user)75 2451 y(pressing)c(the)f(in)o(terrupt)g(k)o ! (ey)g(on)g(his)h(terminal,)f(or)g(a)f(net)o(w)o(ork)g(connection)i(b)q ! (eing)g(brok)o(en.)k(There)15 b(is)75 2506 y(a)e(class)g(of)g(signals)h ! (that)f(can)g(b)q(e)h(sen)o(t)f(to)f(the)i(pro)q(cess)f(curren)o(tly)h ! (reading)f(input)i(from)d(the)h(k)o(eyb)q(oard.)75 2560 ! y(Since)i(Readline)f(c)o(hanges)g(the)f(terminal)h(attributes)f(when)h (it)g(is)g(called,)h(it)e(needs)h(to)f(p)q(erform)g(sp)q(ecial)75 ! 2615 y(pro)q(cessing)i(when)f(suc)o(h)g(a)g(signal)g(is)g(receiv)o(ed)h ! (in)g(order)f(to)f(restore)g(the)h(terminal)g(to)f(a)h(sane)g(state,)e ! (or)75 2670 y(pro)o(vide)k(application)h(writers)e(with)g(functions)h ! (to)f(do)g(so)g(man)o(ually)l(.)p eop ! %%Page: 37 39 ! 37 38 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)843 b(37)137 149 y(Readline)22 b(con)o(tains)e(an)g(in)o ! (ternal)h(signal)g(handler)g(that)f(is)h(installed)h(for)d(a)h(n)o(um)o ! (b)q(er)g(of)g(signals)75 204 y(\()p Ft(SIGINT)p Fu(,)h ! Ft(SIGQUIT)p Fu(,)g Ft(SIGTERM)p Fu(,)g Ft(SIGALRM)p ! Fu(,)g Ft(SIGTSTP)p Fu(,)g Ft(SIGTTIN)p Fu(,)h(and)f ! Ft(SIGTTOU)p Fu(\).)36 b(When)21 b(one)g(of)75 259 y(these)16 ! b(signals)h(is)f(receiv)o(ed,)h(the)f(signal)h(handler)f(will)i(reset)e ! (the)g(terminal)g(attributes)g(to)f(those)h(that)75 314 ! y(w)o(ere)d(in)i(e\013ect)e(b)q(efore)h Ft(readline\(\))e ! Fu(w)o(as)h(called,)i(reset)f(the)f(signal)i(handling)g(to)e(what)g(it) ! h(w)o(as)f(b)q(efore)75 369 y Ft(readline\(\))21 b Fu(w)o(as)h(called,) ! j(and)e(resend)g(the)g(signal)g(to)f(the)h(calling)h(application.)44 ! b(If)23 b(and)f(when)75 423 y(the)17 b(calling)i(application's)f ! (signal)g(handler)g(returns,)f(Readline)h(will)h(reinitialize)h(the)d ! (terminal)h(and)75 478 y(con)o(tin)o(ue)d(to)e(accept)i(input.)20 ! b(When)15 b(a)e Ft(SIGINT)h Fu(is)g(receiv)o(ed,)h(the)g(Readline)g ! (signal)g(handler)g(p)q(erforms)75 533 y(some)k(additional)i(w)o(ork,)e ! (whic)o(h)h(will)h(cause)f(an)o(y)f(partially-en)o(tered)i(line)g(to)d ! (b)q(e)i(ab)q(orted)g(\(see)f(the)75 588 y(description)e(of)d ! Ft(rl_free_line_state\(\))f Fu(b)q(elo)o(w\).)137 655 ! y(There)g(is)f(an)g(additional)i(Readline)g(signal)f(handler,)g(for)f ! Ft(SIGWINCH)p Fu(,)f(whic)o(h)i(the)f(k)o(ernel)h(sends)g(to)e(a)75 ! 710 y(pro)q(cess)k(whenev)o(er)g(the)f(terminal's)h(size)g(c)o(hanges)f ! (\(for)g(example,)h(if)g(a)f(user)h(resizes)g(an)f Ft(xterm)p ! Fu(\).)19 b(The)75 764 y(Readline)g Ft(SIGWINCH)e Fu(handler)i(up)q ! (dates)f(Readline's)h(in)o(ternal)f(screen)h(size)f(information,)h(and) ! f(then)75 819 y(calls)g(an)o(y)f Ft(SIGWINCH)e Fu(signal)j(handler)g ! (the)f(calling)i(application)f(has)f(installed.)27 b(Readline)18 ! b(calls)g(the)75 874 y(application's)h Ft(SIGWINCH)d ! Fu(signal)j(handler)f(without)g(resetting)g(the)f(terminal)i(to)e(its)g ! (original)i(state.)75 929 y(If)d(the)g(application's)h(signal)g ! (handler)g(do)q(es)g(more)e(than)h(up)q(date)h(its)f(idea)h(of)e(the)h ! (terminal)h(size)g(and)75 984 y(return)e(\(for)f(example,)h(a)f ! Ft(longjmp)g Fu(bac)o(k)h(to)f(a)h(main)g(pro)q(cessing)g(lo)q(op\),)g ! (it)g Fl(must)20 b Fu(call)c Ft(rl_cleanup_)75 1038 y(after_signal\(\)) ! d Fu(\(describ)q(ed)k(b)q(elo)o(w\),)e(to)g(restore)f(the)h(terminal)h ! (state.)137 1105 y(Readline)g(pro)o(vides)f(t)o(w)o(o)e(v)m(ariables)i (that)f(allo)o(w)g(application)i(writers)e(to)g(con)o(trol)g(whether)h ! (or)e(not)75 1160 y(it)k(will)h(catc)o(h)e(certain)h(signals)h(and)f (act)f(on)g(them)h(when)g(they)f(are)h(receiv)o(ed.)25 ! b(It)16 b(is)i(imp)q(ortan)o(t)e(that)75 1215 y(applications)k(c)o ! (hange)e(the)h(v)m(alues)g(of)f(these)h(v)m(ariables)g(only)g(when)g ! (calling)h Ft(readline\(\))p Fu(,)d(not)h(in)h(a)75 1270 ! y(signal)d(handler,)g(so)f(Readline's)h(in)o(ternal)g(signal)g(state)e ! (is)i(not)f(corrupted.)1773 1385 y(V)l(ariable)-1861 ! b Fi(int)20 b Fh(rl)p 215 1385 18 3 v 21 w(catc)n(h)p ! 366 1385 V 22 w(signals)195 1440 y Fu(If)15 b(this)g(v)m(ariable)g(is)g ! (non-zero,)g(Readline)h(will)g(install)f(signal)h(handlers)f(for)f ! Ft(SIGINT)p Fu(,)f Ft(SIGQUIT)p Fu(,)195 1495 y Ft(SIGTERM)p ! Fu(,)h Ft(SIGALRM)p Fu(,)g Ft(SIGTSTP)p Fu(,)f Ft(SIGTTIN)p ! Fu(,)h(and)i Ft(SIGTTOU)p Fu(.)195 1562 y(The)f(default)h(v)m(alue)h ! (of)d Ft(rl_catch_signals)f Fu(is)j(1.)1773 1678 y(V)l(ariable)-1861 ! b Fi(int)20 b Fh(rl)p 215 1678 V 21 w(catc)n(h)p 366 ! 1678 V 22 w(sigwinc)n(h)195 1732 y Fu(If)15 b(this)h(v)m(ariable)h(is)e ! (non-zero,)g(Readline)i(will)g(install)f(a)f(signal)h(handler)h(for)d ! Ft(SIGWINCH)p Fu(.)195 1799 y(The)h(default)h(v)m(alue)h(of)d ! Ft(rl_catch_sigwinch)f Fu(is)j(1.)137 1891 y(If)g(an)f(application)j ! (do)q(es)d(not)g(wish)i(to)d(ha)o(v)o(e)h(Readline)i(catc)o(h)f(an)o(y) ! f(signals,)h(or)f(to)f(handle)j(signals)75 1945 y(other)i(than)g(those) ! g(Readline)i(catc)o(hes)e(\()p Ft(SIGHUP)p Fu(,)g(for)g(example\),)h ! (Readline)h(pro)o(vides)e(con)o(v)o(enience)75 2000 y(functions)d(to)f (do)g(the)g(necessary)g(terminal)h(and)g(in)o(ternal)g(state)e(clean)o ! (up)i(up)q(on)g(receipt)g(of)f(a)g(signal.)1762 2116 ! y(F)l(unction)-1861 b Fi(void)20 b Fh(rl)p 241 2116 V ! 21 w(clean)n(up)p 450 2116 V 22 w(after)p 590 2116 V ! 20 w(signal)j Fg(\()p Ft(void)p Fg(\))195 2171 y Fu(This)18 ! b(function)f(will)i(reset)e(the)g(state)f(of)g(the)h(terminal)h(to)e ! (what)h(it)g(w)o(as)f(b)q(efore)h Ft(readline\(\))195 ! 2226 y Fu(w)o(as)d(called,)i(and)f(remo)o(v)o(e)f(the)g(Readline)i ! (signal)g(handlers)g(for)e(all)h(signals,)g(dep)q(ending)i(on)e(the)195 ! 2280 y(v)m(alues)h(of)f Ft(rl_catch_signals)e Fu(and)i ! Ft(rl_catch_sigwinch)p Fu(.)1762 2396 y(F)l(unction)-1861 ! b Fi(void)20 b Fh(rl)p 241 2396 V 21 w(free)p 356 2396 ! V 20 w(line)p 464 2396 V 23 w(state)j Fg(\()p Ft(void)p ! Fg(\))195 2451 y Fu(This)d(will)h(free)f(an)o(y)f(partial)h(state)f ! (asso)q(ciated)h(with)g(the)g(curren)o(t)f(input)i(line)g(\(undo)f ! (infor-)195 2506 y(mation,)i(an)o(y)f(partial)h(history)f(en)o(try)l(,) ! h(an)o(y)f(partially-en)o(tered)i(k)o(eyb)q(oard)e(macro,)h(and)f(an)o ! (y)195 2560 y(partially-en)o(tered)k(n)o(umeric)g(argumen)o(t\).)45 ! b(This)24 b(should)h(b)q(e)g(called)g(b)q(efore)g Ft(rl_cleanup_)195 ! 2615 y(after_signal\(\))p Fu(.)36 b(The)22 b(Readline)h(signal)f ! (handler)g(for)f Ft(SIGINT)f Fu(calls)j(this)e(to)g(ab)q(ort)g(the)195 ! 2670 y(curren)o(t)15 b(input)h(line.)p eop ! %%Page: 38 40 ! 38 39 bop 75 -58 a Fu(38)1299 b(GNU)15 b(Readline)h(Library)1762 ! 149 y(F)l(unction)-1861 b Fi(void)20 b Fh(rl)p 241 149 ! 18 3 v 21 w(reset)p 383 149 V 20 w(after)p 521 149 V ! 21 w(signal)j Fg(\()p Ft(void)p Fg(\))195 204 y Fu(This)15 ! b(will)h(reinitialize)h(the)d(terminal)h(and)g(reinstall)h(an)o(y)d ! (Readline)j(signal)f(handlers,)g(dep)q(end-)195 259 y(ing)h(on)f(the)g ! (v)m(alues)i(of)d Ft(rl_catch_signals)f Fu(and)j Ft(rl_catch_sigwinch)p ! Fu(.)137 352 y(If)k(an)g(application)h(do)q(es)f(not)g(wish)g(Readline) ! h(to)e(catc)o(h)g Ft(SIGWINCH)p Fu(,)h(it)g(ma)o(y)f(call)h ! Ft(rl_resize_)75 407 y(terminal\(\))12 b Fu(or)h Ft ! (rl_set_screen_size\(\))e Fu(to)i(force)g(Readline)i(to)e(up)q(date)h ! (its)g(idea)g(of)g(the)f(terminal)75 461 y(size)j(when)g(a)f ! Ft(SIGWINCH)f Fu(is)h(receiv)o(ed.)1762 579 y(F)l(unction)-1861 ! b Fi(void)20 b Fh(rl)p 241 579 V 21 w(resize)p 401 579 ! V 22 w(terminal)j Fg(\()p Ft(void)p Fg(\))195 634 y Fu(Up)q(date)16 ! b(Readline's)g(in)o(ternal)g(screen)f(size)i(b)o(y)e(reading)g(v)m ! (alues)i(from)d(the)i(k)o(ernel.)1762 752 y(F)l(unction)-1861 ! b Fi(void)20 b Fh(rl)p 241 752 V 21 w(set)p 333 752 V ! 21 w(screen)p 510 752 V 20 w(size)k Fg(\()p Ft(int)15 ! b(rows,)f(int)h(cols)p Fg(\))195 807 y Fu(Set)g(Readline's)h(idea)g(of) ! f(the)g(terminal)h(size)g(to)f Fk(ro)o(ws)h Fu(ro)o(ws)e(and)i ! Fk(cols)h Fu(columns.)137 899 y(If)g(an)g(application)h(do)q(es)f(not)f ! (w)o(an)o(t)g(to)g(install)i(a)f Ft(SIGWINCH)e Fu(handler,)j(but)f(is)g ! (still)h(in)o(terested)f(in)75 954 y(the)e(screen)h(dimensions,)g ! (Readline's)h(idea)e(of)g(the)h(screen)f(size)h(ma)o(y)f(b)q(e)h ! (queried.)1762 1072 y(F)l(unction)-1861 b Fi(void)20 ! b Fh(rl)p 241 1072 V 21 w(get)p 339 1072 V 21 w(screen)p ! 516 1072 V 20 w(size)k Fg(\()p Ft(int)15 b(*rows,)f(int)h(*cols)p ! Fg(\))195 1127 y Fu(Return)g(Readline's)h(idea)f(of)g(the)g(terminal's) ! g(size)h(in)g(the)f(v)m(ariables)i(p)q(oin)o(ted)f(to)e(b)o(y)h(the)g ! (argu-)195 1181 y(men)o(ts.)137 1274 y(The)h(follo)o(wing)g(functions)g ! (install)g(and)g(remo)o(v)o(e)e(Readline's)i(signal)g(handlers.)1762 ! 1392 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 1392 ! V 21 w(set)p 307 1392 V 20 w(signals)j Fg(\()p Ft(void)p ! Fg(\))195 1447 y Fu(Install)c(Readline's)f(signal)h(handler)f(for)f ! Ft(SIGINT)p Fu(,)g Ft(SIGQUIT)p Fu(,)g Ft(SIGTERM)p Fu(,)g ! Ft(SIGALRM)p Fu(,)f Ft(SIGTSTP)p Fu(,)195 1502 y Ft(SIGTTIN)p ! Fu(,)11 b Ft(SIGTTOU)p Fu(,)g(and)h Ft(SIGWINCH)p Fu(,)e(dep)q(ending)k ! (on)e(the)f(v)m(alues)i(of)e Ft(rl_catch_signals)f Fu(and)195 ! 1556 y Ft(rl_catch_sigwinch)p Fu(.)1762 1674 y(F)l(unction)-1861 ! b Fi(int)20 b Fh(rl)p 215 1674 V 21 w(clear)p 354 1674 ! V 21 w(signals)j Fg(\()p Ft(void)p Fg(\))195 1729 y Fu(Remo)o(v)o(e)14 ! b(all)i(of)f(the)g(Readline)i(signal)f(handlers)g(installed)h(b)o(y)e ! Ft(rl_set_signals\(\))p Fu(.)75 1858 y Fs(2.6)33 b(Custom)21 ! b(Completers)137 1955 y Fu(T)o(ypically)l(,)e(a)d(program)f(that)h (reads)h(commands)f(from)g(the)h(user)f(has)h(a)f(w)o(a)o(y)g(of)g ! (disam)o(biguating)75 2010 y(commands)i(and)f(data.)27 b(If)18 b(y)o(our)f(program)g(is)h(one)g(of)f(these,)i(then)f(it)g(can) ! f(pro)o(vide)i(completion)g(for)75 2065 y(commands,)14 b(data,)g(or)g(b)q(oth.)20 b(The)15 b(follo)o(wing)g(sections)g (describ)q(e)h(ho)o(w)e(y)o(our)g(program)g(and)h(Readline)75 ! 2119 y(co)q(op)q(erate)g(to)g(pro)o(vide)g(this)h(service.)75 ! 2232 y Fj(2.6.1)30 b(Ho)n(w)21 b(Completing)f(W)-5 b(orks)137 ! 2329 y Fu(In)18 b(order)f(to)f(complete)i(some)f(text,)g(the)g(full)i (list)e(of)g(p)q(ossible)i(completions)f(m)o(ust)f(b)q(e)h(a)o(v)m ! (ailable.)75 2383 y(That)e(is,)i(it)f(is)h(not)f(p)q(ossible)h(to)f (accurately)g(expand)h(a)e(partial)i(w)o(ord)e(without)h(kno)o(wing)g ! (all)h(of)f(the)75 2438 y(p)q(ossible)i(w)o(ords)e(whic)o(h)h(mak)o(e)f ! (sense)h(in)h(that)d(con)o(text.)26 b(The)18 b(Readline)h(library)f ! (pro)o(vides)g(the)g(user)75 2493 y(in)o(terface)f(to)f(completion,)i (and)e(t)o(w)o(o)g(of)g(the)h(most)f(common)g(completion)i(functions:) ! 23 b(\014lename)18 b(and)75 2548 y(username.)h(F)l(or)10 b(completing)i(other)e(t)o(yp)q(es)h(of)f(text,)h(y)o(ou)g(m)o(ust)f (write)h(y)o(our)f(o)o(wn)h(completion)g(function.)75 ! 2602 y(This)16 b(section)g(describ)q(es)g(exactly)g(what)f(suc)o(h)g (functions)h(m)o(ust)f(do,)f(and)i(pro)o(vides)f(an)h(example.)137 ! 2670 y(There)g(are)f(three)g(ma)s(jor)f(functions)i(used)f(to)g(p)q ! (erform)g(completion:)p eop %%Page: 39 41 39 40 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)843 b(39)100 149 y(1.)29 b(The)22 b(user-in)o(terface)g ! (function)h Ft(rl_complete\(\))p Fu(.)37 b(This)22 b(function)h(is)f ! (called)h(with)f(the)g(same)165 204 y(argumen)o(ts)17 ! b(as)h(other)g(bindable)i(Readline)f(functions:)27 b ! Fk(coun)o(t)19 b Fu(and)f Fk(in)o(v)o(oking)p 1556 204 ! 14 2 v 17 w(k)o(ey)p Fu(.)28 b(It)19 b(isolates)165 259 ! y(the)g(w)o(ord)f(to)g(b)q(e)i(completed)f(and)g(calls)h ! Ft(rl_completion_matches\(\))c Fu(to)i(generate)g(a)h(list)g(of)165 ! 314 y(p)q(ossible)e(completions.)22 b(It)16 b(then)g(either)g(lists)g ! (the)g(p)q(ossible)h(completions,)g(inserts)f(the)f(p)q(ossible)165 ! 369 y(completions,)25 b(or)d(actually)i(p)q(erforms)e(the)g ! (completion,)k(dep)q(ending)e(on)f(whic)o(h)g(b)q(eha)o(vior)g(is)165 ! 423 y(desired.)100 489 y(2.)29 b(The)17 b(in)o(ternal)h(function)f ! Ft(rl_completion_matches\(\))d Fu(uses)j(an)g(application-supplie)q(d)j ! Fk(gener-)165 544 y(ator)h Fu(function)e(to)f(generate)g(the)h(list)g ! (of)f(p)q(ossible)i(matc)o(hes,)f(and)f(then)h(returns)g(the)f(arra)o ! (y)f(of)165 599 y(these)j(matc)o(hes.)32 b(The)20 b(caller)g(should)h ! (place)f(the)g(address)f(of)h(its)f(generator)g(function)h(in)g ! Ft(rl_)165 653 y(completion_entry_function)p Fu(.)100 ! 719 y(3.)29 b(The)12 b(generator)e(function)i(is)g(called)h(rep)q ! (eatedly)g(from)e Ft(rl_completion_matches\(\))p Fu(,)d(returning)165 ! 774 y(a)16 b(string)g(eac)o(h)h(time.)24 b(The)17 b(argumen)o(ts)e(to)h ! (the)g(generator)g(function)h(are)f Fk(text)h Fu(and)g ! Fk(state)p Fu(.)22 b Fk(text)165 828 y Fu(is)17 b(the)f(partial)g(w)o ! (ord)f(to)h(b)q(e)h(completed.)23 b Fk(state)18 b Fu(is)e(zero)g(the)g ! (\014rst)g(time)g(the)g(function)h(is)g(called,)165 883 ! y(allo)o(wing)23 b(the)f(generator)f(to)g(p)q(erform)h(an)o(y)g ! (necessary)g(initialization,)k(and)c(a)g(p)q(ositiv)o(e)h(non-)165 ! 938 y(zero)14 b(in)o(teger)h(for)f(eac)o(h)h(subsequen)o(t)g(call.)21 ! b(The)15 b(generator)e(function)j(returns)e Ft(\(char)h(*\)NULL)f ! Fu(to)165 993 y(inform)19 b Ft(rl_completion_matches\(\))d ! Fu(that)i(there)h(are)g(no)g(more)g(p)q(ossibilities)j(left.)32 ! b(Usually)165 1048 y(the)19 b(generator)g(function)h(computes)g(the)f ! (list)h(of)f(p)q(ossible)i(completions)g(when)e Fk(state)j ! Fu(is)d(zero,)165 1102 y(and)13 b(returns)g(them)f(one)h(at)f(a)h(time) ! g(on)g(subsequen)o(t)g(calls.)20 b(Eac)o(h)13 b(string)f(the)h ! (generator)f(function)165 1157 y(returns)k(as)f(a)h(matc)o(h)f(m)o(ust) ! h(b)q(e)g(allo)q(cated)h(with)g Ft(malloc\(\))p Fu(;)d(Readline)k ! (frees)e(the)g(strings)f(when)165 1212 y(it)g(has)h(\014nished)g(with)g ! (them.)1762 1321 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p ! 215 1321 18 3 v 21 w(complete)j Fg(\()p Ft(int)14 b(ignore,)g(int)h ! (invoking_key)p Fg(\))195 1375 y Fu(Complete)h(the)f(w)o(ord)g(at)f(or) ! h(b)q(efore)h(p)q(oin)o(t.)21 b(Y)l(ou)15 b(ha)o(v)o(e)g(supplied)j ! (the)d(function)i(that)d(do)q(es)i(the)195 1430 y(initial)23 ! b(simple)f(matc)o(hing)e(selection)i(algorithm)f(\(see)f ! Ft(rl_completion_matches\(\))p Fu(\).)33 b(The)195 1485 ! y(default)16 b(is)f(to)g(do)g(\014lename)h(completion.)1773 ! 1594 y(V)l(ariable)-1861 b Fi(rl_compentry_func_t)22 ! b(*)d Fh(rl)p 678 1594 V 21 w(completion)p 973 1594 V ! 21 w(en)n(try)p 1126 1594 V 22 w(function)195 1648 y ! Fu(This)i(is)f(a)g(p)q(oin)o(ter)g(to)f(the)h(generator)g(function)g ! (for)g Ft(rl_completion_matches\(\))p Fu(.)31 b(If)20 ! b(the)195 1703 y(v)m(alue)13 b(of)f Ft(rl_completion_entry_fun)o(ction) ! d Fu(is)j Ft(NULL)f Fu(then)h(the)g(default)h(\014lename)g(generator) ! 195 1758 y(function,)j Ft(rl_filename_completion_f)o(unction)o(\(\))p ! Fu(,)c(is)k(used.)75 1865 y Fj(2.6.2)30 b(Completion)20 ! b(F)-5 b(unctions)137 1960 y Fu(Here)16 b(is)f(the)h(complete)g(list)g ! (of)e(callable)k(completion)e(functions)g(presen)o(t)f(in)h(Readline.) ! 1762 2068 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 ! 2068 V 21 w(complete)p 460 2068 V 21 w(in)n(ternal)k ! Fg(\()p Ft(int)15 b(what_to_do)p Fg(\))195 2123 y Fu(Complete)k(the)g ! (w)o(ord)f(at)g(or)g(b)q(efore)h(p)q(oin)o(t.)31 b Fk(what)p ! 1108 2123 14 2 v 16 w(to)p 1165 2123 V 16 w(do)21 b Fu(sa)o(ys)d(what)g ! (to)g(do)h(with)g(the)g(com-)195 2178 y(pletion.)j(A)16 ! b(v)m(alue)h(of)e(`)p Ft(?)p Fu(')g(means)g(list)i(the)e(p)q(ossible)j ! (completions.)k(`)p Ft(TAB)p Fu(')14 b(means)i(do)f(standard)195 ! 2233 y(completion.)22 b(`)p Ft(*)p Fu(')15 b(means)g(insert)h(all)h(of) ! e(the)h(p)q(ossible)h(completions.)22 b(`)p Ft(!)p Fu(')15 ! b(means)g(to)g(displa)o(y)i(all)195 2287 y(of)g(the)g(p)q(ossible)i ! (completions,)f(if)g(there)f(is)h(more)f(than)g(one,)g(as)g(w)o(ell)h ! (as)f(p)q(erforming)h(partial)195 2342 y(completion.)1762 ! 2451 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 2451 ! 18 3 v 21 w(complete)j Fg(\()p Ft(int)14 b(ignore,)g(int)h ! (invoking_key)p Fg(\))195 2506 y Fu(Complete)21 b(the)g(w)o(ord)e(at)h ! (or)g(b)q(efore)h(p)q(oin)o(t.)37 b(Y)l(ou)21 b(ha)o(v)o(e)f(supplied)j ! (the)d(function)i(that)e(do)q(es)195 2560 y(the)d(initial)h(simple)g ! (matc)o(hing)f(selection)h(algorithm)e(\(see)g Ft ! (rl_completion_matches\(\))e Fu(and)195 2615 y Ft ! (rl_completion_entry_functi)o(on)p Fu(\).)25 b(The)18 ! b(default)h(is)f(to)f(do)h(\014lename)h(completion.)29 ! b(This)195 2670 y(calls)16 b Ft(rl_complete_internal\(\))c ! Fu(with)k(an)f(argumen)o(t)f(dep)q(ending)k(on)d Fk(in)o(v)o(oking)p ! 1657 2670 14 2 v 17 w(k)o(ey)p Fu(.)p eop %%Page: 40 42 ! 40 41 bop 75 -58 a Fu(40)1299 b(GNU)15 b(Readline)h(Library)1762 ! 149 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 149 ! 18 3 v 21 w(p)r(ossible)p 433 149 V 20 w(completions)j ! Fg(\()p Ft(int)15 b(count,)f(int)h(invoking_key)p Fg(\))195 ! 204 y Fu(List)21 b(the)f(p)q(ossible)i(completions.)36 ! b(See)21 b(description)h(of)e Ft(rl_complete)13 b(\(\))p ! Fu(.)35 b(This)21 b(calls)g Ft(rl_)195 259 y(complete_internal\(\))13 ! b Fu(with)i(an)g(argumen)o(t)g(of)f(`)p Ft(?)p Fu('.)1762 ! 371 y(F)l(unction)-1861 b Fi(int)20 b Fh(rl)p 215 371 ! V 21 w(insert)p 378 371 V 21 w(completions)j Fg(\()p ! Ft(int)14 b(count,)g(int)h(invoking_key)p Fg(\))195 426 ! y Fu(Insert)i(the)g(list)h(of)e(p)q(ossible)j(completions)e(in)o(to)g ! (the)g(line,)i(deleting)f(the)f(partially-completed)195 ! 481 y(w)o(ord.)k(See)c(description)g(of)e Ft(rl_complete\(\))p ! Fu(.)20 b(This)d(calls)g Ft(rl_complete_internal\(\))c ! Fu(with)195 535 y(an)i(argumen)o(t)g(of)f(`)p Ft(*)p ! Fu('.)1762 648 y(F)l(unction)-1861 b Fi(char)20 b(**)f ! Fh(rl)p 312 648 V 21 w(completion)p 607 648 V 21 w(matc)n(hes)j ! Fg(\()p Ft(const)15 b(char)f(*text,)283 702 y(rl_compentry_func_t)e ! (*entry_func)p Fg(\))195 757 y Fu(Returns)18 b(an)h(arra)o(y)f(of)g ! (strings)h(whic)o(h)h(is)g(a)e(list)i(of)e(completions)i(for)f ! Fk(text)p Fu(.)30 b(If)19 b(there)g(are)g(no)195 812 ! y(completions,)f(returns)g Ft(NULL)p Fu(.)25 b(The)17 ! b(\014rst)g(en)o(try)g(in)h(the)f(returned)h(arra)o(y)e(is)i(the)f ! (substitution)195 867 y(for)c Fk(text)p Fu(.)18 b(The)c(remaining)g(en) ! o(tries)f(are)g(the)h(p)q(ossible)g(completions.)21 b(The)13 ! b(arra)o(y)f(is)i(terminated)195 921 y(with)i(a)e Ft(NULL)h ! Fu(p)q(oin)o(ter.)195 988 y Fk(en)o(try)p 302 988 14 ! 2 v 16 w(func)h Fu(is)e(a)f(function)h(of)e(t)o(w)o(o)g(args,)g(and)i ! (returns)f(a)f Ft(char)j(*)p Fu(.)k(The)13 b(\014rst)g(argumen)o(t)f ! (is)i Fk(text)p Fu(.)195 1043 y(The)f(second)g(is)f(a)h(state)e ! (argumen)o(t;)h(it)h(is)g(zero)f(on)g(the)h(\014rst)f(call,)i(and)e ! (non-zero)h(on)f(subsequen)o(t)195 1097 y(calls.)20 b ! Fk(en)o(try)p 420 1097 V 16 w(func)15 b Fu(returns)e(a)e ! Ft(NULL)h Fu(p)q(oin)o(ter)h(to)e(the)i(caller)g(when)g(there)f(are)g ! (no)g(more)g(matc)o(hes.)1762 1209 y(F)l(unction)-1861 ! b Fi(char)20 b(*)f Fh(rl)p 286 1209 18 3 v 21 w(\014lename)p ! 515 1209 V 20 w(completion)p 809 1209 V 21 w(function)k ! Fg(\()p Ft(const)15 b(char)f(*text,)h(int)283 1264 y(state)p ! Fg(\))195 1319 y Fu(A)e(generator)f(function)h(for)g(\014lename)h ! (completion)f(in)h(the)f(general)g(case.)19 b Fk(text)14 ! b Fu(is)f(a)g(partial)g(\014le-)195 1374 y(name.)20 b(The)15 ! b(Bash)f(source)h(is)g(a)g(useful)g(reference)h(for)e(writing)h(custom) ! f(completion)i(functions)195 1429 y(\(the)f(Bash)g(completion)i ! (functions)e(call)i(this)e(and)h(other)f(Readline)h(functions\).)1762 ! 1541 y(F)l(unction)-1861 b Fi(char)20 b(*)f Fh(rl)p 286 ! 1541 V 21 w(username)p 547 1541 V 19 w(completion)p 840 ! 1541 V 21 w(function)k Fg(\()p Ft(const)14 b(char)g(*text,)283 ! 1595 y(int)g(state)p Fg(\))195 1650 y Fu(A)g(completion)i(generator)d ! (for)h(usernames.)19 b Fk(text)c Fu(con)o(tains)f(a)g(partial)h ! (username)f(preceded)i(b)o(y)195 1705 y(a)f(random)g(c)o(haracter)f ! (\(usually)j(`)p Ft(~)p Fu('\).)i(As)c(with)g(all)i(completion)f ! (generators,)e Fk(state)j Fu(is)f(zero)f(on)195 1760 ! y(the)g(\014rst)g(call)h(and)g(non-zero)f(for)g(subsequen)o(t)h(calls.) ! 75 1869 y Fj(2.6.3)30 b(Completion)20 b(V)-5 b(ariables)1773 ! 2010 y Fu(V)l(ariable)-1861 b Fi(rl_compentry_func_t)22 ! b(*)d Fh(rl)p 678 2010 V 21 w(completion)p 973 2010 V ! 21 w(en)n(try)p 1126 2010 V 22 w(function)195 2065 y ! Fu(A)e(p)q(oin)o(ter)g(to)f(the)h(generator)f(function)h(for)f ! Ft(rl_completion_matches\(\))p Fu(.)22 b Ft(NULL)16 b ! Fu(means)h(to)195 2120 y(use)f Ft(rl_filename_completion_)o(functio)o ! (n\(\))p Fu(,)c(the)j(default)h(\014lename)g(completer.)1773 ! 2232 y(V)l(ariable)-1861 b Fi(rl_completion_func_t)22 ! b(*)d Fh(rl)p 704 2232 V 22 w(attempted)p 985 2232 V ! 20 w(completion)p 1279 2232 V 21 w(function)195 2286 ! y Fu(A)e(p)q(oin)o(ter)h(to)f(an)g(alternativ)o(e)h(function)g(to)f ! (create)g(matc)o(hes.)26 b(The)18 b(function)g(is)g(called)h(with)195 ! 2341 y Fk(text)p Fu(,)11 b Fk(start)p Fu(,)g(and)h Fk(end)p ! Fu(.)19 b Fk(start)11 b Fu(and)h Fk(end)i Fu(are)d(indices)i(in)g ! Ft(rl_line_buffer)c Fu(de\014ning)k(the)f(b)q(ound-)195 ! 2396 y(aries)h(of)g Fk(text)p Fu(,)f(whic)o(h)i(is)g(a)e(c)o(haracter)h ! (string.)19 b(If)13 b(this)g(function)h(exists)g(and)f(returns)g ! Ft(NULL)p Fu(,)f(or)g(if)195 2451 y(this)f(v)m(ariable)i(is)e(set)g(to) ! f Ft(NULL)p Fu(,)h(then)g Ft(rl_complete\(\))e Fu(will)k(call)f(the)f ! (v)m(alue)h(of)f Ft(rl_completion_)195 2506 y(entry_function)h ! Fu(to)i(generate)g(matc)o(hes,)f(otherwise)i(the)f(arra)o(y)f(of)h ! (strings)g(returned)g(will)i(b)q(e)195 2560 y(used.)j(If)12 ! b(this)f(function)h(sets)f(the)g Ft(rl_attempted_completion_over)d ! Fu(v)m(ariable)k(to)f(a)g(non-zero)195 2615 y(v)m(alue,)18 ! b(Readline)h(will)f(not)f(p)q(erform)f(its)i(default)f(completion)h(ev) ! o(en)f(if)h(this)f(function)h(returns)195 2670 y(no)d(matc)o(hes.)p ! eop %%Page: 41 43 41 42 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)843 b(41)1773 149 y(V)l(ariable)-1861 b Fi(rl_quote_func_t)21 ! b(*)f Fh(rl)p 574 149 18 3 v 21 w(\014lename)p 803 149 ! V 20 w(quoting)p 1012 149 V 21 w(function)195 204 y Fu(A)c(p)q(oin)o ! (ter)h(to)f(a)g(function)h(that)e(will)j(quote)e(a)g(\014lename)i(in)f ! (an)f(application-sp)q(eci\014)q(c)j(fashion.)195 259 ! y(This)h(is)g(called)i(if)e(\014lename)g(completion)h(is)f(b)q(eing)h ! (attempted)e(and)h(one)g(of)f(the)h(c)o(haracters)195 ! 314 y(in)d Ft(rl_filename_quote_characters)c Fu(app)q(ears)k(in)g(a)g ! (completed)g(\014lename.)25 b(The)17 b(function)195 369 ! y(is)i(called)i(with)e Fk(text)p Fu(,)g Fk(matc)o(h)p ! 722 369 14 2 v 16 w(t)o(yp)q(e)p Fu(,)g(and)g Fk(quote)p ! 1059 369 V 17 w(p)q(oin)o(ter)p Fu(.)31 b(The)19 b Fk(text)h ! Fu(is)f(the)g(\014lename)h(to)e(b)q(e)195 423 y(quoted.)39 ! b(The)21 b Fk(matc)o(h)p 607 423 V 16 w(t)o(yp)q(e)j ! Fu(is)e(either)g Ft(SINGLE_MATCH)p Fu(,)f(if)h(there)f(is)h(only)g(one) ! g(completion)195 478 y(matc)o(h,)15 b(or)g Ft(MULT_MATCH)p ! Fu(.)20 b(Some)c(functions)g(use)g(this)g(to)f(decide)j(whether)e(or)f ! (not)g(to)g(insert)h(a)195 533 y(closing)c(quote)e(c)o(haracter.)18 ! b(The)11 b Fk(quote)p 877 533 V 16 w(p)q(oin)o(ter)k ! Fu(is)c(a)f(p)q(oin)o(ter)i(to)e(an)o(y)g(op)q(ening)i(quote)f(c)o ! (haracter)195 588 y(the)k(user)h(t)o(yp)q(ed.)k(Some)15 ! b(functions)h(c)o(ho)q(ose)f(to)g(reset)g(this)g(c)o(haracter.)1773 ! 690 y(V)l(ariable)-1861 b Fi(rl_dequote_func_t)22 b(*)d ! Fh(rl)p 626 690 18 3 v 21 w(\014lename)p 855 690 V 20 ! w(dequoting)p 1122 690 V 21 w(function)195 744 y Fu(A)c(p)q(oin)o(ter)g ! (to)f(a)h(function)g(that)g(will)h(remo)o(v)o(e)e(application-sp)q ! (eci\014)q(c)k(quoting)d(c)o(haracters)f(from)195 799 ! y(a)i(\014lename)h(b)q(efore)g(completion)g(is)g(attempted,)f(so)f ! (those)h(c)o(haracters)g(do)g(not)g(in)o(terfere)h(with)195 ! 854 y(matc)o(hing)i(the)g(text)g(against)f(names)h(in)h(the)f ! (\014lesystem.)33 b(It)19 b(is)g(called)i(with)e Fk(text)p ! Fu(,)g(the)g(text)195 909 y(of)i(the)g(w)o(ord)g(to)g(b)q(e)h ! (dequoted,)h(and)e Fk(quote)p 1009 909 14 2 v 17 w(c)o(har)p ! Fu(,)h(whic)o(h)g(is)g(the)f(quoting)h(c)o(haracter)f(that)195 ! 964 y(delimits)d(the)e(\014lename)i(\(usually)f(`)p Ft(')p ! Fu(')f(or)f(`)p Ft(")p Fu('\).)22 b(If)17 b Fk(quote)p ! 1187 964 V 16 w(c)o(har)i Fu(is)e(zero,)f(the)g(\014lename)i(w)o(as)d ! (not)195 1018 y(in)h(an)f(em)o(b)q(edded)i(string.)1773 ! 1120 y(V)l(ariable)-1861 b Fi(rl_linebuf_func_t)22 b(*)d ! Fh(rl)p 626 1120 18 3 v 21 w(c)n(har)p 754 1120 V 21 ! w(is)p 813 1120 V 21 w(quoted)p 1005 1120 V 21 w(p)195 ! 1175 y Fu(A)f(p)q(oin)o(ter)h(to)f(a)g(function)h(to)f(call)i(that)d ! (determines)j(whether)e(or)g(not)g(a)g(sp)q(eci\014c)j(c)o(haracter)195 ! 1230 y(in)d(the)f(line)i(bu\013er)e(is)h(quoted,)g(according)f(to)g ! (whatev)o(er)f(quoting)i(mec)o(hanism)g(the)f(program)195 ! 1284 y(calling)d(Readline)g(uses.)19 b(The)13 b(function)g(is)g(called) ! h(with)f(t)o(w)o(o)e(argumen)o(ts:)17 b Fk(text)p Fu(,)12 ! b(the)h(text)f(of)g(the)195 1339 y(line,)17 b(and)e Fk(index)p ! Fu(,)i(the)e(index)i(of)e(the)g(c)o(haracter)g(in)h(the)g(line.)22 ! b(It)15 b(is)h(used)g(to)f(decide)i(whether)e(a)195 1394 ! y(c)o(haracter)f(found)i(in)g Ft(rl_completer_word_break_)o(charact)o ! (ers)c Fu(should)k(b)q(e)g(used)g(to)e(break)195 1449 ! y(w)o(ords)g(for)h(the)g(completer.)1773 1551 y(V)l(ariable)-1861 ! b Fi(int)20 b Fh(rl)p 215 1551 V 21 w(completion)p 510 ! 1551 V 21 w(query)p 673 1551 V 21 w(items)195 1605 y ! Fu(Up)e(to)g(this)g(man)o(y)g(items)g(will)i(b)q(e)f(displa)o(y)o(ed)g ! (in)g(resp)q(onse)g(to)e(a)h(p)q(ossible-completions)j(call.)195 ! 1660 y(After)14 b(that,)f(w)o(e)h(ask)g(the)h(user)f(if)h(she)f(is)h ! (sure)g(she)f(w)o(an)o(ts)f(to)h(see)h(them)f(all.)20 ! b(The)15 b(default)g(v)m(alue)195 1715 y(is)h(100.)1773 ! 1817 y(V)l(ariable)-1861 b Fi(const)20 b(char)g(*)f Fh(rl)p ! 436 1817 V 21 w(basic)p 580 1817 V 21 w(w)n(ord)p 725 ! 1817 V 21 w(break)p 886 1817 V 20 w(c)n(haracters)195 ! 1872 y Fu(The)j(basic)h(list)g(of)f(c)o(haracters)f(that)g(signal)i(a)f ! (break)g(b)q(et)o(w)o(een)g(w)o(ords)g(for)f(the)h(completer)195 ! 1926 y(routine.)30 b(The)19 b(default)g(v)m(alue)h(of)e(this)h(v)m ! (ariable)h(is)f(the)g(c)o(haracters)f(whic)o(h)h(break)g(w)o(ords)f ! (for)195 1981 y(completion)e(in)g(Bash:)k Ft(")15 b ! (\\t\\n\\"\\\\'`@$><=;|&{\(")p Fu(.)1773 2083 y(V)l(ariable)-1861 ! b Fi(const)20 b(char)g(*)f Fh(rl)p 436 2083 V 21 w(basic)p ! 580 2083 V 21 w(quote)p 740 2083 V 21 w(c)n(haracters)195 ! 2138 y Fu(A)c(list)h(of)f(quote)g(c)o(haracters)f(whic)o(h)i(can)g ! (cause)f(a)g(w)o(ord)g(break.)1773 2239 y(V)l(ariable)-1861 ! b Fi(const)20 b(char)g(*)f Fh(rl)p 436 2239 V 21 w(completer)p ! 705 2239 V 21 w(w)n(ord)p 850 2239 V 20 w(break)p 1010 ! 2239 V 20 w(c)n(haracters)195 2294 y Fu(The)33 b(list)g(of)f(c)o ! (haracters)g(that)f(signal)j(a)e(break)g(b)q(et)o(w)o(een)h(w)o(ords)f ! (for)g Ft(rl_complete_)195 2349 y(internal\(\))p Fu(.)18 ! b(The)e(default)g(list)g(is)f(the)h(v)m(alue)g(of)f Ft ! (rl_basic_word_break_chara)o(cters)p Fu(.)1773 2451 y(V)l(ariable)-1861 ! b Fi(const)20 b(char)g(*)f Fh(rl)p 436 2451 V 21 w(completer)p ! 705 2451 V 21 w(quote)p 865 2451 V 20 w(c)n(haracters)195 ! 2506 y Fu(A)e(list)h(of)e(c)o(haracters)g(whic)o(h)i(can)f(b)q(e)g ! (used)h(to)e(quote)h(a)f(substring)h(of)g(the)g(line.)26 ! b(Completion)195 2560 y(o)q(ccurs)13 b(on)h(the)f(en)o(tire)g ! (substring,)h(and)f(within)i(the)e(substring)g Ft ! (rl_completer_word_break_)195 2615 y(characters)j Fu(are)h(treated)g ! (as)h(an)o(y)f(other)g(c)o(haracter,)g(unless)i(they)e(also)h(app)q ! (ear)g(within)h(this)195 2670 y(list.)p eop %%Page: 42 44 ! 42 43 bop 75 -58 a Fu(42)1299 b(GNU)15 b(Readline)h(Library)1773 ! 149 y(V)l(ariable)-1861 b Fi(const)20 b(char)g(*)f Fh(rl)p ! 436 149 18 3 v 21 w(\014lename)p 665 149 V 20 w(quote)p ! 824 149 V 21 w(c)n(haracters)195 204 y Fu(A)e(list)h(of)e(c)o ! (haracters)g(that)g(cause)h(a)g(\014lename)h(to)e(b)q(e)i(quoted)e(b)o ! (y)h(the)g(completer)h(when)f(they)195 259 y(app)q(ear)e(in)h(a)f ! (completed)h(\014lename.)21 b(The)16 b(default)g(is)f(the)h(n)o(ull)g ! (string.)1773 376 y(V)l(ariable)-1861 b Fi(const)20 b(char)g(*)f ! Fh(rl)p 436 376 V 21 w(sp)r(ecial)p 623 376 V 22 w(pre\014xes)195 ! 431 y Fu(The)14 b(list)h(of)e(c)o(haracters)g(that)g(are)h(w)o(ord)f ! (break)h(c)o(haracters,)f(but)h(should)h(b)q(e)f(left)g(in)h ! Fk(text)f Fu(when)195 486 y(it)f(is)f(passed)h(to)f(the)g(completion)h ! (function.)20 b(Programs)11 b(can)h(use)h(this)g(to)f(help)h(determine) ! h(what)195 541 y(kind)i(of)e(completing)i(to)e(do.)19 ! b(F)l(or)14 b(instance,)i(Bash)e(sets)h(this)g(v)m(ariable)h(to)e ! Ft(")p Fu($)p Ft(@")g Fu(so)g(that)g(it)h(can)195 596 ! y(complete)h(shell)h(v)m(ariables)f(and)g(hostnames.)1773 ! 713 y(V)l(ariable)-1861 b Fi(int)20 b Fh(rl)p 215 713 ! V 21 w(completion)p 510 713 V 21 w(app)r(end)p 715 713 ! V 19 w(c)n(haracter)195 768 y Fu(When)d(a)f(single)i(completion)g ! (alternativ)o(e)f(matc)o(hes)f(at)g(the)h(end)g(of)f(the)h(command)f ! (line,)j(this)195 823 y(c)o(haracter)10 b(is)h(app)q(ended)i(to)d(the)g ! (inserted)i(completion)g(text.)18 b(The)11 b(default)g(is)g(a)g(space)g ! (c)o(haracter)195 877 y(\(`)j('\).)19 b(Setting)14 b(this)f(to)g(the)g ! (n)o(ull)i(c)o(haracter)e(\(`)p Ft(\\0)p Fu('\))e(prev)o(en)o(ts)i(an)o ! (ything)h(b)q(eing)h(app)q(ended)f(auto-)195 932 y(matically)l(.)21 ! b(This)15 b(can)f(b)q(e)h(c)o(hanged)g(in)g(custom)f(completion)i ! (functions)f(to)f(pro)o(vide)h(the)f(\\most)195 987 y(sensible)i(w)o ! (ord)c(separator)h(c)o(haracter")f(according)i(to)f(an)h ! (application-sp)q(eci\014c)j(command)c(line)195 1042 ! y(syn)o(tax)h(sp)q(eci\014cation.)1773 1159 y(V)l(ariable)-1861 ! b Fi(int)20 b Fh(rl)p 215 1159 V 21 w(ignore)p 391 1159 ! V 20 w(completion)p 685 1159 V 21 w(duplicates)195 1214 ! y Fu(If)15 b(non-zero,)h(then)f(duplicates)i(in)f(the)f(matc)o(hes)g ! (are)g(remo)o(v)o(ed.)k(The)d(default)g(is)f(1.)1773 ! 1331 y(V)l(ariable)-1861 b Fi(int)20 b Fh(rl)p 215 1331 ! V 21 w(\014lename)p 444 1331 V 20 w(completion)p 738 ! 1331 V 21 w(desired)195 1386 y Fu(Non-zero)c(means)g(that)f(the)h ! (results)g(of)g(the)g(matc)o(hes)f(are)h(to)f(b)q(e)i(treated)e(as)g ! (\014lenames.)23 b(This)195 1441 y(is)14 b Fl(always)j ! Fu(zero)c(on)g(en)o(try)l(,)g(and)h(can)f(only)h(b)q(e)g(c)o(hanged)f ! (within)i(a)e(completion)h(en)o(try)f(generator)195 1496 ! y(function.)38 b(If)21 b(it)g(is)g(set)g(to)f(a)g(non-zero)h(v)m(alue,) ! i(directory)e(names)g(ha)o(v)o(e)g(a)f(slash)h(app)q(ended)195 ! 1551 y(and)d(Readline)h(attempts)d(to)h(quote)g(completed)i ! (\014lenames)f(if)g(they)g(con)o(tain)g(an)o(y)f(c)o(haracters)195 ! 1605 y(in)f Ft(rl_filename_quote_character)o(s)d Fu(and)i ! Ft(rl_filename_quoting_desired)d Fu(is)k(set)f(to)f(a)195 ! 1660 y(non-zero)h(v)m(alue.)1773 1778 y(V)l(ariable)-1861 ! b Fi(int)20 b Fh(rl)p 215 1778 V 21 w(\014lename)p 444 ! 1778 V 20 w(quoting)p 653 1778 V 21 w(desired)195 1832 ! y Fu(Non-zero)14 b(means)g(that)f(the)i(results)f(of)g(the)g(matc)o ! (hes)f(are)h(to)f(b)q(e)i(quoted)f(using)h(double)g(quotes)195 ! 1887 y(\(or)c(an)h(application-sp)q(eci\014)q(c)j(quoting)d(mec)o ! (hanism\))g(if)h(the)f(completed)h(\014lename)g(con)o(tains)f(an)o(y) ! 195 1942 y(c)o(haracters)i(in)i Ft(rl_filename_quote_chars)p ! Fu(.)h(This)f(is)f Fl(always)k Fu(non-zero)d(on)f(en)o(try)l(,)f(and)i ! (can)195 1997 y(only)c(b)q(e)g(c)o(hanged)g(within)h(a)f(completion)g ! (en)o(try)g(generator)e(function.)20 b(The)12 b(quoting)g(is)g ! (e\013ected)195 2052 y(via)j(a)g(call)i(to)d(the)i(function)g(p)q(oin)o ! (ted)g(to)e(b)o(y)h Ft(rl_filename_quoting_function)p ! Fu(.)1773 2169 y(V)l(ariable)-1861 b Fi(int)20 b Fh(rl)p ! 215 2169 V 21 w(attempted)p 495 2169 V 20 w(completion)p ! 789 2169 V 21 w(o)n(v)n(er)195 2224 y Fu(If)47 b(an)g(application-sp)q ! (eci\014)q(c)j(completion)e(function)g(assigned)f(to)g ! Ft(rl_attempted_)195 2279 y(completion_function)24 b ! Fu(sets)i(this)h(v)m(ariable)h(to)e(a)g(non-zero)h(v)m(alue,)j ! (Readline)e(will)g(not)195 2333 y(p)q(erform)15 b(its)g(default)g ! (\014lename)h(completion)g(ev)o(en)f(if)g(the)g(application's)h ! (completion)g(function)195 2388 y(returns)f(no)g(matc)o(hes.)20 ! b(It)15 b(should)h(b)q(e)g(set)f(only)h(b)o(y)f(an)g(application's)h ! (completion)h(function.)1773 2506 y(V)l(ariable)-1861 ! b Fi(int)20 b Fh(rl)p 215 2506 V 21 w(completion)p 510 ! 2506 V 21 w(t)n(yp)r(e)195 2560 y Fu(Set)e(to)e(a)i(c)o(haracter)f ! (describing)i(the)e(t)o(yp)q(e)h(of)f(completion)i(Readline)g(is)f ! (curren)o(tly)g(attempt-)195 2615 y(ing;)g(see)f(the)f(description)i ! (of)f Ft(rl_complete_internal\(\))c Fu(\(see)k(Section)h(2.6.2)d ! ([Completion)195 2670 y(F)l(unctions],)g(page)g(39\))g(for)f(the)h ! (list)h(of)f(c)o(haracters.)p eop %%Page: 43 45 43 44 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)843 b(43)1773 149 y(V)l(ariable)-1861 b Fi(int)20 ! b Fh(rl)p 215 149 18 3 v 21 w(inhibit)p 399 149 V 23 ! w(completion)195 204 y Fu(If)14 b(this)h(v)m(ariable)g(is)g(non-zero,)f ! (completion)i(is)e(inhibited.)22 b(The)15 b(completion)g(c)o(haracter)e ! (will)j(b)q(e)195 259 y(inserted)g(as)f(an)o(y)g(other)g(b)q(ound)h(to) ! e Ft(self-insert)p Fu(.)1773 376 y(V)l(ariable)-1861 ! b Fi(rl_compignore_func_t)22 b(*)d Fh(rl)p 704 376 V ! 22 w(ignore)p 881 376 V 20 w(some)p 1028 376 V 19 w(completions)p ! 1344 376 V 21 w(function)195 431 y Fu(This)g(function,)i(if)e ! (de\014ned,)i(is)e(called)h(b)o(y)f(the)g(completer)g(when)h(real)f ! (\014lename)h(completion)195 486 y(is)e(done,)f(after)f(all)i(the)f ! (matc)o(hing)g(names)g(ha)o(v)o(e)g(b)q(een)h(generated.)25 ! b(It)17 b(is)h(passed)f(a)g Ft(NULL)f Fu(ter-)195 540 ! y(minated)g(arra)o(y)e(of)h(matc)o(hes.)20 b(The)c(\014rst)f(elemen)o ! (t)h(\()p Ft(matches[0])p Fu(\))d(is)j(the)g(maximal)g(substring)195 ! 595 y(common)e(to)g(all)h(matc)o(hes.)k(This)c(function)g(can)g ! (re-arrange)f(the)g(list)h(of)f(matc)o(hes)g(as)g(required,)195 ! 650 y(but)h(eac)o(h)h(elemen)o(t)g(deleted)g(from)f(the)g(arra)o(y)f(m) ! o(ust)g(b)q(e)i(freed.)1773 767 y(V)l(ariable)-1861 b ! Fi(rl_icppfunc_t)21 b(*)e Fh(rl)p 521 767 V 21 w(directory)p ! 769 767 V 22 w(completion)p 1065 767 V 21 w(ho)r(ok)195 ! 822 y Fu(This)k(function,)i(if)e(de\014ned,)j(is)d(allo)o(w)o(ed)g(to)f ! (mo)q(dify)h(the)g(directory)g(p)q(ortion)g(of)f(\014lenames)195 ! 877 y(Readline)e(completes.)29 b(It)19 b(is)f(called)i(with)f(the)f ! (address)h(of)e(a)h(string)h(\(the)f(curren)o(t)g(directory)195 ! 932 y(name\))g(as)g(an)h(argumen)o(t,)f(and)h(ma)o(y)f(mo)q(dify)h ! (that)f(string.)30 b(If)19 b(the)f(string)h(is)g(replaced)h(with)195 ! 986 y(a)g(new)g(string,)h(the)f(old)g(v)m(alue)h(should)g(b)q(e)g ! (freed.)34 b(An)o(y)20 b(mo)q(di\014ed)i(directory)e(name)g(should)195 ! 1041 y(ha)o(v)o(e)14 b(a)g(trailing)i(slash.)k(The)15 ! b(mo)q(di\014ed)h(v)m(alue)g(will)g(b)q(e)f(displa)o(y)o(ed)h(as)e ! (part)g(of)h(the)f(completion,)195 1096 y(replacing)h(the)g(directory)f ! (p)q(ortion)g(of)g(the)g(pathname)g(the)h(user)f(t)o(yp)q(ed.)20 ! b(It)14 b(returns)g(an)g(in)o(teger)195 1151 y(that)i(should)h(b)q(e)g ! (non-zero)g(if)g(the)g(function)g(mo)q(di\014es)h(its)e(directory)h ! (argumen)o(t.)23 b(It)17 b(could)g(b)q(e)195 1205 y(used)f(to)e(expand) ! i(sym)o(b)q(olic)h(links)f(or)f(shell)i(v)m(ariables)f(in)g(pathnames.) ! 1773 1323 y(V)l(ariable)-1861 b Fi(rl_compdisp_func_t)22 ! b(*)d Fh(rl)p 652 1323 V 21 w(completion)p 947 1323 V ! 21 w(displa)n(y)p 1141 1323 V 22 w(matc)n(hes)p 1366 ! 1323 V 21 w(ho)r(ok)195 1377 y Fu(If)11 b(non-zero,)h(then)f(this)h(is) ! f(the)g(address)g(of)g(a)g(function)g(to)g(call)h(when)f(completing)i ! (a)d(w)o(ord)h(w)o(ould)195 1432 y(normally)h(displa)o(y)g(the)f(list)h ! (of)f(p)q(ossible)h(matc)o(hes.)18 b(This)12 b(function)g(is)g(called)g ! (in)g(lieu)h(of)e(Readline)195 1487 y(displa)o(ying)21 ! b(the)d(list.)32 b(It)19 b(tak)o(es)f(three)h(argumen)o(ts:)26 ! b(\()p Ft(char)14 b(**)p Fk(matc)o(hes)p Fu(,)19 b Ft(int)f ! Fk(n)o(um)p 1688 1487 14 2 v 17 w(matc)o(hes)p Fu(,)195 ! 1542 y Ft(int)13 b Fk(max)p 368 1542 V 16 w(length)p ! Fu(\))i(where)f Fk(matc)o(hes)h Fu(is)f(the)g(arra)o(y)f(of)g(matc)o ! (hing)h(strings,)g Fk(n)o(um)p 1578 1542 V 16 w(matc)o(hes)i ! Fu(is)e(the)195 1597 y(n)o(um)o(b)q(er)h(of)f(strings)h(in)h(that)e ! (arra)o(y)l(,)f(and)i Fk(max)p 1012 1597 V 16 w(length)h ! Fu(is)f(the)g(length)g(of)g(the)f(longest)h(string)g(in)195 ! 1651 y(that)e(arra)o(y)l(.)19 b(Readline)c(pro)o(vides)g(a)e(con)o(v)o ! (enience)j(function,)f Ft(rl_display_match_list)p Fu(,)c(that)195 ! 1706 y(tak)o(es)17 b(care)g(of)g(doing)h(the)f(displa)o(y)i(to)d ! (Readline's)j(output)e(stream.)26 b(That)16 b(function)j(ma)o(y)d(b)q ! (e)195 1761 y(called)h(from)d(this)i(ho)q(ok.)75 1873 ! y Fj(2.6.4)30 b(A)21 b(Short)f(Completion)g(Example)137 ! 1969 y Fu(Here)11 b(is)f(a)g(small)h(application)h(demonstrating)e(the) ! g(use)h(of)e(the)i(GNU)f(Readline)h(library)l(.)19 b(It)11 ! b(is)f(called)75 2024 y Ft(fileman)p Fu(,)17 b(and)h(the)g(source)g(co) ! q(de)g(resides)h(in)f(`)p Ft(examples/fileman.c)p Fu('.)25 ! b(This)18 b(sample)g(application)75 2079 y(pro)o(vides)c(completion)g ! (of)e(command)h(names,)g(line)i(editing)g(features,)d(and)i(access)f ! (to)f(the)h(history)h(list.)p eop %%Page: 44 46 ! 44 45 bop 75 -58 a Fu(44)1299 b(GNU)15 b(Readline)h(Library)195 ! 149 y Ft(/*)24 b(fileman.c)e(--)i(A)g(tiny)f(application)f(which)h ! (demonstrates)g(how)g(to)h(use)f(the)267 201 y(GNU)g(Readline)g ! (library.)46 b(This)24 b(application)e(interactively)g(allows)h(users) ! 267 253 y(to)g(manipulate)g(files)g(and)g(their)g(modes.)h(*/)195 ! 357 y(#include)f()195 409 y(#include)g()195 ! 461 y(#include)g()195 513 y(#include)g()195 ! 565 y(#include)g()195 668 y(#include)g ! ()195 720 y(#include)g()195 ! 824 y(extern)g(char)g(*xmalloc)g(\(\);)195 928 y(/*)h(The)f(names)g(of) ! h(functions)e(that)i(actually)f(do)g(the)h(manipulation.)e(*/)195 ! 980 y(int)h(com_list)g(__P\(\(char)g(*\)\);)195 1032 ! y(int)g(com_view)g(__P\(\(char)g(*\)\);)195 1083 y(int)g(com_rename)g ! (__P\(\(char)g(*\)\);)195 1135 y(int)g(com_stat)g(__P\(\(char)g(*\)\);) ! 195 1187 y(int)g(com_pwd)g(__P\(\(char)g(*\)\);)195 1239 ! y(int)g(com_delete)g(__P\(\(char)g(*\)\);)195 1291 y(int)g(com_help)g ! (__P\(\(char)g(*\)\);)195 1343 y(int)g(com_cd)g(__P\(\(char)g(*\)\);) ! 195 1395 y(int)g(com_quit)g(__P\(\(char)g(*\)\);)195 ! 1499 y(/*)h(A)f(structure)g(which)g(contains)g(information)f(on)i(the)f ! (commands)g(this)g(program)267 1550 y(can)g(understand.)f(*/)195 ! 1654 y(typedef)h(struct)g({)243 1706 y(char)g(*name;)g(/*)h(User)f ! (printable)g(name)g(of)h(the)f(function.)g(*/)243 1758 ! y(rl_icpfunc_t)f(*func;)h(/*)h(Function)e(to)i(call)f(to)h(do)f(the)h ! (job.)f(*/)243 1810 y(char)g(*doc;)g(/*)h(Documentation)e(for)h(this)h ! (function.)46 b(*/)195 1862 y(})24 b(COMMAND;)195 1966 ! y(COMMAND)f(commands[])f(=)i({)243 2017 y({)f("cd",)h(com_cd,)f ! ("Change)f(to)i(directory)f(DIR")g(},)243 2069 y({)g("delete",)g ! (com_delete,)f("Delete)h(FILE")h(},)243 2121 y({)f("help",)g(com_help,) ! g("Display)g(this)g(text")g(},)243 2173 y({)g("?",)h(com_help,)e ! ("Synonym)h(for)h(`help'")f(},)243 2225 y({)g("list",)g(com_list,)g ! ("List)g(files)g(in)h(DIR")f(},)243 2277 y({)g("ls",)h(com_list,)e ! ("Synonym)h(for)g(`list'")g(},)243 2329 y({)g("pwd",)g(com_pwd,)g ! ("Print)g(the)h(current)f(working)g(directory")f(},)243 ! 2381 y({)h("quit",)g(com_quit,)g("Quit)g(using)g(Fileman")g(},)243 ! 2433 y({)g("rename",)g(com_rename,)f("Rename)h(FILE)h(to)f(NEWNAME")g ! (},)243 2484 y({)g("stat",)g(com_stat,)g("Print)g(out)g(statistics)g ! (on)h(FILE")f(},)243 2536 y({)g("view",)g(com_view,)g("View)g(the)h ! (contents)e(of)i(FILE")f(},)243 2588 y({)g(\(char)h(*\)NULL,)f ! (\(rl_icpfunc_t)f(*\)NULL,)h(\(char)g(*\)NULL)g(})195 ! 2640 y(};)p eop %%Page: 45 47 45 46 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)843 b(45)195 201 y Ft(/*)24 b(Forward)e(declarations.)h(*/) ! 195 253 y(char)g(*stripwhite)g(\(\);)195 305 y(COMMAND)g(*find_command) ! f(\(\);)195 409 y(/*)i(The)f(name)g(of)h(this)f(program,)g(as)h(taken)f ! (from)g(argv[0].)g(*/)195 461 y(char)g(*progname;)195 ! 565 y(/*)h(When)f(non-zero,)g(this)g(means)g(the)g(user)h(is)f(done)h ! (using)f(this)g(program.)g(*/)195 616 y(int)g(done;)195 ! 720 y(char)g(*)195 772 y(dupstr)g(\(s\))314 824 y(int)h(s;)195 ! 876 y({)243 928 y(char)f(*r;)243 1032 y(r)g(=)h(xmalloc)f(\(strlen)g ! (\(s\))g(+)h(1\);)243 1083 y(strcpy)f(\(r,)g(s\);)243 ! 1135 y(return)g(\(r\);)195 1187 y(})195 1291 y(main)g(\(argc,)g(argv\)) ! 314 1343 y(int)h(argc;)314 1395 y(char)g(**argv;)195 ! 1447 y({)243 1499 y(char)f(*line,)g(*s;)243 1602 y(progname)f(=)i ! (argv[0];)243 1706 y(initialize_readline)d(\(\);)i(/*)h(Bind)f(our)h ! (completer.)e(*/)243 1810 y(/*)h(Loop)h(reading)f(and)g(executing)g ! (lines)g(until)g(the)g(user)h(quits.)f(*/)243 1862 y(for)g(\()h(;)g ! (done)f(==)h(0;)f(\))290 1914 y({)338 1966 y(line)g(=)h(readline)f ! (\("FileMan:)f("\);)338 2069 y(if)i(\(!line\))386 2121 ! y(break;)338 2225 y(/*)g(Remove)f(leading)g(and)g(trailing)g ! (whitespace)f(from)i(the)f(line.)410 2277 y(Then,)g(if)h(there)f(is)g ! (anything)g(left,)g(add)h(it)f(to)h(the)f(history)g(list)410 ! 2329 y(and)g(execute)g(it.)h(*/)338 2381 y(s)g(=)g(stripwhite)e ! (\(line\);)338 2484 y(if)i(\(*s\))386 2536 y({)434 2588 ! y(add_history)e(\(s\);)434 2640 y(execute_line)g(\(s\);)p ! eop %%Page: 46 48 ! 46 47 bop 75 -58 a Fu(46)1299 b(GNU)15 b(Readline)h(Library)386 ! 149 y Ft(})338 253 y(free)23 b(\(line\);)290 305 y(})243 ! 357 y(exit)g(\(0\);)195 409 y(})195 513 y(/*)h(Execute)e(a)i(command)f ! (line.)g(*/)195 565 y(int)195 616 y(execute_line)f(\(line\))314 ! 668 y(char)i(*line;)195 720 y({)243 772 y(register)e(int)i(i;)243 ! 824 y(COMMAND)f(*command;)243 876 y(char)g(*word;)243 ! 980 y(/*)g(Isolate)g(the)h(command)f(word.)g(*/)243 1032 ! y(i)g(=)h(0;)243 1083 y(while)f(\(line[i])g(&&)g(whitespace)g ! (\(line[i]\)\))290 1135 y(i++;)243 1187 y(word)g(=)h(line)f(+)h(i;)243 ! 1291 y(while)f(\(line[i])g(&&)g(!whitespace)g(\(line[i]\)\))290 ! 1343 y(i++;)243 1447 y(if)g(\(line[i]\))290 1499 y(line[i++])g(=)h ! ('\\0';)243 1602 y(command)f(=)g(find_command)g(\(word\);)243 ! 1706 y(if)g(\(!command\))290 1758 y({)338 1810 y(fprintf)g(\(stderr,)g ! ("\045s:)g(No)h(such)f(command)g(for)g(FileMan.\\n",)g(word\);)338 ! 1862 y(return)g(\(-1\);)290 1914 y(})243 2017 y(/*)g(Get)h(argument)f ! (to)g(command,)g(if)g(any.)h(*/)243 2069 y(while)f(\(whitespace)f ! (\(line[i]\)\))290 2121 y(i++;)243 2225 y(word)h(=)h(line)f(+)h(i;)243 ! 2329 y(/*)f(Call)h(the)f(function.)g(*/)243 2381 y(return)g ! (\(\(*\(command->func\)\))e(\(word\)\);)195 2433 y(})195 ! 2536 y(/*)j(Look)f(up)g(NAME)h(as)f(the)h(name)f(of)h(a)f(command,)g ! (and)h(return)f(a)g(pointer)g(to)h(that)267 2588 y(command.)46 ! b(Return)23 b(a)h(NULL)f(pointer)g(if)h(NAME)f(isn't)g(a)h(command)f ! (name.)g(*/)195 2640 y(COMMAND)g(*)p eop %%Page: 47 49 ! 47 48 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)843 b(47)195 149 y Ft(find_command)22 b(\(name\))314 ! 201 y(char)i(*name;)195 253 y({)243 305 y(register)e(int)i(i;)243 ! 409 y(for)f(\(i)h(=)f(0;)h(commands[i].name;)e(i++\))290 ! 461 y(if)i(\(strcmp)f(\(name,)g(commands[i].name\))f(==)h(0\))338 ! 513 y(return)g(\(&commands[i]\);)243 616 y(return)g(\(\(COMMAND)f ! (*\)NULL\);)195 668 y(})195 772 y(/*)i(Strip)f(whitespace)f(from)i(the) ! f(start)g(and)h(end)f(of)h(STRING.)46 b(Return)24 b(a)f(pointer)267 ! 824 y(into)g(STRING.)g(*/)195 876 y(char)g(*)195 928 ! y(stripwhite)f(\(string\))314 980 y(char)i(*string;)195 ! 1032 y({)243 1083 y(register)e(char)i(*s,)f(*t;)243 1187 ! y(for)g(\(s)h(=)f(string;)g(whitespace)g(\(*s\);)g(s++\))290 ! 1239 y(;)243 1343 y(if)g(\(*s)h(==)f(0\))290 1395 y(return)g(\(s\);)243 ! 1499 y(t)g(=)h(s)g(+)g(strlen)f(\(s\))g(-)h(1;)243 1550 ! y(while)f(\(t)g(>)h(s)g(&&)g(whitespace)e(\(*t\)\))290 ! 1602 y(t--;)243 1654 y(*++t)h(=)h('\\0';)243 1758 y(return)f(s;)195 ! 1810 y(})195 1914 y(/*)h(***********************)o(*******)o(********)o ! (*******)o(*******)o(********)o(****)d(*/)195 1966 y(/*)1575 ! b(*/)195 2017 y(/*)429 b(Interface)23 b(to)g(Readline)g(Completion)381 ! b(*/)195 2069 y(/*)1575 b(*/)195 2121 y(/*)24 b ! (***********************)o(*******)o(********)o(*******)o(*******)o ! (********)o(****)d(*/)195 2225 y(char)i(*command_generator)f ! (__P\(\(const)g(char)i(*,)f(int\)\);)195 2277 y(char)g ! (**fileman_completion)e(__P\(\(const)i(char)g(*,)h(int,)f(int\)\);)195 ! 2381 y(/*)h(Tell)f(the)g(GNU)h(Readline)f(library)f(how)i(to)g ! (complete.)46 b(We)24 b(want)f(to)h(try)f(to)267 2433 ! y(complete)f(on)i(command)f(names)g(if)h(this)f(is)h(the)f(first)g ! (word)g(in)h(the)g(line,)f(or)267 2484 y(on)g(filenames)g(if)g(not.)h ! (*/)195 2536 y(initialize_readline)d(\(\))195 2588 y({)243 ! 2640 y(/*)i(Allow)g(conditional)g(parsing)g(of)g(the)h(~/.inputrc)e ! (file.)h(*/)p eop %%Page: 48 50 ! 48 49 bop 75 -58 a Fu(48)1299 b(GNU)15 b(Readline)h(Library)243 ! 149 y Ft(rl_readline_name)21 b(=)j("FileMan";)243 253 ! y(/*)f(Tell)h(the)f(completer)g(that)g(we)h(want)f(a)h(crack)f(first.)g ! (*/)243 305 y(rl_attempted_completion_)o(functio)o(n)e(=)j ! (fileman_completion;)195 357 y(})195 461 y(/*)g(Attempt)e(to)i ! (complete)f(on)g(the)h(contents)f(of)g(TEXT.)47 b(START)23 ! b(and)h(END)267 513 y(bound)f(the)g(region)g(of)h(rl_line_buffer)e ! (that)h(contains)g(the)g(word)h(to)267 565 y(complete.)46 ! b(TEXT)23 b(is)h(the)f(word)h(to)f(complete.)47 b(We)23 ! b(can)h(use)f(the)h(entire)267 616 y(contents)e(of)i(rl_line_buffer)e ! (in)h(case)h(we)f(want)h(to)f(do)h(some)f(simple)267 ! 668 y(parsing.)46 b(Returnthe)23 b(array)g(of)h(matches,)e(or)i(NULL)f ! (if)h(there)f(aren't)g(any.)g(*/)195 720 y(char)g(**)195 ! 772 y(fileman_completion)e(\(text,)i(start,)g(end\))314 ! 824 y(const)g(char)h(*text;)314 876 y(int)g(start,)f(end;)195 ! 928 y({)243 980 y(char)g(**matches;)243 1083 y(matches)g(=)g(\(char)h ! (**\)NULL;)243 1187 y(/*)f(If)h(this)f(word)h(is)f(at)h(the)f(start)g ! (of)h(the)f(line,)h(then)f(it)g(is)h(a)g(command)314 ! 1239 y(to)g(complete.)46 b(Otherwise)23 b(it)h(is)f(the)h(name)f(of)h ! (a)f(file)h(in)f(the)h(current)314 1291 y(directory.)f(*/)243 ! 1343 y(if)g(\(start)g(==)h(0\))290 1395 y(matches)f(=)h ! (rl_completion_matches)d(\(text,)i(command_generator\);)243 ! 1499 y(return)g(\(matches\);)195 1550 y(})195 1654 y(/*)h(Generator)e ! (function)h(for)g(command)g(completion.)47 b(STATE)23 ! b(lets)g(us)267 1706 y(know)g(whether)g(to)g(start)h(from)f(scratch;)g ! (without)g(any)g(state)267 1758 y(\(i.e.)g(STATE)g(==)h(0\),)f(then)g ! (we)h(start)f(at)h(the)f(top)h(of)f(the)h(list.)f(*/)195 ! 1810 y(char)g(*)195 1862 y(command_generator)f(\(text,)h(state\))314 ! 1914 y(const)g(char)h(*text;)314 1966 y(int)g(state;)195 ! 2017 y({)243 2069 y(static)f(int)g(list_index,)g(len;)243 ! 2121 y(char)g(*name;)243 2225 y(/*)g(If)h(this)f(is)h(a)g(new)f(word)g ! (to)h(complete,)f(initialize)f(now.)47 b(This)314 2277 ! y(includes)23 b(saving)g(the)h(length)f(of)g(TEXT)h(for)f(efficiency,)f ! (and)314 2329 y(initializing)h(the)g(index)g(variable)g(to)h(0.)f(*/) ! 243 2381 y(if)g(\(!state\))290 2433 y({)338 2484 y(list_index)g(=)g(0;) ! 338 2536 y(len)h(=)f(strlen)g(\(text\);)290 2588 y(})p eop %%Page: 49 51 ! 49 50 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)843 b(49)243 149 y Ft(/*)23 b(Return)g(the)h(next)f(name)g ! (which)h(partially)e(matches)h(from)g(the)314 201 y(command)g(list.)g ! (*/)243 253 y(while)g(\(name)g(=)h(commands[list_index].name)o(\))290 ! 305 y({)338 357 y(list_index++;)338 461 y(if)g(\(strncmp)f(\(name,)g ! (text,)g(len\))g(==)h(0\))386 513 y(return)f(\(dupstr\(name\)\);)290 ! 565 y(})243 668 y(/*)g(If)h(no)f(names)h(matched,)e(then)i(return)f ! (NULL.)g(*/)243 720 y(return)g(\(\(char)g(*\)NULL\);)195 ! 772 y(})195 876 y(/*)h(***********************)o(*******)o(********)o ! (*******)o(*******)o(********)o(****)d(*/)195 928 y(/*)1575 ! b(*/)195 980 y(/*)549 b(FileMan)22 b(Commands)644 b(*/)195 ! 1032 y(/*)1575 b(*/)195 1083 y(/*)24 b(***********************)o ! (*******)o(********)o(*******)o(*******)o(********)o(****)d(*/)195 ! 1187 y(/*)j(String)f(to)g(pass)h(to)f(system)g(\(\).)47 ! b(This)24 b(is)f(for)h(the)f(LIST,)g(VIEW)h(and)f(RENAME)267 ! 1239 y(commands.)f(*/)195 1291 y(static)h(char)g(syscom[1024];)195 ! 1395 y(/*)h(List)f(the)g(file\(s\))g(named)g(in)h(arg.)f(*/)195 ! 1447 y(com_list)g(\(arg\))314 1499 y(char)h(*arg;)195 ! 1550 y({)243 1602 y(if)f(\(!arg\))290 1654 y(arg)h(=)g("";)243 ! 1758 y(sprintf)f(\(syscom,)f("ls)i(-FClg)f(\045s",)g(arg\);)243 ! 1810 y(return)g(\(system)g(\(syscom\)\);)195 1862 y(})195 ! 1966 y(com_view)g(\(arg\))314 2017 y(char)h(*arg;)195 ! 2069 y({)243 2121 y(if)f(\(!valid_argument)f(\("view",)h(arg\)\))290 ! 2173 y(return)g(1;)243 2277 y(sprintf)g(\(syscom,)f("more)i(\045s",)f ! (arg\);)243 2329 y(return)g(\(system)g(\(syscom\)\);)195 ! 2381 y(})195 2484 y(com_rename)f(\(arg\))314 2536 y(char)i(*arg;)195 ! 2588 y({)243 2640 y(too_dangerous)e(\("rename"\);)p eop %%Page: 50 52 ! 50 51 bop 75 -58 a Fu(50)1299 b(GNU)15 b(Readline)h(Library)243 ! 149 y Ft(return)23 b(\(1\);)195 201 y(})195 305 y(com_stat)g(\(arg\)) ! 314 357 y(char)h(*arg;)195 409 y({)243 461 y(struct)f(stat)g(finfo;)243 ! 565 y(if)g(\(!valid_argument)f(\("stat",)h(arg\)\))290 ! 616 y(return)g(\(1\);)243 720 y(if)g(\(stat)g(\(arg,)h(&finfo\))f(==)g ! (-1\))290 772 y({)338 824 y(perror)g(\(arg\);)338 876 ! y(return)g(\(1\);)290 928 y(})243 1032 y(printf)g(\("Statistics)f(for)h ! (`\045s':\\n",)g(arg\);)243 1135 y(printf)g(\("\045s)g(has)h(\045d)f ! (link\045s,)g(and)g(is)h(\045d)g(byte\045s)f(in)g(length.\\n",)g(arg,) ! 434 1187 y(finfo.st_nlink,)434 1239 y(\(finfo.st_nlink)e(==)j(1\))g(?)f ! ("")h(:)g("s",)434 1291 y(finfo.st_size,)434 1343 y(\(finfo.st_size)e ! (==)h(1\))h(?)f("")h(:)g("s"\);)243 1395 y(printf)f(\("Inode)g(Last)g ! (Change)g(at:)g(\045s",)h(ctime)f(\(&finfo.st_ctime\)\);)243 ! 1447 y(printf)g(\(")143 b(Last)23 b(access)g(at:)g(\045s",)h(ctime)f ! (\(&finfo.st_atime\)\);)243 1499 y(printf)g(\(")95 b(Last)23 ! b(modified)g(at:)g(\045s",)h(ctime)f(\(&finfo.st_mtime\)\);)243 ! 1550 y(return)g(\(0\);)195 1602 y(})195 1706 y(com_delete)f(\(arg\))314 ! 1758 y(char)i(*arg;)195 1810 y({)243 1862 y(too_dangerous)e ! (\("delete"\);)243 1914 y(return)h(\(1\);)195 1966 y(})195 ! 2069 y(/*)h(Print)f(out)g(help)h(for)f(ARG,)g(or)h(for)f(all)h(of)f ! (the)h(commands)f(if)g(ARG)h(is)267 2121 y(not)f(present.)g(*/)195 ! 2173 y(com_help)g(\(arg\))314 2225 y(char)h(*arg;)195 ! 2277 y({)243 2329 y(register)e(int)i(i;)243 2381 y(int)f(printed)g(=)h ! (0;)243 2484 y(for)f(\(i)h(=)f(0;)h(commands[i].name;)e(i++\))290 ! 2536 y({)338 2588 y(if)i(\(!*arg)f(||)g(\(strcmp)g(\(arg,)g ! (commands[i].name\))f(==)i(0\)\))386 2640 y({)p eop %%Page: 51 53 ! 51 52 bop 75 -58 a Fu(Chapter)15 b(2:)k(Programming)c(with)g(GNU)g ! (Readline)843 b(51)434 149 y Ft(printf)23 b(\("\045s\\t\\t\045s.\\n",)e ! (commands[i].name,)h(commands[i].doc\);)434 201 y(printed++;)386 ! 253 y(})290 305 y(})243 409 y(if)h(\(!printed\))290 461 ! y({)338 513 y(printf)g(\("No)h(commands)e(match)h(`\045s'.)48 ! b(Possibilties)22 b(are:\\n",)h(arg\);)338 616 y(for)h(\(i)f(=)h(0;)g ! (commands[i].name;)d(i++\))386 668 y({)434 720 y(/*)i(Print)g(in)h(six) ! f(columns.)g(*/)434 772 y(if)g(\(printed)g(==)h(6\))481 ! 824 y({)529 876 y(printed)f(=)h(0;)529 928 y(printf)f(\("\\n"\);)481 ! 980 y(})434 1083 y(printf)g(\("\045s\\t",)f(commands[i].name\);)434 ! 1135 y(printed++;)386 1187 y(})338 1291 y(if)i(\(printed\))386 ! 1343 y(printf)f(\("\\n"\);)290 1395 y(})243 1447 y(return)g(\(0\);)195 ! 1499 y(})195 1602 y(/*)h(Change)f(to)g(the)h(directory)e(ARG.)i(*/)195 ! 1654 y(com_cd)f(\(arg\))314 1706 y(char)h(*arg;)195 1758 ! y({)243 1810 y(if)f(\(chdir)g(\(arg\))h(==)f(-1\))290 ! 1862 y({)338 1914 y(perror)g(\(arg\);)338 1966 y(return)g(1;)290 ! 2017 y(})243 2121 y(com_pwd)g(\(""\);)243 2173 y(return)g(\(0\);)195 ! 2225 y(})195 2329 y(/*)h(Print)f(out)g(the)h(current)f(working)f ! (directory.)h(*/)195 2381 y(com_pwd)g(\(ignore\))314 ! 2433 y(char)h(*ignore;)195 2484 y({)243 2536 y(char)f(dir[1024],)g(*s;) ! 243 2640 y(s)g(=)h(getcwd)f(\(dir,)g(sizeof\(dir\))g(-)g(1\);)p ! eop %%Page: 52 54 ! 52 53 bop 75 -58 a Fu(52)1299 b(GNU)15 b(Readline)h(Library)243 ! 149 y Ft(if)23 b(\(s)h(==)f(0\))290 201 y({)338 253 y(printf)g ! (\("Error)g(getting)g(pwd:)g(\045s\\n",)g(dir\);)338 ! 305 y(return)g(1;)290 357 y(})243 461 y(printf)g(\("Current)f ! (directory)h(is)h(\045s\\n",)f(dir\);)243 513 y(return)g(0;)195 ! 565 y(})195 668 y(/*)h(The)f(user)g(wishes)g(to)h(quit)f(using)g(this)h ! (program.)46 b(Just)24 b(set)f(DONE)267 720 y(non-zero.)f(*/)195 ! 772 y(com_quit)h(\(arg\))314 824 y(char)h(*arg;)195 876 ! y({)243 928 y(done)f(=)h(1;)243 980 y(return)f(\(0\);)195 ! 1032 y(})195 1135 y(/*)h(Function)e(which)i(tells)f(you)g(that)g(you)h ! (can't)f(do)h(this.)f(*/)195 1187 y(too_dangerous)f(\(caller\))314 ! 1239 y(char)i(*caller;)195 1291 y({)243 1343 y(fprintf)f(\(stderr,)457 ! 1395 y("\045s:)h(Too)f(dangerous)g(for)g(me)h(to)g(distribute.)46 ! b(Write)23 b(it)h(yourself.\\n",)p 1987 1405 21 42 v ! 457 1447 a(caller\);)195 1499 y(})195 1602 y(/*)g(Return)f(non-zero)f ! (if)i(ARG)f(is)h(a)g(valid)f(argument)g(for)g(CALLER,)g(else)g(print) ! 267 1654 y(an)g(error)g(message)g(and)h(return)f(zero.)g(*/)195 ! 1706 y(int)195 1758 y(valid_argument)f(\(caller,)h(arg\))314 ! 1810 y(char)h(*caller,)e(*arg;)195 1862 y({)243 1914 ! y(if)h(\(!arg)g(||)h(!*arg\))290 1966 y({)338 2017 y(fprintf)f ! (\(stderr,)g("\045s:)g(Argument)g(required.\\n",)f(caller\);)338 ! 2069 y(return)h(\(0\);)290 2121 y(})243 2225 y(return)g(\(1\);)195 ! 2277 y(})p eop ! %%Page: 53 55 ! 53 54 bop 75 -58 a Fu(Concept)15 b(Index)1466 b(53)75 ! 149 y Fq(Concept)27 b(Index)75 321 y Fs(C)75 382 y Ff(command)14 ! b(editing)e Fe(.)6 b(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)22 ! b Ff(1)75 511 y Fs(E)75 572 y Ff(editing)15 b(command)f(lines)f ! Fe(.)6 b(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)g(.)24 b Ff(1)75 702 y Fs(I)75 ! 763 y Ff(initiali)q(zati)q(on)16 b(\014le,)e(readline)t ! Fe(.)8 b(.)e(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)17 b Ff(4)75 808 y(in)o(teraction,)e(readline)5 ! b Fe(.)j(.)f(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)18 b Ff(1)75 ! 938 y Fs(K)75 999 y Ff(kill)d(ring)8 b Fe(.)f(.)f(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)20 ! b Ff(3)75 1044 y(killing)c(text)9 b Fe(.)d(.)h(.)f(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)21 b Ff(2)1012 321 ! y Fs(N)1012 390 y Ff(notation,)15 b(readline)7 b Fe(.)h(.)e(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)20 b Ff(1)1012 539 y Fs(R)1012 ! 608 y Ff(readline,)15 b(function)8 b Fe(.)g(.)e(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)21 b Ff(19)1012 757 y Fs(V)1012 826 y Ff(v)n(ariables,)15 ! b(readline)t Fe(.)9 b(.)d(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)17 ! b Ff(4)1012 976 y Fs(Y)1012 1044 y Ff(y)o(anking)e(text)t ! Fe(.)7 b(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)17 ! b Ff(2)p eop ! %%Page: 54 56 ! 54 55 bop 75 -58 a Fu(54)1299 b(GNU)15 b(Readline)h(Library)p ! eop ! %%Page: 55 57 ! 55 56 bop 75 -58 a Fu(F)l(unction)16 b(and)f(V)l(ariable)i(Index)1187 ! b(55)75 149 y Fq(F)-7 b(unction)26 b(and)h(V)-7 b(ariable)26 ! b(Index)p 79 307 21 3 v 75 369 a Fd(_rl_digit_)o(p)7 ! b Fe(.)f(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)23 ! b Ff(34)75 415 y Fd(_rl_digit_)o(va)o(lue)6 b Fe(.)t(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)20 b Ff(34)75 462 y Fd(_rl_lowerc)o(as)o(e_p)6 ! b Fe(.)t(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)20 b Ff(33)75 ! 508 y Fd(_rl_to_low)o(er)6 b Fe(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)h(.)f(.)22 b Ff(34)75 554 y Fd(_rl_to_upp)o(er)6 ! b Fe(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)22 ! b Ff(34)75 600 y Fd(_rl_upperc)o(as)o(e_p)6 b Fe(.)t(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)20 b Ff(33)75 733 y Fs(A)75 794 y ! Fd(abort)11 b(\(C-g\))5 b Fe(.)t(.)h(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)17 b Ff(17)75 841 y Fd(accept-lin)o(e)10 ! b(\(Newline)f(or)j(Return\))6 b Fe(.)t(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)19 b Ff(12)75 973 y Fs(B)75 1035 y Fd(backward-c)o(ha)o(r)10 ! b(\(C-b\))e Fe(.)t(.)e(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)21 b Ff(12)75 ! 1081 y Fd(backward-d)o(el)o(ete)o(-c)o(har)9 b(\(Rubout\))e ! Fe(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)22 ! b Ff(14)75 1127 y Fd(backward-k)o(il)o(l-l)o(in)o(e)10 ! b(\(C-x)h(Rubout\))e Fe(.)d(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)24 ! b Ff(15)75 1174 y Fd(backward-k)o(il)o(l-w)o(or)o(d)10 ! b(\(M-)501 1172 y Fn(h)p 512 1146 73 2 v 512 1174 a Fm(DEL)p ! 512 1181 V 583 1172 a Fn(i)598 1174 y Fd(\))g Fe(.)c(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)23 b Ff(15)75 1220 y ! Fd(backward-w)o(or)o(d)10 b(\(M-b\))e Fe(.)t(.)e(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)21 ! b Ff(12)75 1266 y Fd(beginning-)o(of)o(-hi)o(st)o(ory)9 ! b(\(M-<\))h Fe(.)c(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)25 b Ff(13)75 1312 y Fd(beginning-)o(of)o(-li)o(ne)9 ! b(\(C-a\))c Fe(.)t(.)i(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)18 b Ff(12)75 1359 y(b)q(ell-st)o(yle)7 ! b Fe(.)i(.)d(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)20 b Ff(4)75 1490 y Fs(C)75 1552 y Fd(call-last-)o(kb)o(d-m) ! o(ac)o(ro)9 b(\(C-x)j(e\))5 b Fe(.)h(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)g(.)h(.)f(.)18 b Ff(17)75 1598 y Fd(capitalize)o(-w)o(ord)9 ! b(\(M-c\))d Fe(.)f(.)h(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)19 b Ff(14)75 1644 y Fd(character-)o(se) ! o(arc)o(h)10 b(\(C-]\))c Fe(.)t(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)18 b Ff(17)75 ! 1691 y Fd(character-)o(se)o(arc)o(h-)o(bac)o(kwa)o(rd)9 ! b(\(M-C-]\))e Fe(.)s(.)g(.)f(.)g(.)g(.)g(.)g(.)g(.)20 ! b Ff(17)75 1737 y Fd(clear-scre)o(en)9 b(\(C-l\))g Fe(.)t(.)d(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)h(.)f(.)21 b Ff(12)75 1783 y(commen)o(t-b)q(egin)9 ! b Fe(.)f(.)e(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)21 ! b Ff(5)75 1829 y Fd(complete)10 b(\()265 1827 y Fn(h)p ! 276 1801 74 2 v 276 1829 a Fm(T)m(AB)p 276 1837 V 348 ! 1827 a Fn(i)363 1829 y Fd(\))f Fe(.)e(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.) ! 22 b Ff(16)75 1875 y(completion-query-i)q(tems)t Fe(.)9 ! b(.)d(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)h(.)16 b Ff(5)75 1922 y(con)o(v)o(ert-meta)10 ! b Fe(.)c(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)22 ! b Ff(5)75 1968 y Fd(copy-backw)o(ar)o(d-w)o(or)o(d)10 ! b(\(\))c Fe(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)19 b Ff(15)75 2014 y Fd(copy-forwa)o(rd)o ! (-wo)o(rd)9 b(\(\))e Fe(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)20 b Ff(15)75 ! 2060 y Fd(copy-regio)o(n-)o(as-)o(ki)o(ll)9 b(\(\))d ! Fe(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)18 b Ff(15)75 2193 y Fs(D)75 2255 y Fd(delete-cha)o(r)10 ! b(\(C-d\))d Fe(.)f(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)22 b Ff(14)75 ! 2301 y Fd(delete-cha)o(r-)o(or-)o(li)o(st)9 b(\(\))d ! Fe(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)18 b Ff(16)75 2347 y Fd(delete-hor)o(iz)o(ont)o(al)o ! (-sp)o(ace)9 b(\(\))i Fe(.)6 b(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)25 b Ff(15)75 2393 y Fd(digit-argu)o(me)o(nt)9 ! b(\()p Fc(M-0)p Fd(,)i Fc(M-1)p Fd(,)h(...)f Fc(M--)p ! Fd(\))c Fe(.)e(.)h(.)g(.)g(.)h(.)f(.)g(.)g(.)20 b Ff(15)75 ! 2439 y(disable-comple)q(tion)9 b Fe(.)g(.)d(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)21 b Ff(5)75 2486 y Fd(do-upperca)o(se)o(-ve)o(rs)o(ion)9 ! b(\(M-a,)i(M-b,)g(M-)p Fb(x)p Fd(,)h(...)o(\))159 2531 ! y Fe(.)6 b(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)20 b Ff(17)75 2578 y Fd(downcase-w)o(or)o(d)10 ! b(\(M-l\))e Fe(.)t(.)e(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)21 b Ff(14)75 ! 2624 y Fd(dump-funct)o(io)o(ns)9 b(\(\))g Fe(.)d(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)22 b Ff(18)75 2670 y Fd(dump-macro)o(s)10 b(\(\))g ! Fe(.)c(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)24 b Ff(18)1012 ! 307 y Fd(dump-variab)o(le)o(s)10 b(\(\))e Fe(.)e(.)h(.)f(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)23 b Ff(18)1012 465 y Fs(E)1012 537 y Ff(editing-mo)q(de)12 ! b Fe(.)7 b(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)22 ! b Ff(5)1012 587 y(enable-k)o(eypad)9 b Fe(.)g(.)d(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)g(.)22 b Ff(5)1012 638 y Fd(end-kbd-mac)o(ro)9 ! b(\(C-x)i(\)\))e Fe(.)e(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)23 b Ff(16)1012 689 ! y Fd(end-of-hist)o(or)o(y)10 b(\(M->\))d Fe(.)t(.)f(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)20 ! b Ff(13)1012 740 y Fd(end-of-line)9 b(\(C-e\))e Fe(.)f(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)23 b Ff(12)1012 791 y Fd(exchange-po)o(in)o(t-a)o(nd)o(-ma) ! o(rk)9 b(\(C-x)j(C-x\))c Fe(.)e(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)24 ! b Ff(17)1012 842 y(expand-tilde)6 b Fe(.)j(.)d(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)19 b Ff(5)1012 999 y ! Fs(F)1012 1070 y Fd(forward-bac)o(kw)o(ard)o(-d)o(ele)o(te)o(-ch)o(ar)9 ! b(\(\))f Fe(.)e(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)22 ! b Ff(14)1012 1121 y Fd(forward-cha)o(r)10 b(\(C-f\))f ! Fe(.)s(.)e(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)22 b Ff(12)1012 1172 y ! Fd(forward-sea)o(rc)o(h-h)o(is)o(tor)o(y)10 b(\(C-s\))e ! Fe(.)e(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)24 ! b Ff(13)1012 1223 y Fd(forward-wor)o(d)10 b(\(M-f\))f ! Fe(.)s(.)e(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)22 b Ff(12)1012 1373 y ! Fs(H)1012 1445 y Fd(history-sea)o(rc)o(h-b)o(ac)o(kwa)o(rd)9 ! b(\(\))i Fe(.)c(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f ! (.)25 b Ff(13)1012 1496 y Fd(history-sea)o(rc)o(h-f)o(or)o(war)o(d)10 ! b(\(\))s Fe(.)c(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)17 b Ff(13)1012 1546 y(horizon)o(tal-scrol)q(l-mo)r(de)6 ! b Fe(.)j(.)d(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)19 b Ff(5)1012 1697 y ! Fs(I)1012 1768 y Ff(input-meta)8 b Fe(.)g(.)e(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)21 b Ff(6)1012 1819 ! y Fd(insert-comm)o(en)o(t)10 b(\(M-#\))d Fe(.)t(.)f(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)20 ! b Ff(17)1012 1870 y Fd(insert-comp)o(le)o(tio)o(ns)9 ! b(\(M-*\))t Fe(.)c(.)h(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)18 b Ff(16)1012 1921 y(isearc)o(h-terminators)t ! Fe(.)8 b(.)f(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)16 b Ff(6)1012 ! 2071 y Fs(K)1012 2143 y Ff(k)o(eymap)9 b Fe(.)e(.)f(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)22 ! b Ff(6)1012 2194 y Fd(kill-line)10 b(\(C-k\))f Fe(.)d(.)g(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)24 b Ff(14)1012 2245 y Fd(kill-region)9 ! b(\(\))i Fe(.)6 b(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)25 ! b Ff(15)1012 2295 y Fd(kill-whole-)o(li)o(ne)9 b(\(\))g ! Fe(.)c(.)i(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)22 b Ff(15)1012 2346 y ! Fd(kill-word)10 b(\(M-d\))f Fe(.)d(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! 24 b Ff(15)1012 2497 y Fs(M)1012 2568 y Ff(mark-mo)q(di\014ed-li)q(nes) ! 8 b Fe(.)h(.)d(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)21 b Ff(6)1012 ! 2619 y Fd(menu-comple)o(te)9 b(\(\))g Fe(.)e(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)h(.)23 b Ff(16)1012 2670 y(meta-\015ag)t Fe(.)8 b(.)e(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)18 ! b Ff(6)p eop ! %%Page: 56 58 ! 56 57 bop 75 -58 a Fu(56)1299 b(GNU)15 b(Readline)h(Library)75 ! 149 y Fs(N)75 212 y Fd(next-histo)o(ry)9 b(\(C-n\))g ! Fe(.)t(.)d(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)21 b Ff(12)75 258 y Fd(non-increm)o(en)o ! (tal)o(-f)o(orw)o(ard)o(-s)o(ear)o(ch)o(-hi)o(st)o(ory)9 ! b(\(M-n\))159 304 y Fe(.)d(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)20 b Ff(13)75 ! 350 y Fd(non-increm)o(en)o(tal)o(-r)o(eve)o(rse)o(-s)o(ear)o(ch)o(-hi)o ! (st)o(ory)9 b(\(M-p\))159 396 y Fe(.)d(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)20 ! b Ff(13)75 521 y Fs(O)75 583 y Ff(output-meta)5 b Fe(.)i(.)f(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)18 b Ff(6)75 ! 716 y Fs(P)75 778 y Fd(possible-c)o(om)o(ple)o(ti)o(ons)9 ! b(\(M-?\))h Fe(.)c(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)25 b Ff(16)75 824 y Fd(prefix-met)o(a)10 b(\()324 ! 822 y Fn(h)p 335 796 70 2 v 335 824 a Fm(ESC)p 335 832 ! V 402 822 a Fn(i)417 824 y Fd(\))g Fe(.)c(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)23 ! b Ff(17)75 870 y Fd(previous-h)o(is)o(tor)o(y)10 b(\(C-p\))c ! Fe(.)t(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)18 b Ff(12)75 1004 y Fs(Q)75 1066 y Fd(quoted-ins)o(er)o ! (t)10 b(\(C-q)h(or)h(C-v\))c Fe(.)e(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)h(.)f(.)22 b Ff(14)75 1199 y Fs(R)75 ! 1261 y Fd(re-read-in)o(it)o(-fi)o(le)9 b(\(C-x)i(C-r\))5 ! b Fe(.)h(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)18 ! b Ff(17)75 1307 y Fd(readline)s Fe(.)s(.)7 b(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)16 b Ff(19)75 ! 1354 y Fd(redraw-cur)o(re)o(nt-)o(li)o(ne)9 b(\(\))d ! Fe(.)g(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)18 b Ff(12)75 1400 y Fd(reverse-se)o(ar)o(ch-)o(hi)o ! (sto)o(ry)9 b(\(C-r\))g Fe(.)d(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)23 b Ff(13)75 1446 y Fd(revert-lin)o(e)10 ! b(\(M-r\))d Fe(.)f(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)22 b Ff(17)75 ! 1493 y Fd(rl_add_def)o(un)6 b Fe(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)22 b Ff(26)75 1539 y Fd(rl_add_fun)o(ma)o(p_e)o(nt)o(ry) ! t Fe(.)s(.)6 b(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)17 b Ff(29)75 1585 y Fd(rl_add_und)o(o)7 ! b Fe(.)f(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)23 ! b Ff(30)75 1632 y Fd(rl_alphabe)o(ti)o(c)9 b Fe(.)s(.)d(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)22 b Ff(33)75 1678 y Fd(rl_already)o(_p)o(rom)o ! (pt)o(ed)t Fe(.)s(.)6 b(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)17 b Ff(23)75 ! 1724 y Fd(rl_attempt)o(ed)o(_co)o(mp)o(let)o(ion)o(_f)o(unc)o(ti)o(on)t ! Fe(.)s(.)6 b(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)17 b Ff(40)75 ! 1771 y Fd(rl_attempt)o(ed)o(_co)o(mp)o(let)o(ion)o(_o)o(ver)6 ! b Fe(.)s(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)20 ! b Ff(42)75 1817 y Fd(rl_basic_q)o(uo)o(te_)o(ch)o(ara)o(cte)o(rs)8 ! b Fe(.)t(.)e(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! 22 b Ff(41)75 1863 y Fd(rl_basic_w)o(or)o(d_b)o(re)o(ak_)o(cha)o(ra)o ! (cte)o(rs)5 b Fe(.)s(.)h(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)18 ! b Ff(41)75 1910 y Fd(rl_begin_u)o(nd)o(o_g)o(ro)o(up)t ! Fe(.)s(.)6 b(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)g(.)h(.)f(.)17 b Ff(29)75 1956 y Fd(rl_bind_ke)o(y)7 ! b Fe(.)f(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)23 ! b Ff(27)75 2002 y Fd(rl_bind_ke)o(y_)o(in_)o(ma)o(p)5 ! b Fe(.)s(.)i(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)18 b Ff(27)75 2049 y ! Fd(rl_binding)o(_k)o(eym)o(ap)5 b Fe(.)s(.)i(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)19 ! b Ff(24)75 2095 y Fd(rl_callbac)o(k_)o(han)o(dl)o(er_)o(ins)o(ta)o(ll)7 ! b Fe(.)s(.)g(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)20 ! b Ff(35)75 2141 y Fd(rl_callbac)o(k_)o(han)o(dl)o(er_)o(rem)o(ov)o(e)8 ! b Fe(.)t(.)e(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)21 ! b Ff(35)75 2188 y Fd(rl_callbac)o(k_)o(rea)o(d_)o(cha)o(r)9 ! b Fe(.)d(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)25 b Ff(35)75 2234 y Fd(rl_catch_s)o(ig)o(nal)o(s)6 ! b Fe(.)t(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)19 b Ff(37)75 ! 2281 y Fd(rl_catch_s)o(ig)o(win)o(ch)5 b Fe(.)s(.)i(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)19 b Ff(37)75 2327 y Fd(rl_char_is)o(_q)o(uot)o(ed)o(_p)t ! Fe(.)s(.)6 b(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)g(.)h(.)f(.)17 b Ff(41)75 2373 y Fd(rl_cleanup)o(_a)o ! (fte)o(r_)o(sig)o(nal)7 b Fe(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)23 b Ff(37)75 2420 y ! Fd(rl_clear_m)o(es)o(sag)o(e)6 b Fe(.)t(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.) ! 19 b Ff(31)75 2466 y Fd(rl_clear_p)o(en)o(din)o(g_)o(inp)o(ut)8 ! b Fe(.)e(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)24 b Ff(32)75 2512 y Fd(rl_clear_s)o(ig)o(nal)o(s)6 ! b Fe(.)t(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)19 b Ff(38)1012 ! 149 y Fd(rl_complete)6 b Fe(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)24 b Ff(39)1012 196 y Fd(rl_complete)o(_i)o(nte)o(rn)o(al)s ! Fe(.)t(.)6 b(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)17 b Ff(39)1012 242 y Fd(rl_complete)o(r_)o ! (quo)o(te)o(_ch)o(ar)o(act)o(ers)5 b Fe(.)t(.)h(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)20 b Ff(41)1012 288 y Fd(rl_complete)o(r_)o(wor)o ! (d_)o(bre)o(ak)o(_ch)o(ara)o(ct)o(ers)8 b Fe(.)e(.)g(.)g(.)h(.)f(.)g(.) ! 25 b Ff(41)1012 335 y Fd(rl_completi)o(on)o(_ap)o(pe)o(nd_)o(ch)o(ara)o ! (cte)o(r)5 b Fe(.)s(.)i(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)19 ! b Ff(42)1012 381 y Fd(rl_completi)o(on)o(_di)o(sp)o(lay)o(_m)o(atc)o ! (hes)o(_h)o(ook)8 b Fe(.)e(.)g(.)g(.)h(.)f(.)g(.)25 b ! Ff(43)1012 427 y Fd(rl_completi)o(on)o(_en)o(tr)o(y_f)o(un)o(cti)o(on)s ! Fe(.)s(.)6 b(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)17 b Ff(39,)c(40)1012 ! 474 y Fd(rl_completi)o(on)o(_ma)o(tc)o(hes)8 b Fe(.)f(.)f(.)g(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)25 ! b Ff(40)1012 520 y Fd(rl_completi)o(on)o(_qu)o(er)o(y_i)o(te)o(ms)9 ! b Fe(.)s(.)d(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! 23 b Ff(41)1012 566 y Fd(rl_completi)o(on)o(_ty)o(pe)t ! Fe(.)t(.)6 b(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)19 b Ff(42)1012 613 y ! Fd(rl_copy_key)o(ma)o(p)8 b Fe(.)s(.)e(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)21 b Ff(26)1012 659 y Fd(rl_copy_tex)o(t)6 b Fe(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)23 b Ff(31)1012 705 y ! Fd(rl_crlf)t Fe(.)t(.)6 b(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)17 b Ff(30)1012 752 y Fd(rl_delete_t)o(ex)o(t)8 ! b Fe(.)s(.)e(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)21 b ! Ff(31)1012 798 y Fd(rl_deprep_t)o(er)o(m_f)o(un)o(cti)o(on)7 ! b Fe(.)f(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)24 b Ff(24)1012 844 y Fd(rl_deprep_t)o(er)o(min)o(al)t ! Fe(.)t(.)6 b(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)19 b Ff(33)1012 891 y ! Fd(rl_ding)t Fe(.)t(.)6 b(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)17 b Ff(33)1012 937 y Fd(rl_director)o(y_)o ! (com)o(pl)o(eti)o(on)o(_ho)o(ok)7 b Fe(.)s(.)f(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)h(.)20 b Ff(43)1012 983 y Fd(rl_discard_)o(ke)o(yma) ! o(p)6 b Fe(.)s(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)19 b Ff(27)1012 ! 1030 y Fd(rl_dispatch)o(in)o(g)8 b Fe(.)s(.)e(.)h(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)21 b Ff(22)1012 1076 y Fd(rl_display_)o(ma)o(tch)o(_l)o ! (ist)8 b Fe(.)f(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)h(.)25 b Ff(33)1012 1122 y Fd(rl_do_undo)8 ! b Fe(.)e(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)24 ! b Ff(30)1012 1169 y Fd(rl_done)t Fe(.)t(.)6 b(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)17 b Ff(22)1012 ! 1215 y Fd(rl_editing_)o(mo)o(de)7 b Fe(.)s(.)f(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)21 b Ff(26)1012 1261 y Fd(rl_end)5 b Fe(.)t(.)h(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)18 ! b Ff(22)1012 1308 y Fd(rl_end_undo)o(_g)o(rou)o(p)6 b ! Fe(.)s(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)19 b Ff(29)1012 1354 ! y Fd(rl_erase_em)o(pt)o(y_l)o(in)o(e)t Fe(.)t(.)6 b(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)18 ! b Ff(22)1012 1400 y Fd(rl_event_ho)o(ok)8 b Fe(.)s(.)e(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)22 b Ff(23)1012 1447 y Fd(rl_execute_)o(ne)o ! (xt)7 b Fe(.)s(.)f(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)21 ! b Ff(32)1012 1493 y Fd(rl_executin)o(g_)o(key)o(ma)o(p)t ! Fe(.)t(.)6 b(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)18 b Ff(24)1012 1539 y Fd(rl_executin)o(g_) ! o(mac)o(ro)t Fe(.)t(.)6 b(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)19 b Ff(24)1012 ! 1586 y Fd(rl_expand_p)o(ro)o(mpt)6 b Fe(.)s(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)20 b Ff(31)1012 1632 y Fd(rl_explicit)o(_a)o(rg)7 ! b Fe(.)s(.)f(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)21 b Ff(25)1012 ! 1678 y Fd(rl_extend_l)o(in)o(e_b)o(uf)o(fer)8 b Fe(.)f(.)f(.)g(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)25 ! b Ff(33)1012 1725 y Fd(rl_filename)o(_c)o(omp)o(le)o(tio)o(n_)o(des)o ! (ire)o(d)5 b Fe(.)s(.)i(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)19 ! b Ff(42)1012 1771 y Fd(rl_filename)o(_c)o(omp)o(le)o(tio)o(n_)o(fun)o ! (cti)o(on)t Fe(.)s(.)7 b(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)18 ! b Ff(40)1012 1817 y Fd(rl_filename)o(_d)o(equ)o(ot)o(ing)o(_f)o(unc)o ! (tio)o(n)5 b Fe(.)s(.)i(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)19 ! b Ff(41)1012 1864 y Fd(rl_filename)o(_q)o(uot)o(e_)o(cha)o(ra)o(cte)o ! (rs)7 b Fe(.)s(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)20 ! b Ff(42)1012 1910 y Fd(rl_filename)o(_q)o(uot)o(in)o(g_d)o(es)o(ire)o ! (d)8 b Fe(.)s(.)e(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)21 ! b Ff(42)1012 1956 y Fd(rl_filename)o(_q)o(uot)o(in)o(g_f)o(un)o(cti)o ! (on)7 b Fe(.)s(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)20 ! b Ff(41)1012 2003 y Fd(rl_forced_u)o(pd)o(ate)o(_d)o(isp)o(la)o(y)7 ! b Fe(.)f(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)23 b Ff(30)1012 2049 y Fd(rl_free_lin)o(e_)o(sta)o(te)t ! Fe(.)t(.)6 b(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)19 b Ff(37)1012 2095 ! y Fd(rl_free_und)o(o_)o(lis)o(t)6 b Fe(.)s(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! 19 b Ff(30)1012 2142 y Fd(rl_function)o(_d)o(ump)o(er)t ! Fe(.)t(.)6 b(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)19 b Ff(29)1012 2188 ! y Fd(rl_function)o(_o)o(f_k)o(ey)o(seq)8 b Fe(.)f(.)f(.)g(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)25 ! b Ff(28)1012 2234 y Fd(rl_funmap_n)o(am)o(es)7 b Fe(.)s(.)f(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)21 b Ff(29)1012 2281 y Fd(rl_generic_)o(bi)o(nd)7 ! b Fe(.)s(.)f(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)21 b Ff(28)1012 ! 2327 y Fd(rl_get_keym)o(ap)8 b Fe(.)s(.)e(.)h(.)f(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)22 b Ff(27)1012 2373 y Fd(rl_get_keym)o(ap)o(_by)o(_n)o ! (ame)8 b Fe(.)f(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)h(.)25 b Ff(27)1012 2420 y Fd(rl_get_keym)o(ap)o ! (_na)o(me)t Fe(.)t(.)6 b(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)19 b Ff(27)1012 ! 2466 y Fd(rl_get_scre)o(en)o(_si)o(ze)t Fe(.)t(.)6 b(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g ! (.)19 b Ff(38)1012 2512 y Fd(rl_getc)t Fe(.)t(.)6 b(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)17 b ! Ff(32)p eop ! %%Page: 57 59 ! 57 58 bop 75 -58 a Fu(F)l(unction)16 b(and)f(V)l(ariable)i(Index)1187 ! b(57)75 149 y Fd(rl_getc_fu)o(nc)o(tio)o(n)6 b Fe(.)t(.)g(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)g(.)h(.)19 b Ff(24)75 195 y Fd(rl_gnu_rea)o(dl)o(ine)o(_p)5 ! b Fe(.)s(.)i(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)19 b Ff(23)75 241 ! y Fd(rl_ignore_)o(co)o(mpl)o(et)o(ion)o(_du)o(pl)o(ica)o(te)o(s)5 ! b Fe(.)s(.)h(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)18 b Ff(42)75 ! 286 y Fd(rl_ignore_)o(so)o(me_)o(co)o(mpl)o(eti)o(on)o(s_f)o(un)o(cti)o ! (on)7 b Fe(.)g(.)f(.)g(.)g(.)g(.)24 b Ff(43)75 332 y ! Fd(rl_inhibit)o(_c)o(omp)o(le)o(tio)o(n)9 b Fe(.)d(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)25 ! b Ff(43)75 378 y Fd(rl_initial)o(iz)o(e)9 b Fe(.)s(.)d(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)22 b Ff(33)75 424 y Fd(rl_insert_)o(co)o(mpl)o ! (et)o(ion)o(s)9 b Fe(.)d(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)25 b Ff(40)75 469 y Fd(rl_insert_)o(te) ! o(xt)8 b Fe(.)s(.)e(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)21 ! b Ff(31)75 515 y Fd(rl_instrea)o(m)7 b Fe(.)f(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)g(.)23 b Ff(23)75 561 y Fd(rl_invokin)o(g_)o ! (key)o(se)o(qs)t Fe(.)s(.)6 b(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)17 b Ff(28)75 ! 606 y Fd(rl_invokin)o(g_)o(key)o(se)o(qs_)o(in_)o(ma)o(p)8 ! b Fe(.)t(.)e(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)21 ! b Ff(29)75 652 y Fd(rl_kill_te)o(xt)6 b Fe(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)22 b Ff(32)75 698 y Fd(rl_last_fu)o(nc)6 ! b Fe(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)22 ! b Ff(23)75 743 y Fd(rl_library)o(_v)o(ers)o(io)o(n)5 ! b Fe(.)s(.)i(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)18 b Ff(23)75 789 y Fd(rl_line_bu)o(ff) ! o(er)8 b Fe(.)s(.)e(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)21 ! b Ff(22)75 835 y Fd(rl_list_fu)o(nm)o(ap_)o(na)o(mes)s ! Fe(.)s(.)6 b(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)16 b Ff(29)75 880 y Fd(rl_macro_b)o(in)o(d)9 ! b Fe(.)s(.)d(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)22 ! b Ff(34)75 926 y Fd(rl_macro_d)o(um)o(per)6 b Fe(.)t(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)20 b Ff(34)75 972 y Fd(rl_make_ba)o(re)o(_ke)o(ym)o ! (ap)t Fe(.)s(.)6 b(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)17 b Ff(26)75 1017 ! y Fd(rl_make_ke)o(ym)o(ap)8 b Fe(.)s(.)e(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)21 b Ff(26)75 1063 y Fd(rl_mark)t Fe(.)t(.)6 b(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)17 ! b Ff(22)75 1109 y Fd(rl_message)7 b Fe(.)f(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)24 b Ff(31)75 1154 y Fd(rl_modifyi)o(ng)6 ! b Fe(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)22 ! b Ff(30)75 1200 y Fd(rl_named_f)o(un)o(cti)o(on)5 b Fe(.)s(.)i(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)19 b Ff(28)75 1246 y Fd(rl_num_cha)o(rs)o(_to)o(_r)o ! (ead)s Fe(.)s(.)6 b(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)16 b Ff(22)75 1291 y Fd(rl_numeric)o(_a) ! o(rg)8 b Fe(.)s(.)e(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)21 ! b Ff(26)75 1337 y Fd(rl_on_new_)o(li)o(ne)8 b Fe(.)s(.)e(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)21 b Ff(30)75 1383 y Fd(rl_on_new_)o(li)o(ne_)o ! (wi)o(th_)o(pro)o(mp)o(t)8 b Fe(.)t(.)e(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)g(.)h(.)f(.)21 b Ff(30)75 1428 y Fd(rl_outstre)o(am)6 ! b Fe(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)22 ! b Ff(23)75 1474 y Fd(rl_parse_a)o(nd)o(_bi)o(nd)5 b Fe(.)s(.)i(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)19 b Ff(28)75 1520 y Fd(rl_pending)o(_i)o(npu)o(t)6 ! b Fe(.)t(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)19 b Ff(22)75 ! 1565 y Fd(rl_point)s Fe(.)s(.)7 b(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)16 b Ff(22)75 1611 y Fd(rl_possibl)o(e_)o ! (com)o(pl)o(eti)o(ons)7 b Fe(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)23 b Ff(40)75 1657 y ! Fd(rl_pre_inp)o(ut)o(_ho)o(ok)5 b Fe(.)s(.)i(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)19 ! b Ff(23)75 1702 y Fd(rl_prep_te)o(rm)o(_fu)o(nc)o(tio)o(n)9 ! b Fe(.)d(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)25 b Ff(24)75 1748 y Fd(rl_prep_te)o(rm)o(ina)o(l)6 ! b Fe(.)t(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)19 b Ff(32)75 ! 1794 y Fd(rl_prompt)8 b Fe(.)e(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)24 b Ff(22)75 1840 y Fd(rl_push_ma)o(cr)o(o_i)o(np) ! o(ut)t Fe(.)s(.)6 b(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)17 b Ff(32)75 1885 ! y Fd(rl_read_in)o(it)o(_fi)o(le)5 b Fe(.)s(.)i(.)f(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! 19 b Ff(28)75 1931 y Fd(rl_read_ke)o(y)7 b Fe(.)f(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)23 b Ff(32)75 1977 y ! Fd(rl_readlin)o(e_)o(nam)o(e)6 b Fe(.)t(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.) ! 19 b Ff(23)75 2022 y Fd(rl_readlin)o(e_)o(sta)o(te)5 ! b Fe(.)s(.)i(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)19 b Ff(24)75 2068 ! y Fd(rl_redispl)o(ay)6 b Fe(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)f(.)22 b Ff(30)75 2114 y Fd(rl_redispl)o(ay)o(_fu)o(nc)o(tio)o(n)9 ! b Fe(.)d(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)25 b Ff(24)75 2159 y Fd(rl_reset_a)o(ft)o(er_)o(si)o ! (gna)o(l)9 b Fe(.)d(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)25 b Ff(38)75 2205 y Fd(rl_reset_l)o(in)o ! (e_s)o(ta)o(te)t Fe(.)s(.)6 b(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)17 b Ff(30)75 ! 2251 y Fd(rl_reset_t)o(er)o(min)o(al)5 b Fe(.)s(.)i(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)19 b Ff(33)75 2296 y Fd(rl_resize_)o(te)o(rmi)o(na)o(l)5 ! b Fe(.)s(.)i(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)18 b Ff(38)75 2342 y ! Fd(rl_restore)o(_p)o(rom)o(pt)5 b Fe(.)s(.)i(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)19 ! b Ff(31)75 2388 y Fd(rl_save_pr)o(om)o(pt)8 b Fe(.)s(.)e(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)21 b Ff(31)75 2433 y Fd(rl_set_key)7 ! b Fe(.)f(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)24 ! b Ff(28)75 2479 y Fd(rl_set_key)o(bo)o(ard)o(_i)o(npu)o(t_t)o(im)o(eou) ! o(t)6 b Fe(.)s(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)19 ! b Ff(32)1012 149 y Fd(rl_set_keym)o(ap)8 b Fe(.)s(.)e(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)22 b Ff(27)1012 195 y Fd(rl_set_pare)o(n_)o ! (bli)o(nk)o(_ti)o(me)o(out)7 b Fe(.)t(.)f(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)22 b Ff(34)1012 241 y Fd(rl_set_prom)o(pt)8 ! b Fe(.)s(.)e(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)22 ! b Ff(31)1012 287 y Fd(rl_set_scre)o(en)o(_si)o(ze)t Fe(.)t(.)6 ! b(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)g(.)19 b Ff(38)1012 334 y Fd(rl_set_sign)o(al)o(s)8 ! b Fe(.)s(.)e(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)21 b ! Ff(38)1012 380 y Fd(rl_show_cha)o(r)6 b Fe(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)23 b Ff(31)1012 426 y Fd(rl_special_)o(pr)o ! (efi)o(xe)o(s)t Fe(.)t(.)6 b(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)18 b Ff(42)1012 ! 472 y Fd(rl_startup_)o(ho)o(ok)7 b Fe(.)s(.)f(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)21 b Ff(23)1012 518 y Fd(rl_stuff_ch)o(ar)8 b ! Fe(.)s(.)e(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)22 ! b Ff(32)1012 564 y Fd(rl_terminal)o(_n)o(ame)6 b Fe(.)s(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)20 b Ff(23)1012 610 y Fd(rl_tty_set_)o(de)o(fau)o(lt)o ! (_bi)o(nd)o(ing)o(s)8 b Fe(.)s(.)e(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)21 b Ff(33)1012 656 y Fd(rl_unbind_c)o(om)o(man)o(d_)o ! (in_)o(ma)o(p)7 b Fe(.)f(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)h(.)f(.)23 b Ff(28)1012 702 y Fd(rl_unbind_f)o(un)o(cti)o ! (on)o(_in)o(_m)o(ap)9 b Fe(.)s(.)d(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)g(.)23 b Ff(28)1012 748 y Fd(rl_unbind_k)o(ey)8 ! b Fe(.)s(.)e(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)22 ! b Ff(27)1012 794 y Fd(rl_unbind_k)o(ey)o(_in)o(_m)o(ap)s ! Fe(.)t(.)6 b(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.) ! g(.)g(.)g(.)h(.)f(.)g(.)17 b Ff(27)1012 840 y Fd(rl_username)o(_c)o ! (omp)o(le)o(tio)o(n_)o(fun)o(cti)o(on)t Fe(.)s(.)7 b(.)f(.)g(.)g(.)g(.) ! g(.)h(.)f(.)g(.)18 b Ff(40)1012 886 y Fd(rl_variable)o(_b)o(ind)6 ! b Fe(.)s(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)20 b Ff(34)1012 ! 932 y Fd(rl_variable)o(_d)o(ump)o(er)t Fe(.)t(.)6 b(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.) ! 19 b Ff(34)1012 1063 y Fs(S)1012 1125 y Fd(self-insert)9 ! b(\(a,)j(b,)g(A,)g(1,)g(!,)g(...)o(\))6 b Fe(.)g(.)g(.)g(.)g(.)g(.)g(.) ! h(.)f(.)g(.)g(.)g(.)20 b Ff(14)1012 1171 y Fd(set-mark)10 ! b(\(C-@\))g Fe(.)c(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)25 ! b Ff(17)1012 1217 y(sho)o(w-all-if-am)o(bigu)q(ous)14 ! b Fe(.)6 b(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)23 b Ff(6)1012 1263 ! y Fd(start-kbd-m)o(ac)o(ro)9 b(\(C-x)j(\(\))c Fe(.)d(.)i(.)f(.)g(.)g(.) ! g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)22 ! b Ff(16)1012 1386 y Fs(T)1012 1448 y Fd(tab-insert)9 ! b(\(M-)1281 1446 y Fn(h)p 1292 1420 74 2 v 1292 1448 ! a Fm(T)m(AB)p 1292 1456 V 1364 1446 a Fn(i)1379 1448 ! y Fd(\))e Fe(.)f(.)g(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)20 b Ff(14)1012 1494 ! y Fd(tilde-expan)o(d)10 b(\(M-~\))f Fe(.)s(.)e(.)f(.)g(.)g(.)g(.)g(.)g ! (.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)22 ! b Ff(17)1012 1540 y Fd(transpose-c)o(ha)o(rs)9 b(\(C-t\))d ! Fe(.)f(.)h(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)20 b Ff(14)1012 1586 y Fd(transpose-w)o(or)o(ds)9 ! b(\(M-t\))d Fe(.)f(.)h(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)20 b Ff(14)1012 1717 y ! Fs(U)1012 1779 y Fd(undo)12 b(\(C-_)f(or)h(C-x)g(C-u\))c ! Fe(.)t(.)e(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g ! (.)g(.)h(.)f(.)g(.)g(.)21 b Ff(17)1012 1825 y Fd(universal-a)o(rg)o ! (ume)o(nt)9 b(\(\))d Fe(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)20 b Ff(16)1012 ! 1871 y Fd(unix-line-d)o(is)o(car)o(d)10 b(\(C-u\))5 b ! Fe(.)t(.)h(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g ! (.)h(.)f(.)18 b Ff(15)1012 1917 y Fd(unix-word-r)o(ub)o(out)9 ! b(\(C-w\))d Fe(.)t(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)19 b Ff(15)1012 1963 y Fd(upcase-word)9 ! b(\(M-u\))e Fe(.)f(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h ! (.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)23 b Ff(14)1012 ! 2094 y Fs(V)1012 2156 y Ff(visible-stats)14 b Fe(.)6 ! b(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)24 ! b Ff(6)1012 2279 y Fs(Y)1012 2341 y Fd(yank)12 b(\(C-y\))5 ! b Fe(.)t(.)h(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.) ! f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)19 ! b Ff(15)1012 2387 y Fd(yank-last-a)o(rg)9 b(\(M-.)i(or)h(M-_\))c ! Fe(.)f(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)23 ! b Ff(13)1012 2433 y Fd(yank-nth-ar)o(g)10 b(\(M-C-y\))d ! Fe(.)s(.)f(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f ! (.)g(.)g(.)g(.)g(.)h(.)20 b Ff(13)1012 2479 y Fd(yank-pop)10 ! b(\(M-y\))g Fe(.)c(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g ! (.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)25 ! b Ff(15)p eop ! %%Page: 58 60 ! 58 59 bop 75 -58 a Fu(58)1299 b(GNU)15 b(Readline)h(Library)p eop ! %%Page: -1 61 ! -1 60 bop 1862 -58 a Fu(i)75 149 y Fq(T)-7 b(able)27 ! b(of)f(Con)n(ten)n(ts)75 320 y Fs(1)67 b(Command)22 b(Line)i(Editing)d ! Fa(.)10 b(.)h(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)h ! (.)f(.)g(.)g(.)42 b Fs(1)224 389 y Fu(1.1)j(In)o(tro)q(duction)16 ! b(to)f(Line)h(Editing)e Fl(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)27 b Fu(1)224 444 y(1.2)45 b(Readline)16 b(In)o(teraction)8 ! b Fl(.)g(.)g(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)23 b Fu(1)374 499 y(1.2.1)44 b(Readline)16 ! b(Bare)f(Essen)o(tials)f Fl(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h (.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)27 ! b Fu(1)374 553 y(1.2.2)44 b(Readline)16 b(Mo)o(v)o(emen)o(t)e(Commands) ! 7 b Fl(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f ! (.)h(.)21 b Fu(2)374 608 y(1.2.3)44 b(Readline)16 b(Killing)i(Commands) ! 11 b Fl(.)c(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h ! (.)f(.)h(.)f(.)h(.)25 b Fu(2)374 663 y(1.2.4)44 b(Readline)16 ! b(Argumen)o(ts)c Fl(.)c(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h ! (.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)27 ! b Fu(3)374 718 y(1.2.5)44 b(Searc)o(hing)16 b(for)e(Commands)h(in)h ! (the)f(History)e Fl(.)8 b(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)27 ! b Fu(3)224 773 y(1.3)45 b(Readline)16 b(Init)h(File)e ! Fl(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)f(.)29 b Fu(4)374 827 y(1.3.1)44 b(Readline)16 ! b(Init)g(File)h(Syn)o(tax)7 b Fl(.)g(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)21 ! b Fu(4)374 882 y(1.3.2)44 b(Conditional)16 b(Init)g(Constructs)5 ! b Fl(.)i(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)g(.)f(.)19 b Fu(8)374 937 y(1.3.3)44 b(Sample)16 ! b(Init)g(File)11 b Fl(.)e(.)e(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)26 b Fu(9)224 992 y(1.4)45 b(Bindable)17 b(Readline)g(Commands) ! 6 b Fl(.)h(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h ! (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)21 b Fu(12)374 ! 1046 y(1.4.1)44 b(Commands)14 b(F)l(or)h(Mo)o(ving)e ! Fl(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)h(.)28 b Fu(12)374 1101 y(1.4.2)44 b(Commands)14 b(F)l(or)h(Manipulating)i(The)e(History)9 ! b Fl(.)e(.)h(.)f(.)h(.)f(.)h(.)24 b Fu(12)374 1156 y(1.4.3)44 ! b(Commands)14 b(F)l(or)h(Changing)h(T)l(ext)e Fl(.)8 b(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)30 ! b Fu(13)374 1211 y(1.4.4)44 b(Killing)18 b(And)e(Y)l(anking)9 ! b Fl(.)e(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)24 b Fu(14)374 ! 1266 y(1.4.5)44 b(Sp)q(ecifying)17 b(Numeric)f(Argumen)o(ts)c ! Fl(.)c(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)27 ! b Fu(15)374 1320 y(1.4.6)44 b(Letting)15 b(Readline)i(T)o(yp)q(e)e(F)l ! (or)g(Y)l(ou)10 b Fl(.)d(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)25 b Fu(16)374 1375 y(1.4.7)44 b(Keyb)q(oard)15 ! b(Macros)6 b Fl(.)h(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f (.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)21 ! b Fu(16)374 1430 y(1.4.8)44 b(Some)15 b(Miscellaneous)i(Commands)7 ! b Fl(.)g(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! 22 b Fu(17)224 1485 y(1.5)45 b(Readline)16 b(vi)g(Mo)q(de)e ! Fl(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)28 b Fu(18)75 1606 y Fs(2)67 b(Programming)23 ! b(with)g(GNU)f(Readline)12 b Fa(.)f(.)g(.)f(.)g(.)g(.)g(.)h(.)f(.)35 ! b Fs(19)224 1675 y Fu(2.1)45 b(Basic)16 b(Beha)o(vior)8 ! b Fl(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)f(.)h(.)f(.)23 b Fu(19)224 1729 y(2.2)45 ! b(Custom)14 b(F)l(unctions)7 b Fl(.)i(.)f(.)f(.)h(.)f(.)h(.)f(.)h(.)f (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)22 b Fu(20)374 ! 1784 y(2.2.1)44 b(Readline)16 b(T)o(yp)q(edefs)9 b Fl(.)g(.)e(.)h(.)f (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) ! f(.)h(.)f(.)h(.)g(.)f(.)h(.)24 b Fu(20)374 1839 y(2.2.2)44 ! b(W)l(riting)16 b(a)e(New)i(F)l(unction)6 b Fl(.)i(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! 21 b Fu(21)224 1894 y(2.3)45 b(Readline)16 b(V)l(ariables)g ! Fl(.)8 b(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g ! (.)f(.)h(.)29 b Fu(22)224 1949 y(2.4)45 b(Readline)16 ! b(Con)o(v)o(enience)h(F)l(unctions)7 b Fl(.)i(.)e(.)h(.)f(.)h(.)f(.)h ! (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! 23 b Fu(26)374 2003 y(2.4.1)44 b(Naming)15 b(a)g(F)l(unction)e ! Fl(.)7 b(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)27 b Fu(26)374 ! 2058 y(2.4.2)44 b(Selecting)17 b(a)e(Keymap)6 b Fl(.)h(.)h(.)g(.)f(.)h ! (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)21 b Fu(26)374 2113 y(2.4.3)44 b(Binding)17 ! b(Keys)5 b Fl(.)j(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.) ! h(.)f(.)20 b Fu(27)374 2168 y(2.4.4)44 b(Asso)q(ciating)16 ! b(F)l(unction)g(Names)f(and)g(Bindings)8 b Fl(.)h(.)f(.)f(.)h(.)f(.)h ! (.)23 b Fu(28)374 2222 y(2.4.5)44 b(Allo)o(wing)16 b(Undoing)f ! Fl(.)8 b(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)29 b ! Fu(29)374 2277 y(2.4.6)44 b(Redispla)o(y)10 b Fl(.)e(.)g(.)g(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)26 ! b Fu(30)374 2332 y(2.4.7)44 b(Mo)q(difying)16 b(T)l(ext)7 ! b Fl(.)g(.)g(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)22 ! b Fu(31)374 2387 y(2.4.8)44 b(Character)14 b(Input)c ! Fl(.)f(.)e(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h ! (.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)25 ! b Fu(32)374 2442 y(2.4.9)44 b(T)l(erminal)16 b(Managemen)o(t)11 ! b Fl(.)c(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)27 b Fu(32)374 2496 y(2.4.10)43 ! b(Utilit)o(y)17 b(F)l(unctions)c Fl(.)7 b(.)h(.)g(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) ! f(.)h(.)f(.)28 b Fu(33)374 2551 y(2.4.11)43 b(Miscellaneous)18 ! b(F)l(unctions)6 b Fl(.)i(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h ! (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)21 b Fu(34)374 ! 2606 y(2.4.12)43 b(Alternate)16 b(In)o(terface)f Fl(.)7 ! b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f ! (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)30 b Fu(35)374 2661 ! y(2.4.13)43 b(A)16 b(Readline)g(Example)9 b Fl(.)f(.)f(.)h(.)f(.)h(.)g ! (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)24 b Fu(35)p eop ! %%Page: -2 62 ! -2 61 bop 75 -58 a Fu(ii)1321 b(GNU)15 b(Readline)h(Library)224 ! 42 y(2.5)45 b(Readline)16 b(Signal)h(Handling)12 b Fl(.)c(.)g(.)f(.)h ! (.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) ! f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)27 b Fu(36)224 96 ! y(2.6)45 b(Custom)14 b(Completers)f Fl(.)8 b(.)f(.)h(.)f(.)h(.)f(.)h(.) ! f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)28 b Fu(38)374 ! 151 y(2.6.1)44 b(Ho)o(w)14 b(Completing)i(W)l(orks)10 ! b Fl(.)d(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.) ! f(.)h(.)f(.)h(.)f(.)h(.)f(.)25 b Fu(38)374 206 y(2.6.2)44 ! b(Completion)16 b(F)l(unctions)6 b Fl(.)i(.)g(.)f(.)h(.)f(.)h(.)f(.)h (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) ! 21 b Fu(39)374 261 y(2.6.3)44 b(Completion)16 b(V)l(ariables)c ! Fl(.)c(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)27 b Fu(40)374 315 y(2.6.4)44 b(A)15 b(Short)g(Completion)h(Example)5 b ! Fl(.)j(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h ! (.)f(.)20 b Fu(43)75 437 y Fs(Concept)i(Index)10 b Fa(.)i(.)e(.)g(.)g (.)g(.)h(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)h(.)f(.) ! g(.)g(.)g(.)h(.)f(.)g(.)g(.)h(.)f(.)33 b Fs(53)75 572 y(F)-6 b(unction)25 b(and)d(V)-6 b(ariable)24 b(Index)9 ! b Fa(.)i(.)f(.)g(.)h(.)f(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.) ! g(.)32 b Fs(55)p eop %%Trailer end diff -Nrc2 readline-4.1/doc/readline_3.ps readline-4.2/doc/readline_3.ps *** readline-4.1/doc/readline_3.ps Wed Dec 31 19:00:00 1969 --- readline-4.2/doc/readline_3.ps Mon Mar 5 14:37:30 2001 *************** *** 0 **** --- 1,1230 ---- + %!PS-Adobe-3.0 + %%Creator: groff version 1.16.1 + %%CreationDate: Mon Mar 5 14:37:30 2001 + %%DocumentNeededResources: font Times-Roman + %%+ font Times-Bold + %%+ font Times-Italic + %%+ font Courier + %%DocumentSuppliedResources: procset grops 1.16 1 + %%Pages: 13 + %%PageOrder: Ascend + %%Orientation: Portrait + %%EndComments + %%BeginProlog + %%BeginResource: procset grops 1.16 1 + /setpacking where{ + pop + currentpacking + true setpacking + }if + /grops 120 dict dup begin + /SC 32 def + /A/show load def + /B{0 SC 3 -1 roll widthshow}bind def + /C{0 exch ashow}bind def + /D{0 exch 0 SC 5 2 roll awidthshow}bind def + /E{0 rmoveto show}bind def + /F{0 rmoveto 0 SC 3 -1 roll widthshow}bind def + /G{0 rmoveto 0 exch ashow}bind def + /H{0 rmoveto 0 exch 0 SC 5 2 roll awidthshow}bind def + /I{0 exch rmoveto show}bind def + /J{0 exch rmoveto 0 SC 3 -1 roll widthshow}bind def + /K{0 exch rmoveto 0 exch ashow}bind def + /L{0 exch rmoveto 0 exch 0 SC 5 2 roll awidthshow}bind def + /M{rmoveto show}bind def + /N{rmoveto 0 SC 3 -1 roll widthshow}bind def + /O{rmoveto 0 exch ashow}bind def + /P{rmoveto 0 exch 0 SC 5 2 roll awidthshow}bind def + /Q{moveto show}bind def + /R{moveto 0 SC 3 -1 roll widthshow}bind def + /S{moveto 0 exch ashow}bind def + /T{moveto 0 exch 0 SC 5 2 roll awidthshow}bind def + /SF{ + findfont exch + [exch dup 0 exch 0 exch neg 0 0]makefont + dup setfont + [exch/setfont cvx]cvx bind def + }bind def + /MF{ + findfont + [5 2 roll + 0 3 1 roll + neg 0 0]makefont + dup setfont + [exch/setfont cvx]cvx bind def + }bind def + /level0 0 def + /RES 0 def + /PL 0 def + /LS 0 def + /MANUAL{ + statusdict begin/manualfeed true store end + }bind def + /PLG{ + gsave newpath clippath pathbbox grestore + exch pop add exch pop + }bind def + /BP{ + /level0 save def + 1 setlinecap + 1 setlinejoin + 72 RES div dup scale + LS{ + 90 rotate + }{ + 0 PL translate + }ifelse + 1 -1 scale + }bind def + /EP{ + level0 restore + showpage + }bind def + /DA{ + newpath arcn stroke + }bind def + /SN{ + transform + .25 sub exch .25 sub exch + round .25 add exch round .25 add exch + itransform + }bind def + /DL{ + SN + moveto + SN + lineto stroke + }bind def + /DC{ + newpath 0 360 arc closepath + }bind def + /TM matrix def + /DE{ + TM currentmatrix pop + translate scale newpath 0 0 .5 0 360 arc closepath + TM setmatrix + }bind def + /RC/rcurveto load def + /RL/rlineto load def + /ST/stroke load def + /MT/moveto load def + /CL/closepath load def + /FL{ + currentgray exch setgray fill setgray + }bind def + /BL/fill load def + /LW/setlinewidth load def + /RE{ + findfont + dup maxlength 1 index/FontName known not{1 add}if dict begin + { + 1 index/FID ne{def}{pop pop}ifelse + }forall + /Encoding exch def + dup/FontName exch def + currentdict end definefont pop + }bind def + /DEFS 0 def + /EBEGIN{ + moveto + DEFS begin + }bind def + /EEND/end load def + /CNT 0 def + /level1 0 def + /PBEGIN{ + /level1 save def + translate + div 3 1 roll div exch scale + neg exch neg exch translate + 0 setgray + 0 setlinecap + 1 setlinewidth + 0 setlinejoin + 10 setmiterlimit + []0 setdash + /setstrokeadjust where{ + pop + false setstrokeadjust + }if + /setoverprint where{ + pop + false setoverprint + }if + newpath + /CNT countdictstack def + userdict begin + /showpage{}def + }bind def + /PEND{ + clear + countdictstack CNT sub{end}repeat + level1 restore + }bind def + end def + /setpacking where{ + pop + setpacking + }if + %%EndResource + %%IncludeResource: font Times-Roman + %%IncludeResource: font Times-Bold + %%IncludeResource: font Times-Italic + %%IncludeResource: font Courier + grops begin/DEFS 1 dict def DEFS begin/u{.001 mul}bind def end/RES 72 + def/PL 792 def/LS false def/ENC0[/asciicircum/asciitilde/Scaron/Zcaron + /scaron/zcaron/Ydieresis/trademark/quotesingle/.notdef/.notdef/.notdef + /.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef + /.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef/.notdef + /.notdef/.notdef/space/exclam/quotedbl/numbersign/dollar/percent + /ampersand/quoteright/parenleft/parenright/asterisk/plus/comma/hyphen + /period/slash/zero/one/two/three/four/five/six/seven/eight/nine/colon + /semicolon/less/equal/greater/question/at/A/B/C/D/E/F/G/H/I/J/K/L/M/N/O + /P/Q/R/S/T/U/V/W/X/Y/Z/bracketleft/backslash/bracketright/circumflex + /underscore/quoteleft/a/b/c/d/e/f/g/h/i/j/k/l/m/n/o/p/q/r/s/t/u/v/w/x/y + /z/braceleft/bar/braceright/tilde/.notdef/quotesinglbase/guillemotleft + /guillemotright/bullet/florin/fraction/perthousand/dagger/daggerdbl + /endash/emdash/ff/fi/fl/ffi/ffl/dotlessi/dotlessj/grave/hungarumlaut + /dotaccent/breve/caron/ring/ogonek/quotedblleft/quotedblright/oe/lslash + /quotedblbase/OE/Lslash/.notdef/exclamdown/cent/sterling/currency/yen + /brokenbar/section/dieresis/copyright/ordfeminine/guilsinglleft + /logicalnot/minus/registered/macron/degree/plusminus/twosuperior + /threesuperior/acute/mu/paragraph/periodcentered/cedilla/onesuperior + /ordmasculine/guilsinglright/onequarter/onehalf/threequarters + /questiondown/Agrave/Aacute/Acircumflex/Atilde/Adieresis/Aring/AE + /Ccedilla/Egrave/Eacute/Ecircumflex/Edieresis/Igrave/Iacute/Icircumflex + /Idieresis/Eth/Ntilde/Ograve/Oacute/Ocircumflex/Otilde/Odieresis + /multiply/Oslash/Ugrave/Uacute/Ucircumflex/Udieresis/Yacute/Thorn + /germandbls/agrave/aacute/acircumflex/atilde/adieresis/aring/ae/ccedilla + /egrave/eacute/ecircumflex/edieresis/igrave/iacute/icircumflex/idieresis + /eth/ntilde/ograve/oacute/ocircumflex/otilde/odieresis/divide/oslash + /ugrave/uacute/ucircumflex/udieresis/yacute/thorn/ydieresis]def + /Courier@0 ENC0/Courier RE/Times-Italic@0 ENC0/Times-Italic RE + /Times-Bold@0 ENC0/Times-Bold RE/Times-Roman@0 ENC0/Times-Roman RE + %%EndProlog + %%Page: 1 1 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF 342.2(READLINE\(3\) READLINE\(3\))72 48 R/F1 + 10.95/Times-Bold@0 SF -.219(NA)72 84 S(ME).219 E F0 + (readline \255 get a line from a user with editing)108 96 Q F1(SYNOPSIS) + 72 112.8 Q/F2 10/Times-Bold@0 SF(#include )108 124.8 Q + (#include )-.18 E(#include )-.7 E/F3 10/Times-Italic@0 SF + -.15(ch)108 165.6 S(ar *).15 E F2 -.18(re)108 177.6 S(adline).18 E F0 + (\()2.5 E F3(const c)A(har *pr)-.15 E(ompt)-.45 E F0(\);)A F1(COPYRIGHT) + 72 194.4 Q F0(Readline is Cop)108 206.4 Q + (yright \251 1989\2552001 by the Free Softw)-.1 E(are F)-.1 E + (oundation, Inc.)-.15 E F1(DESCRIPTION)72 223.2 Q F2 -.18(re)108 235.2 S + (adline).18 E F0 .088 + (will read a line from the terminal and return it, using)2.588 F F2(pr) + 2.587 E(ompt)-.18 E F0 .087(as a prompt.)2.587 F(If)5.087 E F2(pr)2.587 + E(ompt)-.18 E F0(is)2.587 E F2(NULL)2.587 E F0(or)2.587 E .42 + (the empty string, no prompt is issued.)108 247.2 R .421 + (The line returned is allocated with)5.42 F F3(malloc)2.921 E F0 .421 + (\(3\); the caller must free it).31 F(when \214nished.)108 259.2 Q + (The line returned has the \214nal ne)5 E(wline remo)-.25 E -.15(ve)-.15 + G(d, so only the te).15 E(xt of the line remains.)-.15 E F2 -.18(re)108 + 276 S(adline).18 E F0(of)3.79 E 1.29 + (fers editing capabilities while the user is entering the line.)-.25 F + 1.289(By def)6.289 F 1.289(ault, the line editing com-)-.1 F + (mands are similar to those of emacs.)108 288 Q 2.5(Av)5 G + (i\255style line editing interf)-2.5 E(ace is also a)-.1 E -.25(va)-.2 G + (ilable.).25 E .272 + (This manual page describes only the most basic use of)108 304.8 R F2 + -.18(re)2.772 G(adline).18 E F0 5.272(.M)C .272 + (uch more functionality is a)-5.272 F -.25(va)-.2 G .272(ilable; see).25 + F F3(The GNU Readline Libr)108 316.8 Q(ary)-.15 E F0(and)2.5 E F3 + (The GNU History Libr)2.5 E(ary)-.15 E F0(for additional information.) + 2.5 E F1(RETURN V)72 333.6 Q(ALUE)-1.478 E F2 -.18(re)108 345.6 S + (adline).18 E F0 1.09(returns the te)3.59 F 1.09(xt of the line read.) + -.15 F 3.589(Ab)6.09 G 1.089(lank line returns the empty string.)-3.589 + F(If)6.089 E F2(EOF)3.589 E F0 1.089(is encountered)3.589 F .283 + (while reading a line, and the line is empty)108 357.6 R(,)-.65 E F2 + (NULL)2.783 E F0 .283(is returned.)2.783 F .283(If an)5.283 F F2(EOF) + 2.783 E F0 .283(is read with a non\255empty line, it)2.783 F + (is treated as a ne)108 369.6 Q(wline.)-.25 E F1(NO)72 386.4 Q -.986(TA) + -.438 G(TION)-.054 E F0 .181 + (An emacs-style notation is used to denote k)108 398.4 R -.15(ey)-.1 G + (strok).15 E 2.681(es. Control)-.1 F -.1(ke)2.681 G .18 + (ys are denoted by C\255)-.05 F F3 -.1(ke)C(y)-.2 E F0 2.68(,e)C .18 + (.g., C\255n means)-2.68 F 2.625(Control\255N. Similarly)108 410.4 R(,) + -.65 E F3(meta)2.625 E F0 -.1(ke)2.625 G .125(ys are denoted by M\255) + -.05 F F3 -.1(ke)C(y)-.2 E F0 2.625(,s)C 2.625(oM)-2.625 G .125 + (\255x means Meta\255X.)-2.625 F .126(\(On k)5.126 F -.15(ey)-.1 G .126 + (boards without a).15 F F3(meta)108 422.4 Q F0 -.1(ke)3.309 G 2.109 -.65 + (y, M)-.05 H.65 E F3(x)A F0 .809(means ESC)3.309 F F3(x)3.309 E F0 + 3.309(,i)C .809(.e., press the Escape k)-3.309 F 1.108 -.15(ey t)-.1 H + .808(hen the).15 F F3(x)3.308 E F0 -.1(ke)3.308 G 4.608 -.65(y. T)-.05 H + .808(his mak).65 F .808(es ESC the)-.1 F F3 .808(meta pr)3.308 F(e\214x) + -.37 E F0(.)A .48(The combination M\255C\255)108 434.4 R F3(x)A F0 .48 + (means ESC\255Control\255)2.98 F F3(x)A F0 2.98(,o)C 2.98(rp)-2.98 G .48 + (ress the Escape k)-2.98 F .78 -.15(ey t)-.1 H .48 + (hen hold the Control k).15 F .78 -.15(ey w)-.1 H(hile).15 E + (pressing the)108 446.4 Q F3(x)2.5 E F0 -.1(ke)2.5 G -.65(y.)-.05 G(\)) + .65 E .62(Readline commands may be gi)108 463.2 R -.15(ve)-.25 G 3.119 + (nn).15 G(umeric)-3.119 E F3(ar)3.119 E(guments)-.37 E F0 3.119(,w).27 G + .619(hich normally act as a repeat count.)-3.119 F(Sometimes,)5.619 E + (ho)108 475.2 Q(we)-.25 E -.15(ve)-.25 G 1.418 -.4(r, i).15 H 3.118(ti) + .4 G 3.119(st)-3.118 G .619(he sign of the ar)-3.119 F .619 + (gument that is signi\214cant.)-.18 F -.15(Pa)5.619 G .619(ssing a ne) + .15 F -.05(ga)-.15 G(ti).05 E .919 -.15(ve a)-.25 H -.18(rg).15 G .619 + (ument to a command that).18 F 1.019(acts in the forw)108 487.2 R 1.018 + (ard direction \(e.g.,)-.1 F F2(kill\255line)3.518 E F0 3.518(\)c)C + 1.018(auses that command to act in a backw)-3.518 F 1.018 + (ard direction.)-.1 F(Com-)6.018 E(mands whose beha)108 499.2 Q + (vior with ar)-.2 E(guments de)-.18 E(viates from this are noted.)-.25 E + .811(When a command is described as)108 516 R F3(killing)3.311 E F0(te) + 3.311 E .811(xt, the te)-.15 F .811(xt deleted is sa)-.15 F -.15(ve)-.2 + G 3.311(df).15 G .812(or possible future retrie)-3.311 F -.25(va)-.25 G + 3.312(l\().25 G F3(yank-)-3.312 E(ing)108 528 Q F0 2.529(\). The)B .029 + (killed te)2.529 F .029(xt is sa)-.15 F -.15(ve)-.2 G 2.529(di).15 G + 2.529(na)-2.529 G F3 .029(kill ring)B F0 5.029(.C)C(onsecuti)-5.029 E + .329 -.15(ve k)-.25 H .029(ills cause the te).15 F .029 + (xt to be accumulated into one unit,)-.15 F .567(which can be yank)108 + 540 R .567(ed all at once.)-.1 F .567(Commands which do not kill te) + 5.567 F .567(xt separate the chunks of te)-.15 F .567(xt on the kill) + -.15 F(ring.)108 552 Q F1(INITIALIZA)72 568.8 Q(TION FILE)-1.04 E F0 + .091(Readline is customized by putting commands in an initialization \ + \214le \(the)108 580.8 R F3(inputr)2.591 E(c)-.37 E F0 2.591 + (\214le\). The)2.591 F .091(name of this \214le)2.591 F 1.442(is tak)108 + 592.8 R 1.443(en from the v)-.1 F 1.443(alue of the)-.25 F F2(INPUTRC) + 3.943 E F0(en)3.943 E 1.443(vironment v)-.4 F 3.943(ariable. If)-.25 F + 1.443(that v)3.943 F 1.443(ariable is unset, the def)-.25 F 1.443 + (ault is)-.1 F F3(~/.inputr)108 604.8 Q(c)-.37 E F0 5.359(.W).31 G .359 + (hen a program which uses the readline library starts up, the init \214\ + le is read, and the k)-5.359 F .658 -.15(ey b)-.1 H(ind-).15 E 1.083 + (ings and v)108 616.8 R 1.083(ariables are set.)-.25 F 1.083 + (There are only a fe)6.083 F 3.583(wb)-.25 G 1.083(asic constructs allo) + -3.583 F 1.084(wed in the readline init \214le.)-.25 F(Blank)6.084 E + .737(lines are ignored.)108 628.8 R .737(Lines be)5.737 F .737 + (ginning with a)-.15 F F2(#)3.237 E F0 .737(are comments.)3.237 F .737 + (Lines be)5.737 F .737(ginning with a)-.15 F F2($)3.237 E F0 .736 + (indicate conditional)3.236 F 2.614(constructs. Other)108 640.8 R .114 + (lines denote k)2.614 F .414 -.15(ey b)-.1 H .115(indings and v).15 F + .115(ariable settings.)-.25 F .115 + (Each program using this library may add)5.115 F(its o)108 652.8 Q + (wn commands and bindings.)-.25 E -.15(Fo)108 669.6 S 2.5(re).15 G + (xample, placing)-2.65 E(M\255Control\255u: uni)144 686.4 Q -.15(ve)-.25 + G(rsal\255ar).15 E(gument)-.18 E(or)108 698.4 Q(C\255Meta\255u: uni)144 + 710.4 Q -.15(ve)-.25 G(rsal\255ar).15 E(gument)-.18 E(GNU Readline 4.2) + 72 768 Q(2001 Mar 5)135.96 E(1)205.67 E EP + %%Page: 2 2 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF 342.2(READLINE\(3\) READLINE\(3\))72 48 R + (into the)108 84 Q/F1 10/Times-Italic@0 SF(inputr)2.5 E(c)-.37 E F0 -.1 + (wo)2.5 G(uld mak).1 E 2.5(eM)-.1 G(\255C\255u e)-2.5 E -.15(xe)-.15 G + (cute the readline command).15 E F1(univer)2.5 E(sal\255ar)-.1 E(gument) + -.37 E F0(.).68 E 2.795(The follo)108 100.8 R 2.795 + (wing symbolic character names are recognized while processing k)-.25 F + 3.095 -.15(ey b)-.1 H(indings:).15 E F1(DEL)5.295 E F0(,).53 E F1(ESC) + 5.295 E F0(,).72 E F1(ESCAPE)108 112.8 Q F0(,).73 E F1(LFD)2.5 E F0(,) + .28 E F1(NEWLINE)2.5 E F0(,).73 E F1(RET)2.5 E F0(,)1.27 E F1(RETURN)2.5 + E F0(,)1.1 E F1 -.4(RU)2.5 G(BOUT).4 E F0(,)1.27 E F1(SP)2.5 E -.3(AC) + -.9 G(E).3 E F0(,).73 E F1(SPC)2.5 E F0 2.5(,a).72 G(nd)-2.5 E F1 -.5 + (TA)2.5 G(B).5 E F0(.).27 E .209 + (In addition to command names, readline allo)108 129.6 R .209(ws k)-.25 + F -.15(ey)-.1 G 2.709(st).15 G 2.709(ob)-2.709 G 2.709(eb)-2.709 G .209 + (ound to a string that is inserted when the k)-2.709 F .509 -.15(ey i) + -.1 H(s).15 E(pressed \(a)108 141.6 Q F1(macr)2.5 E(o)-.45 E F0(\).)A/F2 + 10/Times-Bold@0 SF -.25(Ke)87 163.2 S 2.5(yB).25 G(indings)-2.5 E F0 + .382(The syntax for controlling k)108 175.2 R .682 -.15(ey b)-.1 H .382 + (indings in the).15 F F1(inputr)2.882 E(c)-.37 E F0 .382 + (\214le is simple.)2.882 F .382(All that is required is the name of the) + 5.382 F .382(command or the te)108 187.2 R .383(xt of a macro and a k) + -.15 F .683 -.15(ey s)-.1 H .383 + (equence to which it should be bound. The name may be speci-).15 F .853 + (\214ed in one of tw)108 199.2 R 3.353(ow)-.1 G .853 + (ays: as a symbolic k)-3.453 F 1.153 -.15(ey n)-.1 H .853 + (ame, possibly with).15 F F1(Meta\255)3.353 E F0(or)3.353 E F1(Contr) + 3.353 E(ol\255)-.45 E F0(pre\214x)3.353 E .853(es, or as a k)-.15 F -.15 + (ey)-.1 G(sequence.)108 211.2 Q 1.766(When using the form)108 228 R F2 + -.1(ke)4.266 G(yname).1 E F0(:)A F1(function-name).833 E F0(or)4.266 E + F1(macr)4.267 E(o)-.45 E F0(,)A F1 -.1(ke)4.267 G(yname)-.2 E F0 1.767 + (is the name of a k)4.267 F 2.067 -.15(ey s)-.1 H 1.767(pelled out in) + .15 F 2.5(English. F)108 240 R(or e)-.15 E(xample:)-.15 E + (Control\255u: uni)144 264 Q -.15(ve)-.25 G(rsal\255ar).15 E(gument)-.18 + E(Meta\255Rubout: backw)144 276 Q(ard\255kill\255w)-.1 E(ord)-.1 E + (Control\255o: "> output")144 288 Q .229(In the abo)108 304.8 R .529 + -.15(ve ex)-.15 H(ample,).15 E F1(C\255u)2.729 E F0 .229 + (is bound to the function)2.729 F F2(uni)2.729 E -.1(ve)-.1 G + (rsal\255ar).1 E(gument)-.1 E F0(,)A F1(M-DEL)2.729 E F0 .228 + (is bound to the function)2.729 F F2(backward\255kill\255w)108 316.8 Q + (ord)-.1 E F0 3.837(,a)C(nd)-3.837 E F1(C\255o)3.837 E F0 1.337 + (is bound to run the macro e)3.837 F 1.337 + (xpressed on the right hand side \(that is, to)-.15 F(insert the te)108 + 328.8 Q(xt)-.15 E/F3 10/Courier@0 SF 6(>o)2.5 G(utput)-6 E F0 + (into the line\).)2.5 E .056(In the second form,)108 345.6 R F2("k)2.556 + E(eyseq")-.1 E F0(:)A F1(function\255name).833 E F0(or)2.556 E F1(macr) + 2.556 E(o)-.45 E F0(,)A F2 -.1(ke)2.556 G(yseq).1 E F0(dif)2.555 E .055 + (fers from)-.25 F F2 -.1(ke)2.555 G(yname).1 E F0(abo)2.555 E .355 -.15 + (ve i)-.15 H 2.555(nt).15 G .055(hat strings)-2.555 F 1.284 + (denoting an entire k)108 357.6 R 1.584 -.15(ey s)-.1 H 1.284(equence m\ + ay be speci\214ed by placing the sequence within double quotes.).15 F + (Some)6.284 E .386(GNU Emacs style k)108 369.6 R .686 -.15(ey e)-.1 H + .385(scapes can be used, as in the follo).15 F .385(wing e)-.25 F .385 + (xample, b)-.15 F .385(ut the symbolic character names)-.2 F + (are not recognized.)108 381.6 Q("\\C\255u": uni)144 405.6 Q -.15(ve) + -.25 G(rsal\255ar).15 E(gument)-.18 E + ("\\C\255x\\C\255r": re\255read\255init\255\214le)144 417.6 Q + ("\\e[11~": "Function K)144 429.6 Q .3 -.15(ey 1)-.25 H(").15 E .237 + (In this e)108 446.4 R(xample,)-.15 E F1(C-u)2.737 E F0 .237(is ag)2.737 + F .238(ain bound to the function)-.05 F F2(uni)2.738 E -.1(ve)-.1 G + (rsal\255ar).1 E(gument)-.1 E F0(.)A F1 .238(C-x C-r)5.238 F F0 .238 + (is bound to the function)2.738 F F2 -.18(re)108 458.4 S.18 E + (ead\255init\255\214le)-.18 E F0 2.5(,a)C(nd)-2.5 E F1(ESC [ 1 1 ~)2.5 E + F0(is bound to insert the te)2.5 E(xt)-.15 E F3(Function Key 1)2.5 E F0 + (.)A(The full set of GNU Emacs style escape sequences a)108 475.2 Q -.25 + (va)-.2 G(ilable when specifying k).25 E .3 -.15(ey s)-.1 H(equences is) + .15 E F2<5c43ad>144 487.2 Q F0(control pre\214x)20.3 E F2<5c4dad>144 + 499.2 Q F0(meta pre\214x)18.08 E F2(\\e)144 511.2 Q F0 + (an escape character)28.78 E F2(\\\\)144 523.2 Q F0(backslash)30.44 E F2 + (\\")144 535.2 Q F0(literal ", a double quote)27.67 E F2(\\')144 547.2 Q + F0(literal ', a single quote)29.89 E(In addition to the GNU Emacs style\ + escape sequences, a second set of backslash escapes is a)108 564 Q -.25 + (va)-.2 G(ilable:).25 E F2(\\a)144 576 Q F0(alert \(bell\))28.22 E F2 + (\\b)144 588 Q F0(backspace)27.66 E F2(\\d)144 600 Q F0(delete)27.66 E + F2(\\f)144 612 Q F0(form feed)29.89 E F2(\\n)144 624 Q F0(ne)27.66 E + (wline)-.25 E F2(\\r)144 636 Q F0(carriage return)28.78 E F2(\\t)144 648 + Q F0(horizontal tab)29.89 E F2(\\v)144 660 Q F0 -.15(ve)28.22 G + (rtical tab).15 E F2(\\)144 672 Q F1(nnn)A F0 + (the character whose ASCII code is the octal v)18.22 E(alue)-.25 E F1 + (nnn)2.5 E F0(\(one to three digits\))2.5 E F2(\\x)144 684 Q F1(nnn)A F0 + (the character whose ASCII code is the he)13.22 E(xadecimal v)-.15 E + (alue)-.25 E F1(nnn)2.5 E F0(\(one to three digits\))2.5 E .74 + (When entering the te)108 700.8 R .74(xt of a macro, single or double q\ + uotes should be used to indicate a macro de\214nition.)-.15 F .089 + (Unquoted te)108 712.8 R .089(xt is assumed to be a function name.)-.15 + F .09(In the macro body)5.089 F 2.59(,t)-.65 G .09 + (he backslash escapes described abo)-2.59 F -.15(ve)-.15 G(are e)108 + 724.8 Q 2.5(xpanded. Backslash)-.15 F(will quote an)2.5 E 2.5(yo)-.15 G + (ther character in the macro te)-2.5 E(xt, including " and '.)-.15 E + (GNU Readline 4.2)72 768 Q(2001 Mar 5)135.96 E(2)205.67 E EP + %%Page: 3 3 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF 342.2(READLINE\(3\) READLINE\(3\))72 48 R/F1 10 + /Times-Bold@0 SF(Bash)108 84 Q F0(allo)2.93 E .43 + (ws the current readline k)-.25 F .73 -.15(ey b)-.1 H .429 + (indings to be displayed or modi\214ed with the).15 F F1(bind)2.929 E F0 + -.2(bu)2.929 G .429(iltin command.).2 F 1.095 + (The editing mode may be switched during interacti)108 96 R 1.395 -.15 + (ve u)-.25 H 1.095(se by using the).15 F F13.595 E F0 1.095 + (option to the)3.595 F F1(set)3.595 E F0 -.2(bu)3.595 G 1.095 + (iltin com-).2 F 3.097(mand. Other)108 108 R .597 + (programs using this library pro)3.097 F .597(vide similar mechanisms.) + -.15 F(The)5.597 E/F2 10/Times-Italic@0 SF(inputr)3.097 E(c)-.37 E F0 + .596(\214le may be edited and)3.096 F(re-read if a program does not pro) + 108 120 Q(vide an)-.15 E 2.5(yo)-.15 G(ther means to incorporate ne)-2.5 + E 2.5(wb)-.25 G(indings.)-2.5 E F1 -.92(Va)87 136.8 S(riables).92 E F0 + .043(Readline has v)108 148.8 R .044 + (ariables that can be used to further customize its beha)-.25 F(vior)-.2 + E 5.044(.A)-.55 G -.25(va)-2.5 G .044(riable may be set in the).25 F F2 + (inpu-)2.544 E(tr)108 160.8 Q(c)-.37 E F0 + (\214le with a statement of the form)2.5 E F1(set)144 177.6 Q F2 + (variable\255name value)2.5 E F0 .807(Except where noted, readline v)108 + 194.4 R .807(ariables can tak)-.25 F 3.307(et)-.1 G .807(he v)-3.307 F + (alues)-.25 E F1(On)3.307 E F0(or)3.307 E F1(Off)3.307 E F0 .807 + (\(without re)3.307 F -.05(ga)-.15 G .807(rd to case\).).05 F .807 + (The v)5.807 F(ari-)-.25 E(ables and their def)108 206.4 Q(ault v)-.1 E + (alues are:)-.25 E F1(bell\255style \(audible\))108 223.2 Q F0 .01 + (Controls what happens when readline w)144 235.2 R .011 + (ants to ring the terminal bell.)-.1 F .011(If set to)5.011 F F1(none) + 2.511 E F0 2.511(,r)C .011(eadline ne)-2.511 F -.15(ve)-.25 G(r).15 E + .94(rings the bell.)144 247.2 R .94(If set to)5.94 F F1(visible)3.44 E + F0 3.44(,r)C .94(eadline uses a visible bell if one is a)-3.44 F -.25 + (va)-.2 G 3.44(ilable. If).25 F .94(set to)3.44 F F1(audible)3.44 E F0 + (,)A(readline attempts to ring the terminal')144 259.2 Q 2.5(sb)-.55 G + (ell.)-2.5 E F1(comment\255begin \(`)108 271.2 Q(`#')-.63 E('\))-.63 E + F0 .062(The string that is inserted in)144 283.2 R F1(vi)2.562 E F0 .062 + (mode when the)2.562 F F1(insert\255comment)2.562 E F0 .062 + (command is e)2.562 F -.15(xe)-.15 G 2.562(cuted. This).15 F(com-)2.562 + E(mand is bound to)144 295.2 Q F1(M\255#)2.5 E F0(in emacs mode and to) + 2.5 E F1(#)2.5 E F0(in vi command mode.)2.5 E F1(completion\255ignor)108 + 307.2 Q(e\255case \(Off\))-.18 E F0(If set to)144 319.2 Q F1(On)2.5 E F0 + 2.5(,r)C(eadline performs \214lename matching and completion in a case\ + \255insensiti)-2.5 E .3 -.15(ve f)-.25 H(ashion.).05 E F1 + (completion\255query\255items \(100\))108 331.2 Q F0 .53 + (This determines when the user is queried about vie)144 343.2 R .529 + (wing the number of possible completions gen-)-.25 F .56(erated by the) + 144 355.2 R F1(possible\255completions)3.06 E F0 3.06(command. It)3.06 F + .561(may be set to an)3.061 F 3.061(yi)-.15 G(nte)-3.061 E .561(ger v) + -.15 F .561(alue greater than or)-.25 F .783(equal to zero.)144 367.2 R + .783(If the number of possible completions is greater than or equal to \ + the v)5.783 F .782(alue of this)-.25 F -.25(va)144 379.2 S .237 + (riable, the user is ask).25 F .237(ed whether or not he wishes to vie) + -.1 F 2.737(wt)-.25 G .237(hem; otherwise the)-2.737 F 2.737(ya)-.15 G + .237(re simply listed)-2.737 F(on the terminal.)144 391.2 Q F1(con)108 + 403.2 Q -.1(ve)-.4 G(rt\255meta \(On\)).1 E F0 .613(If set to)144 415.2 + R F1(On)3.113 E F0 3.113(,r)C .613(eadline will con)-3.113 F -.15(ve)-.4 + G .613(rt characters with the eighth bit set to an ASCII k).15 F .912 + -.15(ey s)-.1 H .612(equence by).15 F 1.315(stripping the eighth bit an\ + d pre\214xing it with an escape character \(in ef)144 427.2 R 1.316 + (fect, using escape as the)-.25 F F2(meta pr)144 439.2 Q(e\214x)-.37 E + F0(\).)A F1(disable\255completion \(Off\))108 451.2 Q F0 .038(If set to) + 144 463.2 R F1(On)2.538 E F0 2.538(,r)C .038(eadline will inhibit w) + -2.538 F .038(ord completion.)-.1 F .038 + (Completion characters will be inserted into the)5.038 F(line as if the) + 144 475.2 Q 2.5(yh)-.15 G(ad been mapped to)-2.5 E F1(self-insert)2.5 E + F0(.)A F1(editing\255mode \(emacs\))108 487.2 Q F0 .215 + (Controls whether readline be)144 499.2 R .215(gins with a set of k)-.15 + F .515 -.15(ey b)-.1 H .216(indings similar to emacs or vi.).15 F F1 + (editing\255mode)5.216 E F0(can be set to either)144 511.2 Q F1(emacs) + 2.5 E F0(or)2.5 E F1(vi)2.5 E F0(.)A F1(enable\255k)108 523.2 Q + (eypad \(Off\))-.1 E F0 .893(When set to)144 535.2 R F1(On)3.393 E F0 + 3.393(,r)C .893(eadline will try to enable the application k)-3.393 F + -.15(ey)-.1 G .893(pad when it is called.).15 F .892(Some sys-)5.893 F + (tems need this to enable the arro)144 547.2 Q 2.5(wk)-.25 G -.15(ey) + -2.6 G(s.).15 E F1(expand\255tilde \(Off\))108 559.2 Q F0(If set to)144 + 571.2 Q F1(on)2.5 E F0 2.5(,t)C(ilde e)-2.5 E + (xpansion is performed when readline attempts w)-.15 E(ord completion.) + -.1 E F1(horizontal\255scr)108 583.2 Q(oll\255mode \(Off\))-.18 E F0 + .448(When set to)144 595.2 R F1(On)2.948 E F0 2.948(,m)C(ak)-2.948 E + .448(es readline use a single line for display)-.1 F 2.948(,s)-.65 G + .449(crolling the input horizontally on a)-2.948 F 1.194(single screen \ + line when it becomes longer than the screen width rather than wrapping \ + to a ne)144 607.2 R(w)-.25 E(line.)144 619.2 Q F1(input\255meta \(Off\)) + 108 631.2 Q F0 .367(If set to)144 643.2 R F1(On)2.867 E F0 2.867(,r)C + .367(eadline will enable eight-bit input \(that is, it will not clear t\ + he eighth bit in the char)-2.867 F(-)-.2 E .957(acters it reads\), re) + 144 655.2 R -.05(ga)-.15 G .956 + (rdless of what the terminal claims it can support.).05 F .956(The name) + 5.956 F F1(meta\255\215ag)3.456 E F0 .956(is a)3.456 F(synon)144 667.2 Q + (ym for this v)-.15 E(ariable.)-.25 E F1(isear)108 679.2 Q + (ch\255terminators \(`)-.18 E(`C\255[ C\255J')-.63 E('\))-.63 E F0 .439 + (The string of characters that should terminate an incremental search w\ + ithout subsequently e)144 691.2 R -.15(xe)-.15 G(cut-).15 E .935 + (ing the character as a command.)144 703.2 R .935(If this v)5.935 F .935 + (ariable has not been gi)-.25 F -.15(ve)-.25 G 3.434(nav).15 G .934 + (alue, the characters)-3.684 F F2(ESC)3.434 E F0(and)144 715.2 Q F2 + (C\255J)2.5 E F0(will terminate an incremental search.)2.5 E + (GNU Readline 4.2)72 768 Q(2001 Mar 5)135.96 E(3)205.67 E EP + %%Page: 4 4 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF 342.2(READLINE\(3\) READLINE\(3\))72 48 R/F1 10 + /Times-Bold@0 SF -.1(ke)108 84 S(ymap \(emacs\)).1 E F0 2.323 + (Set the current readline k)144 96 R -.15(ey)-.1 G 4.823(map. The).15 F + 2.323(set of le)4.823 F -.05(ga)-.15 G 4.823(lk).05 G -.15(ey)-4.923 G + 2.323(map names is).15 F/F2 10/Times-Italic@0 SF 2.324 + (emacs, emacs-standar)4.823 F(d,)-.37 E .809 + (emacs-meta, emacs-ctlx, vi, vi-mo)144 108 R(ve)-.1 E 3.308(,v)-.1 G + (i-command)-3.308 E F0 3.308(,a)C(nd)-3.308 E F2(vi-insert)3.308 E F0(.) + .68 E F2(vi)5.808 E F0 .808(is equi)3.308 F -.25(va)-.25 G .808(lent to) + .25 F F2(vi-command)3.308 E F0(;)A F2(emacs)144 120 Q F0 .697(is equi) + 3.196 F -.25(va)-.25 G .697(lent to).25 F F2(emacs-standar)3.197 E(d) + -.37 E F0 5.697(.T)C .697(he def)-5.697 F .697(ault v)-.1 F .697 + (alue is)-.25 F F2(emacs)3.197 E F0 5.697(.T).27 G .697(he v)-5.697 F + .697(alue of)-.25 F F1(editing\255mode)3.197 E F0(also af)144 132 Q + (fects the def)-.25 E(ault k)-.1 E -.15(ey)-.1 G(map.).15 E F1 + (mark\255dir)108 144 Q(ectories \(On\))-.18 E F0(If set to)144 156 Q F1 + (On)2.5 E F0 2.5(,c)C(ompleted directory names ha)-2.5 E .3 -.15(ve a s) + -.2 H(lash appended.).15 E F1(mark\255modi\214ed\255lines \(Off\))108 + 168 Q F0(If set to)144 180 Q F1(On)2.5 E F0 2.5(,h)C + (istory lines that ha)-2.5 E .3 -.15(ve b)-.2 H + (een modi\214ed are displayed with a preceding asterisk \().15 E F1(*)A + F0(\).)A F1(output\255meta \(Off\))108 192 Q F0 .507(If set to)144 204 R + F1(On)3.007 E F0 3.007(,r)C .507(eadline will display characters with t\ + he eighth bit set directly rather than as a meta-)-3.007 F(pre\214x)144 + 216 Q(ed escape sequence.)-.15 E F1 + (print\255completions\255horizontally \(Off\))108 228 Q F0 1.318 + (If set to)144 240 R F1(On)3.818 E F0 3.818(,r)C 1.319(eadline will dis\ + play completions with matches sorted horizontally in alphabetical)-3.818 + F(order)144 252 Q 2.5(,r)-.4 G(ather than do)-2.5 E(wn the screen.)-.25 + E F1(sho)108 264 Q(w\255all\255if\255ambiguous \(Off\))-.1 E F0 .478 + (This alters the def)144 276 R .478(ault beha)-.1 F .478 + (vior of the completion functions.)-.2 F .477(If set to)5.477 F F1(on) + 2.977 E F0 2.977(,w)C .477(ords which ha)-3.077 F .777 -.15(ve m)-.2 H + (ore).15 E 1.264(than one possible completion cause the matches to be l\ + isted immediately instead of ringing the)144 288 R(bell.)144 300 Q F1 + (visible\255stats \(Off\))108 312 Q F0 .847(If set to)144 324 R F1(On) + 3.346 E F0 3.346(,ac)C .846(haracter denoting a \214le')-3.346 F 3.346 + (st)-.55 G .846(ype as reported by)-3.346 F F2(stat)3.346 E F0 .846 + (\(2\) is appended to the \214lename)B + (when listing possible completions.)144 336 Q F1(Conditional Constructs) + 87 352.8 Q F0 .05(Readline implements a f)108 364.8 R .05(acility simil\ + ar in spirit to the conditional compilation features of the C preproces\ + sor)-.1 F .097(which allo)108 376.8 R .097(ws k)-.25 F .396 -.15(ey b) + -.1 H .096(indings and v).15 F .096 + (ariable settings to be performed as the result of tests.)-.25 F .096 + (There are four parser)5.096 F(directi)108 388.8 Q -.15(ve)-.25 G 2.5 + (su).15 G(sed.)-2.5 E F1($if)108 405.6 Q F0(The)24.89 E F1($if)2.962 E + F0 .462(construct allo)2.962 F .463(ws bindings to be made based on the\ + editing mode, the terminal being used,)-.25 F .478 + (or the application using readline.)144 417.6 R .477(The te)5.477 F .477 + (xt of the test e)-.15 F .477 + (xtends to the end of the line; no characters)-.15 F + (are required to isolate it.)144 429.6 Q F1(mode)144 446.4 Q F0(The) + 12.67 E F1(mode=)3.711 E F0 1.211(form of the)3.711 F F1($if)3.711 E F0 + (directi)3.711 E 1.511 -.15(ve i)-.25 H 3.711(su).15 G 1.211 + (sed to test whether readline is in emacs or vi)-3.711 F 3.065 + (mode. This)180 458.4 R .565(may be used in conjunction with the)3.065 F + F1 .565(set k)3.065 F(eymap)-.1 E F0 .565(command, for instance, to) + 3.065 F .029(set bindings in the)180 470.4 R F2(emacs-standar)2.529 E(d) + -.37 E F0(and)2.529 E F2(emacs-ctlx)2.529 E F0 -.1(ke)2.529 G .029 + (ymaps only if readline is starting out)-.05 F(in emacs mode.)180 482.4 + Q F1(term)144 499.2 Q F0(The)15.46 E F1(term=)3.197 E F0 .696 + (form may be used to include terminal-speci\214c k)3.197 F .996 -.15 + (ey b)-.1 H .696(indings, perhaps to bind).15 F .654(the k)180 511.2 R + .954 -.15(ey s)-.1 H .654(equences output by the terminal').15 F 3.154 + (sf)-.55 G .654(unction k)-3.154 F -.15(ey)-.1 G 3.154(s. The).15 F -.1 + (wo)3.154 G .654(rd on the right side of).1 F(the)180 523.2 Q F1(=)3.004 + E F0 .504(is tested ag)3.004 F .503(ainst the full name of the terminal\ + and the portion of the terminal name)-.05 F(before the \214rst)180 + 535.2 Q F12.5 E F0 5(.T)C(his allo)-5 E(ws)-.25 E F2(sun)2.5 E F0 + (to match both)2.5 E F2(sun)2.5 E F0(and)2.5 E F2(sun\255cmd)2.5 E F0 + 2.5(,f).77 G(or instance.)-2.5 E F1(application)144 552 Q F0(The)180 564 + Q F1(application)3.003 E F0 .503 + (construct is used to include application-speci\214c settings.)3.003 F + .503(Each program)5.503 F .114(using the readline library sets the)180 + 576 R F2 .114(application name)2.614 F F0 2.614(,a)C .114 + (nd an initialization \214le can test for a)-2.614 F .5(particular v)180 + 588 R 3(alue. This)-.25 F .501(could be used to bind k)3 F .801 -.15 + (ey s)-.1 H .501(equences to functions useful for a spe-).15 F .397 + (ci\214c program.)180 600 R -.15(Fo)5.397 G 2.896(ri).15 G .396 + (nstance, the follo)-2.896 F .396(wing command adds a k)-.25 F .696 -.15 + (ey s)-.1 H .396(equence that quotes the).15 F(current or pre)180 612 Q + (vious w)-.25 E(ord in Bash:)-.1 E F1($if)180 636 Q F0(Bash)2.5 E 2.5 + (#Q)180 648 S(uote the current or pre)-2.5 E(vious w)-.25 E(ord)-.1 E + ("\\C-xq": "\\eb\\"\\ef\\"")180 660 Q F1($endif)180 672 Q($endif)108 + 688.8 Q F0(This command, as seen in the pre)9.33 E(vious e)-.25 E + (xample, terminates an)-.15 E F1($if)2.5 E F0(command.)2.5 E F1($else) + 108 705.6 Q F0(Commands in this branch of the)15.45 E F1($if)2.5 E F0 + (directi)2.5 E .3 -.15(ve a)-.25 H(re e).15 E -.15(xe)-.15 G + (cuted if the test f).15 E(ails.)-.1 E(GNU Readline 4.2)72 768 Q + (2001 Mar 5)135.96 E(4)205.67 E EP + %%Page: 5 5 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF 342.2(READLINE\(3\) READLINE\(3\))72 48 R/F1 10 + /Times-Bold@0 SF($include)108 84 Q F0 .356(This directi)144 96 R .656 + -.15(ve t)-.25 H(ak).15 E .356(es a single \214lename as an ar)-.1 F + .357(gument and reads commands and bindings from that)-.18 F 2.5 + (\214le. F)144 108 R(or e)-.15 E(xample, the follo)-.15 E(wing directi) + -.25 E .3 -.15(ve w)-.25 H(ould read).05 E/F2 10/Times-Italic@0 SF + (/etc/inputr)2.5 E(c)-.37 E F0(:)A F1($include)144 132 Q F2(/etc/inputr) + 5.833 E(c)-.37 E/F3 10.95/Times-Bold@0 SF(SEARCHING)72 148.8 Q F0 1.004 + (Readline pro)108 160.8 R 1.003(vides commands for searching through th\ + e command history for lines containing a speci\214ed)-.15 F 2.5 + (string. There)108 172.8 R(are tw)2.5 E 2.5(os)-.1 G(earch modes:)-2.5 E + F2(incr)2.5 E(emental)-.37 E F0(and)2.5 E F2(non-incr)2.5 E(emental)-.37 + E F0(.).51 E .697(Incremental searches be)108 189.6 R .697 + (gin before the user has \214nished typing the search string.)-.15 F + .698(As each character of the)5.698 F .113 + (search string is typed, readline displays the ne)108 201.6 R .112 + (xt entry from the history matching the string typed so f)-.15 F(ar)-.1 + E 5.112(.A)-.55 G(n)-5.112 E .544 + (incremental search requires only as man)108 213.6 R 3.044(yc)-.15 G + .544(haracters as needed to \214nd the desired history entry)-3.044 F + 5.545(.T)-.65 G 3.045(os)-6.345 G(earch)-3.045 E(backw)108 225.6 Q .181 + (ard in the history for a particular string, type)-.1 F F1(C\255r)2.681 + E F0 5.181(.T)C(yping)-5.981 E F1(C\255s)2.68 E F0 .18(searches forw) + 2.68 F .18(ard through the history)-.1 F(.)-.65 E .354 + (The characters present in the v)108 237.6 R .354(alue of the)-.25 F F1 + (isear)2.854 E(ch-terminators)-.18 E F0 -.25(va)2.854 G .354 + (riable are used to terminate an incremen-).25 F .6(tal search.)108 + 249.6 R .6(If that v)5.6 F .6(ariable has not been assigned a v)-.25 F + .6(alue the)-.25 F F2(Escape)3.1 E F0(and)3.1 E F1(C\255J)3.1 E F0 .6 + (characters will terminate an)3.1 F .122(incremental search.)108 261.6 R + F1(C\255G)5.122 E F0 .122 + (will abort an incremental search and restore the original line.)2.622 F + .123(When the search is)5.123 F(terminated, the history entry containin\ + g the search string becomes the current line.)108 273.6 Q 2.407 -.8 + (To \214)108 290.4 T .806 + (nd other matching entries in the history list, type).8 F F1(C\255s) + 3.306 E F0(or)3.306 E F1(C\255r)3.306 E F0 .806(as appropriate.)3.306 F + .806(This will search back-)5.806 F -.1(wa)108 302.4 S 1.308(rd or forw) + .1 F 1.309(ard in the history for the ne)-.1 F 1.309 + (xt line matching the search string typed so f)-.15 F(ar)-.1 E 6.309(.A) + -.55 G 1.609 -.15(ny o)-6.309 H 1.309(ther k).15 F -.15(ey)-.1 G .317 + (sequence bound to a readline command will terminate the search and e) + 108 314.4 R -.15(xe)-.15 G .317(cute that command.).15 F -.15(Fo)5.317 G + 2.817(ri).15 G(nstance,)-2.817 E 3.48(an)108 326.4 S -.25(ew)-3.48 G .98 + (line will terminate the search and accept the line, thereby e).25 F + -.15(xe)-.15 G .981(cuting the command from the history).15 F 3.062 + (list. A)108 338.4 R(mo)3.062 E -.15(ve)-.15 G .562 + (ment command will terminate the search, mak).15 F 3.062(et)-.1 G .562 + (he last line found the current line, and be)-3.062 F(gin)-.15 E + (editing.)108 350.4 Q .567(Non-incremental searches read the entire sea\ + rch string before starting to search for matching history lines.)108 + 367.2 R(The search string may be typed by the user or be part of the co\ + ntents of the current line.)108 379.2 Q F3(EDITING COMMANDS)72 396 Q F0 + 1.392(The follo)108 408 R 1.391 + (wing is a list of the names of the commands and the def)-.25 F 1.391 + (ault k)-.1 F 1.691 -.15(ey s)-.1 H 1.391(equences to which the).15 F + 3.891(ya)-.15 G(re)-3.891 E 2.5(bound. Command)108 420 R + (names without an accompan)2.5 E(ying k)-.15 E .3 -.15(ey s)-.1 H + (equence are unbound by def).15 E(ault.)-.1 E .054(In the follo)108 + 436.8 R .054(wing descriptions,)-.25 F F2(point)2.554 E F0 .055 + (refers to the current cursor position, and)2.554 F F2(mark)2.555 E F0 + .055(refers to a cursor position)2.555 F(sa)108 448.8 Q -.15(ve)-.2 G + 2.5(db).15 G 2.5(yt)-2.5 G(he)-2.5 E F1(set\255mark)2.5 E F0 2.5 + (command. The)2.5 F(te)2.5 E + (xt between the point and mark is referred to as the)-.15 E F2 -.37(re) + 2.5 G(gion)-.03 E F0(.)A F1(Commands f)87 465.6 Q(or Mo)-.25 E(ving)-.1 + E(beginning\255of\255line \(C\255a\))108 477.6 Q F0(Mo)144 489.6 Q .3 + -.15(ve t)-.15 H 2.5(ot).15 G(he start of the current line.)-2.5 E F1 + (end\255of\255line \(C\255e\))108 501.6 Q F0(Mo)144 513.6 Q .3 -.15 + (ve t)-.15 H 2.5(ot).15 G(he end of the line.)-2.5 E F1 -.25(fo)108 + 525.6 S(rward\255char \(C\255f\)).25 E F0(Mo)144 537.6 Q .3 -.15(ve f) + -.15 H(orw).15 E(ard a character)-.1 E(.)-.55 E F1 + (backward\255char \(C\255b\))108 549.6 Q F0(Mo)144 561.6 Q .3 -.15(ve b) + -.15 H(ack a character).15 E(.)-.55 E F1 -.25(fo)108 573.6 S(rward\255w) + .25 E(ord \(M\255f\))-.1 E F0(Mo)144 585.6 Q .823 -.15(ve f)-.15 H(orw) + .15 E .523(ard to the end of the ne)-.1 F .523(xt w)-.15 F 3.023(ord. W) + -.1 F .522(ords are composed of alphanumeric characters \(let-)-.8 F + (ters and digits\).)144 597.6 Q F1(backward\255w)108 609.6 Q + (ord \(M\255b\))-.1 E F0(Mo)144 621.6 Q 1.71 -.15(ve b)-.15 H 1.41 + (ack to the start of the current or pre).15 F 1.41(vious w)-.25 F 3.91 + (ord. W)-.1 F 1.41(ords are composed of alphanumeric)-.8 F + (characters \(letters and digits\).)144 633.6 Q F1(clear\255scr)108 + 645.6 Q(een \(C\255l\))-.18 E F0 .993(Clear the screen lea)144 657.6 R + .993(ving the current line at the top of the screen.)-.2 F -.4(Wi)5.993 + G .993(th an ar).4 F .993(gument, refresh the)-.18 F + (current line without clearing the screen.)144 669.6 Q F1 -.18(re)108 + 681.6 S(draw\255curr).18 E(ent\255line)-.18 E F0 + (Refresh the current line.)144 693.6 Q(GNU Readline 4.2)72 768 Q + (2001 Mar 5)135.96 E(5)205.67 E EP + %%Page: 6 6 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF 342.2(READLINE\(3\) READLINE\(3\))72 48 R/F1 10 + /Times-Bold@0 SF(Commands f)87 84 Q(or Manipulating the History)-.25 E + (accept\255line \(Newline, Retur)108 96 Q(n\))-.15 E F0 .364 + (Accept the line re)144 108 R -.05(ga)-.15 G .364 + (rdless of where the cursor is.).05 F .364(If this line is non-empty) + 5.364 F 2.864(,i)-.65 G 2.864(tm)-2.864 G .365(ay be added to the)-2.864 + F .741(history list for future recall with)144 120 R F1(add_history\(\)) + 3.241 E F0 5.741(.I)C 3.241(ft)-5.741 G .74 + (he line is a modi\214ed history line, the history)-3.241 F + (line is restored to its original state.)144 132 Q F1(pr)108 144 Q -.15 + (ev)-.18 G(ious\255history \(C\255p\)).15 E F0(Fetch the pre)144 156 Q + (vious command from the history list, mo)-.25 E(ving back in the list.) + -.15 E F1(next\255history \(C\255n\))108 168 Q F0(Fetch the ne)144 180 Q + (xt command from the history list, mo)-.15 E(ving forw)-.15 E + (ard in the list.)-.1 E F1(beginning\255of\255history \(M\255<\))108 192 + Q F0(Mo)144 204 Q .3 -.15(ve t)-.15 H 2.5(ot).15 G + (he \214rst line in the history)-2.5 E(.)-.65 E F1 + (end\255of\255history \(M\255>\))108 216 Q F0(Mo)144 228 Q .3 -.15(ve t) + -.15 H 2.5(ot).15 G(he end of the input history)-2.5 E 2.5(,i)-.65 G + (.e., the line currently being entered.)-2.5 E F1 -2.29 -.18(re v)108 + 240 T(erse\255sear).08 E(ch\255history \(C\255r\))-.18 E F0 1.47 + (Search backw)144 252 R 1.471(ard starting at the current line and mo) + -.1 F 1.471(ving `up' through the history as necessary)-.15 F(.)-.65 E + (This is an incremental search.)144 264 Q F1 -.25(fo)108 276 S + (rward\255sear).25 E(ch\255history \(C\255s\))-.18 E F0 1.132 + (Search forw)144 288 R 1.132(ard starting at the current line and mo)-.1 + F 1.131(ving `do)-.15 F 1.131(wn' through the history as necessary)-.25 + F(.)-.65 E(This is an incremental search.)144 300 Q F1(non\255incr)108 + 312 Q(emental\255r)-.18 E -2.3 -.15(ev e)-.18 H(rse\255sear).15 E + (ch\255history \(M\255p\))-.18 E F0 .164(Search backw)144 324 R .164(ar\ + d through the history starting at the current line using a non-incremen\ + tal search for)-.1 F 2.5(as)144 336 S(tring supplied by the user)-2.5 E + (.)-.55 E F1(non\255incr)108 348 Q(emental\255f)-.18 E(orward\255sear) + -.25 E(ch\255history \(M\255n\))-.18 E F0 1.354(Search forw)144 360 R + 1.354(ard through the history using a non-incremental search for a stri\ + ng supplied by the)-.1 F(user)144 372 Q(.)-.55 E F1(history\255sear)108 + 384 Q(ch\255f)-.18 E(orward)-.25 E F0 .248(Search forw)144 396 R .249(a\ + rd through the history for the string of characters between the start o\ + f the current line)-.1 F(and the current cursor position \(the)144 408 Q + /F2 10/Times-Italic@0 SF(point)2.5 E F0 2.5(\). This)B + (is a non-incremental search.)2.5 E F1(history\255sear)108 420 Q + (ch\255backward)-.18 E F0 .951(Search backw)144 432 R .951(ard through \ + the history for the string of characters between the start of the curre\ + nt)-.1 F(line and the point.)144 444 Q + (This is a non-incremental search.)5 E F1(yank\255nth\255ar)108 456 Q + 2.5(g\()-.1 G<4dad43ad7929>-2.5 E F0 .622(Insert the \214rst ar)144 468 + R .622(gument to the pre)-.18 F .622 + (vious command \(usually the second w)-.25 F .622(ord on the pre)-.1 F + .622(vious line\))-.25 F .795(at point.)144 480 R -.4(Wi)5.795 G .794 + (th an ar).4 F(gument)-.18 E F2(n)3.294 E F0 3.294(,i).24 G .794 + (nsert the)-3.294 F F2(n)3.294 E F0 .794(th w)B .794(ord from the pre) + -.1 F .794(vious command \(the w)-.25 F .794(ords in the)-.1 F(pre)144 + 492 Q .291(vious command be)-.25 F .291(gin with w)-.15 F .291(ord 0\).) + -.1 F 2.791(An)5.291 G -2.25 -.15(eg a)-2.791 H(ti).15 E .591 -.15(ve a) + -.25 H -.18(rg).15 G .291(ument inserts the).18 F F2(n)2.791 E F0 .291 + (th w)B .292(ord from the end of)-.1 F(the pre)144 504 Q(vious command.) + -.25 E F1(yank\255last\255ar)108 516 Q 2.5(g\()-.1 G -1.667(M\255. ,) + -2.5 F -1.667(M\255_ \))2.5 F F0 1.308(Insert the last ar)144 528 R + 1.308(gument to the pre)-.18 F 1.307(vious command \(the last w)-.25 F + 1.307(ord of the pre)-.1 F 1.307(vious history entry\).)-.25 F -.4(Wi) + 144 540 S .735(th an ar).4 F .735(gument, beha)-.18 F 1.035 -.15(ve ex) + -.2 H .735(actly lik).15 F(e)-.1 E F1(yank\255nth\255ar)3.235 E(g)-.1 E + F0 5.736(.S)C(uccessi)-5.736 E 1.036 -.15(ve c)-.25 H .736(alls to).15 F + F1(yank\255last\255ar)3.236 E(g)-.1 E F0(mo)3.236 E -.15(ve)-.15 G + (back through the history list, inserting the last ar)144 552 Q + (gument of each line in turn.)-.18 E F1(Commands f)87 568.8 Q + (or Changing T)-.25 E(ext)-.92 E(delete\255char \(C\255d\))108 580.8 Q + F0 .358(Delete the character at point.)144 592.8 R .358 + (If point is at the be)5.358 F .358 + (ginning of the line, there are no characters in the)-.15 F + (line, and the last character typed w)144 604.8 Q(as not bound to)-.1 E + F1(delete\255char)2.5 E F0 2.5(,t)C(hen return)-2.5 E/F3 9/Times-Bold@0 + SF(EOF)2.5 E/F4 9/Times-Roman@0 SF(.)A F1 + (backward\255delete\255char \(Rubout\))108 616.8 Q F0 .552 + (Delete the character behind the cursor)144 628.8 R 5.553(.W)-.55 G .553 + (hen gi)-5.553 F -.15(ve)-.25 G 3.053(nan).15 G .553(umeric ar)-3.053 F + .553(gument, sa)-.18 F .853 -.15(ve t)-.2 H .553(he deleted te).15 F + .553(xt on)-.15 F(the kill ring.)144 640.8 Q F1 -.25(fo)108 652.8 S + (rward\255backward\255delete\255char).25 E F0 .474 + (Delete the character under the cursor)144 664.8 R 2.974(,u)-.4 G .474 + (nless the cursor is at the end of the line, in which case the)-2.974 F + (character behind the cursor is deleted.)144 676.8 Q F1 + (quoted\255insert \(C\255q, C\255v\))108 688.8 Q F0 1.228(Add the ne)144 + 700.8 R 1.228(xt character that you type to the line v)-.15 F 3.728 + (erbatim. This)-.15 F 1.228(is ho)3.728 F 3.729(wt)-.25 G 3.729(oi) + -3.729 G 1.229(nsert characters lik)-3.729 F(e)-.1 E F1(C\255q)144 712.8 + Q F0 2.5(,f)C(or e)-2.5 E(xample.)-.15 E(GNU Readline 4.2)72 768 Q + (2001 Mar 5)135.96 E(6)205.67 E EP + %%Page: 7 7 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF 342.2(READLINE\(3\) READLINE\(3\))72 48 R/F1 10 + /Times-Bold@0 SF(tab\255insert \(M-T)108 84 Q(AB\))-.9 E F0 + (Insert a tab character)144 96 Q(.)-.55 E F1 + (self\255insert \(a, b, A, 1, !, ...\))108 108 Q F0 + (Insert the character typed.)144 120 Q F1(transpose\255chars \(C\255t\)) + 108 132 Q F0 .322(Drag the character before point forw)144 144 R .321 + (ard o)-.1 F -.15(ve)-.15 G 2.821(rt).15 G .321 + (he character at point, mo)-2.821 F .321(ving point forw)-.15 F .321 + (ard as well.)-.1 F 1.182 + (If point is at the end of the line, then this transposes the tw)144 156 + R 3.683(oc)-.1 G 1.183(haracters before point.)-3.683 F(Ne)6.183 E -.05 + (ga)-.15 G(ti).05 E -.15(ve)-.25 G(ar)144 168 Q(guments ha)-.18 E .3 + -.15(ve n)-.2 H 2.5(oe).15 G -.25(ff)-2.5 G(ect.).25 E F1 + (transpose\255w)108 180 Q(ords \(M\255t\))-.1 E F0(Drag the w)144 192 Q + (ord before point past the w)-.1 E(ord after point, mo)-.1 E + (ving point o)-.15 E -.15(ve)-.15 G 2.5(rt).15 G(hat w)-2.5 E + (ord as well.)-.1 E F1(upcase\255w)108 204 Q(ord \(M\255u\))-.1 E F0 + 1.699(Uppercase the current \(or follo)144 216 R 1.698(wing\) w)-.25 F + 4.198(ord. W)-.1 F 1.698(ith a ne)-.4 F -.05(ga)-.15 G(ti).05 E 1.998 + -.15(ve a)-.25 H -.18(rg).15 G 1.698(ument, uppercase the pre).18 F + (vious)-.25 E -.1(wo)144 228 S(rd, b).1 E(ut do not mo)-.2 E .3 -.15 + (ve p)-.15 H(oint.).15 E F1(do)108 240 Q(wncase\255w)-.1 E + (ord \(M\255l\))-.1 E F0(Lo)144 252 Q 1.647 + (wercase the current \(or follo)-.25 F 1.647(wing\) w)-.25 F 4.147 + (ord. W)-.1 F 1.648(ith a ne)-.4 F -.05(ga)-.15 G(ti).05 E 1.948 -.15 + (ve a)-.25 H -.18(rg).15 G 1.648(ument, lo).18 F 1.648(wercase the pre) + -.25 F(vious)-.25 E -.1(wo)144 264 S(rd, b).1 E(ut do not mo)-.2 E .3 + -.15(ve p)-.15 H(oint.).15 E F1(capitalize\255w)108 276 Q + (ord \(M\255c\))-.1 E F0 1.975(Capitalize the current \(or follo)144 288 + R 1.974(wing\) w)-.25 F 4.474(ord. W)-.1 F 1.974(ith a ne)-.4 F -.05(ga) + -.15 G(ti).05 E 2.274 -.15(ve a)-.25 H -.18(rg).15 G 1.974 + (ument, capitalize the pre).18 F(vious)-.25 E -.1(wo)144 300 S(rd, b).1 + E(ut do not mo)-.2 E .3 -.15(ve p)-.15 H(oint.).15 E F1(Killing and Y)87 + 316.8 Q(anking)-.85 E(kill\255line \(C\255k\))108 328.8 Q F0 + (Kill the te)144 340.8 Q(xt from point to the end of the line.)-.15 E F1 + (backward\255kill\255line \(C\255x Rubout\))108 352.8 Q F0(Kill backw) + 144 364.8 Q(ard to the be)-.1 E(ginning of the line.)-.15 E F1 + (unix\255line\255discard \(C\255u\))108 376.8 Q F0(Kill backw)144 388.8 + Q(ard from point to the be)-.1 E(ginning of the line.)-.15 E + (The killed te)5 E(xt is sa)-.15 E -.15(ve)-.2 G 2.5(do).15 G 2.5(nt) + -2.5 G(he kill-ring.)-2.5 E F1(kill\255whole\255line)108 400.8 Q F0 + (Kill all characters on the current line, no matter where point is.)144 + 412.8 Q F1(kill\255w)108 424.8 Q(ord \(M\255d\))-.1 E F0 1.308 + (Kill from point the end of the current w)144 436.8 R 1.308 + (ord, or if between w)-.1 F 1.308(ords, to the end of the ne)-.1 F 1.308 + (xt w)-.15 F(ord.)-.1 E -.8(Wo)144 448.8 S + (rd boundaries are the same as those used by).8 E F1 -.25(fo)2.5 G + (rward\255w).25 E(ord)-.1 E F0(.)A F1(backward\255kill\255w)108 460.8 Q + (ord \(M\255Rubout\))-.1 E F0(Kill the w)144 472.8 Q(ord behind point.) + -.1 E -.8(Wo)5 G(rd boundaries are the same as those used by).8 E F1 + (backward\255w)2.5 E(ord)-.1 E F0(.)A F1(unix\255w)108 484.8 Q + (ord\255rubout \(C\255w\))-.1 E F0 .365(Kill the w)144 496.8 R .365 + (ord behind point, using white space as a w)-.1 F .364(ord boundary)-.1 + F 5.364(.T)-.65 G .364(he killed te)-5.364 F .364(xt is sa)-.15 F -.15 + (ve)-.2 G 2.864(do).15 G 2.864(nt)-2.864 G(he)-2.864 E(kill-ring.)144 + 508.8 Q F1(delete\255horizontal\255space \(M\255\\\))108 520.8 Q F0 + (Delete all spaces and tabs around point.)144 532.8 Q F1(kill\255r)108 + 544.8 Q(egion)-.18 E F0 1.13(Kill the te)144 556.8 R 1.13 + (xt between the point and)-.15 F/F2 10/Times-Italic@0 SF(mark)3.63 E F0 + (\(sa)3.63 E -.15(ve)-.2 G 3.63(dc).15 G 1.13(ursor position\).)-3.63 F + 1.13(This te)6.13 F 1.13(xt is referred to as the)-.15 F F2 -.37(re)144 + 568.8 S(gion)-.03 E F0(.)A F1(copy\255r)108 580.8 Q(egion\255as\255kill) + -.18 E F0(Cop)144 592.8 Q 2.5(yt)-.1 G(he te)-2.5 E(xt in the re)-.15 E + (gion to the kill b)-.15 E(uf)-.2 E(fer)-.25 E(.)-.55 E F1 + (copy\255backward\255w)108 604.8 Q(ord)-.1 E F0(Cop)144 616.8 Q 4.801 + (yt)-.1 G 2.301(he w)-4.801 F 2.301(ord before point to the kill b)-.1 F + (uf)-.2 E(fer)-.25 E 7.301(.T)-.55 G 2.301(he w)-7.301 F 2.3 + (ord boundaries are the same as)-.1 F F1(back-)4.8 E(ward\255w)144 628.8 + Q(ord)-.1 E F0(.)A F1(copy\255f)108 640.8 Q(orward\255w)-.25 E(ord)-.1 E + F0(Cop)144 652.8 Q 4.507(yt)-.1 G 2.007(he w)-4.507 F 2.007(ord follo) + -.1 F 2.007(wing point to the kill b)-.25 F(uf)-.2 E(fer)-.25 E 7.008 + (.T)-.55 G 2.008(he w)-7.008 F 2.008(ord boundaries are the same as)-.1 + F F1 -.25(fo)4.508 G -.37(r-).25 G(ward\255w)144 664.8 Q(ord)-.1 E F0(.) + A F1(yank \(C\255y\))108 676.8 Q F0 -1(Ya)144 688.8 S + (nk the top of the kill ring into the b)1 E(uf)-.2 E(fer at point.)-.25 + E F1(yank\255pop \(M\255y\))108 700.8 Q F0 + (Rotate the kill ring, and yank the ne)144 712.8 Q 2.5(wt)-.25 G 2.5 + (op. Only)-2.5 F -.1(wo)2.5 G(rks follo).1 E(wing)-.25 E F1(yank)2.5 E + F0(or)2.5 E F1(yank\255pop)2.5 E F0(.)A(GNU Readline 4.2)72 768 Q + (2001 Mar 5)135.96 E(7)205.67 E EP + %%Page: 8 8 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF 342.2(READLINE\(3\) READLINE\(3\))72 48 R/F1 10 + /Times-Bold@0 SF(Numeric Ar)87 84 Q(guments)-.1 E(digit\255ar)108 96 Q + (gument \(M\2550, M\2551, ..., M\255\255\))-.1 E F0 .642 + (Add this digit to the ar)144 108 R .641 + (gument already accumulating, or start a ne)-.18 F 3.141(wa)-.25 G -.18 + (rg)-3.141 G 3.141(ument. M\255\255).18 F .641(starts a ne)3.141 F(g-) + -.15 E(ati)144 120 Q .3 -.15(ve a)-.25 H -.18(rg).15 G(ument.).18 E F1 + (uni)108 132 Q -.1(ve)-.1 G(rsal\255ar).1 E(gument)-.1 E F0 .778 + (This is another w)144 144 R .779(ay to specify an ar)-.1 F 3.279 + (gument. If)-.18 F .779(this command is follo)3.279 F .779 + (wed by one or more digits,)-.25 F 1.376 + (optionally with a leading minus sign, those digits de\214ne the ar)144 + 156 R 3.876(gument. If)-.18 F 1.376(the command is fol-)3.876 F(lo)144 + 168 Q 1.17(wed by digits, e)-.25 F -.15(xe)-.15 G(cuting).15 E F1(uni) + 3.67 E -.1(ve)-.1 G(rsal\255ar).1 E(gument)-.1 E F0(ag)3.67 E 1.17 + (ain ends the numeric ar)-.05 F 1.17(gument, b)-.18 F 1.17(ut is other) + -.2 F(-)-.2 E .899(wise ignored.)144 180 R .898 + (As a special case, if this command is immediately follo)5.899 F .898 + (wed by a character that is)-.25 F .243 + (neither a digit or minus sign, the ar)144 192 R .243 + (gument count for the ne)-.18 F .243(xt command is multiplied by four) + -.15 F 5.243(.T)-.55 G(he)-5.243 E(ar)144 204 Q .378 + (gument count is initially one, so e)-.18 F -.15(xe)-.15 G .378 + (cuting this function the \214rst time mak).15 F .378(es the ar)-.1 F + .378(gument count)-.18 F(four)144 216 Q 2.5(,as)-.4 G(econd time mak) + -2.5 E(es the ar)-.1 E(gument count sixteen, and so on.)-.18 E F1 + (Completing)87 232.8 Q(complete \(T)108 244.8 Q(AB\))-.9 E F0 1.908 + (Attempt to perform completion on the te)144 256.8 R 1.908 + (xt before point.)-.15 F 1.909(The actual completion performed is)6.909 + F(application-speci\214c.)144 268.8 Q F1(Bash)5.518 E F0 3.018(,f)C .518 + (or instance, attempts completion treating the te)-3.018 F .517 + (xt as a v)-.15 F .517(ariable \(if the)-.25 F(te)144 280.8 Q .656 + (xt be)-.15 F .656(gins with)-.15 F F1($)3.156 E F0 .656 + (\), username \(if the te)B .656(xt be)-.15 F .656(gins with)-.15 F F1 + (~)3.156 E F0 .656(\), hostname \(if the te)B .656(xt be)-.15 F .656 + (gins with)-.15 F F1(@)3.157 E F0 .657(\), or)B .93 + (command \(including aliases and functions\) in turn.)144 292.8 R .929 + (If none of these produces a match, \214lename)5.929 F 1.273 + (completion is attempted.)144 304.8 R F1(Gdb)6.273 E F0 3.773(,o)C 3.773 + (nt)-3.773 G 1.273(he other hand, allo)-3.773 F 1.273 + (ws completion of program functions and)-.25 F -.25(va)144 316.8 S(riab\ + les, and only attempts \214lename completion under certain circumstance\ + s.).25 E F1(possible\255completions \(M\255?\))108 328.8 Q F0 + (List the possible completions of the te)144 340.8 Q(xt before point.) + -.15 E F1(insert\255completions \(M\255*\))108 352.8 Q F0 .783 + (Insert all completions of the te)144 364.8 R .783 + (xt before point that w)-.15 F .783(ould ha)-.1 F 1.083 -.15(ve b)-.2 H + .783(een generated by).15 F F1(possible\255com-)3.282 E(pletions)144 + 376.8 Q F0(.)A F1(menu\255complete)108 388.8 Q F0 .928(Similar to)144 + 400.8 R F1(complete)3.428 E F0 3.428(,b)C .929(ut replaces the w)-3.628 + F .929(ord to be completed with a single match from the list of)-.1 F + 1.194(possible completions.)144 412.8 R 1.194(Repeated e)6.194 F -.15 + (xe)-.15 G 1.194(cution of).15 F F1(menu\255complete)3.694 E F0 1.193 + (steps through the list of possible)3.694 F .828 + (completions, inserting each match in turn.)144 424.8 R .828 + (At the end of the list of completions, the bell is rung)5.828 F 1.927 + (\(subject to the setting of Bbell\255style)144 436.8 R F1 4.427(\)a)C + 1.927(nd the original text is r)-4.427 F(estor)-.18 E 4.426(ed. An)-.18 + F(ar)4.426 E 1.926(gument of)-.1 F/F2 10/Times-Italic@0 SF(n)4.426 E F1 + (mo)144 448.8 Q -.1(ve)-.1 G(s).1 E F2(n)3.145 E F1 .645(positions f) + 3.145 F .645(orward in the list of matches; a negati)-.25 F .845 -.1 + (ve a)-.1 H -.1(rg).1 G .645(ument may be used to mo).1 F -.1(ve)-.1 G + .666(backward thr)144 460.8 R .666(ough the list.)-.18 F .665 + (This command is intended to be bound to T)5.666 F .665(AB, b)-.9 F .665 + (ut is unbound)-.2 F(by default.)144 472.8 Q + (delete\255char\255or\255list)108 484.8 Q F0 .373 + (Deletes the character under the cursor if not at the be)144 496.8 R + .374(ginning or end of the line \(lik)-.15 F(e)-.1 E F1(delete-char) + 2.874 E F0(\).)A(If at the end of the line, beha)144 508.8 Q -.15(ve)-.2 + G 2.5(si).15 G(dentically to)-2.5 E F1(possible-completions)2.5 E F0(.)A + F1 -.25(Ke)87 525.6 S(yboard Macr).25 E(os)-.18 E(start\255kbd\255macr) + 108 537.6 Q 2.5(o\()-.18 G(C\255x \()-2.5 E(\)).833 E F0(Be)144 549.6 Q + (gin sa)-.15 E(ving the characters typed into the current k)-.2 E -.15 + (ey)-.1 G(board macro.).15 E F1(end\255kbd\255macr)108 561.6 Q 2.5(o\() + -.18 G(C\255x \))-2.5 E(\)).833 E F0(Stop sa)144 573.6 Q + (ving the characters typed into the current k)-.2 E -.15(ey)-.1 G + (board macro and store the de\214nition.).15 E F1 + (call\255last\255kbd\255macr)108 585.6 Q 2.5(o\()-.18 G(C\255x e\))-2.5 + E F0(Re-e)144 597.6 Q -.15(xe)-.15 G 1(cute the last k).15 F -.15(ey)-.1 + G .999(board macro de\214ned, by making the characters in the macro app\ + ear as if).15 F(typed at the k)144 609.6 Q -.15(ey)-.1 G(board.).15 E F1 + (Miscellaneous)87 626.4 Q -.18(re)108 638.4 S.18 E + (ead\255init\255\214le \(C\255x C\255r\))-.18 E F0 1.776 + (Read in the contents of the)144 650.4 R F2(inputr)4.276 E(c)-.37 E F0 + 1.777(\214le, and incorporate an)4.276 F 4.277(yb)-.15 G 1.777 + (indings or v)-4.277 F 1.777(ariable assignments)-.25 F(found there.)144 + 662.4 Q F1(abort \(C\255g\))108 674.4 Q F0 3.249 + (Abort the current editing command and ring the terminal')144 686.4 R + 5.748(sb)-.55 G 3.248(ell \(subject to the setting of)-5.748 F F1 + (bell\255style)144 698.4 Q F0(\).)A(GNU Readline 4.2)72 768 Q + (2001 Mar 5)135.96 E(8)205.67 E EP + %%Page: 9 9 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF 342.2(READLINE\(3\) READLINE\(3\))72 48 R/F1 10 + /Times-Bold@0 SF(do\255upper)108 84 Q(case\255v)-.18 E + (ersion \(M\255a, M\255b, M\255)-.1 E/F2 10/Times-Italic@0 SF(x)A F1 2.5 + (,.)C(..\))-2.5 E F0 1.755(If the meta\214ed character)144 96 R F2(x) + 4.255 E F0 1.755(is lo)4.255 F 1.756 + (wercase, run the command that is bound to the corresponding)-.25 F + (uppercase character)144 108 Q(.)-.55 E F1(pr)108 120 Q + (e\214x\255meta \(ESC\))-.18 E F0(Metafy the ne)144 132 Q + (xt character typed.)-.15 E/F3 9/Times-Bold@0 SF(ESC)5 E F1(f)2.25 E F0 + (is equi)2.5 E -.25(va)-.25 G(lent to).25 E F1(Meta\255f)2.5 E F0(.)A F1 + (undo \(C\255_, C\255x C\255u\))108 144 Q F0 + (Incremental undo, separately remembered for each line.)144 156 Q F1 + -2.29 -.18(re v)108 168 T(ert\255line \(M\255r\)).08 E F0 1.095 + (Undo all changes made to this line.)144 180 R 1.095(This is lik)6.095 F + 3.595(ee)-.1 G -.15(xe)-3.745 G 1.095(cuting the).15 F F1(undo)3.595 E + F0 1.095(command enough times to)3.595 F + (return the line to its initial state.)144 192 Q F1 + (tilde\255expand \(M\255&\))108 204 Q F0(Perform tilde e)144 216 Q + (xpansion on the current w)-.15 E(ord.)-.1 E F1 + (set\255mark \(C\255@, M\255\))108 228 Q F0 + (Set the mark to the point.)144 240 Q(If a numeric ar)5 E + (gument is supplied, the mark is set to that position.)-.18 E F1 + (exchange\255point\255and\255mark \(C\255x C\255x\))108 252 Q F0(Sw)144 + 264 Q .282(ap the point with the mark.)-.1 F .283 + (The current cursor position is set to the sa)5.283 F -.15(ve)-.2 G + 2.783(dp).15 G .283(osition, and the old)-2.783 F(cursor position is sa) + 144 276 Q -.15(ve)-.2 G 2.5(da).15 G 2.5(st)-2.5 G(he mark.)-2.5 E F1 + (character\255sear)108 288 Q(ch \(C\255]\))-.18 E F0 3.036(Ac)144 300 S + .536(haracter is read and point is mo)-3.036 F -.15(ve)-.15 G 3.035(dt) + .15 G 3.035(ot)-3.035 G .535(he ne)-3.035 F .535 + (xt occurrence of that character)-.15 F 5.535(.A)-.55 G(ne)-2.5 E -.05 + (ga)-.15 G(ti).05 E .835 -.15(ve c)-.25 H(ount).15 E(searches for pre) + 144 312 Q(vious occurrences.)-.25 E F1(character\255sear)108 324 Q + (ch\255backward \(M\255C\255]\))-.18 E F0 3.543(Ac)144 336 S 1.043 + (haracter is read and point is mo)-3.543 F -.15(ve)-.15 G 3.544(dt).15 G + 3.544(ot)-3.544 G 1.044(he pre)-3.544 F 1.044 + (vious occurrence of that character)-.25 F 6.044(.A)-.55 G(ne)-2.5 E + -.05(ga)-.15 G(ti).05 E -.15(ve)-.25 G + (count searches for subsequent occurrences.)144 348 Q F1 + (insert\255comment \(M\255#\))108 360 Q F0 .291(The v)144 372 R .291 + (alue of the readline)-.25 F F1(comment\255begin)2.791 E F0 -.25(va) + 2.791 G .291(riable is inserted at the be).25 F .29 + (ginning of the current line,)-.15 F 1.277 + (and the line is accepted as if a ne)144 384 R 1.277 + (wline had been typed.)-.25 F 1.277(The def)6.277 F 1.277(ault v)-.1 F + 1.277(alue of)-.25 F F1(comment\255begin)3.777 E F0(mak)144 396 Q + (es the current line a shell comment.)-.1 E F1(dump\255functions)108 408 + Q F0 .627(Print all of the functions and their k)144 420 R .927 -.15 + (ey b)-.1 H .626(indings to the readline output stream.).15 F .626 + (If a numeric ar)5.626 F(gu-)-.18 E + (ment is supplied, the output is formatted in such a w)144 432 Q + (ay that it can be made part of an)-.1 E F2(inputr)2.5 E(c)-.37 E F0 + (\214le.)2.5 E F1(dump\255v)108 444 Q(ariables)-.1 E F0 .283 + (Print all of the settable v)144 456 R .283(ariables and their v)-.25 F + .283(alues to the readline output stream.)-.25 F .283(If a numeric ar) + 5.283 F(gu-)-.18 E + (ment is supplied, the output is formatted in such a w)144 468 Q + (ay that it can be made part of an)-.1 E F2(inputr)2.5 E(c)-.37 E F0 + (\214le.)2.5 E F1(dump\255macr)108 480 Q(os)-.18 E F0 .756 + (Print all of the readline k)144 492 R 1.056 -.15(ey s)-.1 H .756 + (equences bound to macros and the strings the).15 F 3.256(yo)-.15 G + 3.256(uput. If)-3.256 F 3.255(an)3.255 G(umeric)-3.255 E(ar)144 504 Q + .528(gument is supplied, the output is formatted in such a w)-.18 F .528 + (ay that it can be made part of an)-.1 F F2(inputr)3.028 E(c)-.37 E F0 + (\214le.)144 516 Q F1(emacs\255editing\255mode \(C\255e\))108 528 Q F0 + (When in)144 540 Q F1(vi)2.5 E F0(editing mode, this causes a switch to) + 2.5 E F1(emacs)2.5 E F0(editing mode.)2.5 E F1 + (vi\255editing\255mode \(M\255C\255j\))108 552 Q F0(When in)144 564 Q F1 + (emacs)2.5 E F0(editing mode, this causes a switch to)2.5 E F1(vi)2.5 E + F0(editing mode.)2.5 E/F4 10.95/Times-Bold@0 SF(DEF)72 580.8 Q -.548(AU) + -.986 G 2.014 -1.007(LT K).548 H(EY BINDINGS)1.007 E F0 .065(The follo) + 108 592.8 R .065(wing is a list of the def)-.25 F .065 + (ault emacs and vi bindings.)-.1 F .064 + (Characters with the eighth bit set are written as)5.064 F .615 + (M\255, and are referred to as)108 604.8 R F2(meta\214ed) + 3.115 E F0 3.115(characters. The)3.115 F .616 + (printable ASCII characters not mentioned)3.116 F 1.116 + (in the list of emacs standard bindings are bound to the)108 616.8 R F1 + (self\255insert)3.615 E F0 1.115(function, which just inserts the gi) + 3.615 F -.15(ve)-.25 G(n).15 E .945(character into the input line.)108 + 628.8 R .945(In vi insertion mode, all characters not speci\214cally me\ + ntioned are bound to)5.945 F F1(self\255insert)108 640.8 Q F0 5.359(.C)C + .359(haracters assigned to signal generation by)-5.359 F F2(stty)2.859 E + F0 .359(\(1\) or the terminal dri).32 F -.15(ve)-.25 G 1.159 -.4(r, s) + .15 H .358(uch as C-Z or C-C,).4 F .187(retain that function.)108 652.8 + R .187(Upper and lo)5.187 F .188(wer case meta\214ed characters are bou\ + nd to the same function in the emacs)-.25 F .305(mode meta k)108 664.8 R + -.15(ey)-.1 G 2.805(map. The).15 F .305(remaining characters are unboun\ + d, which causes readline to ring the bell \(subject)2.805 F + (to the setting of the)108 676.8 Q F1(bell\255style)2.5 E F0 -.25(va)2.5 + G(riable\).).25 E F1(Emacs Mode)87 693.6 Q F0(Emacs Standard bindings) + 151.2 705.6 Q 2.5("C-@" set-mark)151.2 729.6 R(GNU Readline 4.2)72 768 Q + (2001 Mar 5)135.96 E(9)205.67 E EP + %%Page: 10 10 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF 342.2(READLINE\(3\) READLINE\(3\))72 48 R 2.5 + ("C-A" be)151.2 84 R(ginning-of-line)-.15 E 2.5("C-B" backw)151.2 96 R + (ard-char)-.1 E 2.5("C-D" delete-char)151.2 108 R 2.5("C-E" end-of-line) + 151.2 120 R 2.5("C-F" forw)151.2 132 R(ard-char)-.1 E 2.5("C-G" abort) + 151.2 144 R 2.5("C-H" backw)151.2 156 R(ard-delete-char)-.1 E 2.5 + ("C-I" complete)151.2 168 R 2.5("C-J" accept-line)151.2 180 R 2.5 + ("C-K" kill-line)151.2 192 R 2.5("C-L" clear)151.2 204 R(-screen)-.2 E + 2.5("C-M" accept-line)151.2 216 R 2.5("C-N" ne)151.2 228 R(xt-history) + -.15 E 2.5("C-P" pre)151.2 240 R(vious-history)-.25 E 2.5 + ("C-Q" quoted-insert)151.2 252 R 2.5("C-R" re)151.2 264 R -.15(ve)-.25 G + (rse-search-history).15 E 2.5("C-S" forw)151.2 276 R(ard-search-history) + -.1 E 2.5("C-T" transpose-chars)151.2 288 R 2.5("C-U" unix-line-discard) + 151.2 300 R 2.5("C-V" quoted-insert)151.2 312 R 2.5("C-W" unix-w)151.2 + 324 R(ord-rubout)-.1 E 2.5("C-Y" yank)151.2 336 R 2.5("C-]" character) + 151.2 348 R(-search)-.2 E 2.5("C-_" undo)151.2 360 R 3.333("")151.2 372 + S(to "/")-.833 E(self-insert)5 E 2.5("0" to)151.2 384 R 2.5 + ("9" self-insert)2.5 F 2.5(":" to)151.2 396 R 2.5("~" self-insert)2.5 F + 2.5("C-?" backw)151.2 408 R(ard-delete-char)-.1 E(Emacs Meta bindings) + 151.2 424.8 Q 2.5("M-C-G" abort)151.2 448.8 R 2.5("M-C-H" backw)151.2 + 460.8 R(ard-kill-w)-.1 E(ord)-.1 E 2.5("M-C-I" tab-insert)151.2 472.8 R + 2.5("M-C-J" vi-editing-mode)151.2 484.8 R 2.5("M-C-M" vi-editing-mode) + 151.2 496.8 R 2.5("M-C-R" re)151.2 508.8 R -.15(ve)-.25 G(rt-line).15 E + 2.5("M-C-Y" yank-nth-ar)151.2 520.8 R(g)-.18 E 2.5("M-C-[" complete) + 151.2 532.8 R 2.5("M-C-]" character)151.2 544.8 R(-search-backw)-.2 E + (ard)-.1 E 2.5("M-space" set-mark)151.2 556.8 R 2.5 + ("M-#" insert-comment)151.2 568.8 R 2.5("M-&" tilde-e)151.2 580.8 R + (xpand)-.15 E 2.5("M-*" insert-completions)151.2 592.8 R 2.5 + ("M--" digit-ar)151.2 604.8 R(gument)-.18 E 2.5("M-." yank-last-ar)151.2 + 616.8 R(g)-.18 E 2.5("M-0" digit-ar)151.2 628.8 R(gument)-.18 E 2.5 + ("M-1" digit-ar)151.2 640.8 R(gument)-.18 E 2.5("M-2" digit-ar)151.2 + 652.8 R(gument)-.18 E 2.5("M-3" digit-ar)151.2 664.8 R(gument)-.18 E 2.5 + ("M-4" digit-ar)151.2 676.8 R(gument)-.18 E 2.5("M-5" digit-ar)151.2 + 688.8 R(gument)-.18 E 2.5("M-6" digit-ar)151.2 700.8 R(gument)-.18 E 2.5 + ("M-7" digit-ar)151.2 712.8 R(gument)-.18 E 2.5("M-8" digit-ar)151.2 + 724.8 R(gument)-.18 E(GNU Readline 4.2)72 768 Q(2001 Mar 5)135.96 E(10) + 200.67 E EP + %%Page: 11 11 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF 342.2(READLINE\(3\) READLINE\(3\))72 48 R 2.5 + ("M-9" digit-ar)151.2 84 R(gument)-.18 E 2.5("M-<" be)151.2 96 R + (ginning-of-history)-.15 E 2.5("M-=" possible-completions)151.2 108 R + 2.5("M->" end-of-history)151.2 120 R 2.5("M-?" possible-completions) + 151.2 132 R 2.5("M-B" backw)151.2 144 R(ard-w)-.1 E(ord)-.1 E 2.5 + ("M-C" capitalize-w)151.2 156 R(ord)-.1 E 2.5("M-D" kill-w)151.2 168 R + (ord)-.1 E 2.5("M-F" forw)151.2 180 R(ard-w)-.1 E(ord)-.1 E 2.5 + ("M-L" do)151.2 192 R(wncase-w)-.25 E(ord)-.1 E 2.5 + ("M-N" non-incremental-forw)151.2 204 R(ard-search-history)-.1 E 2.5 + ("M-P" non-incremental-re)151.2 216 R -.15(ve)-.25 G(rse-search-history) + .15 E 2.5("M-R" re)151.2 228 R -.15(ve)-.25 G(rt-line).15 E 2.5 + ("M-T" transpose-w)151.2 240 R(ords)-.1 E 2.5("M-U" upcase-w)151.2 252 R + (ord)-.1 E 2.5("M-Y" yank-pop)151.2 264 R 2.5 + ("M-\\" delete-horizontal-space)151.2 276 R 2.5("M-~" tilde-e)151.2 288 + R(xpand)-.15 E 2.5("M-C-?" backw)151.2 300 R(ard-kill-w)-.1 E(ord)-.1 E + 2.5("M-_" yank-last-ar)151.2 312 R(g)-.18 E(Emacs Control-X bindings) + 151.2 328.8 Q 2.5("C-XC-G" abort)151.2 352.8 R 2.5 + ("C-XC-R" re-read-init-\214le)151.2 364.8 R 2.5("C-XC-U" undo)151.2 + 376.8 R 2.5("C-XC-X" e)151.2 388.8 R(xchange-point-and-mark)-.15 E 2.5 + ("C-X\(" start-kbd-macro)151.2 400.8 R 2.5("C-X\)" end-kbd-macro)151.2 + 412.8 R 2.5("C-XE" call-last-kbd-macro)151.2 424.8 R 2.5("C-XC-?" backw) + 151.2 436.8 R(ard-kill-line)-.1 E/F1 10/Times-Bold@0 SF + (VI Mode bindings)87 465.6 Q F0(VI Insert Mode functions)151.2 477.6 Q + 2.5("C-D" vi-eof-maybe)151.2 501.6 R 2.5("C-H" backw)151.2 513.6 R + (ard-delete-char)-.1 E 2.5("C-I" complete)151.2 525.6 R 2.5 + ("C-J" accept-line)151.2 537.6 R 2.5("C-M" accept-line)151.2 549.6 R 2.5 + ("C-R" re)151.2 561.6 R -.15(ve)-.25 G(rse-search-history).15 E 2.5 + ("C-S" forw)151.2 573.6 R(ard-search-history)-.1 E 2.5 + ("C-T" transpose-chars)151.2 585.6 R 2.5("C-U" unix-line-discard)151.2 + 597.6 R 2.5("C-V" quoted-insert)151.2 609.6 R 2.5("C-W" unix-w)151.2 + 621.6 R(ord-rubout)-.1 E 2.5("C-Y" yank)151.2 633.6 R 2.5("C-[" vi-mo) + 151.2 645.6 R -.15(ve)-.15 G(ment-mode).15 E 2.5("C-_" undo)151.2 657.6 + R 3.333("")151.2 669.6 S(to "~")-.833 E(self-insert)5 E 2.5("C-?" backw) + 151.2 681.6 R(ard-delete-char)-.1 E(VI Command Mode functions)151.2 + 698.4 Q 2.5("C-D" vi-eof-maybe)151.2 722.4 R(GNU Readline 4.2)72 768 Q + (2001 Mar 5)135.96 E(11)200.67 E EP + %%Page: 12 12 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF 342.2(READLINE\(3\) READLINE\(3\))72 48 R 2.5 + ("C-E" emacs-editing-mode)151.2 84 R 2.5("C-G" abort)151.2 96 R 2.5 + ("C-H" backw)151.2 108 R(ard-char)-.1 E 2.5("C-J" accept-line)151.2 120 + R 2.5("C-K" kill-line)151.2 132 R 2.5("C-L" clear)151.2 144 R(-screen) + -.2 E 2.5("C-M" accept-line)151.2 156 R 2.5("C-N" ne)151.2 168 R + (xt-history)-.15 E 2.5("C-P" pre)151.2 180 R(vious-history)-.25 E 2.5 + ("C-Q" quoted-insert)151.2 192 R 2.5("C-R" re)151.2 204 R -.15(ve)-.25 G + (rse-search-history).15 E 2.5("C-S" forw)151.2 216 R(ard-search-history) + -.1 E 2.5("C-T" transpose-chars)151.2 228 R 2.5("C-U" unix-line-discard) + 151.2 240 R 2.5("C-V" quoted-insert)151.2 252 R 2.5("C-W" unix-w)151.2 + 264 R(ord-rubout)-.1 E 2.5("C-Y" yank)151.2 276 R 2.5("C-_" vi-undo) + 151.2 288 R -4.166 3.333("" f)151.2 300 T(orw)-3.333 E(ard-char)-.1 E + 2.5("#" insert-comment)151.2 312 R 2.5("$" end-of-line)151.2 324 R 2.5 + ("%" vi-match)151.2 336 R 2.5("&" vi-tilde-e)151.2 348 R(xpand)-.15 E + 2.5("*" vi-complete)151.2 360 R 2.5("+" ne)151.2 372 R(xt-history)-.15 E + 2.5("," vi-char)151.2 384 R(-search)-.2 E 2.5("-" pre)151.2 396 R + (vious-history)-.25 E 2.5("." vi-redo)151.2 408 R 2.5("/" vi-search) + 151.2 420 R 2.5("0" be)151.2 432 R(ginning-of-line)-.15 E("1" to "9") + 151.2 444 Q(vi-ar)5 E(g-digit)-.18 E 2.5(";" vi-char)151.2 456 R + (-search)-.2 E 2.5("=" vi-complete)151.2 468 R 2.5("?" vi-search)151.2 + 480 R 2.5("A" vi-append-eol)151.2 492 R 2.5("B" vi-pre)151.2 504 R(v-w) + -.25 E(ord)-.1 E 2.5("C" vi-change-to)151.2 516 R 2.5("D" vi-delete-to) + 151.2 528 R 2.5("E" vi-end-w)151.2 540 R(ord)-.1 E 2.5("F" vi-char)151.2 + 552 R(-search)-.2 E 2.5("G" vi-fetch-history)151.2 564 R 2.5 + ("I" vi-insert-be)151.2 576 R(g)-.15 E 2.5("N" vi-search-ag)151.2 588 R + (ain)-.05 E 2.5("P" vi-put)151.2 600 R 2.5("R" vi-replace)151.2 612 R + 2.5("S" vi-subst)151.2 624 R 2.5("T" vi-char)151.2 636 R(-search)-.2 E + 2.5("U" re)151.2 648 R -.15(ve)-.25 G(rt-line).15 E 2.5("W" vi-ne)151.2 + 660 R(xt-w)-.15 E(ord)-.1 E 2.5("X" backw)151.2 672 R(ard-delete-char) + -.1 E 2.5("Y" vi-yank-to)151.2 684 R 2.5("\\" vi-complete)151.2 696 R + 2.5("^" vi-\214rst-print)151.2 708 R 2.5("_" vi-yank-ar)151.2 720 R(g) + -.18 E(GNU Readline 4.2)72 768 Q(2001 Mar 5)135.96 E(12)200.67 E EP + %%Page: 13 13 + %%BeginPageSetup + BP + %%EndPageSetup + /F0 10/Times-Roman@0 SF 342.2(READLINE\(3\) READLINE\(3\))72 48 R 2.5 + ("`" vi-goto-mark)151.2 84 R 2.5("a" vi-append-mode)151.2 96 R 2.5 + ("b" vi-pre)151.2 108 R(v-w)-.25 E(ord)-.1 E 2.5("c" vi-change-to)151.2 + 120 R 2.5("d" vi-delete-to)151.2 132 R 2.5("e" vi-end-w)151.2 144 R(ord) + -.1 E 2.5("f" vi-char)151.2 156 R(-search)-.2 E 2.5("h" backw)151.2 168 + R(ard-char)-.1 E 2.5("i" vi-insertion-mode)151.2 180 R 2.5("j" ne)151.2 + 192 R(xt-history)-.15 E 2.5("k" pre)151.2 204 R(v-history)-.25 E 2.5 + ("l" forw)151.2 216 R(ard-char)-.1 E 2.5("m" vi-set-mark)151.2 228 R 2.5 + ("n" vi-search-ag)151.2 240 R(ain)-.05 E 2.5("p" vi-put)151.2 252 R 2.5 + ("r" vi-change-char)151.2 264 R 2.5("s" vi-subst)151.2 276 R 2.5 + ("t" vi-char)151.2 288 R(-search)-.2 E 2.5("u" vi-undo)151.2 300 R 2.5 + ("w" vi-ne)151.2 312 R(xt-w)-.15 E(ord)-.1 E 2.5("x" vi-delete)151.2 324 + R 2.5("y" vi-yank-to)151.2 336 R 2.5("|" vi-column)151.2 348 R 2.5 + ("~" vi-change-case)151.2 360 R/F1 10.95/Times-Bold@0 SF(SEE ALSO)72 + 376.8 Q/F2 10/Times-Italic@0 SF(The Gnu Readline Libr)108 388.8 Q(ary) + -.15 E F0 2.5(,B)C(rian F)-2.5 E(ox and Chet Rame)-.15 E(y)-.15 E F2 + (The Gnu History Libr)108 400.8 Q(ary)-.15 E F0 2.5(,B)C(rian F)-2.5 E + (ox and Chet Rame)-.15 E(y)-.15 E F2(bash)108 412.8 Q F0(\(1\))A F1 + (FILES)72 429.6 Q F2(~/.inputr)109.666 441.6 Q(c)-.37 E F0(Indi)144 + 453.6 Q(vidual)-.25 E/F3 10/Times-Bold@0 SF -.18(re)2.5 G(adline).18 E + F0(initialization \214le)2.5 E F1 -.548(AU)72 470.4 S(THORS).548 E F0 + (Brian F)108 482.4 Q(ox, Free Softw)-.15 E(are F)-.1 E(oundation)-.15 E + (bfox@gnu.or)108 494.4 Q(g)-.18 E(Chet Rame)108 511.2 Q 1.3 -.65(y, C) + -.15 H(ase W).65 E(estern Reserv)-.8 E 2.5(eU)-.15 G(ni)-2.5 E -.15(ve) + -.25 G(rsity).15 E(chet@ins.CWR)108 523.2 Q(U.Edu)-.4 E F1 -.11(BU)72 + 540 S 2.738(GR).11 G(EPOR)-2.738 E(TS)-.438 E F0 .69(If you \214nd a b) + 108 552 R .69(ug in)-.2 F F3 -.18(re)3.19 G(adline,).18 E F0 .69 + (you should report it.)3.19 F .691(But \214rst, you should mak)5.69 F + 3.191(es)-.1 G .691(ure that it really is a b)-3.191 F(ug,)-.2 E + (and that it appears in the latest v)108 564 Q(ersion of the)-.15 E F3 + -.18(re)2.5 G(adline).18 E F0(library that you ha)2.5 E -.15(ve)-.2 G(.) + .15 E .705(Once you ha)108 580.8 R 1.005 -.15(ve d)-.2 H .705 + (etermined that a b).15 F .704(ug actually e)-.2 F .704(xists, mail a b) + -.15 F .704(ug report to)-.2 F F2 -.2(bu)3.204 G(g\255r).2 E(eadline) + -.37 E F0(@)A F2(gnu.or)A(g)-.37 E F0 5.704(.I)C 3.204(fy)-5.704 G(ou) + -3.204 E(ha)108 592.8 Q 1.809 -.15(ve a \214)-.2 H 1.509 + (x, you are welcome to mail that as well!).15 F 1.51 + (Suggestions and `philosophical' b)6.51 F 1.51(ug reports may be)-.2 F + (mailed to)108 604.8 Q F2 -.2(bu)2.5 G(g-r).2 E(eadline)-.37 E F0(@)A F2 + (gnu.or)A(g)-.37 E F0(or posted to the Usenet ne)2.5 E(wsgroup)-.25 E F3 + (gnu.bash.b)2.5 E(ug)-.2 E F0(.)A(Comments and b)108 621.6 Q + (ug reports concerning this manual page should be directed to)-.2 E F2 + -.15(ch)2.5 G(et@ins.CWR).15 E -.25(U.)-.4 G(Edu).25 E F0(.).25 E F1 + -.11(BU)72 638.4 S(GS).11 E F0(It')108 650.4 Q 2.5(st)-.55 G + (oo big and too slo)-2.5 E -.65(w.)-.25 G(GNU Readline 4.2)72 768 Q + (2001 Mar 5)135.96 E(13)200.67 E EP + %%Trailer + end + %%EOF diff -Nrc2 readline-4.1/doc/rlman.texinfo readline-4.2/doc/rlman.texinfo *** readline-4.1/doc/rlman.texinfo Thu Aug 5 08:25:33 1999 --- readline-4.2/doc/rlman.texinfo Fri Feb 2 11:49:17 2001 *************** *** 19,23 **** to provide a command line interface. ! Copyright (C) 1988-1999 Free Software Foundation, Inc. Permission is granted to make and distribute verbatim copies of --- 19,23 ---- to provide a command line interface. ! Copyright (C) 1988-2001 Free Software Foundation, Inc. Permission is granted to make and distribute verbatim copies of *************** *** 74,78 **** @vskip 0pt plus 1filll ! Copyright @copyright{} 1988-1999 Free Software Foundation, Inc. @end titlepage --- 74,78 ---- @vskip 0pt plus 1filll ! Copyright @copyright{} 1988-2001 Free Software Foundation, Inc. @end titlepage diff -Nrc2 readline-4.1/doc/rltech.texinfo readline-4.2/doc/rltech.texinfo *** readline-4.1/doc/rltech.texinfo Mon Feb 28 10:55:08 2000 --- readline-4.2/doc/rltech.texinfo Mon Mar 12 05:42:09 2001 *************** *** 9,13 **** to provide a command line interface. ! Copyright (C) 1988, 1994, 1996, 1998, 1999 Free Software Foundation, Inc. Permission is granted to make and distribute verbatim copies of --- 9,13 ---- to provide a command line interface. ! Copyright (C) 1988-2001 Free Software Foundation, Inc. Permission is granted to make and distribute verbatim copies of *************** *** 36,42 **** @chapter Programming with GNU Readline ! This chapter describes the interface between the GNU Readline Library and other programs. If you are a programmer, and you wish to include the ! features found in GNU Readline such as completion, line editing, and interactive history manipulation in your own programs, this section is for you. --- 36,42 ---- @chapter Programming with GNU Readline ! This chapter describes the interface between the @sc{gnu} Readline Library and other programs. If you are a programmer, and you wish to include the ! features found in @sc{gnu} Readline such as completion, line editing, and interactive history manipulation in your own programs, this section is for you. *************** *** 62,77 **** Readline is sufficient. This section describes how to use Readline in the simplest way possible, perhaps to replace calls in your code to ! @code{gets()} or @code{fgets ()}. @findex readline @cindex readline, function ! The function @code{readline ()} prints a prompt and then reads and returns ! a single line of text from the user. The line @code{readline} ! returns is allocated with @code{malloc ()}; you should @code{free ()} ! the line when you are done with it. The declaration for @code{readline} ! in ANSI C is @example ! @code{char *readline (char *@var{prompt});} @end example --- 62,79 ---- Readline is sufficient. This section describes how to use Readline in the simplest way possible, perhaps to replace calls in your code to ! @code{gets()} or @code{fgets()}. @findex readline @cindex readline, function ! ! The function @code{readline()} prints a prompt @var{prompt} ! and then reads and returns a single line of text from the user. ! If @var{prompt} is @code{NULL} or the empty string, no prompt is displayed. ! The line @code{readline} returns is allocated with @code{malloc()}; ! the caller should @code{free()} the line when it has finished with it. ! The declaration for @code{readline} in ANSI C is @example ! @code{char *readline (const char *@var{prompt});} @end example *************** *** 91,95 **** If you want the user to be able to get at the line later, (with ! @key{C-p} for example), you must call @code{add_history ()} to save the line away in a @dfn{history} list of such lines. --- 93,97 ---- If you want the user to be able to get at the line later, (with ! @key{C-p} for example), you must call @code{add_history()} to save the line away in a @dfn{history} list of such lines. *************** *** 103,107 **** It is preferable to avoid saving empty lines on the history list, since users rarely have a burning need to reuse a blank line. Here is ! a function which usefully replaces the standard @code{gets ()} library function, and has the advantage of no static buffer to overflow: --- 105,109 ---- It is preferable to avoid saving empty lines on the history list, since users rarely have a burning need to reuse a blank line. Here is ! a function which usefully replaces the standard @code{gets()} library function, and has the advantage of no static buffer to overflow: *************** *** 136,150 **** completion: completion on file names. If you do not want Readline to complete on filenames, you can change the binding of the @key{TAB} key ! with @code{rl_bind_key ()}. @example ! @code{int rl_bind_key (int @var{key}, int (*@var{function})());} @end example ! @code{rl_bind_key ()} takes two arguments: @var{key} is the character that you want to bind, and @var{function} is the address of the function to ! call when @var{key} is pressed. Binding @key{TAB} to @code{rl_insert ()} makes @key{TAB} insert itself. ! @code{rl_bind_key ()} returns non-zero if @var{key} is not a valid ASCII character code (between 0 and 255). --- 138,152 ---- completion: completion on file names. If you do not want Readline to complete on filenames, you can change the binding of the @key{TAB} key ! with @code{rl_bind_key()}. @example ! @code{int rl_bind_key (int @var{key}, rl_command_func_t *@var{function});} @end example ! @code{rl_bind_key()} takes two arguments: @var{key} is the character that you want to bind, and @var{function} is the address of the function to ! call when @var{key} is pressed. Binding @key{TAB} to @code{rl_insert()} makes @key{TAB} insert itself. ! @code{rl_bind_key()} returns non-zero if @var{key} is not a valid ASCII character code (between 0 and 255). *************** *** 155,159 **** This code should be executed once at the start of your program; you ! might write a function called @code{initialize_readline ()} which performs this and other desired initializations, such as installing custom completers (@pxref{Custom Completers}). --- 157,161 ---- This code should be executed once at the start of your program; you ! might write a function called @code{initialize_readline()} which performs this and other desired initializations, such as installing custom completers (@pxref{Custom Completers}). *************** *** 176,217 **** @menu ! * The Function Type:: C declarations to make code readable. * Function Writing:: Variables and calling conventions. @end menu ! @node The Function Type ! @subsection The Function Type ! For readabilty, we declare a new type of object, called ! @dfn{Function}. A @code{Function} is a C function which ! returns an @code{int}. The type declaration for @code{Function} is: ! @noindent ! @code{typedef int Function ();} ! The reason for declaring this new type is to make it easier to write ! code describing pointers to C functions. Let us say we had a variable ! called @var{func} which was a pointer to a function. Instead of the ! classic C declaration ! @code{int (*)()func;} @noindent we may write ! @code{Function *func;} ! @noindent ! Similarly, there are ! @example ! typedef void VFunction (); ! typedef char *CPFunction (); @r{and} ! typedef char **CPPFunction (); ! @end example ! @noindent ! for functions returning no value, @code{pointer to char}, and ! @code{pointer to pointer to char}, respectively. @node Function Writing --- 178,246 ---- @menu ! * Readline Typedefs:: C declarations to make code readable. * Function Writing:: Variables and calling conventions. @end menu ! @node Readline Typedefs ! @subsection Readline Typedefs ! For readabilty, we declare a number of new object types, all pointers ! to functions. ! The reason for declaring these new types is to make it easier to write ! code describing pointers to C functions with appropriately prototyped ! arguments and return values. ! ! For instance, say we want to declare a variable @var{func} as a pointer ! to a function which takes two @code{int} arguments and returns an ! @code{int} (this is the type of all of the Readline bindable functions). ! Instead of the classic C declaration ! @code{int (*func)();} ! ! @noindent ! or the ANSI-C style declaration ! @code{int (*func)(int, int);} @noindent we may write ! @code{rl_command_func_t *func;} ! The full list of function pointer types available is ! @table @code ! @item typedef int rl_command_func_t (int, int); ! @item typedef char *rl_compentry_func_t (const char *, int); ! ! @item typedef char **rl_completion_func_t (const char *, int, int); ! ! @item typedef char *rl_quote_func_t (char *, int, char *); ! ! @item typedef char *rl_dequote_func_t (char *, int); ! ! @item typedef int rl_compignore_func_t (char **); ! ! @item typedef void rl_compdisp_func_t (char **, int, int); ! ! @item typedef int rl_hook_func_t (void); ! ! @item typedef int rl_getc_func_t (FILE *); ! ! @item typedef int rl_linebuf_func_t (char *, int); ! ! @item typedef int rl_intfunc_t (int); ! @item #define rl_ivoidfunc_t rl_hook_func_t ! @item typedef int rl_icpfunc_t (char *); ! @item typedef int rl_icppfunc_t (char **); ! ! @item typedef void rl_voidfunc_t (void); ! @item typedef void rl_vintfunc_t (int); ! @item typedef void rl_vcpfunc_t (char *); ! @item typedef void rl_vcppfunc_t (char **); ! ! @end table @node Function Writing *************** *** 266,270 **** @deftypevar int rl_mark ! The mark (saved position) in the current line. If set, the mark and point define a @emph{region}. @end deftypevar --- 295,299 ---- @deftypevar int rl_mark ! The @var{mark} (saved position) in the current line. If set, the mark and point define a @emph{region}. @end deftypevar *************** *** 275,278 **** --- 304,313 ---- @end deftypevar + @deftypevar int rl_num_chars_to_read + Setting this to a positive value before calling @code{readline()} causes + Readline to return after accepting that many characters, rather + than reading up to a character bound to @code{accept-line}. + @end deftypevar + @deftypevar int rl_pending_input Setting this to a value makes it the next keystroke read. This is a *************** *** 280,283 **** --- 315,324 ---- @end deftypevar + @deftypevar int rl_dispatching + Set to a non-zero value if a function is being called from a key binding; + zero otherwise. Application functions can test this to discover whether + they were called directly or by Readline's dispatching mechanism. + @end deftypevar + @deftypevar int rl_erase_empty_line Setting this to a non-zero value causes Readline to completely erase *************** *** 289,293 **** @deftypevar {char *} rl_prompt The prompt Readline uses. This is set from the argument to ! @code{readline ()}, and should not be assigned to directly. @end deftypevar --- 330,336 ---- @deftypevar {char *} rl_prompt The prompt Readline uses. This is set from the argument to ! @code{readline()}, and should not be assigned to directly. ! The @code{rl_set_prompt()} function (@pxref{Redisplay}) may ! be used to modify the prompt string after calling @code{readline()}. @end deftypevar *************** *** 302,314 **** @end deftypevar ! @deftypevar {char *} rl_library_version The version number of this revision of the library. @end deftypevar ! @deftypevar {char *} rl_terminal_name ! The terminal type, used for initialization. @end deftypevar ! @deftypevar {char *} rl_readline_name This variable is set to a unique name by each application using Readline. The value allows conditional parsing of the inputrc file --- 345,364 ---- @end deftypevar ! @deftypevar {const char *} rl_library_version The version number of this revision of the library. @end deftypevar ! @deftypevar {int} rl_gnu_readline_p ! Always set to 1, denoting that this is @sc{gnu} readline rather than some ! emulation. ! @end deftypevar ! ! @deftypevar {const char *} rl_terminal_name ! The terminal type, used for initialization. If not set by the application, ! Readline sets this to the value of the @env{TERM} environment variable ! the first time it is called. @end deftypevar ! @deftypevar {const char *} rl_readline_name This variable is set to a unique name by each application using Readline. The value allows conditional parsing of the inputrc file *************** *** 324,333 **** @end deftypevar ! @deftypevar {Function *} rl_startup_hook If non-zero, this is the address of a function to call just before @code{readline} prints the first prompt. @end deftypevar ! @deftypevar {Function *} rl_pre_input_hook If non-zero, this is the address of a function to call after the first prompt has been printed and just before @code{readline} --- 374,389 ---- @end deftypevar ! @deftypevar {rl_command_func_t *} rl_last_func ! The address of the last command function Readline executed. May be used to ! test whether or not a function is being executed twice in succession, for ! example. ! @end deftypevar ! ! @deftypevar {rl_hook_func_t *} rl_startup_hook If non-zero, this is the address of a function to call just before @code{readline} prints the first prompt. @end deftypevar ! @deftypevar {rl_hook_func_t *} rl_pre_input_hook If non-zero, this is the address of a function to call after the first prompt has been printed and just before @code{readline} *************** *** 335,357 **** @end deftypevar ! @deftypevar {Function *} rl_event_hook If non-zero, this is the address of a function to call periodically ! when readline is waiting for terminal input. @end deftypevar ! @deftypevar {Function *} rl_getc_function ! If non-zero, @code{readline} will call indirectly through this pointer to get a character from the input stream. By default, it is set to ! @code{rl_getc}, the default @code{readline} character input function ! (@pxref{Utility Functions}). @end deftypevar ! @deftypevar {VFunction *} rl_redisplay_function ! If non-zero, @code{readline} will call indirectly through this pointer to update the display with the current contents of the editing buffer. ! By default, it is set to @code{rl_redisplay}, the default @code{readline} redisplay function (@pxref{Redisplay}). @end deftypevar @deftypevar {Keymap} rl_executing_keymap This variable is set to the keymap (@pxref{Keymaps}) in which the --- 391,431 ---- @end deftypevar ! @deftypevar {rl_hook_func_t *} rl_event_hook If non-zero, this is the address of a function to call periodically ! when Readline is waiting for terminal input. ! By default, this will be called at most ten times a second if there ! is no keyboard input. @end deftypevar ! @deftypevar {rl_getc_func_t *} rl_getc_function ! If non-zero, Readline will call indirectly through this pointer to get a character from the input stream. By default, it is set to ! @code{rl_getc}, the default Readline character input function ! (@pxref{Character Input}). @end deftypevar ! @deftypevar {rl_voidfunc_t *} rl_redisplay_function ! If non-zero, Readline will call indirectly through this pointer to update the display with the current contents of the editing buffer. ! By default, it is set to @code{rl_redisplay}, the default Readline redisplay function (@pxref{Redisplay}). @end deftypevar + @deftypevar {rl_vintfunc_t *} rl_prep_term_function + If non-zero, Readline will call indirectly through this pointer + to initialize the terminal. The function takes a single argument, an + @code{int} flag that says whether or not to use eight-bit characters. + By default, this is set to @code{rl_prep_terminal} + (@pxref{Terminal Management}). + @end deftypevar + + @deftypevar {rl_voidfunc_t *} rl_deprep_term_function + If non-zero, Readline will call indirectly through this pointer + to reset the terminal. This function should undo the effects of + @code{rl_prep_term_function}. + By default, this is set to @code{rl_deprep_terminal} + (@pxref{Terminal Management}). + @end deftypevar + @deftypevar {Keymap} rl_executing_keymap This variable is set to the keymap (@pxref{Keymaps}) in which the *************** *** 364,367 **** --- 438,514 ---- @end deftypevar + @deftypevar {char *} rl_executing_macro + This variable is set to the text of any currently-executing macro. + @end deftypevar + + @deftypevar {int} rl_readline_state + A variable with bit values that encapsulate the current Readline state. + A bit is set with the @code{RL_SETSTATE} macro, and unset with the + @code{RL_UNSETSTATE} macro. Use the @code{RL_ISSTATE} macro to test + whether a particular state bit is set. Current state bits include: + + @table @code + @item RL_STATE_NONE + Readline has not yet been called, nor has it begun to intialize. + @item RL_STATE_INITIALIZING + Readline is initializing its internal data structures. + @item RL_STATE_INITIALIZED + Readline has completed its initialization. + @item RL_STATE_TERMPREPPED + Readline has modified the terminal modes to do its own input and redisplay. + @item RL_STATE_READCMD + Readline is reading a command from the keyboard. + @item RL_STATE_METANEXT + Readline is reading more input after reading the meta-prefix character. + @item RL_STATE_DISPATCHING + Readline is dispatching to a command. + @item RL_STATE_MOREINPUT + Readline is reading more input while executing an editing command. + @item RL_STATE_ISEARCH + Readline is performing an incremental history search. + @item RL_STATE_NSEARCH + Readline is performing a non-incremental history search. + @item RL_STATE_SEARCH + Readline is searching backward or forward through the history for a string. + @item RL_STATE_NUMERICARG + Readline is reading a numeric argument. + @item RL_STATE_MACROINPUT + Readline is currently getting its input from a previously-defined keyboard + macro. + @item RL_STATE_MACRODEF + Readline is currently reading characters defining a keyboard macro. + @item RL_STATE_OVERWRITE + Readline is in overwrite mode. + @item RL_STATE_COMPLETING + Readline is performing word completion. + @item RL_STATE_SIGHANDLER + Readline is currently executing the readline signal handler. + @item RL_STATE_UNDOING + Readline is performing an undo. + @item RL_STATE_DONE + Readline has read a key sequence bound to @code{accept-line} + and is about to return the line to the caller. + @end table + + @end deftypevar + + @deftypevar {int} rl_explicit_arg + Set to a non-zero value if an explicit numeric argument was specified by + the user. Only valid in a bindable command function. + @end deftypevar + + @deftypevar {int} rl_numeric_arg + Set to the value of any numeric argument explicitly specified by the user + before executing the current Readline function. Only valid in a bindable + command function. + @end deftypevar + + @deftypevar {int} rl_editing_mode + Set to a value denoting Readline's current editing mode. A value of + @var{1} means Readline is currently in emacs mode; @var{0} + means that vi mode is active. + @end deftypevar + + @node Readline Convenience Functions @section Readline Convenience Functions *************** *** 376,381 **** --- 523,532 ---- * Redisplay:: Functions to control line display. * Modifying Text:: Functions to modify @code{rl_line_buffer}. + * Character Input:: Functions to read keyboard input. + * Terminal Management:: Functions to manage terminal settings. * Utility Functions:: Generally useful functions and hooks. + * Miscellaneous Functions:: Functions that don't fall into any category. * Alternate Interface:: Using Readline in a `callback' fashion. + * A Readline Example:: An example Readline function. @end menu *************** *** 397,404 **** well. Readline provides a function for doing that: ! @deftypefun int rl_add_defun (char *name, Function *function, int key) Add @var{name} to the list of named functions. Make @var{function} be the function that gets called. If @var{key} is not -1, then bind it to ! @var{function} using @code{rl_bind_key ()}. @end deftypefun --- 548,555 ---- well. Readline provides a function for doing that: ! @deftypefun int rl_add_defun (const char *name, rl_command_func_t *function, int key) Add @var{name} to the list of named functions. Make @var{function} be the function that gets called. If @var{key} is not -1, then bind it to ! @var{function} using @code{rl_bind_key()}. @end deftypefun *************** *** 417,423 **** Readline which keymap to use. ! @deftypefun Keymap rl_make_bare_keymap () Returns a new, empty keymap. The space for the keymap is allocated with ! @code{malloc ()}; you should @code{free ()} it when you are done. @end deftypefun --- 568,575 ---- Readline which keymap to use. ! @deftypefun Keymap rl_make_bare_keymap (void) Returns a new, empty keymap. The space for the keymap is allocated with ! @code{malloc()}; the caller should free it by calling ! @code{rl_discard_keymap()} when done. @end deftypefun *************** *** 426,430 **** @end deftypefun ! @deftypefun Keymap rl_make_keymap () Return a new keymap with the printing characters bound to rl_insert, the lowercase Meta characters bound to run their equivalents, and --- 578,582 ---- @end deftypefun ! @deftypefun Keymap rl_make_keymap (void) Return a new keymap with the printing characters bound to rl_insert, the lowercase Meta characters bound to run their equivalents, and *************** *** 439,443 **** change which keymap is active. ! @deftypefun Keymap rl_get_keymap () Returns the currently active keymap. @end deftypefun --- 591,595 ---- change which keymap is active. ! @deftypefun Keymap rl_get_keymap (void) Returns the currently active keymap. @end deftypefun *************** *** 447,451 **** @end deftypefun ! @deftypefun Keymap rl_get_keymap_by_name (char *name) Return the keymap matching @var{name}. @var{name} is one which would be supplied in a @code{set keymap} inputrc line (@pxref{Readline Init File}). --- 599,603 ---- @end deftypefun ! @deftypefun Keymap rl_get_keymap_by_name (const char *name) Return the keymap matching @var{name}. @var{name} is one which would be supplied in a @code{set keymap} inputrc line (@pxref{Readline Init File}). *************** *** 460,465 **** @subsection Binding Keys ! You associate keys with functions through the keymap. Readline has ! several internal keymaps: @code{emacs_standard_keymap}, @code{emacs_meta_keymap}, @code{emacs_ctlx_keymap}, @code{vi_movement_keymap}, and @code{vi_insertion_keymap}. --- 612,617 ---- @subsection Binding Keys ! Key sequences are associate with functions through the keymap. ! Readline has several internal keymaps: @code{emacs_standard_keymap}, @code{emacs_meta_keymap}, @code{emacs_ctlx_keymap}, @code{vi_movement_keymap}, and @code{vi_insertion_keymap}. *************** *** 467,473 **** this manual assume that. ! Since @code{readline} installs a set of default key bindings the first time it is called, there is always the danger that a custom binding ! installed before the first call to @code{readline} will be overridden. An alternate mechanism is to install custom key bindings in an initialization function assigned to the @code{rl_startup_hook} variable --- 619,625 ---- this manual assume that. ! Since @code{readline()} installs a set of default key bindings the first time it is called, there is always the danger that a custom binding ! installed before the first call to @code{readline()} will be overridden. An alternate mechanism is to install custom key bindings in an initialization function assigned to the @code{rl_startup_hook} variable *************** *** 476,485 **** These functions manage key bindings. ! @deftypefun int rl_bind_key (int key, Function *function) Binds @var{key} to @var{function} in the currently active keymap. Returns non-zero in the case of an invalid @var{key}. @end deftypefun ! @deftypefun int rl_bind_key_in_map (int key, Function *function, Keymap map) Bind @var{key} to @var{function} in @var{map}. Returns non-zero in the case of an invalid @var{key}. --- 628,637 ---- These functions manage key bindings. ! @deftypefun int rl_bind_key (int key, rl_command_func_t *function) Binds @var{key} to @var{function} in the currently active keymap. Returns non-zero in the case of an invalid @var{key}. @end deftypefun ! @deftypefun int rl_bind_key_in_map (int key, rl_command_func_t *function, Keymap map) Bind @var{key} to @var{function} in @var{map}. Returns non-zero in the case of an invalid @var{key}. *************** *** 496,508 **** @end deftypefun ! @deftypefun int rl_unbind_function_in_map (Function *function, Keymap map) Unbind all keys that execute @var{function} in @var{map}. @end deftypefun ! @deftypefun int rl_unbind_command_in_map (char *command, Keymap map) Unbind all keys that are bound to @var{command} in @var{map}. @end deftypefun ! @deftypefun int rl_generic_bind (int type, char *keyseq, char *data, Keymap map) Bind the key sequence represented by the string @var{keyseq} to the arbitrary pointer @var{data}. @var{type} says what kind of data is pointed to by --- 648,666 ---- @end deftypefun ! @deftypefun int rl_unbind_function_in_map (rl_command_func_t *function, Keymap map) Unbind all keys that execute @var{function} in @var{map}. @end deftypefun ! @deftypefun int rl_unbind_command_in_map (const char *command, Keymap map) Unbind all keys that are bound to @var{command} in @var{map}. @end deftypefun ! @deftypefun int rl_set_key (const char *keyseq, rl_command_func_t *function, Keymap map) ! Bind the key sequence represented by the string @var{keyseq} to the function ! @var{function}. This makes new keymaps as ! necessary. The initial keymap in which to do bindings is @var{map}. ! @end deftypefun ! ! @deftypefun int rl_generic_bind (int type, const char *keyseq, char *data, Keymap map) Bind the key sequence represented by the string @var{keyseq} to the arbitrary pointer @var{data}. @var{type} says what kind of data is pointed to by *************** *** 518,522 **** @end deftypefun ! @deftypefun int rl_read_init_file (char *filename) Read keybindings and variable assignments from @var{filename} (@pxref{Readline Init File}). --- 676,680 ---- @end deftypefun ! @deftypefun int rl_read_init_file (const char *filename) Read keybindings and variable assignments from @var{filename} (@pxref{Readline Init File}). *************** *** 527,549 **** These functions allow you to find out what keys invoke named functions ! and the functions invoked by a particular key sequence. ! @deftypefun {Function *} rl_named_function (char *name) Return the function with name @var{name}. @end deftypefun ! @deftypefun {Function *} rl_function_of_keyseq (char *keyseq, Keymap map, int *type) Return the function invoked by @var{keyseq} in keymap @var{map}. ! If @var{map} is NULL, the current keymap is used. If @var{type} is ! not NULL, the type of the object is returned in it (one of @code{ISFUNC}, ! @code{ISKMAP}, or @code{ISMACR}). @end deftypefun ! @deftypefun {char **} rl_invoking_keyseqs (Function *function) Return an array of strings representing the key sequences used to invoke @var{function} in the current keymap. @end deftypefun ! @deftypefun {char **} rl_invoking_keyseqs_in_map (Function *function, Keymap map) Return an array of strings representing the key sequences used to invoke @var{function} in the keymap @var{map}. --- 685,708 ---- These functions allow you to find out what keys invoke named functions ! and the functions invoked by a particular key sequence. You may also ! associate a new function name with an arbitrary function. ! @deftypefun {rl_command_func_t *} rl_named_function (const char *name) Return the function with name @var{name}. @end deftypefun ! @deftypefun {rl_command_func_t *} rl_function_of_keyseq (const char *keyseq, Keymap map, int *type) Return the function invoked by @var{keyseq} in keymap @var{map}. ! If @var{map} is @code{NULL}, the current keymap is used. If @var{type} is ! not @code{NULL}, the type of the object is returned in the @code{int} variable ! it points to (one of @code{ISFUNC}, @code{ISKMAP}, or @code{ISMACR}). @end deftypefun ! @deftypefun {char **} rl_invoking_keyseqs (rl_command_func_t *function) Return an array of strings representing the key sequences used to invoke @var{function} in the current keymap. @end deftypefun ! @deftypefun {char **} rl_invoking_keyseqs_in_map (rl_command_func_t *function, Keymap map) Return an array of strings representing the key sequences used to invoke @var{function} in the keymap @var{map}. *************** *** 557,568 **** @end deftypefun ! @deftypefun void rl_list_funmap_names () Print the names of all bindable Readline functions to @code{rl_outstream}. @end deftypefun ! @deftypefun {char **} rl_funmap_names () Return a NULL terminated array of known function names. The array is sorted. The array itself is allocated, but not the strings inside. You ! should free () the array when you done, but not the pointrs. @end deftypefun --- 716,732 ---- @end deftypefun ! @deftypefun void rl_list_funmap_names (void) Print the names of all bindable Readline functions to @code{rl_outstream}. @end deftypefun ! @deftypefun {const char **} rl_funmap_names (void) Return a NULL terminated array of known function names. The array is sorted. The array itself is allocated, but not the strings inside. You ! should @code{free()} the array when you are done, but not the pointers. ! @end deftypefun ! ! @deftypefun int rl_add_funmap_entry (const char *name, rl_command_func_t *function) ! Add @var{name} to the list of bindable Readline command names, and make ! @var{function} the function to be called when @var{name} is invoked. @end deftypefun *************** *** 572,586 **** Supporting the undo command is a painless thing, and makes your functions much more useful. It is certainly easy to try ! something if you know you can undo it. I could use an undo function for ! the stock market. If your function simply inserts text once, or deletes text once, and ! uses @code{rl_insert_text ()} or @code{rl_delete_text ()} to do it, then undoing is already done for you automatically. If you do multiple insertions or multiple deletions, or any combination of these operations, you should group them together into one operation. ! This is done with @code{rl_begin_undo_group ()} and ! @code{rl_end_undo_group ()}. The types of events that can be undone are: --- 736,749 ---- Supporting the undo command is a painless thing, and makes your functions much more useful. It is certainly easy to try ! something if you know you can undo it. If your function simply inserts text once, or deletes text once, and ! uses @code{rl_insert_text()} or @code{rl_delete_text()} to do it, then undoing is already done for you automatically. If you do multiple insertions or multiple deletions, or any combination of these operations, you should group them together into one operation. ! This is done with @code{rl_begin_undo_group()} and ! @code{rl_end_undo_group()}. The types of events that can be undone are: *************** *** 592,610 **** Notice that @code{UNDO_DELETE} means to insert some text, and @code{UNDO_INSERT} means to delete some text. That is, the undo code ! tells undo what to undo, not how to undo it. @code{UNDO_BEGIN} and ! @code{UNDO_END} are tags added by @code{rl_begin_undo_group ()} and ! @code{rl_end_undo_group ()}. ! @deftypefun int rl_begin_undo_group () Begins saving undo information in a group construct. The undo ! information usually comes from calls to @code{rl_insert_text ()} and ! @code{rl_delete_text ()}, but could be the result of calls to ! @code{rl_add_undo ()}. @end deftypefun ! @deftypefun int rl_end_undo_group () Closes the current undo group started with @code{rl_begin_undo_group ! ()}. There should be one call to @code{rl_end_undo_group ()} ! for each call to @code{rl_begin_undo_group ()}. @end deftypefun --- 755,773 ---- Notice that @code{UNDO_DELETE} means to insert some text, and @code{UNDO_INSERT} means to delete some text. That is, the undo code ! tells what to undo, not how to undo it. @code{UNDO_BEGIN} and ! @code{UNDO_END} are tags added by @code{rl_begin_undo_group()} and ! @code{rl_end_undo_group()}. ! @deftypefun int rl_begin_undo_group (void) Begins saving undo information in a group construct. The undo ! information usually comes from calls to @code{rl_insert_text()} and ! @code{rl_delete_text()}, but could be the result of calls to ! @code{rl_add_undo()}. @end deftypefun ! @deftypefun int rl_end_undo_group (void) Closes the current undo group started with @code{rl_begin_undo_group ! ()}. There should be one call to @code{rl_end_undo_group()} ! for each call to @code{rl_begin_undo_group()}. @end deftypefun *************** *** 614,622 **** @end deftypefun ! @deftypefun void free_undo_list () Free the existing undo list. @end deftypefun ! @deftypefun int rl_do_undo () Undo the first thing on the undo list. Returns @code{0} if there was nothing to undo, non-zero if something was undone. --- 777,785 ---- @end deftypefun ! @deftypefun void rl_free_undo_list (void) Free the existing undo list. @end deftypefun ! @deftypefun int rl_do_undo (void) Undo the first thing on the undo list. Returns @code{0} if there was nothing to undo, non-zero if something was undone. *************** *** 624,628 **** Finally, if you neither insert nor delete text, but directly modify the ! existing text (e.g., change its case), call @code{rl_modifying ()} once, just before you modify the text. You must supply the indices of the text range that you are going to modify. --- 787,791 ---- Finally, if you neither insert nor delete text, but directly modify the ! existing text (e.g., change its case), call @code{rl_modifying()} once, just before you modify the text. You must supply the indices of the text range that you are going to modify. *************** *** 637,656 **** @subsection Redisplay ! @deftypefun void rl_redisplay () Change what's displayed on the screen to reflect the current contents of @code{rl_line_buffer}. @end deftypefun ! @deftypefun int rl_forced_update_display () Force the line to be updated and redisplayed, whether or not Readline thinks the screen display is correct. @end deftypefun ! @deftypefun int rl_on_new_line () Tell the update functions that we have moved onto a new (empty) line, usually after ouputting a newline. @end deftypefun ! @deftypefun int rl_on_new_line_with_prompt () Tell the update functions that we have moved onto a new line, with @var{rl_prompt} already displayed. --- 800,819 ---- @subsection Redisplay ! @deftypefun void rl_redisplay (void) Change what's displayed on the screen to reflect the current contents of @code{rl_line_buffer}. @end deftypefun ! @deftypefun int rl_forced_update_display (void) Force the line to be updated and redisplayed, whether or not Readline thinks the screen display is correct. @end deftypefun ! @deftypefun int rl_on_new_line (void) Tell the update functions that we have moved onto a new (empty) line, usually after ouputting a newline. @end deftypefun ! @deftypefun int rl_on_new_line_with_prompt (void) Tell the update functions that we have moved onto a new line, with @var{rl_prompt} already displayed. *************** *** 661,693 **** @end deftypefun ! @deftypefun int rl_reset_line_state () Reset the display state to a clean state and redisplay the current line starting on a new line. @end deftypefun ! @deftypefun int rl_message (va_alist) ! The arguments are a string as would be supplied to @code{printf}. The ! resulting string is displayed in the @dfn{echo area}. The echo area is also used to display numeric arguments and search strings. @end deftypefun ! @deftypefun int rl_clear_message () Clear the message in the echo area. @end deftypefun ! @deftypefun void rl_save_prompt () Save the local Readline prompt display state in preparation for ! displaying a new message in the message area with @code{rl_message}. @end deftypefun ! @deftypefun void rl_restore_prompt () Restore the local Readline prompt display state saved by the most recent call to @code{rl_save_prompt}. @end deftypefun @node Modifying Text @subsection Modifying Text ! @deftypefun int rl_insert_text (char *text) Insert @var{text} into the line at the current cursor position. @end deftypefun --- 824,886 ---- @end deftypefun ! @deftypefun int rl_reset_line_state (void) Reset the display state to a clean state and redisplay the current line starting on a new line. @end deftypefun ! @deftypefun int rl_crlf (void) ! Move the cursor to the start of the next screen line. ! @end deftypefun ! ! @deftypefun int rl_show_char (int c) ! Display character @var{c} on @code{rl_outstream}. ! If Readline has not been set to display meta characters directly, this ! will convert meta characters to a meta-prefixed key sequence. ! This is intended for use by applications which wish to do their own ! redisplay. ! @end deftypefun ! ! @deftypefun int rl_message (const char *, @dots{}) ! The arguments are a format string as would be supplied to @code{printf}, ! possibly containing conversion specifications such as @samp{%d}, and ! any additional arguments necessary to satisfy the conversion specifications. ! The resulting string is displayed in the @dfn{echo area}. The echo area is also used to display numeric arguments and search strings. @end deftypefun ! @deftypefun int rl_clear_message (void) Clear the message in the echo area. @end deftypefun ! @deftypefun void rl_save_prompt (void) Save the local Readline prompt display state in preparation for ! displaying a new message in the message area with @code{rl_message()}. @end deftypefun ! @deftypefun void rl_restore_prompt (void) Restore the local Readline prompt display state saved by the most recent call to @code{rl_save_prompt}. @end deftypefun + @deftypefun int rl_expand_prompt (char *prompt) + Expand any special character sequences in @var{prompt} and set up the + local Readline prompt redisplay variables. + This function is called by @code{readline()}. It may also be called to + expand the primary prompt if the @code{rl_on_new_line_with_prompt()} + function or @code{rl_already_prompted} variable is used. + It returns the number of visible characters on the last line of the + (possibly multi-line) prompt. + @end deftypefun + + @deftypefun int rl_set_prompt (const char *prompt) + Make Readline use @var{prompt} for subsequent redisplay. This calls + @code{rl_expand_prompt()} to expand the prompt and sets @code{rl_prompt} + to the result. + @end deftypefun + @node Modifying Text @subsection Modifying Text ! @deftypefun int rl_insert_text (const char *text) Insert @var{text} into the line at the current cursor position. @end deftypefun *************** *** 711,725 **** @end deftypefun ! @node Utility Functions ! @subsection Utility Functions ! ! @deftypefun int rl_read_key () ! Return the next character available. This handles input inserted into ! the input stream via @var{pending input} (@pxref{Readline Variables}) ! and @code{rl_stuff_char ()}, macros, and characters read from the keyboard. ! @end deftypefun ! ! @deftypefun int rl_getc (FILE *) ! Return the next character available from the keyboard. @end deftypefun --- 904,928 ---- @end deftypefun ! @deftypefun int rl_push_macro_input (char *macro) ! Cause @var{macro} to be inserted into the line, as if it had been invoked ! by a key bound to a macro. Not especially useful; use ! @code{rl_insert_text()} instead. ! @end deftypefun ! ! @node Character Input ! @subsection Character Input ! ! @deftypefun int rl_read_key (void) ! Return the next character available from Readline's current input stream. ! This handles input inserted into ! the input stream via @var{rl_pending_input} (@pxref{Readline Variables}) ! and @code{rl_stuff_char()}, macros, and characters read from the keyboard. ! While waiting for input, this function will call any function assigned to ! the @code{rl_event_hook} variable. ! @end deftypefun ! ! @deftypefun int rl_getc (FILE *stream) ! Return the next character available from @var{stream}, which is assumed to ! be the keyboard. @end deftypefun *************** *** 727,761 **** Insert @var{c} into the Readline input stream. It will be "read" before Readline attempts to read characters from the terminal with ! @code{rl_read_key ()}. @end deftypefun ! @deftypefun int rl_extend_line_buffer (int len) ! Ensure that @code{rl_line_buffer} has enough space to hold @var{len} ! characters, possibly reallocating it if necessary. @end deftypefun ! @deftypefun int rl_initialize () ! Initialize or re-initialize Readline's internal state. @end deftypefun ! @deftypefun int rl_reset_terminal (char *terminal_name) Reinitialize Readline's idea of the terminal settings using @var{terminal_name} as the terminal type (e.g., @code{vt100}). ! If @var{terminal_name} is NULL, the value of the @code{TERM} environment variable is used. @end deftypefun ! @deftypefun int alphabetic (int c) ! Return 1 if @var{c} is an alphabetic character. @end deftypefun ! @deftypefun int numeric (int c) ! Return 1 if @var{c} is a numeric character. @end deftypefun ! @deftypefun int ding () Ring the terminal bell, obeying the setting of @code{bell-style}. @end deftypefun @deftypefun void rl_display_match_list (char **matches, int len, int max) A convenience function for displaying a list of strings in --- 930,1005 ---- Insert @var{c} into the Readline input stream. It will be "read" before Readline attempts to read characters from the terminal with ! @code{rl_read_key()}. @end deftypefun ! @deftypefun int rl_execute_next (int c) ! Make @var{c} be the next command to be executed when @code{rl_read_key()} ! is called. This sets @var{rl_pending_input}. @end deftypefun ! @deftypefun int rl_clear_pending_input (void) ! Unset @var{rl_pending_input}, effectively negating the effect of any ! previous call to @code{rl_execute_next()}. This works only if the ! pending input has not already been read with @code{rl_read_key()}. ! @end deftypefun ! ! @deftypefun int rl_set_keyboard_input_timeout (int u) ! While waiting for keyboard input in @code{rl_read_key()}, Readline will ! wait for @var{u} microseconds for input before calling any function ! assigned to @code{rl_event_hook}. The default waiting period is ! one-tenth of a second. Returns the old timeout value. @end deftypefun ! @node Terminal Management ! @subsection Terminal Management ! ! @deftypefun void rl_prep_terminal (int meta_flag) ! Modify the terminal settings for Readline's use, so @code{readline()} ! can read a single character at a time from the keyboard. ! The @var{meta_flag} argument should be non-zero if Readline should ! read eight-bit input. ! @end deftypefun ! ! @deftypefun void rl_deprep_terminal (void) ! Undo the effects of @code{rl_prep_terminal()}, leaving the terminal in ! the state in which it was before the most recent call to ! @code{rl_prep_terminal()}. ! @end deftypefun ! ! @deftypefun void rl_tty_set_default_bindings (Keymap kmap) ! Read the operating system's terminal editing characters (as would be displayed ! by @code{stty}) to their Readline equivalents. The bindings are performed ! in @var{kmap}. ! @end deftypefun ! ! @deftypefun int rl_reset_terminal (const char *terminal_name) Reinitialize Readline's idea of the terminal settings using @var{terminal_name} as the terminal type (e.g., @code{vt100}). ! If @var{terminal_name} is @code{NULL}, the value of the @code{TERM} environment variable is used. @end deftypefun ! @node Utility Functions ! @subsection Utility Functions ! ! @deftypefun int rl_extend_line_buffer (int len) ! Ensure that @code{rl_line_buffer} has enough space to hold @var{len} ! characters, possibly reallocating it if necessary. @end deftypefun ! @deftypefun int rl_initialize (void) ! Initialize or re-initialize Readline's internal state. ! It's not strictly necessary to call this; @code{readline()} calls it before ! reading any input. @end deftypefun ! @deftypefun int rl_ding (void) Ring the terminal bell, obeying the setting of @code{bell-style}. @end deftypefun + @deftypefun int rl_alphabetic (int c) + Return 1 if @var{c} is an alphabetic character. + @end deftypefun + @deftypefun void rl_display_match_list (char **matches, int len, int max) A convenience function for displaying a list of strings in *************** *** 768,799 **** @end deftypefun ! The following are implemented as macros, defined in @code{chartypes.h}. ! @deftypefun int uppercase_p (int c) Return 1 if @var{c} is an uppercase alphabetic character. @end deftypefun ! @deftypefun int lowercase_p (int c) Return 1 if @var{c} is a lowercase alphabetic character. @end deftypefun ! @deftypefun int digit_p (int c) Return 1 if @var{c} is a numeric character. @end deftypefun ! @deftypefun int to_upper (int c) If @var{c} is a lowercase alphabetic character, return the corresponding uppercase character. @end deftypefun ! @deftypefun int to_lower (int c) If @var{c} is an uppercase alphabetic character, return the corresponding lowercase character. @end deftypefun ! @deftypefun int digit_value (int c) If @var{c} is a number, return the value it represents. @end deftypefun @node Alternate Interface @subsection Alternate Interface --- 1012,1080 ---- @end deftypefun ! The following are implemented as macros, defined in @code{chardefs.h}. ! Applications should refrain from using them. ! @deftypefun int _rl_uppercase_p (int c) Return 1 if @var{c} is an uppercase alphabetic character. @end deftypefun ! @deftypefun int _rl_lowercase_p (int c) Return 1 if @var{c} is a lowercase alphabetic character. @end deftypefun ! @deftypefun int _rl_digit_p (int c) Return 1 if @var{c} is a numeric character. @end deftypefun ! @deftypefun int _rl_to_upper (int c) If @var{c} is a lowercase alphabetic character, return the corresponding uppercase character. @end deftypefun ! @deftypefun int _rl_to_lower (int c) If @var{c} is an uppercase alphabetic character, return the corresponding lowercase character. @end deftypefun ! @deftypefun int _rl_digit_value (int c) If @var{c} is a number, return the value it represents. @end deftypefun + @node Miscellaneous Functions + @subsection Miscellaneous Functions + + @deftypefun int rl_macro_bind (const char *keyseq, const char *macro, Keymap map) + Bind the key sequence @var{keyseq} to invoke the macro @var{macro}. + The binding is performed in @var{map}. When @var{keyseq} is invoked, the + @var{macro} will be inserted into the line. This function is deprecated; + use @code{rl_generic_bind()} instead. + @end deftypefun + + @deftypefun void rl_macro_dumper (int readable) + Print the key sequences bound to macros and their values, using + the current keymap, to @code{rl_outstream}. + If @var{readable} is non-zero, the list is formatted in such a way + that it can be made part of an @code{inputrc} file and re-read. + @end deftypefun + + @deftypefun int rl_variable_bind (const char *variable, const char *value) + Make the Readline variable @var{variable} have @var{value}. + This behaves as if the readline command + @samp{set @var{variable} @var{value}} had been executed in an @code{inputrc} + file (@pxref{Readline Init File Syntax}). + @end deftypefun + + @deftypefun void rl_variable_dumper (int readable) + Print the readline variable names and their current values + to @code{rl_outstream}. + If @var{readable} is non-zero, the list is formatted in such a way + that it can be made part of an @code{inputrc} file and re-read. + @end deftypefun + + @deftypefun int rl_set_paren_blink_timeout (int u) + Set the time interval (in microseconds) that Readline waits when showing + a balancing character when @code{blink-matching-paren} has been enabled. + @end deftypefun + @node Alternate Interface @subsection Alternate Interface *************** *** 806,816 **** are functions available to make this easy. ! @deftypefun void rl_callback_handler_install (char *prompt, Vfunction *lhandler) Set up the terminal for readline I/O and display the initial expanded value of @var{prompt}. Save the value of @var{lhandler} to ! use as a callback when a complete line of input has been entered. @end deftypefun ! @deftypefun void rl_callback_read_char () Whenever an application determines that keyboard input is available, it should call @code{rl_callback_read_char()}, which will read the next --- 1087,1098 ---- are functions available to make this easy. ! @deftypefun void rl_callback_handler_install (const char *prompt, rl_vcpfunc_t *lhandler) Set up the terminal for readline I/O and display the initial expanded value of @var{prompt}. Save the value of @var{lhandler} to ! use as a function to call when a complete line of input has been entered. ! The function takes the text of the line as an argument. @end deftypefun ! @deftypefun void rl_callback_read_char (void) Whenever an application determines that keyboard input is available, it should call @code{rl_callback_read_char()}, which will read the next *************** *** 822,831 **** @end deftypefun ! @deftypefun void rl_callback_handler_remove () Restore the terminal to its initial state and remove the line handler. This may be called from within a callback as well as independently. @end deftypefun ! @subsection An Example Here is a function which changes lowercase characters to their uppercase --- 1104,1114 ---- @end deftypefun ! @deftypefun void rl_callback_handler_remove (void) Restore the terminal to its initial state and remove the line handler. This may be called from within a callback as well as independently. @end deftypefun ! @node A Readline Example ! @subsection A Readline Example Here is a function which changes lowercase characters to their uppercase *************** *** 882,889 **** for (i = start; i != end; i++) @{ ! if (uppercase_p (rl_line_buffer[i])) ! rl_line_buffer[i] = to_lower (rl_line_buffer[i]); ! else if (lowercase_p (rl_line_buffer[i])) ! rl_line_buffer[i] = to_upper (rl_line_buffer[i]); @} /* Move point to on top of the last character changed. */ --- 1165,1172 ---- for (i = start; i != end; i++) @{ ! if (_rl_uppercase_p (rl_line_buffer[i])) ! rl_line_buffer[i] = _rl_to_lower (rl_line_buffer[i]); ! else if (_rl_lowercase_p (rl_line_buffer[i])) ! rl_line_buffer[i] = _rl_to_upper (rl_line_buffer[i]); @} /* Move point to on top of the last character changed. */ *************** *** 898,908 **** Signals are asynchronous events sent to a process by the Unix kernel, sometimes on behalf of another process. They are intended to indicate ! exceptional events, like a user pressing the interrupt key on his ! terminal, or a network connection being broken. There is a class of ! signals that can be sent to the process currently reading input from ! the keyboard. Since Readline changes the terminal attributes when it ! is called, it needs to perform special processing when a signal is ! received to restore the terminal to a sane state, or provide application ! writers with functions to do so manually. Readline contains an internal signal handler that is installed for a --- 1181,1191 ---- Signals are asynchronous events sent to a process by the Unix kernel, sometimes on behalf of another process. They are intended to indicate ! exceptional events, like a user pressing the interrupt key on his terminal, ! or a network connection being broken. There is a class of signals that can ! be sent to the process currently reading input from the keyboard. Since ! Readline changes the terminal attributes when it is called, it needs to ! perform special processing when such a signal is received in order to ! restore the terminal to a sane state, or provide application writers with ! functions to do so manually. Readline contains an internal signal handler that is installed for a *************** *** 911,916 **** When one of these signals is received, the signal handler will reset the terminal attributes to those that were in effect before ! @code{readline ()} was called, reset the signal handling to what it was ! before @code{readline ()} was called, and resend the signal to the calling application. If and when the calling application's signal handler returns, Readline --- 1194,1199 ---- When one of these signals is received, the signal handler will reset the terminal attributes to those that were in effect before ! @code{readline()} was called, reset the signal handling to what it was ! before @code{readline()} was called, and resend the signal to the calling application. If and when the calling application's signal handler returns, Readline *************** *** 918,933 **** When a @code{SIGINT} is received, the Readline signal handler performs some additional work, which will cause any partially-entered line to be ! aborted (see the description of @code{rl_free_line_state ()}). There is an additional Readline signal handler, for @code{SIGWINCH}, which the kernel sends to a process whenever the terminal's size changes (for example, if a user resizes an @code{xterm}). The Readline @code{SIGWINCH} ! handler updates Readline's internal screen size state, and then calls any ! @code{SIGWINCH} signal handler the calling application has installed. Readline calls the application's @code{SIGWINCH} signal handler without resetting the terminal to its original state. If the application's signal handler does more than update its idea of the terminal size and return (for example, a @code{longjmp} back to a main processing loop), it @emph{must} ! call @code{rl_cleanup_after_signal ()} (described below), to restore the terminal state. --- 1201,1216 ---- When a @code{SIGINT} is received, the Readline signal handler performs some additional work, which will cause any partially-entered line to be ! aborted (see the description of @code{rl_free_line_state()} below). There is an additional Readline signal handler, for @code{SIGWINCH}, which the kernel sends to a process whenever the terminal's size changes (for example, if a user resizes an @code{xterm}). The Readline @code{SIGWINCH} ! handler updates Readline's internal screen size information, and then calls ! any @code{SIGWINCH} signal handler the calling application has installed. Readline calls the application's @code{SIGWINCH} signal handler without resetting the terminal to its original state. If the application's signal handler does more than update its idea of the terminal size and return (for example, a @code{longjmp} back to a main processing loop), it @emph{must} ! call @code{rl_cleanup_after_signal()} (described below), to restore the terminal state. *************** *** 935,939 **** control whether or not it will catch certain signals and act on them when they are received. It is important that applications change the ! values of these variables only when calling @code{readline ()}, not in a signal handler, so Readline's internal signal state is not corrupted. --- 1218,1222 ---- control whether or not it will catch certain signals and act on them when they are received. It is important that applications change the ! values of these variables only when calling @code{readline()}, not in a signal handler, so Readline's internal signal state is not corrupted. *************** *** 961,965 **** @deftypefun void rl_cleanup_after_signal (void) This function will reset the state of the terminal to what it was before ! @code{readline ()} was called, and remove the Readline signal handlers for all signals, depending on the values of @code{rl_catch_signals} and @code{rl_catch_sigwinch}. --- 1244,1248 ---- @deftypefun void rl_cleanup_after_signal (void) This function will reset the state of the terminal to what it was before ! @code{readline()} was called, and remove the Readline signal handlers for all signals, depending on the values of @code{rl_catch_signals} and @code{rl_catch_sigwinch}. *************** *** 970,974 **** (undo information, any partial history entry, any partially-entered keyboard macro, and any partially-entered numeric argument). This ! should be called before @code{rl_cleanup_after_signal ()}. The Readline signal handler for @code{SIGINT} calls this to abort the current input line. --- 1253,1257 ---- (undo information, any partial history entry, any partially-entered keyboard macro, and any partially-entered numeric argument). This ! should be called before @code{rl_cleanup_after_signal()}. The Readline signal handler for @code{SIGINT} calls this to abort the current input line. *************** *** 982,990 **** If an application does not wish Readline to catch @code{SIGWINCH}, it may ! call @code{rl_resize_terminal ()} to force Readline to update its idea of ! the terminal size when a @code{SIGWINCH} is received. @deftypefun void rl_resize_terminal (void) ! Update Readline's internal screen size. @end deftypefun --- 1265,1288 ---- If an application does not wish Readline to catch @code{SIGWINCH}, it may ! call @code{rl_resize_terminal()} or @code{rl_set_screen_size()} to force ! Readline to update its idea of the terminal size when a @code{SIGWINCH} ! is received. @deftypefun void rl_resize_terminal (void) ! Update Readline's internal screen size by reading values from the kernel. ! @end deftypefun ! ! @deftypefun void rl_set_screen_size (int rows, int cols) ! Set Readline's idea of the terminal size to @var{rows} rows and ! @var{cols} columns. ! @end deftypefun ! ! If an application does not want to install a @code{SIGWINCH} handler, but ! is still interested in the screen dimensions, Readline's idea of the screen ! size may be queried. ! ! @deftypefun void rl_get_screen_size (int *rows, int *cols) ! Return Readline's idea of the terminal's size in the ! variables pointed to by the arguments. @end deftypefun *************** *** 1000,1004 **** @deftypefun int rl_clear_signals (void) Remove all of the Readline signal handlers installed by ! @code{rl_set_signals ()}. @end deftypefun --- 1298,1302 ---- @deftypefun int rl_clear_signals (void) Remove all of the Readline signal handlers installed by ! @code{rl_set_signals()}. @end deftypefun *************** *** 1035,1043 **** @enumerate @item ! The user-interface function @code{rl_complete ()}. This function is ! called with the same arguments as other Readline ! functions intended for interactive use: @var{count} and ! @var{invoking_key}. It isolates the word to be completed and calls ! @code{completion_matches ()} to generate a list of possible completions. It then either lists the possible completions, inserts the possible completions, or actually performs the --- 1333,1341 ---- @enumerate @item ! The user-interface function @code{rl_complete()}. This function is ! called with the same arguments as other bindable Readline functions: ! @var{count} and @var{invoking_key}. ! It isolates the word to be completed and calls ! @code{rl_completion_matches()} to generate a list of possible completions. It then either lists the possible completions, inserts the possible completions, or actually performs the *************** *** 1045,1062 **** @item ! The internal function @code{completion_matches ()} uses your ! @dfn{generator} function to generate the list of possible matches, and ! then returns the array of these matches. You should place the address ! of your generator function in @code{rl_completion_entry_function}. @item The generator function is called repeatedly from ! @code{completion_matches ()}, returning a string each time. The arguments to the generator function are @var{text} and @var{state}. @var{text} is the partial word to be completed. @var{state} is zero the first time the function is called, allowing the generator to perform any necessary initialization, and a positive non-zero integer for ! each subsequent call. When the generator function returns ! @code{(char *)NULL} this signals @code{completion_matches ()} that there are no more possibilities left. Usually the generator function computes the list of possible completions when @var{state} is zero, and returns them --- 1343,1361 ---- @item ! The internal function @code{rl_completion_matches()} uses an ! application-supplied @dfn{generator} function to generate the list of ! possible matches, and then returns the array of these matches. ! The caller should place the address of its generator function in ! @code{rl_completion_entry_function}. @item The generator function is called repeatedly from ! @code{rl_completion_matches()}, returning a string each time. The arguments to the generator function are @var{text} and @var{state}. @var{text} is the partial word to be completed. @var{state} is zero the first time the function is called, allowing the generator to perform any necessary initialization, and a positive non-zero integer for ! each subsequent call. The generator function returns ! @code{(char *)NULL} to inform @code{rl_completion_matches()} that there are no more possibilities left. Usually the generator function computes the list of possible completions when @var{state} is zero, and returns them *************** *** 1070,1081 **** Complete the word at or before point. You have supplied the function that does the initial simple matching selection algorithm (see ! @code{completion_matches ()}). The default is to do filename completion. @end deftypefun ! @deftypevar {Function *} rl_completion_entry_function ! This is a pointer to the generator function for @code{completion_matches ! ()}. If the value of @code{rl_completion_entry_function} is ! @code{(Function *)NULL} then the default filename generator function, ! @code{filename_completion_function ()}, is used. @end deftypevar --- 1369,1381 ---- Complete the word at or before point. You have supplied the function that does the initial simple matching selection algorithm (see ! @code{rl_completion_matches()}). The default is to do filename completion. @end deftypefun ! @deftypevar {rl_compentry_func_t *} rl_completion_entry_function ! This is a pointer to the generator function for ! @code{rl_completion_matches()}. ! If the value of @code{rl_completion_entry_function} is ! @code{NULL} then the default filename generator ! function, @code{rl_filename_completion_function()}, is used. @end deftypevar *************** *** 1098,1122 **** Complete the word at or before point. You have supplied the function that does the initial simple matching selection algorithm (see ! @code{completion_matches ()} and @code{rl_completion_entry_function}). The default is to do filename ! completion. This calls @code{rl_complete_internal ()} with an argument depending on @var{invoking_key}. @end deftypefun ! @deftypefun int rl_possible_completions (int count, int invoking_key)) List the possible completions. See description of @code{rl_complete ! ()}. This calls @code{rl_complete_internal ()} with an argument of @samp{?}. @end deftypefun ! @deftypefun int rl_insert_completions (int count, int invoking_key)) Insert the list of possible completions into the line, deleting the ! partially-completed word. See description of @code{rl_complete ()}. ! This calls @code{rl_complete_internal ()} with an argument of @samp{*}. @end deftypefun ! @deftypefun {char **} completion_matches (char *text, CPFunction *entry_func) ! Returns an array of @code{(char *)} which is a list of completions for ! @var{text}. If there are no completions, returns @code{(char **)NULL}. The first entry in the returned array is the substitution for @var{text}. The remaining entries are the possible completions. The array is --- 1398,1422 ---- Complete the word at or before point. You have supplied the function that does the initial simple matching selection algorithm (see ! @code{rl_completion_matches()} and @code{rl_completion_entry_function}). The default is to do filename ! completion. This calls @code{rl_complete_internal()} with an argument depending on @var{invoking_key}. @end deftypefun ! @deftypefun int rl_possible_completions (int count, int invoking_key) List the possible completions. See description of @code{rl_complete ! ()}. This calls @code{rl_complete_internal()} with an argument of @samp{?}. @end deftypefun ! @deftypefun int rl_insert_completions (int count, int invoking_key) Insert the list of possible completions into the line, deleting the ! partially-completed word. See description of @code{rl_complete()}. ! This calls @code{rl_complete_internal()} with an argument of @samp{*}. @end deftypefun ! @deftypefun {char **} rl_completion_matches (const char *text, rl_compentry_func_t *entry_func) ! Returns an array of strings which is a list of completions for ! @var{text}. If there are no completions, returns @code{NULL}. The first entry in the returned array is the substitution for @var{text}. The remaining entries are the possible completions. The array is *************** *** 1124,1128 **** @var{entry_func} is a function of two args, and returns a ! @code{(char *)}. The first argument is @var{text}. The second is a state argument; it is zero on the first call, and non-zero on subsequent calls. @var{entry_func} returns a @code{NULL} pointer to the caller --- 1424,1428 ---- @var{entry_func} is a function of two args, and returns a ! @code{char *}. The first argument is @var{text}. The second is a state argument; it is zero on the first call, and non-zero on subsequent calls. @var{entry_func} returns a @code{NULL} pointer to the caller *************** *** 1130,1142 **** @end deftypefun ! @deftypefun {char *} filename_completion_function (char *text, int state) ! A generator function for filename completion in the general case. Note ! that completion in Bash is a little different because of all ! the pathnames that must be followed when looking up completions for a ! command. The Bash source is a useful reference for writing custom ! completion functions. @end deftypefun ! @deftypefun {char *} username_completion_function (char *text, int state) A completion generator for usernames. @var{text} contains a partial username preceded by a random character (usually @samp{~}). As with all --- 1430,1442 ---- @end deftypefun ! @deftypefun {char *} rl_filename_completion_function (const char *text, int state) ! A generator function for filename completion in the general case. ! @var{text} is a partial filename. ! The Bash source is a useful reference for writing custom ! completion functions (the Bash completion functions call this and other ! Readline functions). @end deftypefun ! @deftypefun {char *} rl_username_completion_function (const char *text, int state) A completion generator for usernames. @var{text} contains a partial username preceded by a random character (usually @samp{~}). As with all *************** *** 1148,1171 **** @subsection Completion Variables ! @deftypevar {Function *} rl_completion_entry_function ! A pointer to the generator function for @code{completion_matches ()}. ! @code{NULL} means to use @code{filename_completion_function ()}, the default filename completer. @end deftypevar ! @deftypevar {CPPFunction *} rl_attempted_completion_function A pointer to an alternative function to create matches. The function is called with @var{text}, @var{start}, and @var{end}. ! @var{start} and @var{end} are indices in @code{rl_line_buffer} saying ! what the boundaries of @var{text} are. If this function exists and ! returns @code{NULL}, or if this variable is set to @code{NULL}, then ! @code{rl_complete ()} will call the value of @code{rl_completion_entry_function} to generate matches, otherwise the array of strings returned will be used. @end deftypevar ! @deftypevar {CPFunction *} rl_filename_quoting_function ! A pointer to a function that will quote a filename in an application- ! specific fashion. This is called if filename completion is being attempted and one of the characters in @code{rl_filename_quote_characters} appears in a completed filename. The function is called with --- 1448,1474 ---- @subsection Completion Variables ! @deftypevar {rl_compentry_func_t *} rl_completion_entry_function ! A pointer to the generator function for @code{rl_completion_matches()}. ! @code{NULL} means to use @code{rl_filename_completion_function()}, the default filename completer. @end deftypevar ! @deftypevar {rl_completion_func_t *} rl_attempted_completion_function A pointer to an alternative function to create matches. The function is called with @var{text}, @var{start}, and @var{end}. ! @var{start} and @var{end} are indices in @code{rl_line_buffer} defining ! the boundaries of @var{text}, which is a character string. ! If this function exists and returns @code{NULL}, or if this variable is ! set to @code{NULL}, then @code{rl_complete()} will call the value of @code{rl_completion_entry_function} to generate matches, otherwise the array of strings returned will be used. + If this function sets the @code{rl_attempted_completion_over} + variable to a non-zero value, Readline will not perform its default + completion even if this function returns no matches. @end deftypevar ! @deftypevar {rl_quote_func_t *} rl_filename_quoting_function ! A pointer to a function that will quote a filename in an ! application-specific fashion. This is called if filename completion is being attempted and one of the characters in @code{rl_filename_quote_characters} appears in a completed filename. The function is called with *************** *** 1179,1183 **** @end deftypevar ! @deftypevar {CPFunction *} rl_filename_dequoting_function A pointer to a function that will remove application-specific quoting characters from a filename before completion is attempted, so those --- 1482,1486 ---- @end deftypevar ! @deftypevar {rl_dequote_func_t *} rl_filename_dequoting_function A pointer to a function that will remove application-specific quoting characters from a filename before completion is attempted, so those *************** *** 1189,1196 **** @end deftypevar ! @deftypevar {Function *} rl_char_is_quoted_p A pointer to a function to call that determines whether or not a specific character in the line buffer is quoted, according to whatever quoting ! mechanism the program calling readline uses. The function is called with two arguments: @var{text}, the text of the line, and @var{index}, the index of the character in the line. It is used to decide whether a --- 1492,1499 ---- @end deftypevar ! @deftypevar {rl_linebuf_func_t *} rl_char_is_quoted_p A pointer to a function to call that determines whether or not a specific character in the line buffer is quoted, according to whatever quoting ! mechanism the program calling Readline uses. The function is called with two arguments: @var{text}, the text of the line, and @var{index}, the index of the character in the line. It is used to decide whether a *************** *** 1205,1227 **** @end deftypevar ! @deftypevar {char *} rl_basic_word_break_characters The basic list of characters that signal a break between words for the completer routine. The default value of this variable is the characters ! which break words for completion in Bash, i.e., @code{" \t\n\"\\'`@@$><=;|&@{("}. @end deftypevar ! @deftypevar {char *} rl_basic_quote_characters ! List of quote characters which can cause a word break. @end deftypevar ! @deftypevar {char *} rl_completer_word_break_characters The list of characters that signal a break between words for ! @code{rl_complete_internal ()}. The default list is the value of @code{rl_basic_word_break_characters}. @end deftypevar ! @deftypevar {char *} rl_completer_quote_characters ! List of characters which can be used to quote a substring of the line. Completion occurs on the entire substring, and within the substring @code{rl_completer_word_break_characters} are treated as any other character, --- 1508,1530 ---- @end deftypevar ! @deftypevar {const char *} rl_basic_word_break_characters The basic list of characters that signal a break between words for the completer routine. The default value of this variable is the characters ! which break words for completion in Bash: @code{" \t\n\"\\'`@@$><=;|&@{("}. @end deftypevar ! @deftypevar {const char *} rl_basic_quote_characters ! A list of quote characters which can cause a word break. @end deftypevar ! @deftypevar {const char *} rl_completer_word_break_characters The list of characters that signal a break between words for ! @code{rl_complete_internal()}. The default list is the value of @code{rl_basic_word_break_characters}. @end deftypevar ! @deftypevar {const char *} rl_completer_quote_characters ! A list of characters which can be used to quote a substring of the line. Completion occurs on the entire substring, and within the substring @code{rl_completer_word_break_characters} are treated as any other character, *************** *** 1229,1238 **** @end deftypevar ! @deftypevar {char *} rl_filename_quote_characters A list of characters that cause a filename to be quoted by the completer when they appear in a completed filename. The default is the null string. @end deftypevar ! @deftypevar {char *} rl_special_prefixes The list of characters that are word break characters, but should be left in @var{text} when it is passed to the completion function. --- 1532,1541 ---- @end deftypevar ! @deftypevar {const char *} rl_filename_quote_characters A list of characters that cause a filename to be quoted by the completer when they appear in a completed filename. The default is the null string. @end deftypevar ! @deftypevar {const char *} rl_special_prefixes The list of characters that are word break characters, but should be left in @var{text} when it is passed to the completion function. *************** *** 1253,1257 **** @deftypevar int rl_ignore_completion_duplicates ! If non-zero, then disallow duplicates in the matches. Default is 1. @end deftypevar --- 1556,1561 ---- @deftypevar int rl_ignore_completion_duplicates ! If non-zero, then duplicates in the matches are removed. ! The default is 1. @end deftypevar *************** *** 1261,1266 **** within a completion entry generator function. If it is set to a non-zero value, directory names have a slash appended and Readline attempts to ! quote completed filenames if they contain any embedded word break ! characters. @end deftypevar --- 1565,1571 ---- within a completion entry generator function. If it is set to a non-zero value, directory names have a slash appended and Readline attempts to ! quote completed filenames if they contain any characters in ! @code{rl_filename_quote_characters} and @code{rl_filename_quoting_desired} ! is set to a non-zero value. @end deftypevar *************** *** 1275,1284 **** @end deftypevar @deftypevar int rl_inhibit_completion ! If this variable is non-zero, completion is inhibit - extern char *getwd (); extern char *xmalloc (); /* The names of functions that actually do the manipulation. */ ! int com_list (), com_view (), com_rename (), com_stat (), com_pwd (); ! int com_delete (), com_help (), com_cd (), com_quit (); /* A structure which contains information on the commands this program --- 1660,1675 ---- #include extern char *xmalloc (); /* The names of functions that actually do the manipulation. */ ! int com_list __P((char *)); ! int com_view __P((char *)); ! int com_rename __P((char *)); ! int com_stat __P((char *)); ! int com_pwd __P((char *)); ! int com_delete __P((char *)); ! int com_help __P((char *)); ! int com_cd __P((char *)); ! int com_quit __P((char *)); /* A structure which contains information on the commands this program *************** *** 1347,1351 **** typedef struct @{ char *name; /* User printable name of the function. */ ! Function *func; /* Function to call to do the job. */ char *doc; /* Documentation for this function. */ @} COMMAND; --- 1678,1682 ---- typedef struct @{ char *name; /* User printable name of the function. */ ! rl_icpfunc_t *func; /* Function to call to do the job. */ char *doc; /* Documentation for this function. */ @} COMMAND; *************** *** 1363,1367 **** @{ "stat", com_stat, "Print out statistics on FILE" @}, @{ "view", com_view, "View the contents of FILE" @}, ! @{ (char *)NULL, (Function *)NULL, (char *)NULL @} @}; --- 1694,1698 ---- @{ "stat", com_stat, "Print out statistics on FILE" @}, @{ "view", com_view, "View the contents of FILE" @}, ! @{ (char *)NULL, (rl_icpfunc_t *)NULL, (char *)NULL @} @}; *************** *** 1373,1377 **** char *progname; ! /* When non-zero, this global means the user is done using this program. */ int done; --- 1704,1708 ---- char *progname; ! /* When non-zero, this means the user is done using this program. */ int done; *************** *** 1503,1512 **** /* **************************************************************** */ ! char *command_generator (); ! char **fileman_completion (); ! /* Tell the GNU Readline library how to complete. We want to try to complete ! on command names if this is the first word in the line, or on filenames ! if not. */ initialize_readline () @{ --- 1834,1843 ---- /* **************************************************************** */ ! char *command_generator __P((const char *, int)); ! char **fileman_completion __P((const char *, int, int)); ! /* Tell the GNU Readline library how to complete. We want to try to ! complete on command names if this is the first word in the line, or ! on filenames if not. */ initialize_readline () @{ *************** *** 1515,1529 **** /* Tell the completer that we want a crack first. */ ! rl_attempted_completion_function = (CPPFunction *)fileman_completion; @} ! /* Attempt to complete on the contents of TEXT. START and END bound the ! region of rl_line_buffer that contains the word to complete. TEXT is ! the word to complete. We can use the entire contents of rl_line_buffer ! in case we want to do some simple parsing. Return the array of matches, ! or NULL if there aren't any. */ char ** fileman_completion (text, start, end) ! char *text; int start, end; @{ --- 1846,1860 ---- /* Tell the completer that we want a crack first. */ ! rl_attempted_completion_function = fileman_completion; @} ! /* Attempt to complete on the contents of TEXT. START and END ! bound the region of rl_line_buffer that contains the word to ! complete. TEXT is the word to complete. We can use the entire ! contents of rl_line_buffer in case we want to do some simple ! parsing. Returnthe array of matches, or NULL if there aren't any. */ char ** fileman_completion (text, start, end) ! const char *text; int start, end; @{ *************** *** 1536,1550 **** directory. */ if (start == 0) ! matches = completion_matches (text, command_generator); return (matches); @} ! /* Generator function for command completion. STATE lets us know whether ! to start from scratch; without any state (i.e. STATE == 0), then we ! start at the top of the list. */ char * command_generator (text, state) ! char *text; int state; @{ --- 1867,1881 ---- directory. */ if (start == 0) ! matches = rl_completion_matches (text, command_generator); return (matches); @} ! /* Generator function for command completion. STATE lets us ! know whether to start from scratch; without any state ! (i.e. STATE == 0), then we start at the top of the list. */ char * command_generator (text, state) ! const char *text; int state; @{ *************** *** 1552,1558 **** char *name; ! /* If this is a new word to complete, initialize now. This includes ! saving the length of TEXT for efficiency, and initializing the index ! variable to 0. */ if (!state) @{ --- 1883,1889 ---- char *name; ! /* If this is a new word to complete, initialize now. This ! includes saving the length of TEXT for efficiency, and ! initializing the index variable to 0. */ if (!state) @{ *************** *** 1561,1565 **** @} ! /* Return the next name which partially matches from the command list. */ while (name = commands[list_index].name) @{ --- 1892,1897 ---- @} ! /* Return the next name which partially matches from the ! command list. */ while (name = commands[list_index].name) @{ *************** *** 1706,1710 **** char dir[1024], *s; ! s = getwd (dir); if (s == 0) @{ --- 2038,2042 ---- char dir[1024], *s; ! s = getcwd (dir, sizeof(dir) - 1); if (s == 0) @{ *************** *** 1717,1721 **** @} ! /* The user wishes to quit using this program. Just set DONE non-zero. */ com_quit (arg) char *arg; --- 2049,2054 ---- @} ! /* The user wishes to quit using this program. Just set DONE ! non-zero. */ com_quit (arg) char *arg; diff -Nrc2 readline-4.1/doc/rluser.texinfo readline-4.2/doc/rluser.texinfo *** readline-4.1/doc/rluser.texinfo Tue Feb 22 12:19:32 2000 --- readline-4.2/doc/rluser.texinfo Mon Mar 5 11:11:53 2001 *************** *** 11,15 **** GNU Readline Library. ! Copyright (C) 1988-1999 Free Software Foundation, Inc. Authored by Brian Fox and Chet Ramey. --- 11,15 ---- GNU Readline Library. ! Copyright (C) 1988-2000 Free Software Foundation, Inc. Authored by Brian Fox and Chet Ramey. *************** *** 73,81 **** keystrokes. ! The text @key{C-k} is read as `Control-K' and describes the character produced when the @key{k} key is pressed while the Control key is depressed. ! The text @key{M-k} is read as `Meta-K' and describes the character produced when the Meta key (if you have one) is depressed, and the @key{k} key is pressed. --- 73,81 ---- keystrokes. ! The text @kbd{C-k} is read as `Control-K' and describes the character produced when the @key{k} key is pressed while the Control key is depressed. ! The text @kbd{M-k} is read as `Meta-K' and describes the character produced when the Meta key (if you have one) is depressed, and the @key{k} key is pressed. *************** *** 90,98 **** If you do not have a Meta or @key{ALT} key, or another key working as a Meta key, the identical keystroke can be generated by typing @key{ESC} ! @i{first}, and then typing @key{k}. Either process is known as @dfn{metafying} the @key{k} key. ! The text @key{M-C-k} is read as `Meta-Control-k' and describes the ! character produced by @dfn{metafying} @key{C-k}. In addition, several keys have their own names. Specifically, --- 90,98 ---- If you do not have a Meta or @key{ALT} key, or another key working as a Meta key, the identical keystroke can be generated by typing @key{ESC} ! @emph{first}, and then typing @key{k}. Either process is known as @dfn{metafying} the @key{k} key. ! The text @kbd{M-C-k} is read as `Meta-Control-k' and describes the ! character produced by @dfn{metafying} @kbd{C-k}. In addition, several keys have their own names. Specifically, *************** *** 116,121 **** you move the cursor to the place that needs correction, and delete or insert the text of the corrections. Then, when you are satisfied with ! the line, you simply press @key{RETURN}. You do not have to be at the ! end of the line to press @key{RETURN}; the entire line is accepted regardless of the location of the cursor within the line. --- 116,121 ---- you move the cursor to the place that needs correction, and delete or insert the text of the corrections. Then, when you are satisfied with ! the line, you simply press @key{RET}. You do not have to be at the ! end of the line to press @key{RET}; the entire line is accepted regardless of the location of the cursor within the line. *************** *** 141,147 **** Sometimes you may mistype a character, and not notice the error until you have typed several other characters. In ! that case, you can type @key{C-b} to move the cursor to the left, and then correct your mistake. Afterwards, you can move the cursor to the right ! with @key{C-f}. When you add text in the middle of a line, you will notice that characters --- 141,147 ---- Sometimes you may mistype a character, and not notice the error until you have typed several other characters. In ! that case, you can type @kbd{C-b} to move the cursor to the left, and then correct your mistake. Afterwards, you can move the cursor to the right ! with @kbd{C-f}. When you add text in the middle of a line, you will notice that characters *************** *** 153,167 **** @table @asis ! @item @key{C-b} Move back one character. ! @item @key{C-f} Move forward one character. @item @key{DEL} or @key{Backspace} Delete the character to the left of the cursor. ! @item @key{C-d} Delete the character underneath the cursor. @item @w{Printing characters} Insert the character into the line at the cursor. ! @item @key{C-_} or @key{C-x C-u} Undo the last editing command. You can undo all the way back to an empty line. --- 153,167 ---- @table @asis ! @item @kbd{C-b} Move back one character. ! @item @kbd{C-f} Move forward one character. @item @key{DEL} or @key{Backspace} Delete the character to the left of the cursor. ! @item @kbd{C-d} Delete the character underneath the cursor. @item @w{Printing characters} Insert the character into the line at the cursor. ! @item @kbd{C-_} or @kbd{C-x C-u} Undo the last editing command. You can undo all the way back to an empty line. *************** *** 171,175 **** (Depending on your configuration, the @key{Backspace} key be set to delete the character to the left of the cursor and the @key{DEL} key set ! to delete the character underneath the cursor, like @key{C-d}, rather than the character to the left of the cursor.) --- 171,175 ---- (Depending on your configuration, the @key{Backspace} key be set to delete the character to the left of the cursor and the @key{DEL} key set ! to delete the character underneath the cursor, like @kbd{C-d}, rather than the character to the left of the cursor.) *************** *** 180,188 **** The above table describes the most basic keystrokes that you need in order to do editing of the input line. For your convenience, many ! other commands have been added in addition to @key{C-b}, @key{C-f}, ! @key{C-d}, and @key{DEL}. Here are some commands for moving more rapidly about the line. ! @table @key @item C-a Move to the start of the line. --- 180,188 ---- The above table describes the most basic keystrokes that you need in order to do editing of the input line. For your convenience, many ! other commands have been added in addition to @kbd{C-b}, @kbd{C-f}, ! @kbd{C-d}, and @key{DEL}. Here are some commands for moving more rapidly about the line. ! @table @kbd @item C-a Move to the start of the line. *************** *** 197,201 **** @end table ! Notice how @key{C-f} moves forward a character, while @key{M-f} moves forward a word. It is a loose convention that control keystrokes operate on characters while meta keystrokes operate on words. --- 197,201 ---- @end table ! Notice how @kbd{C-f} moves forward a character, while @kbd{M-f} moves forward a word. It is a loose convention that control keystrokes operate on characters while meta keystrokes operate on words. *************** *** 226,230 **** Here is the list of commands for killing text. ! @table @key @item C-k Kill the text from the current cursor position to the end of the line. --- 226,230 ---- Here is the list of commands for killing text. ! @table @kbd @item C-k Kill the text from the current cursor position to the end of the line. *************** *** 233,246 **** Kill from the cursor to the end of the current word, or, if between words, to the end of the next word. ! Word boundaries are the same as those used by @key{M-f}. ! @item M-DEL Kill from the cursor the start of the previous word, or, if between words, to the start of the previous word. ! Word boundaries are the same as those used by @key{M-b}. @item C-w Kill from the cursor to the previous whitespace. This is different than ! @key{M-DEL} because the word boundaries differ. @end table --- 233,246 ---- Kill from the cursor to the end of the current word, or, if between words, to the end of the next word. ! Word boundaries are the same as those used by @kbd{M-f}. ! @item M-@key{DEL} Kill from the cursor the start of the previous word, or, if between words, to the start of the previous word. ! Word boundaries are the same as those used by @kbd{M-b}. @item C-w Kill from the cursor to the previous whitespace. This is different than ! @kbd{M-@key{DEL}} because the word boundaries differ. @end table *************** *** 249,253 **** means to copy the most-recently-killed text from the kill buffer. ! @table @key @item C-y Yank the most recently killed text back into the buffer at the cursor. --- 249,253 ---- means to copy the most-recently-killed text from the kill buffer. ! @table @kbd @item C-y Yank the most recently killed text back into the buffer at the cursor. *************** *** 255,259 **** @item M-y Rotate the kill-ring, and yank the new top. You can only do this if ! the prior command is @key{C-y} or @key{M-y}. @end table --- 255,259 ---- @item M-y Rotate the kill-ring, and yank the new top. You can only do this if ! the prior command is @kbd{C-y} or @kbd{M-y}. @end table *************** *** 273,277 **** you have typed one meta digit to get the argument started, you can type the remainder of the digits, and then the command. For example, to give ! the @key{C-d} command an argument of 10, you could type @samp{M-1 0 C-d}. @node Searching --- 273,278 ---- you have typed one meta digit to get the argument started, you can type the remainder of the digits, and then the command. For example, to give ! the @kbd{C-d} command an argument of 10, you could type @samp{M-1 0 C-d}, ! which will delete the next ten characters on the input line. @node Searching *************** *** 283,287 **** @end ifset for lines containing a specified string. ! There are two search modes: @var{incremental} and @var{non-incremental}. Incremental searches begin before the user has finished typing the --- 284,288 ---- @end ifset for lines containing a specified string. ! There are two search modes: @dfn{incremental} and @dfn{non-incremental}. Incremental searches begin before the user has finished typing the *************** *** 292,306 **** find the desired history entry. To search backward in the history for a particular string, type ! @key{C-r}. Typing @key{C-s} searches forward through the history. The characters present in the value of the @code{isearch-terminators} variable are used to terminate an incremental search. If that variable has not been assigned a value, the @key{ESC} and ! @key{C-J} characters will terminate an incremental search. ! @key{C-g} will abort an incremental search and restore the original line. When the search is terminated, the history entry containing the search string becomes the current line. ! To find other matching entries in the history list, type @key{C-r} or ! @key{C-s} as appropriate. This will search backward or forward in the history for the next entry matching the search string typed so far. --- 293,307 ---- find the desired history entry. To search backward in the history for a particular string, type ! @kbd{C-r}. Typing @kbd{C-s} searches forward through the history. The characters present in the value of the @code{isearch-terminators} variable are used to terminate an incremental search. If that variable has not been assigned a value, the @key{ESC} and ! @kbd{C-J} characters will terminate an incremental search. ! @kbd{C-g} will abort an incremental search and restore the original line. When the search is terminated, the history entry containing the search string becomes the current line. ! To find other matching entries in the history list, type @kbd{C-r} or ! @kbd{C-s} as appropriate. This will search backward or forward in the history for the next entry matching the search string typed so far. *************** *** 309,312 **** --- 310,315 ---- For instance, a @key{RET} will terminate the search and accept the line, thereby executing the command from the history list. + A movement command will terminate the search, make the last line found + the current line, and begin editing. Non-incremental searches read the entire search string before starting *************** *** 325,332 **** The name of this @ifset BashFeatures ! file is taken from the value of the shell variable @code{INPUTRC}. If @end ifset @ifclear BashFeatures ! file is taken from the value of the environment variable @code{INPUTRC}. If @end ifclear that variable is unset, the default is @file{~/.inputrc}. --- 328,335 ---- The name of this @ifset BashFeatures ! file is taken from the value of the shell variable @env{INPUTRC}. If @end ifset @ifclear BashFeatures ! file is taken from the value of the environment variable @env{INPUTRC}. If @end ifclear that variable is unset, the default is @file{~/.inputrc}. *************** *** 360,364 **** You can modify the run-time behavior of Readline by altering the values of variables in Readline ! using the @code{set} command within the init file. Here is how to change from the default Emacs-like key binding to use @code{vi} line editing commands: --- 363,375 ---- You can modify the run-time behavior of Readline by altering the values of variables in Readline ! using the @code{set} command within the init file. ! The syntax is simple: ! ! @example ! set @var{variable} @var{value} ! @end example ! ! @noindent ! Here, for example, is how to change from the default Emacs-like key binding to use @code{vi} line editing commands: *************** *** 368,371 **** --- 379,385 ---- @end example + Variable names and values, where appropriate, are recognized without regard + to case. + @ifset BashFeatures The @w{@code{bind -V}} command lists the current Readline variable names *************** *** 376,379 **** --- 390,394 ---- variables. + @cindex variables, readline @table @code *************** *** 403,413 **** number of possible completions is greater than this value, Readline will ask the user whether or not he wishes to view ! them; otherwise, they are simply listed. The default limit is ! @code{100}. @item convert-meta @vindex convert-meta If set to @samp{on}, Readline will convert characters with the ! eighth bit set to an ASCII key sequence by stripping the eighth bit and prefixing an @key{ESC} character, converting them to a meta-prefixed key sequence. The default value is @samp{on}. --- 418,429 ---- number of possible completions is greater than this value, Readline will ask the user whether or not he wishes to view ! them; otherwise, they are simply listed. ! This variable must be set to an integer value greater than or equal to 0. ! The default limit is @code{100}. @item convert-meta @vindex convert-meta If set to @samp{on}, Readline will convert characters with the ! eighth bit set to an @sc{ascii} key sequence by stripping the eighth bit and prefixing an @key{ESC} character, converting them to a meta-prefixed key sequence. The default value is @samp{on}. *************** *** 449,453 **** @vindex meta-flag If set to @samp{on}, Readline will enable eight-bit input (it ! will not strip the eighth bit from the characters it reads), regardless of what the terminal claims it can support. The default value is @samp{off}. The name @code{meta-flag} is a --- 465,469 ---- @vindex meta-flag If set to @samp{on}, Readline will enable eight-bit input (it ! will not clear the eighth bit in the characters it reads), regardless of what the terminal claims it can support. The default value is @samp{off}. The name @code{meta-flag} is a *************** *** 459,463 **** subsequently executing the character as a command (@pxref{Searching}). If this variable has not been given a value, the characters @key{ESC} and ! @key{C-J} will terminate an incremental search. @item keymap --- 475,479 ---- subsequently executing the character as a command (@pxref{Searching}). If this variable has not been given a value, the characters @key{ESC} and ! @kbd{C-J} will terminate an incremental search. @item keymap *************** *** 470,473 **** --- 486,490 ---- @code{emacs-ctlx}, @code{vi}, + @code{vi-move}, @code{vi-command}, and @code{vi-insert}. *************** *** 521,529 **** the command does. ! Once you know the name of the command, simply place the name of the key you wish to bind the command to, a colon, and then the name of the ! command on a line in the init file. The name of the key ! can be expressed in different ways, depending on which is most ! comfortable for you. @ifset BashFeatures --- 538,550 ---- the command does. ! Once you know the name of the command, simply place on a line ! in the init file the name of the key you wish to bind the command to, a colon, and then the name of the ! command. The name of the key ! can be expressed in different ways, depending on what you find most ! comfortable. ! ! In addition to command names, readline allows keys to be bound ! to a string that is inserted when the key is pressed (a @var{macro}). @ifset BashFeatures *************** *** 542,550 **** @end example ! In the above example, @key{C-u} is bound to the function ! @code{universal-argument}, and @key{C-o} is bound to run the macro expressed on the right hand side (that is, to insert the text @samp{> output} into the line). @item @w{"@var{keyseq}": @var{function-name} or @var{macro}} @var{keyseq} differs from @var{keyname} above in that strings --- 563,588 ---- @end example ! In the above example, @kbd{C-u} is bound to the function ! @code{universal-argument}, ! @kbd{M-DEL} is bound to the function @code{backward-kill-word}, and ! @kbd{C-o} is bound to run the macro expressed on the right hand side (that is, to insert the text @samp{> output} into the line). + A number of symbolic character names are recognized while + processing this key binding syntax: + @var{DEL}, + @var{ESC}, + @var{ESCAPE}, + @var{LFD}, + @var{NEWLINE}, + @var{RET}, + @var{RETURN}, + @var{RUBOUT}, + @var{SPACE}, + @var{SPC}, + and + @var{TAB}. + @item @w{"@var{keyseq}": @var{function-name} or @var{macro}} @var{keyseq} differs from @var{keyname} above in that strings *************** *** 560,566 **** @end example ! In the above example, @key{C-u} is bound to the function @code{universal-argument} (just as it was in the first example), ! @samp{@key{C-x} @key{C-r}} is bound to the function @code{re-read-init-file}, and @samp{@key{ESC} @key{[} @key{1} @key{1} @key{~}} is bound to insert the text @samp{Function Key 1}. --- 598,604 ---- @end example ! In the above example, @kbd{C-u} is again bound to the function @code{universal-argument} (just as it was in the first example), ! @samp{@kbd{C-x} @kbd{C-r}} is bound to the function @code{re-read-init-file}, and @samp{@key{ESC} @key{[} @key{1} @key{1} @key{~}} is bound to insert the text @samp{Function Key 1}. *************** *** 607,614 **** vertical tab @item \@var{nnn} ! the character whose @code{ASCII} code is the octal value @var{nnn} (one to three digits) @item \x@var{nnn} ! the character whose @code{ASCII} code is the hexadecimal value @var{nnn} (one to three digits) @end table --- 645,652 ---- vertical tab @item \@var{nnn} ! the character whose @sc{ascii} code is the octal value @var{nnn} (one to three digits) @item \x@var{nnn} ! the character whose @sc{ascii} code is the hexadecimal value @var{nnn} (one to three digits) @end table *************** *** 620,624 **** Backslash will quote any other character in the macro text, including @samp{"} and @samp{'}. ! For example, the following binding will make @samp{C-x \} insert a single @samp{\} into the line: @example --- 658,662 ---- Backslash will quote any other character in the macro text, including @samp{"} and @samp{'}. ! For example, the following binding will make @samp{@kbd{C-x} \} insert a single @samp{\} into the line: @example *************** *** 664,668 **** The @var{application} construct is used to include application-specific settings. Each program using the Readline ! library sets the @var{application name}, and you can test for it. This could be used to bind key sequences to functions useful for a specific program. For instance, the following command adds a --- 702,707 ---- The @var{application} construct is used to include application-specific settings. Each program using the Readline ! library sets the @var{application name}, and you can test for ! a particular value. This could be used to bind key sequences to functions useful for a specific program. For instance, the following command adds a *************** *** 687,690 **** --- 726,730 ---- This directive takes a single filename as an argument and reads commands and bindings from that file. + For example, the following directive reads from @file{/etc/inputrc}: @example $include /etc/inputrc *************** *** 695,699 **** @subsection Sample Init File ! Here is an example of an inputrc file. This illustrates key binding, variable assignment, and conditional syntax. --- 735,739 ---- @subsection Sample Init File ! Here is an example of an @var{inputrc} file. This illustrates key binding, variable assignment, and conditional syntax. *************** *** 820,829 **** @var{inputrc} file, @w{@code{bind -p}}. (@xref{Bash Builtins}.) @end ifset - Command names without an accompanying key sequence are unbound by default. ! In the following descriptions, @var{point} refers to the current cursor ! position, and @var{mark} refers to a cursor position saved by the @code{set-mark} command. ! The text between the point and mark is referred to as the @var{region}. @node Commands For Moving --- 860,869 ---- @var{inputrc} file, @w{@code{bind -p}}. (@xref{Bash Builtins}.) @end ifset Command names without an accompanying key sequence are unbound by default. ! ! In the following descriptions, @dfn{point} refers to the current cursor ! position, and @dfn{mark} refers to a cursor position saved by the @code{set-mark} command. ! The text between the point and mark is referred to as the @dfn{region}. @node Commands For Moving *************** *** 863,885 **** @ftable @code ! @item accept-line (Newline, Return) @ifset BashFeatures ! Accept the line regardless of where the cursor is. If this line is non-empty, add it to the history list according to the setting of ! the @code{HISTCONTROL} and @code{HISTIGNORE} variables. ! If this line was a history line, then restore the history line to its ! original state. @end ifset @ifclear BashFeatures ! Accept the line regardless of where the cursor is. If this line is ! non-empty, add it to the history list. If this line was a history ! line, then restore the history line to its original state. @end ifclear @item previous-history (C-p) ! Move `up' through the history list. @item next-history (C-n) ! Move `down' through the history list. @item beginning-of-history (M-<) --- 903,929 ---- @ftable @code ! @item accept-line (Newline or Return) @ifset BashFeatures ! Accept the line regardless of where the cursor is. ! If this line is non-empty, add it to the history list according to the setting of ! the @env{HISTCONTROL} and @env{HISTIGNORE} variables. ! If this line is a modified history line, then restore the history line ! to its original state. @end ifset @ifclear BashFeatures ! Accept the line regardless of where the cursor is. ! If this line is ! non-empty, it may be added to the history list for future recall with ! @code{add_history()}. ! If this line is a modified history line, the history line is restored ! to its original state. @end ifclear @item previous-history (C-p) ! Move `back' through the history list, fetching the previous command. @item next-history (C-n) ! Move `forward' through the history list, fetching the next command. @item beginning-of-history (M-<) *************** *** 921,930 **** @item yank-nth-arg (M-C-y) Insert the first argument to the previous command (usually ! the second word on the previous line). With an argument @var{n}, insert the @var{n}th word from the previous command (the words in the previous command begin with word 0). A negative argument inserts the @var{n}th word from the end of the previous command. ! @item yank-last-arg (M-., M-_) Insert last argument to the previous command (the last word of the previous history entry). With an --- 965,975 ---- @item yank-nth-arg (M-C-y) Insert the first argument to the previous command (usually ! the second word on the previous line) at point. ! With an argument @var{n}, insert the @var{n}th word from the previous command (the words in the previous command begin with word 0). A negative argument inserts the @var{n}th word from the end of the previous command. ! @item yank-last-arg (M-. or M-_) Insert last argument to the previous command (the last word of the previous history entry). With an *************** *** 940,947 **** @ftable @code @item delete-char (C-d) ! Delete the character under the cursor. If the cursor is at the beginning of the line, there are no characters in the line, and the last character typed was not bound to @code{delete-char}, then ! return @code{EOF}. @item backward-delete-char (Rubout) --- 985,992 ---- @ftable @code @item delete-char (C-d) ! Delete the character at point. If point is at the beginning of the line, there are no characters in the line, and the last character typed was not bound to @code{delete-char}, then ! return @sc{eof}. @item backward-delete-char (Rubout) *************** *** 954,967 **** deleted. By default, this is not bound to a key. ! @item quoted-insert (C-q, C-v) Add the next character typed to the line verbatim. This is ! how to insert key sequences like @key{C-q}, for example. @ifclear BashFeatures ! @item tab-insert (M-TAB) Insert a tab character. @end ifclear ! @item self-insert (a, b, A, 1, !, ...) Insert yourself. --- 999,1012 ---- deleted. By default, this is not bound to a key. ! @item quoted-insert (C-q or C-v) Add the next character typed to the line verbatim. This is ! how to insert key sequences like @kbd{C-q}, for example. @ifclear BashFeatures ! @item tab-insert (M-@key{TAB}) Insert a tab character. @end ifclear ! @item self-insert (a, b, A, 1, !, @dots{}) Insert yourself. *************** *** 1007,1011 **** @item kill-whole-line () ! Kill all characters on the current line, no matter point is. By default, this is unbound. --- 1052,1056 ---- @item kill-whole-line () ! Kill all characters on the current line, no matter where point is. By default, this is unbound. *************** *** 1015,1019 **** Word boundaries are the same as @code{forward-word}. ! @item backward-kill-word (M-DEL) Kill the word behind point. Word boundaries are the same as @code{backward-word}. --- 1060,1064 ---- Word boundaries are the same as @code{forward-word}. ! @item backward-kill-word (M-@key{DEL}) Kill the word behind point. Word boundaries are the same as @code{backward-word}. *************** *** 1045,1054 **** @item yank (C-y) ! Yank the top of the kill ring into the buffer at the current ! cursor position. @item yank-pop (M-y) Rotate the kill-ring, and yank the new top. You can only do this if ! the prior command is yank or yank-pop. @end ftable --- 1090,1098 ---- @item yank (C-y) ! Yank the top of the kill ring into the buffer at point. @item yank-pop (M-y) Rotate the kill-ring, and yank the new top. You can only do this if ! the prior command is @code{yank} or @code{yank-pop}. @end ftable *************** *** 1057,1063 **** @ftable @code ! @item digit-argument (M-0, M-1, ... M--) Add this digit to the argument already accumulating, or start a new ! argument. @key{M--} starts a negative argument. @item universal-argument () --- 1101,1107 ---- @ftable @code ! @item digit-argument (@kbd{M-0}, @kbd{M-1}, @dots{} @kbd{M--}) Add this digit to the argument already accumulating, or start a new ! argument. @kbd{M--} starts a negative argument. @item universal-argument () *************** *** 1080,1090 **** @ftable @code ! @item complete (TAB) ! Attempt to do completion on the text before the cursor. This is ! application-specific. Generally, if you are typing a filename ! argument, you can do filename completion; if you are typing a command, ! you can do command completion; if you are typing in a symbol to GDB, you ! can do symbol name completion; if you are typing in a variable to Bash, ! you can do variable name completion, and so on. @ifset BashFeatures Bash attempts completion treating the text as a variable (if the --- 1124,1130 ---- @ftable @code ! @item complete (@key{TAB}) ! Attempt to perform completion on the text before point. ! The actual completion performed is application-specific. @ifset BashFeatures Bash attempts completion treating the text as a variable (if the *************** *** 1094,1100 **** of these produces a match, filename completion is attempted. @end ifset @item possible-completions (M-?) ! List the possible completions of the text before the cursor. @item insert-completions (M-*) --- 1134,1143 ---- of these produces a match, filename completion is attempted. @end ifset + @ifclear BashFeatures + The default is filename completion. + @end ifclear @item possible-completions (M-?) ! List the possible completions of the text before point. @item insert-completions (M-*) *************** *** 1107,1116 **** Repeated execution of @code{menu-complete} steps through the list of possible completions, inserting each match in turn. ! At the end of the list of completions, the bell is rung and the ! original text is restored. An argument of @var{n} moves @var{n} positions forward in the list of matches; a negative argument may be used to move backward through the list. ! This command is intended to be bound to @code{TAB}, but is unbound by default. --- 1150,1160 ---- Repeated execution of @code{menu-complete} steps through the list of possible completions, inserting each match in turn. ! At the end of the list of completions, the bell is rung ! (subject to the setting of @code{bell-style}) ! and the original text is restored. An argument of @var{n} moves @var{n} positions forward in the list of matches; a negative argument may be used to move backward through the list. ! This command is intended to be bound to @key{TAB}, but is unbound by default. *************** *** 1165,1169 **** treating it as a command name. ! @item dynamic-complete-history (M-TAB) Attempt completion on the text before point, comparing the text against lines from the history list for possible --- 1209,1213 ---- treating it as a command name. ! @item dynamic-complete-history (M-@key{TAB}) Attempt completion on the text before point, comparing the text against lines from the history list for possible *************** *** 1212,1221 **** that is bound to the corresponding uppercase character. ! @item prefix-meta (ESC) ! Make the next character typed be metafied. This is for keyboards ! without a meta key. Typing @samp{ESC f} is equivalent to typing ! @samp{M-f}. ! @item undo (C-_, C-x C-u) Incremental undo, separately remembered for each line. --- 1256,1265 ---- that is bound to the corresponding uppercase character. ! @item prefix-meta (@key{ESC}) ! Metafy the next character typed. This is for keyboards ! without a meta key. Typing @samp{@key{ESC} f} is equivalent to typing ! @kbd{M-f}. ! @item undo (C-_ or C-x C-u) Incremental undo, separately remembered for each line. *************** *** 1233,1237 **** @item set-mark (C-@@) ! Set the mark to the current point. If a numeric argument is supplied, the mark is set to that position. --- 1277,1281 ---- @item set-mark (C-@@) ! Set the mark to the point. If a numeric argument is supplied, the mark is set to that position. *************** *** 1272,1276 **** @item dump-macros () Print all of the Readline key sequences bound to macros and the ! strings they ouput. If a numeric argument is supplied, the output is formatted in such a way that it can be made part of an @var{inputrc} file. This command is unbound by default. --- 1316,1320 ---- @item dump-macros () Print all of the Readline key sequences bound to macros and the ! strings they output. If a numeric argument is supplied, the output is formatted in such a way that it can be made part of an @var{inputrc} file. This command is unbound by default. *************** *** 1306,1310 **** Perform history and alias expansion on the current line. ! @item insert-last-argument (M-., M-_) A synonym for @code{yank-last-arg}. --- 1350,1354 ---- Perform history and alias expansion on the current line. ! @item insert-last-argument (M-. or M-_) A synonym for @code{yank-last-arg}. *************** *** 1329,1333 **** editing functions, it does contain enough to allow simple editing of the line. The Readline @code{vi} mode behaves as specified in ! the @sc{POSIX} 1003.2 standard. @ifset BashFeatures --- 1373,1377 ---- editing functions, it does contain enough to allow simple editing of the line. The Readline @code{vi} mode behaves as specified in ! the @sc{posix} 1003.2 standard. @ifset BashFeatures *************** *** 1338,1342 **** @ifclear BashFeatures In order to switch interactively between @code{emacs} and @code{vi} ! editing modes, use the command M-C-j (toggle-editing-mode). @end ifclear The Readline default is @code{emacs} mode. --- 1382,1387 ---- @ifclear BashFeatures In order to switch interactively between @code{emacs} and @code{vi} ! editing modes, use the command @kbd{M-C-j} (bound to emacs-editing-mode ! when in @code{vi} mode and to vi-editing-mode in @code{emacs} mode). @end ifclear The Readline default is @code{emacs} mode. *************** *** 1375,1392 **** Only matches which are prefixed by the word being completed are returned. ! When the @samp{-f} or @samp{-d} option is used for filename or ! directory name completion, the shell variable @code{FIGNORE} is used to filter the matches. ! @xref{Bash Variables}, for a description of @code{FIGNORE}. Any completions specified by a filename expansion pattern to the ! @samp{-G} option are generated next. The words generated by the pattern need not match the word being completed. ! The @code{GLOBIGNORE} shell variable is not used to filter the matches, ! but the @code{FIGNORE} shell variable is used. ! Next, the string specified as the argument to the @samp{-W} option is considered. ! The string is first split using the characters in the @code{IFS} special variable as delimiters. Shell quoting is honored. --- 1420,1437 ---- Only matches which are prefixed by the word being completed are returned. ! When the @option{-f} or @option{-d} option is used for filename or ! directory name completion, the shell variable @env{FIGNORE} is used to filter the matches. ! @xref{Bash Variables}, for a description of @env{FIGNORE}. Any completions specified by a filename expansion pattern to the ! @option{-G} option are generated next. The words generated by the pattern need not match the word being completed. ! The @env{GLOBIGNORE} shell variable is not used to filter the matches, ! but the @env{FIGNORE} shell variable is used. ! Next, the string specified as the argument to the @option{-W} option is considered. ! The string is first split using the characters in the @env{IFS} special variable as delimiters. Shell quoting is honored. *************** *** 1401,1410 **** After these matches have been generated, any shell function or command ! specified with the @samp{-F} and @samp{-C} options is invoked. ! When the command or function is invoked, the @code{COMP_LINE} and ! @code{COMP_POINT} variables are assigned values as described above (@pxref{Bash Variables}). ! If a shell function is being invoked, the @code{COMP_WORDS} and ! @code{COMP_CWORD} variables are also set. When the function or command is invoked, the first argument is the name of the command whose arguments are being completed, the --- 1446,1455 ---- After these matches have been generated, any shell function or command ! specified with the @option{-F} and @option{-C} options is invoked. ! When the command or function is invoked, the @env{COMP_LINE} and ! @env{COMP_POINT} variables are assigned values as described above (@pxref{Bash Variables}). ! If a shell function is being invoked, the @env{COMP_WORDS} and ! @env{COMP_CWORD} variables are also set. When the function or command is invoked, the first argument is the name of the command whose arguments are being completed, the *************** *** 1415,1426 **** the matches. ! Any function specified with @samp{-F} is invoked first. The function may use any of the shell facilities, including the @code{compgen} builtin described below (@pxref{Programmable Completion Builtins}), to generate the matches. ! It must put the possible completions in the @code{COMPREPLY} array variable. ! Next, any command specified with the @samp{-C} option is invoked in an environment equivalent to command substitution. It should print a list of completions, one per line, to --- 1460,1471 ---- the matches. ! Any function specified with @option{-F} is invoked first. The function may use any of the shell facilities, including the @code{compgen} builtin described below (@pxref{Programmable Completion Builtins}), to generate the matches. ! It must put the possible completions in the @env{COMPREPLY} array variable. ! Next, any command specified with the @option{-C} option is invoked in an environment equivalent to command substitution. It should print a list of completions, one per line, to *************** *** 1429,1433 **** After all of the possible completions are generated, any filter ! specified with the @samp{-X} option is applied to the list. The filter is a pattern as used for pathname expansion; a @samp{&} in the pattern is replaced with the text of the word being completed. --- 1474,1478 ---- After all of the possible completions are generated, any filter ! specified with the @option{-X} option is applied to the list. The filter is a pattern as used for pathname expansion; a @samp{&} in the pattern is replaced with the text of the word being completed. *************** *** 1438,1450 **** not matching the pattern will be removed. ! Finally, any prefix and suffix specified with the @samp{-P} and @samp{-S} options are added to each member of the completion list, and the result is returned to the Readline completion code as the list of possible completions. ! If a compspec is found, whatever it generates is returned to the completion ! code as the full set of possible completions. ! The default Bash completions are not attempted, and the Readline ! default of filename completion is disabled. @node Programmable Completion Builtins --- 1483,1502 ---- not matching the pattern will be removed. ! Finally, any prefix and suffix specified with the @option{-P} and @option{-S} options are added to each member of the completion list, and the result is returned to the Readline completion code as the list of possible completions. ! If the previously-applied actions do not generate any matches, and the ! @option{-o dirnames} option was supplied to @code{complete} when the ! compspec was defined, directory name completion is attempted. ! ! By default, if a compspec is found, whatever it generates is returned to ! the completion code as the full set of possible completions. ! The default Bash completions are not attempted, and the Readline default ! of filename completion is disabled. ! If the @option{-o default} option was supplied to @code{complete} when the ! compspec was defined, Readline's default completion will be performed ! if the compspec generates no matches. @node Programmable Completion Builtins *************** *** 1465,1471 **** the @var{option}s, which may be any option accepted by the @code{complete} ! builtin with the exception of @samp{-p} and @samp{-r}, and write the matches to the standard output. ! When using the @samp{-F} or @samp{-C} options, the various shell variables set by the programmable completion facilities, while available, will not have useful values. --- 1517,1523 ---- the @var{option}s, which may be any option accepted by the @code{complete} ! builtin with the exception of @option{-p} and @option{-r}, and write the matches to the standard output. ! When using the @option{-F} or @option{-C} options, the various shell variables set by the programmable completion facilities, while available, will not have useful values. *************** *** 1483,1487 **** @btindex complete @example ! @code{complete [-abcdefjkvu] [-A @var{action}] [-G @var{globpat}] [-W @var{wordlist}] [-P @var{prefix}] [-S @var{suffix}] [-X @var{filterpat}] [-F @var{function}] [-C @var{command}] @var{name} [@var{name} @dots{}]} --- 1535,1539 ---- @btindex complete @example ! @code{complete [-abcdefjkvu] [-o @var{comp-option}] [-A @var{action}] [-G @var{globpat}] [-W @var{wordlist}] [-P @var{prefix}] [-S @var{suffix}] [-X @var{filterpat}] [-F @var{function}] [-C @var{command}] @var{name} [@var{name} @dots{}]} *************** *** 1490,1497 **** Specify how arguments to each @var{name} should be completed. ! If the @samp{-p} option is supplied, or if no options are supplied, existing completion specifications are printed in a way that allows them to be reused as input. ! The @samp{-r} option removes a completion specification for each @var{name}, or, if no @var{name}s are supplied, all completion specifications. --- 1542,1549 ---- Specify how arguments to each @var{name} should be completed. ! If the @option{-p} option is supplied, or if no options are supplied, existing completion specifications are printed in a way that allows them to be reused as input. ! The @option{-r} option removes a completion specification for each @var{name}, or, if no @var{name}s are supplied, all completion specifications. *************** *** 1501,1510 **** Other options, if specified, have the following meanings. ! The arguments to the @samp{-G}, @samp{-W}, and @samp{-X} options ! (and, if necessary, the @samp{-P} and @samp{-S} options) should be quoted to protect them from expansion before the @code{complete} builtin is invoked. @table @code @item -A @var{action} The @var{action} may be one of the following to generate a list of possible --- 1553,1583 ---- Other options, if specified, have the following meanings. ! The arguments to the @option{-G}, @option{-W}, and @option{-X} options ! (and, if necessary, the @option{-P} and @option{-S} options) should be quoted to protect them from expansion before the @code{complete} builtin is invoked. + + @table @code + @item -o @var{comp-option} + The @var{comp-option} controls several aspects of the compspec's behavior + beyond the simple generation of completions. + @var{comp-option} may be one of: + @table @code + + @item default + Use readline's default completion if the compspec generates no matches. + + @item dirnames + Perform directory name completion if the compspec generates no matches. + + @item filenames + Tell Readline that the compspec generates filenames, so it can perform any + filename\-specific processing (like adding a slash to directory names or + suppressing trailing spaces). This option is intended to be used with + shell functions specified with @option{-F}. + @end table + @item -A @var{action} The @var{action} may be one of the following to generate a list of possible *************** *** 1513,1517 **** @table @code @item alias ! Alias names. May also be specified as @samp{-a}. @item arrayvar --- 1586,1590 ---- @table @code @item alias ! Alias names. May also be specified as @option{-a}. @item arrayvar *************** *** 1522,1532 **** @item builtin ! Names of shell builtin commands. May also be specified as @samp{-b}. @item command ! Command names. May also be specified as @samp{-c}. @item directory ! Directory names. May also be specified as @samp{-d}. @item disabled --- 1595,1605 ---- @item builtin ! Names of shell builtin commands. May also be specified as @option{-b}. @item command ! Command names. May also be specified as @option{-c}. @item directory ! Directory names. May also be specified as @option{-d}. @item disabled *************** *** 1537,1544 **** @item export ! Names of exported shell variables. May also be specified as @samp{-e}. @item file ! File names. May also be specified as @samp{-f}. @item function --- 1610,1617 ---- @item export ! Names of exported shell variables. May also be specified as @option{-e}. @item file ! File names. May also be specified as @option{-f}. @item function *************** *** 1550,1560 **** @item hostname Hostnames, as taken from the file specified by the ! @code{HOSTFILE} shell variable (@pxref{Bash Variables}). @item job ! Job names, if job control is active. May also be specified as @samp{-j}. @item keyword ! Shell reserved words. May also be specified as @samp{-k}. @item running --- 1623,1633 ---- @item hostname Hostnames, as taken from the file specified by the ! @env{HOSTFILE} shell variable (@pxref{Bash Variables}). @item job ! Job names, if job control is active. May also be specified as @option{-j}. @item keyword ! Shell reserved words. May also be specified as @option{-k}. @item running *************** *** 1562,1566 **** @item setopt ! Valid arguments for the @samp{-o} option to the @code{set} builtin (@pxref{The Set Builtin}). --- 1635,1639 ---- @item setopt ! Valid arguments for the @option{-o} option to the @code{set} builtin (@pxref{The Set Builtin}). *************** *** 1576,1583 **** @item user ! User names. May also be specified as @samp{-u}. @item variable ! Names of all shell variables. May also be specified as @samp{-v}. @end table --- 1649,1656 ---- @item user ! User names. May also be specified as @option{-u}. @item variable ! Names of all shell variables. May also be specified as @option{-v}. @end table *************** *** 1588,1592 **** @item -W @var{wordlist} The @var{wordlist} is split using the characters in the ! @code{IFS} special variable as delimiters, and each resultant word is expanded. The possible completions are the members of the resultant list which --- 1661,1665 ---- @item -W @var{wordlist} The @var{wordlist} is split using the characters in the ! @env{IFS} special variable as delimiters, and each resultant word is expanded. The possible completions are the members of the resultant list which *************** *** 1601,1605 **** environment. When it finishes, the possible completions are retrieved from the value ! of the @code{COMPREPLY} array variable. @item -X @var{filterpat} --- 1674,1678 ---- environment. When it finishes, the possible completions are retrieved from the value ! of the @env{COMPREPLY} array variable. @item -X @var{filterpat} *************** *** 1621,1625 **** The return value is true unless an invalid option is supplied, an option ! other than @samp{-p} or @samp{-r} is supplied without a @var{name} argument, an attempt is made to remove a completion specification for a @var{name} for which no specification exists, or --- 1694,1698 ---- The return value is true unless an invalid option is supplied, an option ! other than @option{-p} or @option{-r} is supplied without a @var{name} argument, an attempt is made to remove a completion specification for a @var{name} for which no specification exists, or Binary files readline-4.1/doc/rluserman.dvi and readline-4.2/doc/rluserman.dvi differ diff -Nrc2 readline-4.1/doc/rluserman.html readline-4.2/doc/rluserman.html *** readline-4.1/doc/rluserman.html Wed Mar 1 14:53:13 2000 --- readline-4.2/doc/rluserman.html Mon Apr 16 11:05:46 2001 *************** *** 2,6 **** GNU Readline Library --- 2,6 ---- GNU Readline Library *************** *** 8,13 ****

    GNU Readline Library User Interface

    !

    Edition 4.1, for Readline Library Version 4.1.

    !

    January 2000

    Brian Fox, Free Software Foundation
    Chet Ramey, Case Western Reserve University
    --- 8,13 ----

    GNU Readline Library User Interface

    !

    Edition 4.2, for Readline Library Version 4.2.

    !

    Apr 2001

    Brian Fox, Free Software Foundation
    Chet Ramey, Case Western Reserve University
    *************** *** 82,86 ****

    ! Copyright (C) 1988-1999 Free Software Foundation, Inc.

    --- 82,86 ----

    ! Copyright (C) 1988-2001 Free Software Foundation, Inc.

    *************** *** 137,141 **** If you do not have a Meta or ALT key, or another key working as a Meta key, the identical keystroke can be generated by typing ESC ! first, and then typing k. Either process is known as metafying the k key. --- 137,141 ---- If you do not have a Meta or ALT key, or another key working as a Meta key, the identical keystroke can be generated by typing ESC ! first, and then typing k. Either process is known as metafying the k key. *************** *** 172,177 **** you move the cursor to the place that needs correction, and delete or insert the text of the corrections. Then, when you are satisfied with ! the line, you simply press RETURN. You do not have to be at the ! end of the line to press RETURN; the entire line is accepted regardless of the location of the cursor within the line. --- 172,177 ---- you move the cursor to the place that needs correction, and delete or insert the text of the corrections. Then, when you are satisfied with ! the line, you simply press RET. You do not have to be at the ! end of the line to press RET; the entire line is accepted regardless of the location of the cursor within the line. *************** *** 334,338 **** Word boundaries are the same as those used by M-f. !
    M-DEL
    Kill from the cursor the start of the previous word, or, if between --- 334,338 ---- Word boundaries are the same as those used by M-f. !
    M-DEL
    Kill from the cursor the start of the previous word, or, if between *************** *** 343,347 ****
    Kill from the cursor to the previous whitespace. This is different than ! M-DEL because the word boundaries differ.
    --- 343,347 ----
    Kill from the cursor to the previous whitespace. This is different than ! M-DEL because the word boundaries differ.
    *************** *** 383,387 **** you have typed one meta digit to get the argument started, you can type the remainder of the digits, and then the command. For example, to give ! the C-d command an argument of 10, you could type `M-1 0 C-d'.

    --- 383,388 ---- you have typed one meta digit to get the argument started, you can type the remainder of the digits, and then the command. For example, to give ! the C-d command an argument of 10, you could type `M-1 0 C-d', ! which will delete the next ten characters on the input line.

    *************** *** 393,397 **** Readline provides commands for searching through the command history for lines containing a specified string. ! There are two search modes: incremental and non-incremental.

    --- 394,398 ---- Readline provides commands for searching through the command history for lines containing a specified string. ! There are two search modes: incremental and non-incremental.

    *************** *** 423,426 **** --- 424,429 ---- For instance, a RET will terminate the search and accept the line, thereby executing the command from the history list. + A movement command will terminate the search, make the last line found + the current line, and begin editing.

    *************** *** 445,449 **** commands in an inputrc file, conventionally in his home directory. The name of this ! file is taken from the value of the environment variable INPUTRC. If that variable is unset, the default is `~/.inputrc'. --- 448,452 ---- commands in an inputrc file, conventionally in his home directory. The name of this ! file is taken from the value of the environment variable @env{INPUTRC}. If that variable is unset, the default is `~/.inputrc'. *************** *** 487,491 **** You can modify the run-time behavior of Readline by altering the values of variables in Readline ! using the set command within the init file. Here is how to change from the default Emacs-like key binding to use vi line editing commands: --- 490,502 ---- You can modify the run-time behavior of Readline by altering the values of variables in Readline ! using the set command within the init file. ! The syntax is simple: ! ! !
    ! set variable value
    ! 
    ! ! Here, for example, is how to change from the default Emacs-like key binding to use vi line editing commands: *************** *** 496,507 ****
  • A great deal of run-time behavior is changeable with the following variables.
    bell-style
    ! Controls what happens when Readline wants to ring the terminal bell. If set to `none', Readline never rings the bell. If set to --- 507,522 ---- + Variable names and values, where appropriate, are recognized without regard + to case. + A great deal of run-time behavior is changeable with the following variables. +
    bell-style
    ! Controls what happens when Readline wants to ring the terminal bell. If set to `none', Readline never rings the bell. If set to *************** *** 512,516 ****
    comment-begin
    ! The string to insert at the beginning of the line when the insert-comment command is executed. The default value --- 527,531 ----
    comment-begin
    ! The string to insert at the beginning of the line when the insert-comment command is executed. The default value *************** *** 525,539 ****
    completion-query-items
    ! The number of possible completions that determines when the user is asked whether he wants to see the list of possibilities. If the number of possible completions is greater than this value, Readline will ask the user whether or not he wishes to view ! them; otherwise, they are simply listed. The default limit is ! 100.
    convert-meta
    ! If set to `on', Readline will convert characters with the eighth bit set to an ASCII key sequence by stripping the eighth --- 540,555 ----
    completion-query-items
    ! The number of possible completions that determines when the user is asked whether he wants to see the list of possibilities. If the number of possible completions is greater than this value, Readline will ask the user whether or not he wishes to view ! them; otherwise, they are simply listed. ! This variable must be set to an integer value greater than or equal to 0. ! The default limit is 100.
    convert-meta
    ! If set to `on', Readline will convert characters with the eighth bit set to an ASCII key sequence by stripping the eighth *************** *** 543,547 ****
    disable-completion
    ! If set to `On', Readline will inhibit word completion. Completion characters will be inserted into the line as if they had --- 559,563 ----
    disable-completion
    ! If set to `On', Readline will inhibit word completion. Completion characters will be inserted into the line as if they had *************** *** 550,554 ****
    editing-mode
    ! The editing-mode variable controls which default set of key bindings is used. By default, Readline starts up in Emacs editing --- 566,570 ----
    editing-mode
    ! The editing-mode variable controls which default set of key bindings is used. By default, Readline starts up in Emacs editing *************** *** 558,562 ****
    enable-keypad
    ! When set to `on', Readline will try to enable the application keypad when it is called. Some systems need this to enable the --- 574,578 ----
    enable-keypad
    ! When set to `on', Readline will try to enable the application keypad when it is called. Some systems need this to enable the *************** *** 565,569 ****
    expand-tilde
    ! If set to `on', tilde expansion is performed when Readline attempts word completion. The default is `off'. --- 581,585 ----
    expand-tilde
    ! If set to `on', tilde expansion is performed when Readline attempts word completion. The default is `off'. *************** *** 571,575 ****
    horizontal-scroll-mode
    ! This variable can be set to either `on' or `off'. Setting it to `on' means that the text of the lines being edited will scroll --- 587,591 ----
    horizontal-scroll-mode
    ! This variable can be set to either `on' or `off'. Setting it to `on' means that the text of the lines being edited will scroll *************** *** 580,587 ****
    input-meta
    - If set to `on', Readline will enable eight-bit input (it ! will not strip the eighth bit from the characters it reads), regardless of what the terminal claims it can support. The default value is `off'. The name meta-flag is a --- 596,603 ----
    input-meta
    + If set to `on', Readline will enable eight-bit input (it ! will not clear the eighth bit in the characters it reads), regardless of what the terminal claims it can support. The default value is `off'. The name meta-flag is a *************** *** 590,594 ****
    isearch-terminators
    ! The string of characters that should terminate an incremental search without subsequently executing the character as a command (see section Searching for Commands in the History). --- 606,610 ----
    isearch-terminators
    ! The string of characters that should terminate an incremental search without subsequently executing the character as a command (see section Searching for Commands in the History). *************** *** 598,602 ****
    keymap
    ! Sets Readline's idea of the current keymap for key binding commands. Acceptable keymap names are --- 614,618 ----
    keymap
    ! Sets Readline's idea of the current keymap for key binding commands. Acceptable keymap names are *************** *** 606,609 **** --- 622,626 ---- emacs-ctlx, vi, + vi-move, vi-command, and vi-insert. *************** *** 620,624 ****
    mark-modified-lines
    ! This variable, when set to `on', causes Readline to display an asterisk (`*') at the start of history lines which have been modified. --- 637,641 ----
    mark-modified-lines
    ! This variable, when set to `on', causes Readline to display an asterisk (`*') at the start of history lines which have been modified. *************** *** 627,631 ****
    output-meta
    ! If set to `on', Readline will display characters with the eighth bit set directly rather than as a meta-prefixed escape --- 644,648 ----
    output-meta
    ! If set to `on', Readline will display characters with the eighth bit set directly rather than as a meta-prefixed escape *************** *** 640,644 ****
    show-all-if-ambiguous
    ! This alters the default behavior of the completion functions. If set to `on', --- 657,661 ----
    show-all-if-ambiguous
    ! This alters the default behavior of the completion functions. If set to `on', *************** *** 649,653 ****
    visible-stats
    ! If set to `on', a character denoting a file's type is appended to the filename when listing possible --- 666,670 ----
    visible-stats
    ! If set to `on', a character denoting a file's type is appended to the filename when listing possible *************** *** 664,672 **** the command does. ! Once you know the name of the command, simply place the name of the key you wish to bind the command to, a colon, and then the name of the ! command on a line in the init file. The name of the key ! can be expressed in different ways, depending on which is most ! comfortable for you.
    --- 681,693 ---- the command does. ! Once you know the name of the command, simply place on a line ! in the init file the name of the key you wish to bind the command to, a colon, and then the name of the ! command. The name of the key ! can be expressed in different ways, depending on what you find most ! comfortable. ! ! In addition to command names, readline allows keys to be bound ! to a string that is inserted when the key is pressed (a macro).
    *************** *** 683,690 **** In the above example, C-u is bound to the function ! universal-argument, and C-o is bound to run the macro expressed on the right hand side (that is, to insert the text `> output' into the line).
    "keyseq": function-name or macro
    --- 704,728 ---- In the above example, C-u is bound to the function ! universal-argument, ! M-DEL is bound to the function backward-kill-word, and ! C-o is bound to run the macro expressed on the right hand side (that is, to insert the text `> output' into the line). + A number of symbolic character names are recognized while + processing this key binding syntax: + DEL, + ESC, + ESCAPE, + LFD, + NEWLINE, + RET, + RETURN, + RUBOUT, + SPACE, + SPC, + and + TAB. +
    "keyseq": function-name or macro
    *************** *** 702,706 **** ! In the above example, C-u is bound to the function universal-argument (just as it was in the first example), `C-x C-r' is bound to the function re-read-init-file, --- 740,744 ---- ! In the above example, C-u is again bound to the function universal-argument (just as it was in the first example), `C-x C-r' is bound to the function re-read-init-file, *************** *** 766,774 ****
    \nnn
    ! the character whose ASCII code is the octal value nnn (one to three digits)
    \xnnn
    ! the character whose ASCII code is the hexadecimal value nnn (one to three digits)
    --- 804,812 ----
    \nnn
    ! the character whose ASCII code is the octal value nnn (one to three digits)
    \xnnn
    ! the character whose ASCII code is the hexadecimal value nnn (one to three digits)
    *************** *** 780,784 **** Backslash will quote any other character in the macro text, including `"' and `''. ! For example, the following binding will make `C-x \' insert a single `\' into the line: --- 818,822 ---- Backslash will quote any other character in the macro text, including `"' and `''. ! For example, the following binding will make `C-x \' insert a single `\' into the line: *************** *** 834,838 **** The application construct is used to include application-specific settings. Each program using the Readline ! library sets the application name, and you can test for it. This could be used to bind key sequences to functions useful for a specific program. For instance, the following command adds a --- 872,877 ---- The application construct is used to include application-specific settings. Each program using the Readline ! library sets the application name, and you can test for ! a particular value. This could be used to bind key sequences to functions useful for a specific program. For instance, the following command adds a *************** *** 862,865 **** --- 901,905 ---- This directive takes a single filename as an argument and reads commands and bindings from that file. + For example, the following directive reads from `/etc/inputrc':
    ***************
    *** 874,878 ****
      
      

    ! Here is an example of an inputrc file. This illustrates key binding, variable assignment, and conditional syntax. --- 914,918 ----

    ! Here is an example of an inputrc file. This illustrates key binding, variable assignment, and conditional syntax. *************** *** 998,1009 **** This section describes Readline commands that may be bound to key sequences.

    ! Command names without an accompanying key sequence are unbound by default. ! In the following descriptions, point refers to the current cursor ! position, and mark refers to a cursor position saved by the set-mark command. ! The text between the point and mark is referred to as the region.

    --- 1038,1049 ---- This section describes Readline commands that may be bound to key sequences. + Command names without an accompanying key sequence are unbound by default.

    ! In the following descriptions, point refers to the current cursor ! position, and mark refers to a cursor position saved by the set-mark command. ! The text between the point and mark is referred to as the region.

    *************** *** 1015,1039 ****
    beginning-of-line (C-a)
    ! Move to the start of the current line.
    end-of-line (C-e)
    ! Move to the end of the line.
    forward-char (C-f)
    ! Move forward a character.
    backward-char (C-b)
    ! Move back a character.
    forward-word (M-f)
    ! Move forward to the end of the next word. Words are composed of letters and digits. --- 1055,1079 ----
    beginning-of-line (C-a)
    ! Move to the start of the current line.
    end-of-line (C-e)
    ! Move to the end of the line.
    forward-char (C-f)
    ! Move forward a character.
    backward-char (C-b)
    ! Move back a character.
    forward-word (M-f)
    ! Move forward to the end of the next word. Words are composed of letters and digits. *************** *** 1041,1045 ****
    backward-word (M-b)
    ! Move back to the start of the current or previous word. Words are composed of letters and digits. --- 1081,1085 ----
    backward-word (M-b)
    ! Move back to the start of the current or previous word. Words are composed of letters and digits. *************** *** 1047,1051 ****
    clear-screen (C-l)
    ! Clear the screen and redraw the current line, leaving the current line at the top of the screen. --- 1087,1091 ----
    clear-screen (C-l)
    ! Clear the screen and redraw the current line, leaving the current line at the top of the screen. *************** *** 1053,1057 ****
    redraw-current-line ()
    ! Refresh the current line. By default, this is unbound. --- 1093,1097 ----
    redraw-current-line ()
    ! Refresh the current line. By default, this is unbound. *************** *** 1064,1092 ****
    !
    accept-line (Newline, Return)
    ! ! Accept the line regardless of where the cursor is. If this line is ! non-empty, add it to the history list. If this line was a history ! line, then restore the history line to its original state.
    previous-history (C-p)
    ! ! Move `up' through the history list.
    next-history (C-n)
    ! ! Move `down' through the history list.
    beginning-of-history (M-<)
    ! Move to the first line in the history.
    end-of-history (M->)
    ! Move to the end of the input history, i.e., the line currently being entered. --- 1104,1135 ----
    !
    accept-line (Newline or Return)
    ! ! Accept the line regardless of where the cursor is. ! If this line is ! non-empty, it may be added to the history list for future recall with ! add_history(). ! If this line is a modified history line, the history line is restored ! to its original state.
    previous-history (C-p)
    ! ! Move `back' through the history list, fetching the previous command.
    next-history (C-n)
    ! ! Move `forward' through the history list, fetching the next command.
    beginning-of-history (M-<)
    ! Move to the first line in the history.
    end-of-history (M->)
    ! Move to the end of the input history, i.e., the line currently being entered. *************** *** 1094,1098 ****
    reverse-search-history (C-r)
    ! Search backward starting at the current line and moving `up' through the history as necessary. This is an incremental search. --- 1137,1141 ----
    reverse-search-history (C-r)
    ! Search backward starting at the current line and moving `up' through the history as necessary. This is an incremental search. *************** *** 1100,1104 ****
    forward-search-history (C-s)
    ! Search forward starting at the current line and moving `down' through the the history as necessary. This is an incremental search. --- 1143,1147 ----
    forward-search-history (C-s)
    ! Search forward starting at the current line and moving `down' through the the history as necessary. This is an incremental search. *************** *** 1106,1110 ****
    non-incremental-reverse-search-history (M-p)
    ! Search backward starting at the current line and moving `up' through the history as necessary using a non-incremental search --- 1149,1153 ----
    non-incremental-reverse-search-history (M-p)
    ! Search backward starting at the current line and moving `up' through the history as necessary using a non-incremental search *************** *** 1113,1117 ****
    non-incremental-forward-search-history (M-n)
    ! Search forward starting at the current line and moving `down' through the the history as necessary using a non-incremental search --- 1156,1160 ----
    non-incremental-forward-search-history (M-n)
    ! Search forward starting at the current line and moving `down' through the the history as necessary using a non-incremental search *************** *** 1120,1124 ****
    history-search-forward ()
    ! Search forward through the history for the string of characters between the start of the current line and the point. --- 1163,1167 ----
    history-search-forward ()
    ! Search forward through the history for the string of characters between the start of the current line and the point. *************** *** 1128,1132 ****
    history-search-backward ()
    ! Search backward through the history for the string of characters between the start of the current line and the point. This --- 1171,1175 ----
    history-search-backward ()
    ! Search backward through the history for the string of characters between the start of the current line and the point. This *************** *** 1135,1148 ****
    yank-nth-arg (M-C-y)
    ! Insert the first argument to the previous command (usually ! the second word on the previous line). With an argument n, insert the nth word from the previous command (the words in the previous command begin with word 0). A negative argument inserts the nth word from the end of the previous command. !
    yank-last-arg (M-., M-_)
    ! Insert last argument to the previous command (the last word of the previous history entry). With an --- 1178,1192 ----
    yank-nth-arg (M-C-y)
    ! Insert the first argument to the previous command (usually ! the second word on the previous line) at point. ! With an argument n, insert the nth word from the previous command (the words in the previous command begin with word 0). A negative argument inserts the nth word from the end of the previous command. !
    yank-last-arg (M-. or M-_)
    ! Insert last argument to the previous command (the last word of the previous history entry). With an *************** *** 1161,1173 ****
    delete-char (C-d)
    ! ! Delete the character under the cursor. If the cursor is at the beginning of the line, there are no characters in the line, and the last character typed was not bound to delete-char, then ! return EOF.
    backward-delete-char (Rubout)
    ! Delete the character behind the cursor. A numeric argument means to kill the characters instead of deleting them. --- 1205,1217 ----
    delete-char (C-d)
    ! ! Delete the character at point. If point is at the beginning of the line, there are no characters in the line, and the last character typed was not bound to delete-char, then ! return EOF.
    backward-delete-char (Rubout)
    ! Delete the character behind the cursor. A numeric argument means to kill the characters instead of deleting them. *************** *** 1175,1202 ****
    forward-backward-delete-char ()
    ! Delete the character under the cursor, unless the cursor is at the end of the line, in which case the character behind the cursor is deleted. By default, this is not bound to a key. !
    quoted-insert (C-q, C-v)
    ! Add the next character typed to the line verbatim. This is how to insert key sequences like C-q, for example. !
    tab-insert (M-TAB)
    ! Insert a tab character.
    self-insert (a, b, A, 1, !, ...)
    ! Insert yourself.
    transpose-chars (C-t)
    ! Drag the character before the cursor forward over the character at the cursor, moving the --- 1219,1246 ----
    forward-backward-delete-char ()
    ! Delete the character under the cursor, unless the cursor is at the end of the line, in which case the character behind the cursor is deleted. By default, this is not bound to a key. !
    quoted-insert (C-q or C-v)
    ! Add the next character typed to the line verbatim. This is how to insert key sequences like C-q, for example. !
    tab-insert (M-TAB)
    ! Insert a tab character.
    self-insert (a, b, A, 1, !, ...)
    ! Insert yourself.
    transpose-chars (C-t)
    ! Drag the character before the cursor forward over the character at the cursor, moving the *************** *** 1208,1212 ****
    transpose-words (M-t)
    ! Drag the word before point past the word after point, moving point past that word as well. --- 1252,1256 ----
    transpose-words (M-t)
    ! Drag the word before point past the word after point, moving point past that word as well. *************** *** 1214,1218 ****
    upcase-word (M-u)
    ! Uppercase the current (or following) word. With a negative argument, uppercase the previous word, but do not move the cursor. --- 1258,1262 ----
    upcase-word (M-u)
    ! Uppercase the current (or following) word. With a negative argument, uppercase the previous word, but do not move the cursor. *************** *** 1220,1224 ****
    downcase-word (M-l)
    ! Lowercase the current (or following) word. With a negative argument, lowercase the previous word, but do not move the cursor. --- 1264,1268 ----
    downcase-word (M-l)
    ! Lowercase the current (or following) word. With a negative argument, lowercase the previous word, but do not move the cursor. *************** *** 1226,1230 ****
    capitalize-word (M-c)
    ! Capitalize the current (or following) word. With a negative argument, capitalize the previous word, but do not move the cursor. --- 1270,1274 ----
    capitalize-word (M-c)
    ! Capitalize the current (or following) word. With a negative argument, capitalize the previous word, but do not move the cursor. *************** *** 1240,1272 ****
    kill-line (C-k)
    ! Kill the text from point to the end of the line.
    backward-kill-line (C-x Rubout)
    ! Kill backward to the beginning of the line.
    unix-line-discard (C-u)
    ! Kill backward from the cursor to the beginning of the current line.
    kill-whole-line ()
    ! ! Kill all characters on the current line, no matter point is. By default, this is unbound.
    kill-word (M-d)
    ! Kill from point to the end of the current word, or if between words, to the end of the next word. Word boundaries are the same as forward-word. !
    backward-kill-word (M-DEL)
    ! Kill the word behind point. Word boundaries are the same as backward-word. --- 1284,1316 ----
    kill-line (C-k)
    ! Kill the text from point to the end of the line.
    backward-kill-line (C-x Rubout)
    ! Kill backward to the beginning of the line.
    unix-line-discard (C-u)
    ! Kill backward from the cursor to the beginning of the current line.
    kill-whole-line ()
    ! ! Kill all characters on the current line, no matter where point is. By default, this is unbound.
    kill-word (M-d)
    ! Kill from point to the end of the current word, or if between words, to the end of the next word. Word boundaries are the same as forward-word. !
    backward-kill-word (M-DEL)
    ! Kill the word behind point. Word boundaries are the same as backward-word. *************** *** 1274,1278 ****
    unix-word-rubout (C-w)
    ! Kill the word behind point, using white space as a word boundary. The killed text is saved on the kill-ring. --- 1318,1322 ----
    unix-word-rubout (C-w)
    ! Kill the word behind point, using white space as a word boundary. The killed text is saved on the kill-ring. *************** *** 1280,1289 ****
    delete-horizontal-space ()
    ! Delete all spaces and tabs around point. By default, this is unbound.
    kill-region ()
    ! Kill the text in the current region. By default, this command is unbound. --- 1324,1333 ----
    delete-horizontal-space ()
    ! Delete all spaces and tabs around point. By default, this is unbound.
    kill-region ()
    ! Kill the text in the current region. By default, this command is unbound. *************** *** 1291,1295 ****
    copy-region-as-kill ()
    ! Copy the text in the region to the kill buffer, so it can be yanked right away. By default, this command is unbound. --- 1335,1339 ----
    copy-region-as-kill ()
    ! Copy the text in the region to the kill buffer, so it can be yanked right away. By default, this command is unbound. *************** *** 1297,1301 ****
    copy-backward-word ()
    ! Copy the word before point to the kill buffer. The word boundaries are the same as backward-word. --- 1341,1345 ----
    copy-backward-word ()
    ! Copy the word before point to the kill buffer. The word boundaries are the same as backward-word. *************** *** 1304,1308 ****
    copy-forward-word ()
    ! Copy the word following point to the kill buffer. The word boundaries are the same as forward-word. --- 1348,1352 ----
    copy-forward-word ()
    ! Copy the word following point to the kill buffer. The word boundaries are the same as forward-word. *************** *** 1311,1323 ****
    yank (C-y)
    ! ! Yank the top of the kill ring into the buffer at the current ! cursor position.
    yank-pop (M-y)
    ! Rotate the kill-ring, and yank the new top. You can only do this if ! the prior command is yank or yank-pop.
    --- 1355,1366 ----
    yank (C-y)
    ! ! Yank the top of the kill ring into the buffer at point.
    yank-pop (M-y)
    ! Rotate the kill-ring, and yank the new top. You can only do this if ! the prior command is yank or yank-pop.
    *************** *** 1327,1333 ****
    !
    digit-argument (M-0, M-1, ... M--)
    ! Add this digit to the argument already accumulating, or start a new argument. M-- starts a negative argument. --- 1370,1376 ----
    !
    digit-argument (M-0, M-1, ... M--)
    ! Add this digit to the argument already accumulating, or start a new argument. M-- starts a negative argument. *************** *** 1335,1339 ****
    universal-argument ()
    ! This is another way to specify an argument. If this command is followed by one or more digits, optionally with a --- 1378,1382 ----
    universal-argument ()
    ! This is another way to specify an argument. If this command is followed by one or more digits, optionally with a *************** *** 1356,1377 ****
    !
    complete (TAB)
    ! ! Attempt to do completion on the text before the cursor. This is ! application-specific. Generally, if you are typing a filename ! argument, you can do filename completion; if you are typing a command, ! you can do command completion; if you are typing in a symbol to GDB, you ! can do symbol name completion; if you are typing in a variable to Bash, ! you can do variable name completion, and so on.
    possible-completions (M-?)
    ! ! List the possible completions of the text before the cursor.
    insert-completions (M-*)
    ! Insert all completions of the text before point that would have been generated by possible-completions. --- 1399,1417 ----
    !
    complete (TAB)
    ! ! Attempt to perform completion on the text before point. ! The actual completion performed is application-specific. ! The default is filename completion.
    possible-completions (M-?)
    ! ! List the possible completions of the text before point.
    insert-completions (M-*)
    ! Insert all completions of the text before point that would have been generated by possible-completions. *************** *** 1379,1398 ****
    menu-complete ()
    ! Similar to complete, but replaces the word to be completed with a single match from the list of possible completions. Repeated execution of menu-complete steps through the list of possible completions, inserting each match in turn. ! At the end of the list of completions, the bell is rung and the ! original text is restored. An argument of n moves n positions forward in the list of matches; a negative argument may be used to move backward through the list. ! This command is intended to be bound to TAB, but is unbound by default.
    delete-char-or-list ()
    ! Deletes the character under the cursor if not at the beginning or end of the line (like delete-char). --- 1419,1439 ----
    menu-complete ()
    ! Similar to complete, but replaces the word to be completed with a single match from the list of possible completions. Repeated execution of menu-complete steps through the list of possible completions, inserting each match in turn. ! At the end of the list of completions, the bell is rung ! (subject to the setting of bell-style) ! and the original text is restored. An argument of n moves n positions forward in the list of matches; a negative argument may be used to move backward through the list. ! This command is intended to be bound to TAB, but is unbound by default.
    delete-char-or-list ()
    ! Deletes the character under the cursor if not at the beginning or end of the line (like delete-char). *************** *** 1410,1419 ****
    start-kbd-macro (C-x ()
    ! Begin saving the characters typed into the current keyboard macro.
    end-kbd-macro (C-x ))
    ! Stop saving the characters typed into the current keyboard macro and save the definition. --- 1451,1460 ----
    start-kbd-macro (C-x ()
    ! Begin saving the characters typed into the current keyboard macro.
    end-kbd-macro (C-x ))
    ! Stop saving the characters typed into the current keyboard macro and save the definition. *************** *** 1421,1425 ****
    call-last-kbd-macro (C-x e)
    ! Re-execute the last keyboard macro defined, by making the characters in the macro appear as if typed at the keyboard. --- 1462,1466 ----
    call-last-kbd-macro (C-x e)
    ! Re-execute the last keyboard macro defined, by making the characters in the macro appear as if typed at the keyboard. *************** *** 1434,1438 ****
    re-read-init-file (C-x C-r)
    ! Read in the contents of the inputrc file, and incorporate any bindings or variable assignments found there. --- 1475,1479 ----
    re-read-init-file (C-x C-r)
    ! Read in the contents of the inputrc file, and incorporate any bindings or variable assignments found there. *************** *** 1440,1444 ****
    abort (C-g)
    ! Abort the current editing command and ring the terminal's bell (subject to the setting of --- 1481,1485 ----
    abort (C-g)
    ! Abort the current editing command and ring the terminal's bell (subject to the setting of *************** *** 1447,1469 ****
    do-uppercase-version (M-a, M-b, M-x, ...)
    ! If the metafied character x is lowercase, run the command that is bound to the corresponding uppercase character. !
    prefix-meta (ESC)
    ! ! Make the next character typed be metafied. This is for keyboards ! without a meta key. Typing `ESC f' is equivalent to typing ! `M-f'. !
    undo (C-_, C-x C-u)
    ! Incremental undo, separately remembered for each line.
    revert-line (M-r)
    ! Undo all changes made to this line. This is like executing the undo command enough times to get back to the beginning. --- 1488,1510 ----
    do-uppercase-version (M-a, M-b, M-x, ...)
    ! If the metafied character x is lowercase, run the command that is bound to the corresponding uppercase character. !
    prefix-meta (ESC)
    ! ! Metafy the next character typed. This is for keyboards ! without a meta key. Typing `ESC f' is equivalent to typing ! M-f. !
    undo (C-_ or C-x C-u)
    ! Incremental undo, separately remembered for each line.
    revert-line (M-r)
    ! Undo all changes made to this line. This is like executing the undo command enough times to get back to the beginning. *************** *** 1471,1486 ****
    tilde-expand (M-~)
    ! Perform tilde expansion on the current word.
    set-mark (C-@)
    ! ! Set the mark to the current point. If a numeric argument is supplied, the mark is set to that position.
    exchange-point-and-mark (C-x C-x)
    ! Swap the point with the mark. The current cursor position is set to the saved position, and the old cursor position is saved as the mark. --- 1512,1527 ----
    tilde-expand (M-~)
    ! Perform tilde expansion on the current word.
    set-mark (C-@)
    ! ! Set the mark to the point. If a numeric argument is supplied, the mark is set to that position.
    exchange-point-and-mark (C-x C-x)
    ! Swap the point with the mark. The current cursor position is set to the saved position, and the old cursor position is saved as the mark. *************** *** 1488,1492 ****
    character-search (C-])
    ! A character is read and point is moved to the next occurrence of that character. A negative count searches for previous occurrences. --- 1529,1533 ----
    character-search (C-])
    ! A character is read and point is moved to the next occurrence of that character. A negative count searches for previous occurrences. *************** *** 1494,1498 ****
    character-search-backward (M-C-])
    ! A character is read and point is moved to the previous occurrence of that character. A negative count searches for subsequent --- 1535,1539 ----
    character-search-backward (M-C-])
    ! A character is read and point is moved to the previous occurrence of that character. A negative count searches for subsequent *************** *** 1501,1505 ****
    insert-comment (M-#)
    ! The value of the comment-begin variable is inserted at the beginning of the current line, --- 1542,1546 ----
    insert-comment (M-#)
    ! The value of the comment-begin variable is inserted at the beginning of the current line, *************** *** 1508,1512 ****
    dump-functions ()
    ! Print all of the functions and their key bindings to the Readline output stream. If a numeric argument is supplied, --- 1549,1553 ----
    dump-functions ()
    ! Print all of the functions and their key bindings to the Readline output stream. If a numeric argument is supplied, *************** *** 1516,1520 ****
    dump-variables ()
    ! Print all of the settable variables and their values to the Readline output stream. If a numeric argument is supplied, --- 1557,1561 ----
    dump-variables ()
    ! Print all of the settable variables and their values to the Readline output stream. If a numeric argument is supplied, *************** *** 1524,1530 ****
    dump-macros ()
    ! Print all of the Readline key sequences bound to macros and the ! strings they ouput. If a numeric argument is supplied, the output is formatted in such a way that it can be made part of an inputrc file. This command is unbound by default. --- 1565,1571 ----
    dump-macros ()
    ! Print all of the Readline key sequences bound to macros and the ! strings they output. If a numeric argument is supplied, the output is formatted in such a way that it can be made part of an inputrc file. This command is unbound by default. *************** *** 1545,1549 ****

    In order to switch interactively between emacs and vi ! editing modes, use the command M-C-j (toggle-editing-mode). The Readline default is emacs mode. --- 1586,1591 ----

    In order to switch interactively between emacs and vi ! editing modes, use the command M-C-j (bound to emacs-editing-mode ! when in vi mode and to vi-editing-mode in emacs mode). The Readline default is emacs mode. *************** *** 1560,1564 ****


    ! This document was generated on 1 March 2000 using the texi2html translator version 1.52.

    --- 1602,1606 ----


    ! This document was generated on 16 April 2001 using the texi2html translator version 1.52.

    diff -Nrc2 readline-4.1/doc/rluserman.info readline-4.2/doc/rluserman.info *** readline-4.1/doc/rluserman.info Wed Mar 1 14:52:59 2000 --- readline-4.2/doc/rluserman.info Tue Mar 6 13:37:34 2001 *************** *** 1,9 **** ! This is Info file rluserman.info, produced by Makeinfo version 1.68 ! from the input file /usr/homes/chet/src/bash/readline-src/doc/rluserman.texinfo. INFO-DIR-SECTION Libraries START-INFO-DIR-ENTRY ! * Readline: (readline). The GNU readline library API END-INFO-DIR-ENTRY --- 1,8 ---- ! This is rluserman.info, produced by makeinfo version 4.0 from /usr/homes/chet/src/bash/readline-src/doc/rluserman.texinfo. INFO-DIR-SECTION Libraries START-INFO-DIR-ENTRY ! * RLuserman: (rluserman). The GNU readline library User's Manual. END-INFO-DIR-ENTRY *************** *** 12,16 **** across discrete programs that need to provide a command line interface. ! Copyright (C) 1988-1999 Free Software Foundation, Inc. Permission is granted to make and distribute verbatim copies of this --- 11,15 ---- across discrete programs that need to provide a command line interface. ! Copyright (C) 1988-2001 Free Software Foundation, Inc. Permission is granted to make and distribute verbatim copies of this *************** *** 70,77 **** keystrokes. ! The text is read as `Control-K' and describes the character produced when the key is pressed while the Control key is depressed. ! The text is read as `Meta-K' and describes the character produced when the Meta key (if you have one) is depressed, and the key is pressed. The Meta key is labeled on many keyboards. On --- 69,76 ---- keystrokes. ! The text `C-k' is read as `Control-K' and describes the character produced when the key is pressed while the Control key is depressed. ! The text `M-k' is read as `Meta-K' and describes the character produced when the Meta key (if you have one) is depressed, and the key is pressed. The Meta key is labeled on many keyboards. On *************** *** 84,99 **** If you do not have a Meta or key, or another key working as a Meta key, the identical keystroke can be generated by typing ! first, and then typing . Either process is known as "metafying" the ! key. ! The text is read as `Meta-Control-k' and describes the ! character produced by "metafying" . In addition, several keys have their own names. Specifically, , , , , , and all stand for themselves ! when seen in this text, or in an init file (*note Readline Init ! File::.). If your keyboard lacks a key, typing will ! produce the desired character. The key may be labeled ! or on some keyboards.  --- 83,98 ---- If you do not have a Meta or key, or another key working as a Meta key, the identical keystroke can be generated by typing ! _first_, and then typing . Either process is known as "metafying" ! the key. ! The text `M-C-k' is read as `Meta-Control-k' and describes the ! character produced by "metafying" `C-k'. In addition, several keys have their own names. Specifically, , , , , , and all stand for themselves ! when seen in this text, or in an init file (*note Readline Init File::). ! If your keyboard lacks a key, typing will produce the ! desired character. The key may be labeled or on ! some keyboards.  *************** *** 110,116 **** you move the cursor to the place that needs correction, and delete or insert the text of the corrections. Then, when you are satisfied with ! the line, you simply press . You do not have to be at the end ! of the line to press ; the entire line is accepted regardless ! of the location of the cursor within the line. * Menu: --- 109,115 ---- you move the cursor to the place that needs correction, and delete or insert the text of the corrections. Then, when you are satisfied with ! the line, you simply press . You do not have to be at the end of ! the line to press ; the entire line is accepted regardless of the ! location of the cursor within the line. * Menu: *************** *** 135,140 **** Sometimes you may mistype a character, and not notice the error until you have typed several other characters. In that case, you can ! type to move the cursor to the left, and then correct your ! mistake. Afterwards, you can move the cursor to the right with . When you add text in the middle of a line, you will notice that --- 134,139 ---- Sometimes you may mistype a character, and not notice the error until you have typed several other characters. In that case, you can ! type `C-b' to move the cursor to the left, and then correct your ! mistake. Afterwards, you can move the cursor to the right with `C-f'. When you add text in the middle of a line, you will notice that *************** *** 146,153 **** follows. ! Move back one character. ! Move forward one character. --- 145,152 ---- follows. ! `C-b' Move back one character. ! `C-f' Move forward one character. *************** *** 155,159 **** Delete the character to the left of the cursor. ! Delete the character underneath the cursor. --- 154,158 ---- Delete the character to the left of the cursor. ! `C-d' Delete the character underneath the cursor. *************** *** 161,165 **** Insert the character into the line at the cursor. ! or Undo the last editing command. You can undo all the way back to an empty line. --- 160,164 ---- Insert the character into the line at the cursor. ! `C-_' or `C-x C-u' Undo the last editing command. You can undo all the way back to an empty line. *************** *** 167,171 **** (Depending on your configuration, the key be set to delete the character to the left of the cursor and the key set to delete ! the character underneath the cursor, like , rather than the character to the left of the cursor.) --- 166,170 ---- (Depending on your configuration, the key be set to delete the character to the left of the cursor and the key set to delete ! the character underneath the cursor, like `C-d', rather than the character to the left of the cursor.) *************** *** 178,201 **** The above table describes the most basic keystrokes that you need in order to do editing of the input line. For your convenience, many ! other commands have been added in addition to , , , and . Here are some commands for moving more rapidly about the line. ! Move to the start of the line. ! Move to the end of the line. ! Move forward a word, where a word is composed of letters and digits. ! Move backward a word. ! Clear the screen, reprinting the current line at the top. ! Notice how moves forward a character, while moves forward a word. It is a loose convention that control keystrokes operate on characters while meta keystrokes operate on words. --- 177,200 ---- The above table describes the most basic keystrokes that you need in order to do editing of the input line. For your convenience, many ! other commands have been added in addition to `C-b', `C-f', `C-d', and . Here are some commands for moving more rapidly about the line. ! `C-a' Move to the start of the line. ! `C-e' Move to the end of the line. ! `M-f' Move forward a word, where a word is composed of letters and digits. ! `M-b' Move backward a word. ! `C-l' Clear the screen, reprinting the current line at the top. ! Notice how `C-f' moves forward a character, while `M-f' moves forward a word. It is a loose convention that control keystrokes operate on characters while meta keystrokes operate on words. *************** *** 224,255 **** Here is the list of commands for killing text. ! Kill the text from the current cursor position to the end of the line. ! Kill from the cursor to the end of the current word, or, if between words, to the end of the next word. Word boundaries are the same ! as those used by . ! Kill from the cursor the start of the previous word, or, if between words, to the start of the previous word. Word boundaries are the ! same as those used by . ! Kill from the cursor to the previous whitespace. This is ! different than because the word boundaries differ. Here is how to "yank" the text back into the line. Yanking means to copy the most-recently-killed text from the kill buffer. ! Yank the most recently killed text back into the buffer at the cursor. ! Rotate the kill-ring, and yank the new top. You can only do this ! if the prior command is or .  --- 223,254 ---- Here is the list of commands for killing text. ! `C-k' Kill the text from the current cursor position to the end of the line. ! `M-d' Kill from the cursor to the end of the current word, or, if between words, to the end of the next word. Word boundaries are the same ! as those used by `M-f'. ! `M-' Kill from the cursor the start of the previous word, or, if between words, to the start of the previous word. Word boundaries are the ! same as those used by `M-b'. ! `C-w' Kill from the cursor to the previous whitespace. This is ! different than `M-' because the word boundaries differ. Here is how to "yank" the text back into the line. Yanking means to copy the most-recently-killed text from the kill buffer. ! `C-y' Yank the most recently killed text back into the buffer at the cursor. ! `M-y' Rotate the kill-ring, and yank the new top. You can only do this ! if the prior command is `C-y' or `M-y'.  *************** *** 271,275 **** have typed one meta digit to get the argument started, you can type the remainder of the digits, and then the command. For example, to give ! the command an argument of 10, you could type `M-1 0 C-d'.  --- 270,275 ---- have typed one meta digit to get the argument started, you can type the remainder of the digits, and then the command. For example, to give ! the `C-d' command an argument of 10, you could type `M-1 0 C-d', which ! will delete the next ten characters on the input line.  *************** *** 281,285 **** Readline provides commands for searching through the command history for lines containing a specified string. There are two search modes: ! INCREMENTAL and NON-INCREMENTAL. Incremental searches begin before the user has finished typing the --- 281,285 ---- Readline provides commands for searching through the command history for lines containing a specified string. There are two search modes: ! "incremental" and "non-incremental". Incremental searches begin before the user has finished typing the *************** *** 288,307 **** typed so far. An incremental search requires only as many characters as needed to find the desired history entry. To search backward in the ! history for a particular string, type . Typing searches forward through the history. The characters present in the value of the `isearch-terminators' variable are used to terminate an incremental search. If that variable has not been assigned a value, the and ! characters will terminate an incremental search. will abort an incremental search and restore the original line. When the search is terminated, the history entry containing the search string becomes the current line. ! To find other matching entries in the history list, type or ! as appropriate. This will search backward or forward in the history for the next entry matching the search string typed so far. Any other key sequence bound to a Readline command will terminate the search and execute that command. For instance, a will terminate the search and accept the line, thereby executing the command from the ! history list. Non-incremental searches read the entire search string before --- 288,308 ---- typed so far. An incremental search requires only as many characters as needed to find the desired history entry. To search backward in the ! history for a particular string, type `C-r'. Typing `C-s' searches forward through the history. The characters present in the value of the `isearch-terminators' variable are used to terminate an incremental search. If that variable has not been assigned a value, the and ! `C-J' characters will terminate an incremental search. `C-g' will abort an incremental search and restore the original line. When the search is terminated, the history entry containing the search string becomes the current line. ! To find other matching entries in the history list, type `C-r' or ! `C-s' as appropriate. This will search backward or forward in the history for the next entry matching the search string typed so far. Any other key sequence bound to a Readline command will terminate the search and execute that command. For instance, a will terminate the search and accept the line, thereby executing the command from the ! history list. A movement command will terminate the search, make the ! last line found the current line, and begin editing. Non-incremental searches read the entire search string before *************** *** 346,350 **** file. Blank lines are ignored. Lines beginning with a `#' are comments. Lines beginning with a `$' indicate conditional constructs ! (*note Conditional Init Constructs::.). Other lines denote variable settings and key bindings. --- 347,351 ---- file. Blank lines are ignored. Lines beginning with a `#' are comments. Lines beginning with a `$' indicate conditional constructs ! (*note Conditional Init Constructs::). Other lines denote variable settings and key bindings. *************** *** 352,360 **** You can modify the run-time behavior of Readline by altering the values of variables in Readline using the `set' command within the ! init file. Here is how to change from the default Emacs-like key ! binding to use `vi' line editing commands: set editing-mode vi A great deal of run-time behavior is changeable with the following variables. --- 353,368 ---- You can modify the run-time behavior of Readline by altering the values of variables in Readline using the `set' command within the ! init file. The syntax is simple: ! ! set VARIABLE VALUE ! ! Here, for example, is how to change from the default Emacs-like ! key binding to use `vi' line editing commands: set editing-mode vi + Variable names and values, where appropriate, are recognized + without regard to case. + A great deal of run-time behavior is changeable with the following variables. *************** *** 383,387 **** greater than this value, Readline will ask the user whether or not he wishes to view them; otherwise, they are simply ! listed. The default limit is `100'. `convert-meta' --- 391,396 ---- greater than this value, Readline will ask the user whether or not he wishes to view them; otherwise, they are simply ! listed. This variable must be set to an integer value ! greater than or equal to 0. The default limit is `100'. `convert-meta' *************** *** 420,424 **** `input-meta' If set to `on', Readline will enable eight-bit input (it will ! not strip the eighth bit from the characters it reads), regardless of what the terminal claims it can support. The default value is `off'. The name `meta-flag' is a synonym --- 429,433 ---- `input-meta' If set to `on', Readline will enable eight-bit input (it will ! not clear the eighth bit in the characters it reads), regardless of what the terminal claims it can support. The default value is `off'. The name `meta-flag' is a synonym *************** *** 428,433 **** The string of characters that should terminate an incremental search without subsequently executing the character as a ! command (*note Searching::.). If this variable has not been ! given a value, the characters and will terminate an incremental search. --- 437,442 ---- The string of characters that should terminate an incremental search without subsequently executing the character as a ! command (*note Searching::). If this variable has not been ! given a value, the characters and `C-J' will terminate an incremental search. *************** *** 435,439 **** Sets Readline's idea of the current keymap for key binding commands. Acceptable `keymap' names are `emacs', ! `emacs-standard', `emacs-meta', `emacs-ctlx', `vi', `vi-command', and `vi-insert'. `vi' is equivalent to `vi-command'; `emacs' is equivalent to `emacs-standard'. The --- 444,448 ---- Sets Readline's idea of the current keymap for key binding commands. Acceptable `keymap' names are `emacs', ! `emacs-standard', `emacs-meta', `emacs-ctlx', `vi', `vi-move', `vi-command', and `vi-insert'. `vi' is equivalent to `vi-command'; `emacs' is equivalent to `emacs-standard'. The *************** *** 478,486 **** description of what the command does. ! Once you know the name of the command, simply place the name of ! the key you wish to bind the command to, a colon, and then the ! name of the command on a line in the init file. The name of the ! key can be expressed in different ways, depending on which is most ! comfortable for you. KEYNAME: FUNCTION-NAME or MACRO --- 487,498 ---- description of what the command does. ! Once you know the name of the command, simply place on a line in ! the init file the name of the key you wish to bind the command to, ! a colon, and then the name of the command. The name of the key ! can be expressed in different ways, depending on what you find most ! comfortable. ! ! In addition to command names, readline allows keys to be bound to ! a string that is inserted when the key is pressed (a MACRO). KEYNAME: FUNCTION-NAME or MACRO *************** *** 491,499 **** Control-o: "> output" ! In the above example, is bound to the function ! `universal-argument', and is bound to run the macro expressed on the right hand side (that is, to insert the text `> output' into the line). "KEYSEQ": FUNCTION-NAME or MACRO KEYSEQ differs from KEYNAME above in that strings denoting an --- 503,516 ---- Control-o: "> output" ! In the above example, `C-u' is bound to the function ! `universal-argument', `M-DEL' is bound to the function ! `backward-kill-word', and `C-o' is bound to run the macro expressed on the right hand side (that is, to insert the text `> output' into the line). + A number of symbolic character names are recognized while + processing this key binding syntax: DEL, ESC, ESCAPE, LFD, + NEWLINE, RET, RETURN, RUBOUT, SPACE, SPC, and TAB. + "KEYSEQ": FUNCTION-NAME or MACRO KEYSEQ differs from KEYNAME above in that strings denoting an *************** *** 507,515 **** "\e[11~": "Function Key 1" ! In the above example, is bound to the function `universal-argument' (just as it was in the first example), ! ` ' is bound to the function `re-read-init-file', ! and ` <[> <1> <1> <~>' is bound to insert the text ! `Function Key 1'. The following GNU Emacs style escape sequences are available when --- 524,532 ---- "\e[11~": "Function Key 1" ! In the above example, `C-u' is again bound to the function `universal-argument' (just as it was in the first example), ! `C-x C-r' is bound to the function `re-read-init-file', and ! ` <[> <1> <1> <~>' is bound to insert the text `Function ! Key 1'. The following GNU Emacs style escape sequences are available when *************** *** 562,570 **** `\NNN' ! the character whose `ASCII' code is the octal value NNN (one ! to three digits) `\xNNN' ! the character whose `ASCII' code is the hexadecimal value NNN (one to three digits) --- 579,587 ---- `\NNN' ! the character whose ASCII code is the octal value NNN (one to ! three digits) `\xNNN' ! the character whose ASCII code is the hexadecimal value NNN (one to three digits) *************** *** 615,622 **** application-specific settings. Each program using the Readline library sets the APPLICATION NAME, and you can test ! for it. This could be used to bind key sequences to ! functions useful for a specific program. For instance, the ! following command adds a key sequence that quotes the current ! or previous word in Bash: $if Bash # Quote the current or previous word --- 632,639 ---- application-specific settings. Each program using the Readline library sets the APPLICATION NAME, and you can test ! for a particular value. This could be used to bind key ! sequences to functions useful for a specific program. For ! instance, the following command adds a key sequence that ! quotes the current or previous word in Bash: $if Bash # Quote the current or previous word *************** *** 634,638 **** `$include' This directive takes a single filename as an argument and reads ! commands and bindings from that file. $include /etc/inputrc --- 651,656 ---- `$include' This directive takes a single filename as an argument and reads ! commands and bindings from that file. For example, the following ! directive reads from `/etc/inputrc': $include /etc/inputrc *************** *** 643,647 **** ---------------- ! Here is an example of an inputrc file. This illustrates key binding, variable assignment, and conditional syntax. --- 661,665 ---- ---------------- ! Here is an example of an INPUTRC file. This illustrates key binding, variable assignment, and conditional syntax. *************** *** 763,773 **** This section describes Readline commands that may be bound to key ! sequences. ! Command names without an accompanying key sequence are unbound by ! default. In the following descriptions, POINT refers to the current ! cursor position, and MARK refers to a cursor position saved by the `set-mark' command. The text between the point and mark is referred to ! as the REGION.  --- 781,791 ---- This section describes Readline commands that may be bound to key ! sequences. Command names without an accompanying key sequence are ! unbound by default. ! In the following descriptions, "point" refers to the current cursor ! position, and "mark" refers to a cursor position saved by the `set-mark' command. The text between the point and mark is referred to ! as the "region".  *************** *** 810,823 **** ------------------------------------- ! `accept-line (Newline, Return)' Accept the line regardless of where the cursor is. If this line is ! non-empty, add it to the history list. If this line was a history ! line, then restore the history line to its original state. `previous-history (C-p)' ! Move `up' through the history list. `next-history (C-n)' ! Move `down' through the history list. `beginning-of-history (M-<)' --- 828,843 ---- ------------------------------------- ! `accept-line (Newline or Return)' Accept the line regardless of where the cursor is. If this line is ! non-empty, it may be added to the history list for future recall ! with `add_history()'. If this line is a modified history line, ! the history line is restored to its original state. `previous-history (C-p)' ! Move `back' through the history list, fetching the previous ! command. `next-history (C-n)' ! Move `forward' through the history list, fetching the next command. `beginning-of-history (M-<)' *************** *** 859,868 **** `yank-nth-arg (M-C-y)' Insert the first argument to the previous command (usually the ! second word on the previous line). With an argument N, insert the ! Nth word from the previous command (the words in the previous ! command begin with word 0). A negative argument inserts the Nth ! word from the end of the previous command. ! `yank-last-arg (M-., M-_)' Insert last argument to the previous command (the last word of the previous history entry). With an argument, behave exactly like --- 879,888 ---- `yank-nth-arg (M-C-y)' Insert the first argument to the previous command (usually the ! second word on the previous line) at point. With an argument N, ! insert the Nth word from the previous command (the words in the ! previous command begin with word 0). A negative argument inserts ! the Nth word from the end of the previous command. ! `yank-last-arg (M-. or M-_)' Insert last argument to the previous command (the last word of the previous history entry). With an argument, behave exactly like *************** *** 878,885 **** `delete-char (C-d)' ! Delete the character under the cursor. If the cursor is at the ! beginning of the line, there are no characters in the line, and ! the last character typed was not bound to `delete-char', then ! return `EOF'. `backward-delete-char (Rubout)' --- 898,904 ---- `delete-char (C-d)' ! Delete the character at point. If point is at the beginning of ! the line, there are no characters in the line, and the last ! character typed was not bound to `delete-char', then return EOF. `backward-delete-char (Rubout)' *************** *** 892,900 **** deleted. By default, this is not bound to a key. ! `quoted-insert (C-q, C-v)' Add the next character typed to the line verbatim. This is how to ! insert key sequences like , for example. ! `tab-insert (M-TAB)' Insert a tab character. --- 911,919 ---- deleted. By default, this is not bound to a key. ! `quoted-insert (C-q or C-v)' Add the next character typed to the line verbatim. This is how to ! insert key sequences like `C-q', for example. ! `tab-insert (M-)' Insert a tab character. *************** *** 940,945 **** `kill-whole-line ()' ! Kill all characters on the current line, no matter point is. By ! default, this is unbound. `kill-word (M-d)' --- 959,964 ---- `kill-whole-line ()' ! Kill all characters on the current line, no matter where point is. ! By default, this is unbound. `kill-word (M-d)' *************** *** 948,952 **** as `forward-word'. ! `backward-kill-word (M-DEL)' Kill the word behind point. Word boundaries are the same as `backward-word'. --- 967,971 ---- as `forward-word'. ! `backward-kill-word (M-)' Kill the word behind point. Word boundaries are the same as `backward-word'. *************** *** 979,988 **** `yank (C-y)' ! Yank the top of the kill ring into the buffer at the current ! cursor position. `yank-pop (M-y)' Rotate the kill-ring, and yank the new top. You can only do this ! if the prior command is yank or yank-pop.  --- 998,1006 ---- `yank (C-y)' ! Yank the top of the kill ring into the buffer at point. `yank-pop (M-y)' Rotate the kill-ring, and yank the new top. You can only do this ! if the prior command is `yank' or `yank-pop'.  *************** *** 994,998 **** `digit-argument (M-0, M-1, ... M--)' Add this digit to the argument already accumulating, or start a new ! argument. starts a negative argument. `universal-argument ()' --- 1012,1016 ---- `digit-argument (M-0, M-1, ... M--)' Add this digit to the argument already accumulating, or start a new ! argument. `M--' starts a negative argument. `universal-argument ()' *************** *** 1015,1029 **** ----------------------------- ! `complete (TAB)' ! Attempt to do completion on the text before the cursor. This is ! application-specific. Generally, if you are typing a filename ! argument, you can do filename completion; if you are typing a ! command, you can do command completion; if you are typing in a ! symbol to GDB, you can do symbol name completion; if you are ! typing in a variable to Bash, you can do variable name completion, ! and so on. `possible-completions (M-?)' ! List the possible completions of the text before the cursor. `insert-completions (M-*)' --- 1033,1043 ---- ----------------------------- ! `complete ()' ! Attempt to perform completion on the text before point. The ! actual completion performed is application-specific. The default ! is filename completion. `possible-completions (M-?)' ! List the possible completions of the text before point. `insert-completions (M-*)' *************** *** 1036,1043 **** execution of `menu-complete' steps through the list of possible completions, inserting each match in turn. At the end of the list ! of completions, the bell is rung and the original text is restored. ! An argument of N moves N positions forward in the list of matches; ! a negative argument may be used to move backward through the list. ! This command is intended to be bound to `TAB', but is unbound by default. --- 1050,1058 ---- execution of `menu-complete' steps through the list of possible completions, inserting each match in turn. At the end of the list ! of completions, the bell is rung (subject to the setting of ! `bell-style') and the original text is restored. An argument of N ! moves N positions forward in the list of matches; a negative ! argument may be used to move backward through the list. This ! command is intended to be bound to , but is unbound by default. *************** *** 1083,1091 **** bound to the corresponding uppercase character. ! `prefix-meta (ESC)' ! Make the next character typed be metafied. This is for keyboards ! without a meta key. Typing `ESC f' is equivalent to typing `M-f'. ! `undo (C-_, C-x C-u)' Incremental undo, separately remembered for each line. --- 1098,1106 ---- bound to the corresponding uppercase character. ! `prefix-meta ()' ! Metafy the next character typed. This is for keyboards without a ! meta key. Typing ` f' is equivalent to typing `M-f'. ! `undo (C-_ or C-x C-u)' Incremental undo, separately remembered for each line. *************** *** 1098,1103 **** `set-mark (C-@)' ! Set the mark to the current point. If a numeric argument is ! supplied, the mark is set to that position. `exchange-point-and-mark (C-x C-x)' --- 1113,1118 ---- `set-mark (C-@)' ! Set the mark to the point. If a numeric argument is supplied, the ! mark is set to that position. `exchange-point-and-mark (C-x C-x)' *************** *** 1135,1141 **** `dump-macros ()' Print all of the Readline key sequences bound to macros and the ! strings they ouput. If a numeric argument is supplied, the output ! is formatted in such a way that it can be made part of an INPUTRC ! file. This command is unbound by default.  --- 1150,1156 ---- `dump-macros ()' Print all of the Readline key sequences bound to macros and the ! strings they output. If a numeric argument is supplied, the ! output is formatted in such a way that it can be made part of an ! INPUTRC file. This command is unbound by default.  *************** *** 1151,1155 **** In order to switch interactively between `emacs' and `vi' editing ! modes, use the command M-C-j (toggle-editing-mode). The Readline default is `emacs' mode. --- 1166,1171 ---- In order to switch interactively between `emacs' and `vi' editing ! modes, use the command `M-C-j' (bound to emacs-editing-mode when in ! `vi' mode and to vi-editing-mode in `emacs' mode). The Readline default is `emacs' mode. *************** *** 1163,1189 ****  Tag Table: ! Node: Top1221 ! Node: Command Line Editing1617 ! Node: Introduction and Notation2231 ! Node: Readline Interaction3850 ! Node: Readline Bare Essentials5044 ! Node: Readline Movement Commands6826 ! Node: Readline Killing Commands7784 ! Node: Readline Arguments9691 ! Node: Searching10667 ! Node: Readline Init File12511 ! Node: Readline Init File Syntax13573 ! Node: Conditional Init Constructs22839 ! Node: Sample Init File25279 ! Node: Bindable Readline Commands28450 ! Node: Commands For Moving29495 ! Node: Commands For History30345 ! Node: Commands For Text33063 ! Node: Commands For Killing35067 ! Node: Numeric Arguments37035 ! Node: Commands For Completion38163 ! Node: Keyboard Macros39912 ! Node: Miscellaneous Commands40472 ! Node: Readline vi Mode43277  End Tag Table --- 1179,1205 ----  Tag Table: ! Node: Top1208 ! Node: Command Line Editing1604 ! Node: Introduction and Notation2218 ! Node: Readline Interaction3837 ! Node: Readline Bare Essentials5025 ! Node: Readline Movement Commands6807 ! Node: Readline Killing Commands7765 ! Node: Readline Arguments9676 ! Node: Searching10713 ! Node: Readline Init File12670 ! Node: Readline Init File Syntax13732 ! Node: Conditional Init Constructs23655 ! Node: Sample Init File26181 ! Node: Bindable Readline Commands29352 ! Node: Commands For Moving30403 ! Node: Commands For History31253 ! Node: Commands For Text34112 ! Node: Commands For Killing36100 ! Node: Numeric Arguments38052 ! Node: Commands For Completion39181 ! Node: Keyboard Macros40714 ! Node: Miscellaneous Commands41274 ! Node: Readline vi Mode44068  End Tag Table diff -Nrc2 readline-4.1/doc/rluserman.ps readline-4.2/doc/rluserman.ps *** readline-4.1/doc/rluserman.ps Wed Mar 1 14:53:17 2000 --- readline-4.2/doc/rluserman.ps Mon Apr 16 11:05:47 2001 *************** *** 1,4 **** %!PS-Adobe-2.0 ! %%Creator: dvips(k) 5.82 Copyright 1998 Radical Eye Software %%Title: rluserman.dvi %%Pages: 22 --- 1,4 ---- %!PS-Adobe-2.0 ! %%Creator: dvips(k) 5.86 Copyright 1999 Radical Eye Software %%Title: rluserman.dvi %%Pages: 22 *************** *** 9,13 **** %DVIPSCommandLine: dvips -D 300 -t letter -o rluserman.ps rluserman.dvi %DVIPSParameters: dpi=300, compressed ! %DVIPSSource: TeX output 2000.03.01:1453 %%BeginProcSet: texc.pro %! --- 9,13 ---- %DVIPSCommandLine: dvips -D 300 -t letter -o rluserman.ps rluserman.dvi %DVIPSParameters: dpi=300, compressed ! %DVIPSSource: TeX output 2001.04.16:1105 %%BeginProcSet: texc.pro %! *************** *** 21,27 **** exch round exch]setmatrix}N/@landscape{/isls true N}B/@manualfeed{ statusdict/manualfeed true put}B/@copies{/#copies X}B/FMat[1 0 0 -1 0 0] ! N/FBB[0 0 0 0]N/nn 0 N/IE 0 N/ctr 0 N/df-tail{/nn 8 dict N nn begin /FontType 3 N/FontMatrix fntrx N/FontBBox FBB N string/base X array ! /BitMaps X/BuildChar{CharBuilder}N/Encoding IE N end A{/foo setfont}2 array copy cvx N load 0 nn put/ctr 0 N[}B/sf 0 N/df{/sf 1 N/fntrx FMat N df-tail}B/dfs{div/sf X/fntrx[sf 0 0 sf neg 0 0]N df-tail}B/E{pop nn A --- 21,27 ---- exch round exch]setmatrix}N/@landscape{/isls true N}B/@manualfeed{ statusdict/manualfeed true put}B/@copies{/#copies X}B/FMat[1 0 0 -1 0 0] ! N/FBB[0 0 0 0]N/nn 0 N/IEn 0 N/ctr 0 N/df-tail{/nn 8 dict N nn begin /FontType 3 N/FontMatrix fntrx N/FontBBox FBB N string/base X array ! /BitMaps X/BuildChar{CharBuilder}N/Encoding IEn N end A{/foo setfont}2 array copy cvx N load 0 nn put/ctr 0 N[}B/sf 0 N/df{/sf 1 N/fntrx FMat N df-tail}B/dfs{div/sf X/fntrx[sf 0 0 sf neg 0 0]N df-tail}B/E{pop nn A *************** *** 51,55 **** SI restore userdict/eop-hook known{eop-hook}if showpage}N/@start{ userdict/start-hook known{start-hook}if pop/VResolution X/Resolution X ! 1000 div/DVImag X/IE 256 array N 2 string 0 1 255{IE S A 360 add 36 4 index cvrs cvn put}for pop 65781.76 div/vsize X 65781.76 div/hsize X}N /p{show}N/RMat[1 0 0 -1 0 0]N/BDot 260 string N/Rx 0 N/Ry 0 N/V{}B/RV/v{ --- 51,55 ---- SI restore userdict/eop-hook known{eop-hook}if showpage}N/@start{ userdict/start-hook known{start-hook}if pop/VResolution X/Resolution X ! 1000 div/DVImag X/IEn 256 array N 2 string 0 1 255{IEn S A 360 add 36 4 index cvrs cvn put}for pop 65781.76 div/vsize X 65781.76 div/hsize X}N /p{show}N/RMat[1 0 0 -1 0 0]N/BDot 260 string N/Rx 0 N/Ry 0 N/V{}B/RV/v{ *************** *** 70,96 **** TeXDict begin 40258431 52099146 1000 300 300 (rluserman.dvi) @start ! %DVIPSBitmapFont: Fa cmti10 10.95 1 ! /Fa 1 47 df<127012F8A212F012E005057B840E>46 D E ! %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fb cmbxti10 14.4 1 ! /Fb 1 47 df<120E123FEA7F80A212FFA21300127E123C0909798815>46 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fc cmmi10 10.95 1 ! /Fc 1 59 df<127012F8A3127005057C840D>58 D E ! %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fd cmsltt10 10.95 6 ! /Fd 6 102 df<1206120FEA1F80120FA21203EA0700A25A120E123C127C12F01260090E ! 769B18>39 D<387FFFC0B512E0A26C13C013047C8F18>45 D67 D<3907E01F80000FEB3FC0000714803903B02E ! 00146EA214CE380730DC1331149CA21333141C000E5B13371336133E133C131848C65AA6 ! 38FE03F800FF7F00FE5B1A1C7F9B18>77 D<126012F0A37E1278A3127C123CA3123E121E ! A3121F7EA313801207A313C01203A413E01201A313F0120013600C24789F18>92 ! D<13F8EA07FE487E381F0780EA3C03387801C0127012E0A2B5FCA2148000E0C7FCA21303 ! 3870078038780F00EA3FFE6C5AEA07F012147B9318>101 D E ! %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fe cmbx12 13.14 46 ! /Fe 46 122 df<123C127E12FFA4127E123C08087C8711>46 D<131C133C13FC12FFA212 00B3AA387FFFFCA216237CA21F>49 D<48B4FC000713C0381E07F0383803F8386001FC38 7C00FE12FE14FF147FA2127C003813FFC7FC14FEA2EB01FC14F8EB03F0EB07E01480EB0F --- 70,79 ---- TeXDict begin 40258431 52099146 1000 300 300 (rluserman.dvi) @start ! %DVIPSBitmapFont: Fa cmbxti10 14.4 1 ! /Fa 1 47 df<120E123FEA7F80A212FFA21300127E123C0909798815>46 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fb cmbx12 13.14 46 ! /Fb 46 122 df<123C127E12FFA4127E123C08087C8711>46 D<131C133C13FC12FFA212 00B3AA387FFFFCA216237CA21F>49 D<48B4FC000713C0381E07F0383803F8386001FC38 7C00FE12FE14FF147FA2127C003813FFC7FC14FEA2EB01FC14F8EB03F0EB07E01480EB0F *************** *** 181,223 **** 1370EA68E0EA7FC0001FC8FC1D237F9720>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Ff cmsl10 10.95 22 ! /Ff 22 122 df12 ! D45 D<3A07FF803FE03A00F8001F000178130C5D4913205D5D4A ! C7FC1402140848485A5C146014F013E1EBE4F83803C878EBD07CEBE03CEBC03E141E141F ! 48487E81140781140381380F00016D487E39FFF00FFE231F7E9E23>75 D97 D<13FEEA0383380E0780121C0038130090 ! C7FC12785AA45AA37E5BEA70026C5AEA1C18EA07E011147D9314>99 ! D<13F8EA070EEA0E07121C383803801278127012F0A2B5FC00F0C7FC5AA46C5AEA7002EA ! 3004EA1C18EA07E011147D9314>101 DI<140EEB3E11EB ! E1A33801C1C2380381E0EA07801301120FA3380703C01480EB8700EA04FC48C7FCA21218 ! 121CEA0FFF14C014E0381800F04813305A5AA3006013606C13C0381C0700EA07FC181F80 ! 9417>I105 D<13E0120712011200A2485AA6485AEB81FCEB80F014 ! C0EB81801400EA07045B13181338137C131C120E7FA2130F7F1480EA1C03381E07C038FF ! 8FF016207E9F18>107 D<13E0120712011200A2EA01C0A6EA0380A6EA0700A6120EA65A ! 121EEAFF800B207F9F0C>I<390387C07C391F9861863907A072073903C03403EB803800 ! 07EB7807EB0070A5000EEBE00EA64848485A001EEBE01E3AFFCFFCFFC022147E9326>I< ! 38038F80381F90E0EA07A03803C0601380000713E01300A5380E01C0A6381C0380001E13 ! C038FF8FF014147E9319>I<13FCEA0387380E0180381C00C04813E0A24813F012F0A438 ! E001E0A214C0130300F0138038700700EA380E6C5AEA07E014147D9317>IIIII<1380EA0100A35A5A5A121EEAFFF8EA0E00A45AA65A1310A41320A2EA1840 ! EA0F800D1C7C9B12>I<381C0380EAFC1FEA3C07EA1C03A238380700A6EA700EA4131EA2 ! 5BEA305E381F9F8011147B9319>I<381FF0FF3803C0780001137014403800E0C0EBE180 ! EB73001376133CA2131C132E134E1387EA0107380203801204380C01C0383C03E038FE07 ! FC18147F9318>120 D<390FF83F803901E00E00EBC00C140813E000005B143014205C13 ! 705CA20171C7FC1339133A133E133C133813181310A25BA25BEA70C0EAF08000F1C8FC12 ! E61278191D809318>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fg cmr8 8 41 ! /Fg 41 124 df<126012F0A212701210A21220A21240A2040A7D960A>39 D45 D<1206120E12FE120EB1EAFFE00B157D9412>49 D<13101338A3135CA3138EA3EA0107A238020380A33807FFC0EA0401A2380800E0A20018 --- 164,256 ---- 1370EA68E0EA7FC0001FC8FC1D237F9720>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fc cmsl10 10.95 39 ! /Fc 39 122 df45 D<1408140C141C143CA2147C147E149EA2EB ! 011EA21302801304A21308A20110138014071320A2EB7FFF90384007C0EB8003A2EA0100 ! A21202EC01E01206001F130339FF801FFE1F207F9F22>65 D<0007B5FC3900F803C09038 ! 7801E0EC00F04913F8A515F03801E001EC03E015C0EC0F809038FFFE009038E00F803903 ! C003C0EC01E015F0A21400A2485A1401A215E01403EC07C0390F000F80EC3E00B512F01D ! 1F7E9E20>II<0007B57E3900F801E09038780070 ! 81497F151E150E150FA348481480A6484814005DA3151E153E4848133C5DA25D4A5A4A5A ! 260F000FC7FC143CB512F0211F7E9E23>I<0007B512FC3900F8007C0178131C150C5B15 ! 04A414043901E00800A31438EBFFF8EBE0383803C010A4EC00081510485AA21520A21560 ! 15C0380F00011407B612801E1F7E9E1F>I<0007B512F83900F800780178133815185B15 ! 08A53901E00800A314181438EBFFF83803C0301410A491C7FC485AA648C8FC7FEAFFFC1D ! 1F7E9E1E>I<3807FF803800F8001378A25BA6485AA6485AA6485AA648C7FC7FEAFFF011 ! 1F7E9E10>73 D<3A07FF803FE03A00F8001F000178130C5D4913205D5D4AC7FC14021408 ! 48485A5C146014F013E1EBE4F83803C878EBD07CEBE03CEBC03E141E141F48487E811407 ! 81140381380F00016D487E39FFF00FFE231F7E9E23>75 D<3807FFE0D800FCC7FC1378A2 ! 5BA6485AA6485AA41580EC0100EA0780A25C14021406140E380F001E147CB512FC191F7E ! 9E1C>I78 DI<0007B5FC3900F803C090387800F015785B157CA41578484813F815F0EC01 ! E0EC03C0EC0F00EBFFFCD803C0C7FCA6485AA648C8FC7FEAFFF81E1F7E9E1F>I<3807FF ! FE3900F8078090387801E0EC00F05B15F8A415F03801E00115E0EC03C0EC0780EC1E00EB ! FFF03803C03880141E140EA2140F48485AA51501D80F0013029038800F8239FFF8078CC7 ! EA01F020207E9E22>82 DI<003FB512F0 ! 383C078000301430126039400F0010A212C01280A3D8001E1300A65BA65BA65B7F383FFF ! E01C1F7A9E21>I<39FFF00FF8391F0003E06CEB01801400001EEB0100A6481302A6485B ! A600705BA25CA200785B1238001813C06C48C7FCEA0706EA01F81D20799E22>I<3BFFF0 ! 7FF81FF03B1F000FC007C0001E903907800380001FED01006C1502140F5EEC17C002135B ! 142301805C000713435E14C3913883E0401481D981015B13C1D803C213E193C7FC13C415 ! F2EBC80015F4EA01F015F85B5D5B15605B000014402C207A9E2F>87 D97 D<1207123F120F7EA2120EA65A137CEA1D ! 83381E0180001C13C0EB00E05A14F0A5387001E0A214C013031480EB0700EAE80EEACC38 ! EA83E014207B9F19>I<13FEEA0383380E0780121C0038130090C7FC12785AA45AA37E5B ! EA70026C5AEA1C18EA07E011147D9314>I<13F8EA070EEA0E07381C0380123812781270 ! 12F0B5FC00F0C7FCA25AA46C5AEA7002EA3004EA1C18EA07E011147D9314>101 ! DI<140EEB3E11EBE1A33801C1C2380381E0EA0780130112 ! 0FA3380703C01480EB8700EA04FC48C7FCA21218121CEA0FFF14C014E0381800F0481330 ! 5A5AA3006013606C13C0381C0700EA07FC181F809417>I105 ! D<13E0120712011200A2485AA6485AEB81FCEB80F014C0EB81801400EA07045B13181338 ! 137C131C120E7FA2130F7F1480EA1C03381E07C038FF8FF016207E9F18>107 ! D<13E0120712011200A2EA01C0A6EA0380A6EA0700A6120EA65A121EEAFF800B207F9F0C ! >I<390387C07C391F9861863907A072073903C03403EB80380007EB7807EB0070A5000E ! EBE00EA64848485A001EEBE01E3AFFCFFCFFC022147E9326>I<38038F80381F90E0EA07 ! A03803C0601380000713E01300A5380E01C0A6381C0380001E13C038FF8FF014147E9319 ! >I<13FCEA0387380E0180381C00C04813E0A24813F012F0A438E001E0A214C0130300F0 ! 138038700700EA380E6C5AEA07E014147D9317>IIIII<1380EA01 ! 00A35A5A5A121EEAFFF8EA0E00A45AA65A1310A41320A2EA1840EA0F800D1C7C9B12>I< ! 381C0380EAFC1FEA3C07EA1C03A238380700A6EA700EA4131EA25BEA305E381F9F801114 ! 7B9319>I<38FF83F8381E00E0001C13C01480121E380E01005B13025B12075BA25BEA03 ! 9013A013E05B5B120190C7FC15147C9318>I<381FF0FF3803C0780001137014403800E0 ! C0EBE180EB73001376133CA2131C132E134E1387EA0107380203801204380C01C0383C03 ! E038FE07FC18147F9318>120 D<390FF83F803901E00E00EBC00C140813E000005B1430 ! 14205C13705CA20171C7FC1339133A133E133C133813181310A25BA25BEA70C0EAF08000 ! F1C8FC12E61278191D809318>I E ! %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fd cmti10 10.95 8 ! /Fd 8 117 df12 ! D<127012F8A212F012E005057B840E>46 D103 D<13C0EA01E0A213C0C7FCA7120E12131223EA ! 4380EA4700A21287120EA35AA3EA38401380A21270EA31001232121C0B1F7C9E0E>105 ! D<381C0F80382630C0384740601380EB0070A2008E13E0120EA3381C01C0A3EB03840038 ! 1388A2EB0708EB031000701330383001C016147C931A>110 D114 ! D<13FCEA0302EA0601EA0C03130713061300EA0F8013F0EA07F8EA03FCEA003E130E1270 ! EAF00CA2EAE008EA4010EA2060EA1F8010147D9313>II ! E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fe cmr8 8 26 ! /Fe 26 118 df<126012F0A212701210A21220A21240A2040A7D960A>39 D45 D<1206120E12FE120EB1EAFFE00B157D9412>49 D<13101338A3135CA3138EA3EA0107A238020380A33807FFC0EA0401A2380800E0A20018 *************** *** 229,294 **** E0EA1C00146014201410A3EB0400A3130CEA1FFCEA1C0C13041408A2130014181410A214 3014F0B5FC15177F9618>II74 D76 D<00FEEB03F8001E14C000171305A338138009A23811C011A33810E021A2EB7041A3 ! EB3881A2EB1D01A2130EA2123839FE040FF81D177F9620>I<00FC13FE001E1338001F13 ! 101217EA1380EA11C0A2EA10E013701338A2131C130E130F1307EB0390EB01D0A2EB00F0 ! 14701430123800FE131017177F961A>I80 D82 DI<387FFFF8386038 ! 1800401308A200801304A300001300AF3803FF8016177F9619>I<38FF80FE381C003814 ! 10B06C132012066C13403801818038007E0017177F961A>I<12FCA212C0B3AB12FCA206 ! 217D980A>91 D97 D<12F81238A8EA39F0EA3E0CEA380613077F1480A41400 ! 5B1306EA361CEA21F011177F9614>II<133E130EA8EA07CEEA1C3EEA300E1270126012 ! E0A412601270EA301EEA182E3807CF8011177F9614>IIII<1203EA0780A2EA0300C7FCA5EA1F801203AF1243EAE30012E712 ! 7C091D82960B>106 D<12F81238A8133E13381330134013801239EA3FC0EA39E0123813 ! F01378133CA2EAFE7F10177F9613>I<12F81238B3A312FE07177F960A>I110 DIIIII<1208A31218A21238EAFFC0 ! EA3800A71340A4EA1C80EA0F000A147F930E>II<38FEFE7C383838381410133C001C1320134C381E4E60380ECE40138700 ! 0713801303A200031300EA0201160E7F8D19>119 DII123 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fh cmsy9 9 2 ! /Fh 2 106 df<13801201EA0300A31206A25AA35AA35AA25AA35AA21260A37EA27EA37E A37EA27EA3EA0180120009267D9B0F>104 D<12C0A21260A37EA27EA37EA37EA27EA3EA 0180A2EA0300A31206A25AA35AA35AA25AA35AA209267E9B0F>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fi cmcsc10 10.95 8 ! /Fi 8 118 df73 D79 DI<3803F02038 ! 0C0C60381803E0EA30005A146012E01420A36C13007E127CEA7F80EA3FFC6CB4FC000713 ! 80000113C038000FE013031301EB00F014707EA46C136014E06C13C038F8018038C60300 ! EA81FC14217C9F1C>83 D<397FF807FE390FE001F0D807C013C06C6C6C5A000149C7FCEB ! F0023800F806EB78046D5AEB3E18EB1F106D5A14C0130713036D7E497EEB06F8EB0478EB ! 087CEB183EEB101EEB201F496C7EEBC007496C7ED801007F486D7E481300391F8001F83A ! FFC007FF80211F7E9E25>88 D103 D<38FC01FC381E007014201217EA1380A2EA11C0EA10E0A213701338A2131C ! 130E1307A2EB03A0EB01E0A213001460123800FE132016177E961C>110 D<38FF81FC381C00701420B0000C1340120E6C138038018300EA007C16177E961C>117 ! D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fj cmbx12 17.28 18 ! /Fj 18 117 df49 D<913A03FF800180023FEBF00349B5EAFC0701079038003F0FD91FF8EB 079FD93FC0EB01FFD9FF807F4848C8127F4848153F0007161F49150F485A001F1607A248 --- 262,363 ---- E0EA1C00146014201410A3EB0400A3130CEA1FFCEA1C0C13041408A2130014181410A214 3014F0B5FC15177F9618>II76 D80 D82 ! DI<387FFFF8386038180040 ! 1308A200801304A300001300AF3803FF8016177F9619>I<12FCA212C0B3AB12FCA20621 ! 7D980A>91 D97 D99 D101 D<1203EA0780A2EA0300C7FCA5 ! EA1F801203AF1243EAE30012E7127C091D82960B>106 D<12F81238A8133E1338133013 ! 4013801239EA3FC0EA39E0123813F01378133CA2EAFE7F10177F9613>I110 D112 D114 DI<1208A31218A21238EAFFC0EA3800A7 ! 1340A4EA1C80EA0F000A147F930E>II E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Ff cmsy9 9 2 ! /Ff 2 106 df<13801201EA0300A31206A25AA35AA35AA25AA35AA21260A37EA27EA37E A37EA27EA3EA0180120009267D9B0F>104 D<12C0A21260A37EA27EA37EA37EA27EA3EA 0180A2EA0300A31206A25AA35AA35AA25AA35AA209267E9B0F>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fg cmsltt10 10.95 29 ! /Fg 29 122 df<1206120FEA1F80120FA21203EA0700A25A120E123C127C12F01260090E ! 769B18>39 D<387FFFC0B512E0A26C13C013047C8F18>45 D<133E13FF000313803807C3 ! C0EA0F01000E13E0EA1C00123C003813F014705AA34813E0A4EB01C0A2130300F01380EA ! 7007EB0F00EA781E6C5AEA1FF85BEA07C0141C7C9B18>48 D<13181338A2137813F81203 ! 120F137012041200A413E0A6EA01C0A6EA7FFE12FF127F0F1C7B9B18>I67 D<3807FFC014E014F03801C0F814 ! 78143C141CEA0380141EA2140EA33807001CA4143C1438120E147014F0EB01E0EB03C013 ! 07387FFF8038FFFE00EA7FF8171C7F9B18>I<0007B5FC5A7E3801C007A3140638038000 ! A2EB818014C0A213FF481380A21303A2140090C7FC120E140C141CA4387FFFF8B5FC7E18 ! 1C7F9B18>I74 D76 D<3907E01F80000FEB3FC0000714803903 ! B02E00146EA214CE380730DC1331149CA21333141C000E5B13371336133E133C131848C6 ! 5AA638FE03F800FF7F00FE5B1A1C7F9B18>I<126012F0A37E1278A3127C123CA3123E12 ! 1EA3121F7EA313801207A313C01203A413E01201A313F0120013600C24789F18>92 ! D<387FFFC0B512E0A26C13C013047E7F18>95 D97 D<127EA3120EA45A137CEA1DFF001F13801383381E01C0123CEB00E012 ! 38A4387801C0A2EB0380A2EB0F00EA7C1FEAFFFCEAEFF8EA63E0131C7C9B18>I100 D<13F8EA07FE487E381F ! 0780EA3C03387801C0127012E0A2B5FCA2148000E0C7FCA213033870078038780F00EA3F ! FE6C5AEA07F012147B9318>III<14C0EB01E013031301EB00C01400A4EBFFC0A31301A2EB0380A6 ! EB0700A6130EA65BA2EA6038EAF078B45A5BEA3F8013277F9C18>106 ! DII<13FCEA03FF000F1380 ! EA1F07383C03C0EA7801007013E0EAE000A4EB01C0A2EB0380EAF007EB0F00EA7C3EEA3F ! FC6C5AEA07E013147C9318>111 D113 D<381FE1F8EBE7FCEBEFFE3800FE1EEBFC0C3801F8005B5B5BA3485AA6EA ! FFFC7F5B17147E9318>II<387E07E0EAFE0FEA7E07EA0E00A2381C01C0A638380380A41307131F383FFF ! E06C13F03807E3E014147D9318>117 D<38FF87F8138F1387383800E0EB01C0A3148013 ! E3EA39F31233EB7700A212371376EA3666136EEA3C7CA2EA383815147C9318>119 ! D<381FE3FC13E713E33803C3C000011380EBE700EA00EE13FC137C1338137813FCEA01DC ! EA038E12071307120E38FF1FE0EB9FF0EB1FE016147E9318>I<380FF1FE381FF9FF380F ! F1FE3803807013C0000113E0A213C114C0A23800E380A2EBE700A213E6136E136C137C13 ! 78A21370A25BA2485A12F3EAF780B4C7FC5A1278181E7F9318>I ! E ! %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fh cmcsc10 10.95 12 ! /Fh 12 121 df<1318A2133CA3134EA213CF1387A238010380A2000313C0EA0201A23807 ! FFE0EA0400A2481370A2001813380038137838FE01FF18177F961C>97 ! D99 ! D101 DII105 D<38FC01FC381E007014201217EA1380A2EA11C0EA10E0A213701338A2131C13 ! 0E1307A2EB03A0EB01E0A213001460123800FE132016177E961C>110 ! D<13FE38038380380E00E0481370003C1378003813380078133C0070131C00F0131EA700 ! 70131C0078133C00381338003C1378001C13706C13E0380383803800FE0017177E961D> ! II115 D<38FF81FC381C00701420B0000C1340120E6C138038018300EA007C16177E961C>117 ! D<38FF80FE381F0070000E13606C1340EB80803803C100EA01C3EA00E213F4137813387F ! 133E134E13C7EB8780380103C0EA0201380600E0000413F0000C1370003C137800FE13FF ! 18177F961C>120 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fi cmbx12 17.28 18 ! /Fi 18 117 df49 D<913A03FF800180023FEBF00349B5EAFC0701079038003F0FD91FF8EB 079FD93FC0EB01FFD9FF807F4848C8127F4848153F0007161F49150F485A001F1607A248 *************** *** 331,342 **** 01EC0700EA00FEEB7F0EEB3FFCEB07F0192E7FAD1F>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fk cmsy10 10.95 1 ! /Fk 1 14 df<14FF010713E090381F00F80178131E01E01307D80180EB018048C812C000 ! 061560481530A248151848150CA2481506A4481503A900601506A46C150CA26C15186C15 ! 30A26C15606C15C06C6CEB0180D800E0EB07000178131E011F13F8903807FFE0010090C7 ! FC282B7EA02D>13 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fl cmbx12 14.4 39 ! /Fl 39 122 df<123C127FEAFF80A213C0A3127F123E1200A2EA0180A3EA0300A2120612 0E5A5A12100A157B8813>44 D<121C127FA2EAFF80A3EA7F00A2121C09097B8813>46 D<130E131E137EEA07FE12FFA212F81200B3ABB512FEA317277BA622>49 --- 400,411 ---- 01EC0700EA00FEEB7F0EEB3FFCEB07F0192E7FAD1F>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fj cmsy10 10.95 1 ! /Fj 1 14 df<14FE903807FFC090381F01F0903878003C01E0130ED80180130348C7EA01 ! 800006EC00C0481560A2481530481518A248150CA4481506A90060150CA46C1518A26C15 ! 306C1560A26C15C06CEC01806C6CEB0300D800E0130E0178133C90381F01F0903807FFC0 ! D900FEC7FC272B7DA02E>13 D E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fk cmbx12 14.4 39 ! /Fk 39 122 df<123C127FEAFF80A213C0A3127F123E1200A2EA0180A3EA0300A2120612 0E5A5A12100A157B8813>44 D<121C127FA2EAFF80A3EA7F00A2121C09097B8813>46 D<130E131E137EEA07FE12FFA212F81200B3ABB512FEA317277BA622>49 *************** *** 419,424 **** EA74F0EA3FE0EA0F8020277F9A23>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fm cmtt10 10.95 77 ! /Fm 77 127 df<127012F8B012701200A5127012F8A31270051C779B18>33 DI --- 488,493 ---- EA74F0EA3FE0EA0F8020277F9A23>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fl cmtt10 10.95 77 ! /Fl 77 127 df<127012F8B012701200A5127012F8A31270051C779B18>33 DI *************** *** 460,465 **** 00A214F01470A814F014E0A2130114C01303EB0F80387FFF00485AEA7FF8141C7F9B18> III<3801F1C0EA03FDEA0FFFEA1F0FEA1C03123813011270A290C7FC5AA5 EB0FF0131F130F387001C0A213031238A2EA1C07EA1F0FEA0FFFEA03FDEA01F1141C7E9B 18>I<387F07F038FF8FF8387F07F0381C01C0A9EA1FFFA3EA1C01AA387F07F038FF8FF8 --- 529,534 ---- 00A214F01470A814F014E0A2130114C01303EB0F80387FFF00485AEA7FF8141C7F9B18> III<3801F1C0EA03FDEA0FFFEA1F0FEA1C03123813011270A290C7FC5AA5 EB0FF0131F130F387001C0A213031238A2EA1C07EA1F0FEA0FFFEA03FDEA01F1141C7E9B 18>I<387F07F038FF8FF8387F07F0381C01C0A9EA1FFFA3EA1C01AA387F07F038FF8FF8 *************** *** 528,533 **** 60C00F067C9B18>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fn cmr10 10.95 72 ! /Fn 72 123 df<90381F83E09038F06E303901C07878380380F8903800F03048EB7000A7 B612803907007000B2383FE3FF1D20809F1B>11 D<133FEBE0C0EA01C0380381E0EA0701 A290C7FCA6B512E0EA0700B2383FC3FC1620809F19>I<127012F812FCA212741204A312 --- 597,602 ---- 60C00F067C9B18>I E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fm cmr10 10.95 71 ! /Fm 71 123 df<90381F83E09038F06E303901C07878380380F8903800F03048EB7000A7 B612803907007000B2383FE3FF1D20809F1B>11 D<133FEBE0C0EA01C0380381E0EA0701 A290C7FCA6B512E0EA0700B2383FC3FC1620809F19>I<127012F812FCA212741204A312 *************** *** 539,543 **** 7C840D>I48 D<13801203120F12F31203B3A6 ! EA07C0EAFFFE0F1E7C9D17>III48 D<13801203120F12F31203B3A6 ! EA07C0EA7FFE0F1E7C9D17>IIII<90380FE0109038381C309038E002703803C00139078000F048C7127012 ! 1E15305A1510127C127800F81400A7EC3FFEEC01F000781300127C123CA27EA27E6C7E39 ! 03C001703900E002309038380C1090380FF0001F217E9F24>I<39FFF07FF8390F000780 ! AD90B5FCEB0007AF39FFF07FF81D1F7E9E22>I ! I<3807FFC038003E00131EB3A3122012F8A3EAF01CEA403CEA6038EA1070EA0FC012207F ! 9E17>I<39FFF007FC390F0003E0EC0180150014025C5C5C5C5C5C49C7FC5B497E130FEB ! 13C0EB21E01341EB80F0EB0078A28080A280EC0780A2EC03C015E015F039FFF01FFE1F1F ! 7E9E23>IIIIII82 D<3803F040380C0CC0EA1803EA3001EA6000A212E01440A36C13007E127CEA7F80EA3FF8 6CB4FC00071380C613C0EB1FE013031301EB00F014707EA46C136014E06C13C038F80180 --- 636,656 ---- 13001440A3EC0020A31540A315C01401EC0380140FB6FC1B1F7E9E1F>II<90380FE02090387818609038E004E03803800238070001481300001E14 ! 60A25A1520127C127800F81400A7EC7FFCEC03E000781301127C123CA27EA27E7E380380 ! 023900E00460903878182090380FE0001E217D9F24>I<39FFF07FF8390F000780AD90B5 ! FCEB0007AF39FFF07FF81D1F7E9E22>II<39FF ! F007FC390F0003E0EC0180150014025C5C5C5C5C5C49C7FC5B497E130FEB13C0EB21E013 ! 41EB80F0EB0078A28080A280EC0780A2EC03C015E015F039FFF01FFE1F1F7E9E23>75 ! DI ! IIII82 D<3803F040380C0CC0EA1803EA3001EA6000A212E01440A36C13007E127CEA7F80EA3FF8 6CB4FC00071380C613C0EB1FE013031301EB00F014707EA46C136014E06C13C038F80180 *************** *** 599,603 **** D<12FFA212C0B3B3A512FFA2082D7CA10D>91 D<12FFA21203B3B3A512FFA2082D80A10D >93 D<120812101220A21240A21280A312B812FCA2127C1238060E7D9F0D>96 ! DI<121C12FC121CAA137CEA1D87381E0180EB00 C0001C13E01470A21478A6147014F014E0001E13C0381A018038198700EA107C15207E9F --- 667,671 ---- D<12FFA212C0B3B3A512FFA2082D7CA10D>91 D<12FFA21203B3B3A512FFA2082D80A10D >93 D<120812101220A21240A21280A312B812FCA2127C1238060E7D9F0D>96 ! DI<121C12FC121CAA137CEA1D87381E0180EB00 C0001C13E01470A21478A6147014F014E0001E13C0381A018038198700EA107C15207E9F *************** *** 605,640 **** 0100EA0706EA01F811147F9314>III<137CEA01C6EA030F1207EA0E061300A7EAFFF0EA0E00B2EA7FE0 ! 1020809F0E>I<14E03803E330EA0E3CEA1C1C38380E00EA780FA5EA380E6C5AEA1E38EA ! 33E00020C7FCA21230A2EA3FFE381FFF8014C0383001E038600070481330A4006013606C ! 13C0381C03803803FC00141F7F9417>I<121C12FC121CAA137C1386EA1D03001E1380A2 ! 121CAE38FF8FF014207E9F19>I<1238127CA31238C7FCA6121C12FC121CB1EAFF80091F ! 7F9E0C>I<13E0EA01F0A3EA00E01300A61370EA07F012001370B3A31260EAF06013C0EA ! 6180EA3F000C28829E0E>I<121C12FC121CAAEB1FE0EB0780EB060013045B5B5B136013 ! E0EA1DF0EA1E70EA1C38133C131C7F130F7F148014C038FF9FF014207E9F18>I<121C12 ! FC121CB3ABEAFF8009207F9F0C>I<391C3E03E039FCC30C30391D039038391E01E01CA2 ! 001C13C0AE3AFF8FF8FF8021147E9326>IIII<3801F04038070CC0EA0E02EA1C03EA38011278127012F0A612 ! 7012781238EA1C03EA0C05EA0709EA01F1EA0001A8EB0FF8151D7F9318>III<1202A31206A2120EA2123EEAFFF8EA0E00AB1304A5EA07081203EA01F00E1C ! 7F9B12>I<381C0380EAFC1FEA1C03AE1307120CEA061B3803E3F014147E9319>I<38FF83 ! F8383E00E0001C13C06C1380A338070100A21383EA0382A2EA01C4A213E4EA00E8A21370 ! A3132015147F9318>I<39FF9FE1FC393C078070391C030060EC8020000E1440A214C0D8 ! 0704138014E0A239038861001471A23801D032143A143E3800E01CA2EB6018EB40081E14 ! 7F9321>I<38FF87F8381E03C0380E0180EB0300EA0702EA0384EA01C813D8EA00F01370 ! 137813F8139CEA010E1202EA060738040380000C13C0003C13E038FE07FC16147F9318> ! I<38FF83F8383E00E0001C13C06C1380A338070100A21383EA0382A2EA01C4A213E4EA00 ! E8A21370A31320A25BA3EAF080A200F1C7FC1262123C151D7F9318>II E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fo cmbx12 20.736 19 ! /Fo 19 122 dfIII<137CEA01C6EA030F1207EA0E061300A7EAFFF0EA0E00B2EA7FE010 ! 20809F0E>I<14E03803E330EA0E3CEA1C1C38380E00EA780FA5EA380E6C5AEA1E38EA33 ! E00020C7FCA21230A2EA3FFE381FFF8014C0383001E038600070481330A4006013606C13 ! C0381C03803803FC00141F7F9417>I<121C12FC121CAA137C1386EA1D03001E1380A212 ! 1CAE38FF8FF014207E9F19>I<1238127CA31238C7FCA6121C12FC121CB1EAFF80091F7F ! 9E0C>I<13E0EA01F0A3EA00E01300A61370EA07F012001370B3A31260EAF06013C0EA61 ! 80EA3F000C28829E0E>I<121C12FC121CAAEB1FE0EB0780EB060013045B5B5B136013E0 ! EA1DF0EA1E70EA1C38133C131C7F130F7F148014C038FF9FF014207E9F18>I<121C12FC ! 121CB3ABEAFF8009207F9F0C>I<391C3E03E039FCC30C30391D019018001EEBE01CA200 ! 1C13C0AE3AFF8FF8FF8021147E9326>IIII<3801F04038070CC0EA0E02EA1C03EA38011278127012F0A61270 ! 12781238EA1C03EA0C05EA0709EA01F1EA0001A8EB0FF8151D7F9318>III<1202A31206A2120EA2123EEAFFF8EA0E00AB1304A5EA07081203EA01F00E1C7F ! 9B12>I<381C0380EAFC1FEA1C03AE1307120CEA061B3803E3F014147E9319>I<38FF83F8 ! 383E00E0001C13C06C1380A338070100A21383EA0382A2EA01C4A213E4EA00E8A21370A3 ! 132015147F9318>I<39FF9FE1FC393C078070391C030060EC8020000E1440A214C0D807 ! 04138014E0A239038861001471A23801D032143A143E3800E01CA2EB6018EB40081E147F ! 9321>I<38FF87F8381E03C0380E0180EB0300EA0702EA0384EA01C813D8EA00F0137013 ! 7813F8139CEA010E1202EA060738040380000C13C0003C13E038FE07FC16147F9318>I< ! 38FF83F8383E00E0001C13C06C1380A338070100A21383EA0382A2EA01C4A213E4EA00E8 ! A21370A31320A25BA3EAF080A200F1C7FC1262123C151D7F9318>II E %EndDVIPSBitmapFont ! %DVIPSBitmapFont: Fn cmbx12 20.736 19 ! /Fn 19 122 df)i(output")555 ! 605 y Fn(In)19 b(the)f(ab)q(o)o(v)o(e)g(example,)1023 ! 603 y Fh(h)p 1035 577 57 2 v 1035 605 a Fg(C-u)p 1035 ! 613 V 1090 603 a Fh(i)1123 605 y Fn(is)h(b)q(ound)g(to)f(the)g ! (function)h Fm(universal-)555 660 y(argument)p Fn(,)g(and)872 ! 658 y Fh(h)p 884 632 55 2 v 884 660 a Fg(C-o)p 884 667 ! V 937 658 a Fh(i)971 660 y Fn(is)h(b)q(ound)g(to)f(run)h(the)f(macro)g ! (expressed)h(on)g(the)555 715 y(righ)o(t)13 b(hand)h(side)h(\(that)e ! (is,)h(to)f(insert)h(the)g(text)f(`)p Fm(>)h(output)p ! Fn(')f(in)o(to)g(the)h(line\).)315 793 y Fm(")p Ff(k)o(eyseq)q ! Fm(")p Fn(:)20 b Ff(function-name)e Fn(or)d Ff(macro)555 ! 848 y(k)o(eyseq)i Fn(di\013ers)e(from)g Ff(k)o(eyname)j ! Fn(ab)q(o)o(v)o(e)d(in)i(that)d(strings)i(denoting)g(an)f(en-)555 ! 902 y(tire)i(k)o(ey)g(sequence)h(can)f(b)q(e)g(sp)q(eci\014ed,)i(b)o(y) ! e(placing)h(the)f(k)o(ey)g(sequence)h(in)555 957 y(double)e(quotes.)j ! (Some)c Fi(gnu)g Fn(Emacs)f(st)o(yle)h(k)o(ey)g(escap)q(es)g(can)g(b)q ! (e)g(used,)g(as)555 1012 y(in)j(the)f(follo)o(wing)g(example,)h(but)f ! (the)g(sp)q(ecial)i(c)o(haracter)d(names)h(are)f(not)555 ! 1067 y(recognized.)675 1130 y Fm("\\C-u":)23 b(universal-argument)675 ! 1182 y("\\C-x\\C-r":)f(re-read-init-file)675 1234 y("\\e[11~":)h ! ("Function)f(Key)i(1")555 1301 y Fn(In)19 b(the)f(ab)q(o)o(v)o(e)g ! (example,)1023 1299 y Fh(h)p 1035 1273 57 2 v 1035 1301 ! a Fg(C-u)p 1035 1308 V 1090 1299 a Fh(i)1123 1301 y Fn(is)h(b)q(ound)g ! (to)f(the)g(function)h Fm(universal-)555 1355 y(argument)9 ! b Fn(\(just)h(as)h(it)g(w)o(as)e(in)j(the)e(\014rst)h(example\),)g(`) ! 1463 1353 y Fh(h)p 1475 1327 56 2 v 1475 1355 a Fg(C-x)p ! 1475 1363 V 1529 1353 a Fh(i)k(h)p 1571 1327 51 2 v 1571 ! 1355 a Fg(C-r)p 1571 1363 V 1620 1353 a Fh(i)1635 1355 ! y Fn(')10 b(is)h(b)q(ound)h(to)555 1410 y(the)k(function)i ! Fm(re-read-init-file)p Fn(,)c(and)i(`)1351 1408 y Fh(h)p ! 1363 1382 70 2 v 1363 1410 a Fg(ESC)p 1363 1418 V 1430 ! 1408 a Fh(i)f(h)p 1472 1382 10 2 v 1472 1410 a Fg([)p ! 1472 1419 V 1480 1408 a Fh(i)g(h)p 1522 1382 18 2 v 1522 ! 1410 a Fg(1)p 1522 1418 V 1538 1408 a Fh(i)g(h)p 1580 ! 1382 V 1580 1410 a Fg(1)p 1580 1418 V 1595 1408 a Fh(i)g(h)p ! 1637 1382 24 2 v 1637 1410 a Fm(~)p 1637 1418 V 1659 ! 1408 a Fh(i)1674 1410 y Fn(')h(is)h(b)q(ound)555 1465 ! y(to)e(insert)g(the)g(text)g(`)p Fm(Function)f(Key)h(1)p ! Fn('.)315 1543 y(The)g(follo)o(wing)h Fi(gnu)e Fn(Emacs)h(st)o(yle)g ! (escap)q(e)h(sequences)g(are)e(a)o(v)m(ailable)j(when)e(sp)q(ecifying) ! 315 1598 y(k)o(ey)g(sequences:)315 1676 y Fd(\\C-)168 ! b Fn(con)o(trol)15 b(pre\014x)315 1755 y Fd(\\M-)168 ! b Fn(meta)15 b(pre\014x)315 1833 y Fd(\\e)192 b Fn(an)15 ! b(escap)q(e)h(c)o(haracter)315 1911 y Fd(\\\\)192 b Fn(bac)o(kslash)315 ! 1989 y Fd(\\)p Fm(")555 1987 y Fh(h)p 567 1961 V 567 ! 1989 a Fm(")p 567 1997 V 589 1987 a Fh(i)604 1989 y Fn(,)15 ! b(a)f(double)j(quotation)e(mark)315 2068 y Fd(\\')555 ! 2066 y Fh(h)p 567 2040 10 2 v 567 2068 a Fg(')p 567 2075 ! V 575 2066 a Fh(i)590 2068 y Fn(,)g(a)f(single)j(quote)e(or)g(ap)q ! (ostrophe)315 2146 y(In)f(addition)h(to)f(the)f Fi(gnu)h ! Fn(Emacs)g(st)o(yle)f(escap)q(e)i(sequences,)g(a)e(second)i(set)e(of)h ! (bac)o(kslash)315 2201 y(escap)q(es)i(is)g(a)o(v)m(ailable:)315 ! 2279 y Fm(\\a)192 b Fn(alert)15 b(\(b)q(ell\))315 2357 ! y Fm(\\b)192 b Fn(bac)o(kspace)315 2435 y Fm(\\d)g Fn(delete)315 ! 2514 y Fm(\\f)g Fn(form)14 b(feed)315 2592 y Fm(\\n)192 ! b Fn(newline)315 2670 y Fm(\\r)g Fn(carriage)15 b(return)p eop %%Page: 8 10 ! 8 9 bop 75 -58 a Fn(8)1322 b(GNU)15 b(Readline)i(Library)315 ! 183 y Fm(\\t)192 b Fn(horizon)o(tal)16 b(tab)315 262 ! y Fm(\\v)192 b Fn(v)o(ertical)16 b(tab)315 340 y Fm(\\)p ! Ff(nnn)141 b Fn(the)13 b(c)o(haracter)e(whose)i Fm(ASCII)e ! Fn(co)q(de)j(is)f(the)f(o)q(ctal)h(v)m(alue)h Ff(nnn)f ! Fn(\(one)f(to)g(three)555 395 y(digits\))315 473 y Fm(\\x)p ! Ff(nnn)117 b Fn(the)15 b(c)o(haracter)e(whose)i Fm(ASCII)e ! Fn(co)q(de)j(is)f(the)f(hexadecimal)i(v)m(alue)g Ff(nnn)f ! Fn(\(one)555 528 y(to)g(three)g(digits\))315 607 y(When)k(en)o(tering)g ! (the)g(text)f(of)g(a)h(macro,)f(single)i(or)e(double)i(quotes)f(m)o ! (ust)f(b)q(e)h(used)h(to)315 662 y(indicate)12 b(a)f(macro)f ! (de\014nition.)20 b(Unquoted)11 b(text)f(is)i(assumed)e(to)h(b)q(e)g(a) ! f(function)i(name.)18 b(In)315 716 y(the)11 b(macro)f(b)q(o)q(dy)l(,)i ! (the)f(bac)o(kslash)g(escap)q(es)g(describ)q(ed)i(ab)q(o)o(v)o(e)d(are) ! g(expanded.)20 b(Bac)o(kslash)315 771 y(will)i(quote)d(an)o(y)h(other)g ! (c)o(haracter)f(in)i(the)f(macro)f(text,)h(including)j(`)p ! Fm(")p Fn(')c(and)h(`)p Fm(')p Fn('.)34 b(F)l(or)315 ! 826 y(example,)14 b(the)f(follo)o(wing)g(binding)i(will)g(mak)o(e)d(`)p ! Fm(C-x)i(\\)p Fn(')f(insert)g(a)g(single)h(`)p Fm(\\)p ! Fn(')e(in)o(to)h(the)g(line:)435 890 y Fm("\\C-x\\\\":)23 ! b("\\\\")75 1000 y Fe(1.3.2)30 b(Conditional)20 b(Init)g(Constructs)137 ! 1096 y Fn(Readline)g(implemen)o(ts)f(a)f(facilit)o(y)g(similar)h(in)g ! (spirit)f(to)f(the)h(conditional)h(compilation)g(features)75 ! 1150 y(of)e(the)g(C)g(prepro)q(cessor)g(whic)o(h)i(allo)o(ws)e(k)o(ey)g ! (bindings)i(and)f(v)m(ariable)g(settings)f(to)g(b)q(e)h(p)q(erformed)f ! (as)75 1205 y(the)e(result)h(of)f(tests.)k(There)c(are)g(four)g(parser) ! g(directiv)o(es)h(used.)75 1284 y Fm($if)168 b Fn(The)16 ! b Fm($if)f Fn(construct)g(allo)o(ws)h(bindings)i(to)d(b)q(e)h(made)g ! (based)g(on)f(the)h(editing)h(mo)q(de,)f(the)315 1338 ! y(terminal)k(b)q(eing)g(used,)g(or)f(the)g(application)i(using)e ! (Readline.)34 b(The)19 b(text)g(of)f(the)i(test)315 1393 ! y(extends)c(to)e(the)h(end)h(of)f(the)g(line;)i(no)e(c)o(haracters)f ! (are)h(required)i(to)d(isolate)i(it.)315 1472 y Fm(mode)144 ! b Fn(The)11 b Fm(mode=)e Fn(form)h(of)g(the)h Fm($if)f ! Fn(directiv)o(e)h(is)g(used)g(to)f(test)g(whether)h(Readline)555 ! 1527 y(is)k(in)h Fm(emacs)e Fn(or)g Fm(vi)g Fn(mo)q(de.)20 b(This)c(ma)o(y)e(b)q(e)h(used)g(in)h(conjunction)g(with)f(the)555 ! 1581 y(`)p Fm(set)f(keymap)p Fn(')f(command,)g(for)h(instance,)g(to)f ! (set)h(bindings)h(in)g(the)f Fm(emacs-)555 1636 y(standard)d ! Fn(and)i Fm(emacs-ctlx)e Fn(k)o(eymaps)h(only)i(if)f(Readline)h(is)f ! (starting)f(out)555 1691 y(in)k Fm(emacs)f Fn(mo)q(de.)315 ! 1769 y Fm(term)144 b Fn(The)14 b Fm(term=)e Fn(form)h(ma)o(y)g(b)q(e)h (used)g(to)f(include)j(terminal-sp)q(eci\014c)g(k)o(ey)d(bind-)555 ! 1824 y(ings,)19 b(p)q(erhaps)g(to)e(bind)i(the)g(k)o(ey)e(sequences)j ! (output)e(b)o(y)g(the)g(terminal's)555 1879 y(function)13 b(k)o(eys.)18 b(The)13 b(w)o(ord)e(on)h(the)g(righ)o(t)g(side)g(of)g ! (the)g(`)p Fm(=)p Fn(')f(is)h(tested)g(against)555 1934 y(b)q(oth)j(the)g(full)i(name)e(of)f(the)h(terminal)h(and)f(the)g(p)q ! (ortion)h(of)e(the)h(terminal)555 1989 y(name)i(b)q(efore)g(the)g ! (\014rst)f(`)p Fm(-)p Fn('.)24 b(This)17 b(allo)o(ws)g ! Fm(sun)f Fn(to)g(matc)o(h)h(b)q(oth)f Fm(sun)h Fn(and)555 ! 2043 y Fm(sun-cmd)p Fn(,)d(for)g(instance.)315 2122 y ! Fm(application)555 2177 y Fn(The)d Ff(application)i Fn(construct)e(is)g ! (used)h(to)e(include)j(application-sp)q(eci)q(\014c)h(set-)555 ! 2231 y(tings.)19 b(Eac)o(h)12 b(program)f(using)j(the)e(Readline)j ! (library)e(sets)f(the)g Ff(application)555 2286 y(name)p ! Fn(,)17 b(and)f(y)o(ou)h(can)f(test)g(for)g(it.)24 b(This)18 ! b(could)f(b)q(e)g(used)g(to)f(bind)i(k)o(ey)f(se-)555 ! 2341 y(quences)c(to)e(functions)i(useful)g(for)e(a)h(sp)q(eci\014c)i ! (program.)j(F)l(or)12 b(instance,)h(the)555 2396 y(follo)o(wing)i ! (command)f(adds)g(a)f(k)o(ey)h(sequence)h(that)f(quotes)f(the)i(curren) ! o(t)e(or)555 2451 y(previous)j(w)o(ord)e(in)i(Bash:)675 ! 2514 y Fm($if)23 b(Bash)675 2566 y(#)h(Quote)f(the)g(current)g(or)h ! (previous)f(word)675 2618 y("\\C-xq":)g("\\eb\\"\\ef\\"")675 ! 2670 y($endif)p eop %%Page: 9 11 ! 9 10 bop 75 -58 a Fn(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1077 ! b(9)75 183 y Fm($endif)96 b Fn(This)16 b(command,)e(as)h(seen)h(in)g ! (the)f(previous)h(example,)g(terminates)f(an)g Fm($if)f ! Fn(command.)75 263 y Fm($else)120 b Fn(Commands)15 b(in)h(this)f(branc) ! o(h)h(of)e(the)i Fm($if)e Fn(directiv)o(e)j(are)e(executed)h(if)g(the)f ! (test)g(fails.)75 343 y Fm($include)48 b Fn(This)14 b(directiv)o(e)i ! (tak)o(es)d(a)g(single)i(\014lename)g(as)f(an)f(argumen)o(t)g(and)h ! (reads)g(commands)g(and)315 397 y(bindings)j(from)e(that)f(\014le.)435 ! 462 y Fm($include)23 b(/etc/inputrc)75 574 y Fe(1.3.3)30 ! b(Sample)20 b(Init)h(File)137 670 y Fn(Here)16 b(is)g(an)f(example)h ! (of)f(an)h(inputrc)g(\014le.)22 b(This)16 b(illustrates)g(k)o(ey)g ! (binding,)h(v)m(ariable)f(assignmen)o(t,)75 725 y(and)f(conditional)i ! (syn)o(tax.)p eop %%Page: 10 12 ! 10 11 bop 75 -58 a Fn(10)1299 b(GNU)15 b(Readline)i(Library)195 ! 235 y Fm(#)24 b(This)f(file)g(controls)g(the)h(behaviour)e(of)i(line)f ! (input)g(editing)g(for)195 287 y(#)h(programs)e(that)i(use)f(the)h(Gnu) f(Readline)g(library.)47 b(Existing)22 b(programs)195 ! 339 y(#)i(include)f(FTP,)g(Bash,)g(and)h(Gdb.)195 391 ! y(#)195 443 y(#)g(You)f(can)h(re-read)f(the)g(inputrc)g(file)g(with)h ! (C-x)f(C-r.)195 495 y(#)h(Lines)f(beginning)g(with)g('#')g(are)h ! (comments.)195 546 y(#)195 598 y(#)g(First,)f(include)g(any)g (systemwide)g(bindings)f(and)i(variable)f(assignments)f(from)195 ! 650 y(#)i(/etc/Inputrc)195 702 y($include)f(/etc/Inputrc)195 ! 806 y(#)195 858 y(#)h(Set)f(various)g(bindings)g(for)g(emacs)g(mode.) ! 195 962 y(set)g(editing-mode)g(emacs)195 1065 y($if)g(mode=emacs)195 ! 1169 y(Meta-Control-h:)46 b(backward-kill-word)21 b(Text)i(after)h(the) ! f(function)g(name)g(is)h(ignored)p 1986 1179 21 38 v ! 195 1273 a(#)195 1325 y(#)g(Arrow)f(keys)g(in)h(keypad)f(mode)195 ! 1377 y(#)195 1429 y(#"\\M-OD":)190 b(backward-char)195 ! 1480 y(#"\\M-OC":)g(forward-char)195 1532 y(#"\\M-OA":)g ! (previous-history)195 1584 y(#"\\M-OB":)g(next-history)195 ! 1636 y(#)195 1688 y(#)24 b(Arrow)f(keys)g(in)h(ANSI)f(mode)195 ! 1740 y(#)195 1792 y("\\M-[D":)190 b(backward-char)195 ! 1844 y("\\M-[C":)g(forward-char)195 1896 y("\\M-[A":)g ! (previous-history)195 1947 y("\\M-[B":)g(next-history)195 ! 1999 y(#)195 2051 y(#)24 b(Arrow)f(keys)g(in)h(8)g(bit)f(keypad)g(mode) ! 195 2103 y(#)195 2155 y(#"\\M-\\C-OD":)165 b(backward-char)195 ! 2207 y(#"\\M-\\C-OC":)g(forward-char)195 2259 y(#"\\M-\\C-OA":)g ! (previous-history)195 2311 y(#"\\M-\\C-OB":)g(next-history)195 ! 2363 y(#)195 2414 y(#)24 b(Arrow)f(keys)g(in)h(8)g(bit)f(ANSI)g(mode) ! 195 2466 y(#)195 2518 y(#"\\M-\\C-[D":)165 b(backward-char)195 ! 2570 y(#"\\M-\\C-[C":)g(forward-char)195 2622 y(#"\\M-\\C-[A":)g ! (previous-history)p eop %%Page: 11 13 ! 11 12 bop 75 -58 a Fn(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1055 ! b(11)195 183 y Fm(#"\\M-\\C-[B":)165 b(next-history)195 ! 287 y(C-q:)23 b(quoted-insert)195 391 y($endif)195 495 ! y(#)h(An)f(old-style)g(binding.)47 b(This)23 b(happens)g(to)g(be)h(the) ! f(default.)195 546 y(TAB:)g(complete)195 650 y(#)h(Macros)f(that)g(are) ! h(convenient)e(for)h(shell)h(interaction)195 702 y($if)f(Bash)195 ! 754 y(#)h(edit)f(the)g(path)195 806 y("\\C-xp":)g ! ("PATH=${PATH}\\e\\C-e\\C-a\\)o(ef\\C-f")195 858 y(#)h(prepare)f(to)g ! (type)h(a)f(quoted)g(word)h(--)f(insert)g(open)h(and)f(close)g(double)g ! (quotes)195 910 y(#)h(and)f(move)g(to)h(just)f(after)h(the)f(open)g ! (quote)195 962 y("\\C-x\\"":)g("\\"\\"\\C-b")195 1013 ! y(#)h(insert)f(a)g(backslash)g(\(testing)g(backslash)g(escapes)f(in)i ! (sequences)f(and)g(macros\))195 1065 y("\\C-x\\\\":)g("\\\\")195 ! 1117 y(#)h(Quote)f(the)g(current)g(or)h(previous)f(word)195 ! 1169 y("\\C-xq":)g("\\eb\\"\\ef\\"")195 1221 y(#)h(Add)f(a)h(binding)f (to)g(refresh)g(the)h(line,)f(which)g(is)h(unbound)195 ! 1273 y("\\C-xr":)f(redraw-current-line)195 1325 y(#)h(Edit)f(variable)g ! (on)g(current)g(line.)195 1377 y("\\M-\\C-v":)f ! ("\\C-a\\C-k$\\C-y\\M-\\C-e\\C-a\\C-y=)o(")195 1429 y($endif)195 ! 1532 y(#)i(use)f(a)h(visible)f(bell)g(if)h(one)f(is)h(available)195 ! 1584 y(set)f(bell-style)g(visible)195 1688 y(#)h(don't)f(strip)g ! (characters)g(to)g(7)h(bits)f(when)h(reading)195 1740 ! y(set)f(input-meta)g(on)195 1844 y(#)h(allow)f(iso-latin1)f(characters) h(to)g(be)h(inserted)f(rather)g(than)g(converted)g(to)195 ! 1896 y(#)h(prefix-meta)e(sequences)195 1947 y(set)h(convert-meta)g(off) ! 195 2051 y(#)h(display)f(characters)f(with)h(the)h(eighth)f(bit)g(set)h ! (directly)f(rather)g(than)195 2103 y(#)h(as)f(meta-prefixed)f ! (characters)195 2155 y(set)h(output-meta)g(on)195 2259 y(#)h(if)f(there)g(are)h(more)f(than)h(150)f(possible)g(completions)f ! (for)i(a)f(word,)h(ask)f(the)195 2311 y(#)h(user)f(if)h(he)f(wants)g ! (to)h(see)f(all)h(of)f(them)195 2363 y(set)g(completion-query-items)e ! (150)195 2466 y(#)j(For)f(FTP)195 2518 y($if)g(Ftp)195 ! 2570 y("\\C-xg":)g("get)g(\\M-?")195 2622 y("\\C-xt":)g("put)g(\\M-?")p eop %%Page: 12 14 ! 12 13 bop 75 -58 a Fn(12)1299 b(GNU)15 b(Readline)i(Library)195 ! 183 y Fm("\\M-.":)23 b(yank-last-arg)195 235 y($endif)75 ! 359 y Fl(1.4)33 b(Bindable)24 b(Readline)f(Commands)137 ! 453 y Fn(This)16 b(section)g(describ)q(es)h(Readline)g(commands)e(that) ! g(ma)o(y)f(b)q(e)i(b)q(ound)g(to)f(k)o(ey)g(sequences.)137 ! 519 y(Command)j(names)g(without)h(an)f(accompan)o(ying)g(k)o(ey)g ! (sequence)i(are)e(un)o(b)q(ound)h(b)o(y)g(default.)29 ! b(In)75 573 y(the)15 b(follo)o(wing)h(descriptions,)g ! Ff(p)q(oin)o(t)h Fn(refers)e(to)f(the)i(curren)o(t)f(cursor)f(p)q ! (osition,)i(and)g Ff(mark)h Fn(refers)e(to)f(a)75 628 ! y(cursor)h(p)q(osition)h(sa)o(v)o(ed)e(b)o(y)h(the)g ! Fm(set-mark)f Fn(command.)20 b(The)15 b(text)g(b)q(et)o(w)o(een)g(the)g ! (p)q(oin)o(t)h(and)f(mark)f(is)75 683 y(referred)h(to)g(as)g(the)g ! Ff(region)p Fn(.)75 790 y Fe(1.4.1)30 b(Commands)21 b(F)-5 ! b(or)19 b(Mo)n(ving)75 895 y Fm(beginning-of-line)13 ! b(\(C-a\))315 950 y Fn(Mo)o(v)o(e)h(to)h(the)g(start)f(of)h(the)g ! (curren)o(t)g(line.)75 1026 y Fm(end-of-line)f(\(C-e\))315 ! 1081 y Fn(Mo)o(v)o(e)g(to)h(the)g(end)h(of)f(the)g(line.)75 ! 1157 y Fm(forward-char)f(\(C-f\))315 1212 y Fn(Mo)o(v)o(e)g(forw)o(ard) ! g(a)h(c)o(haracter.)75 1288 y Fm(backward-char)e(\(C-b\))315 ! 1343 y Fn(Mo)o(v)o(e)h(bac)o(k)h(a)g(c)o(haracter.)75 ! 1419 y Fm(forward-word)f(\(M-f\))315 1474 y Fn(Mo)o(v)o(e)g(forw)o(ard) ! g(to)g(the)i(end)g(of)e(the)h(next)h(w)o(ord.)j(W)l(ords)c(are)f(comp)q ! (osed)i(of)f(letters)g(and)315 1529 y(digits.)75 1605 ! y Fm(backward-word)e(\(M-b\))315 1660 y Fn(Mo)o(v)o(e)j(bac)o(k)g(to)h ! (the)f(start)g(of)g(the)h(curren)o(t)g(or)f(previous)i(w)o(ord.)24 ! b(W)l(ords)16 b(are)h(comp)q(osed)315 1715 y(of)e(letters)g(and)g ! (digits.)75 1791 y Fm(clear-screen)f(\(C-l\))315 1846 ! y Fn(Clear)f(the)h(screen)g(and)f(redra)o(w)g(the)g(curren)o(t)g(line,) ! i(lea)o(ving)g(the)e(curren)o(t)g(line)i(at)e(the)g(top)315 ! 1900 y(of)i(the)g(screen.)75 1977 y Fm(redraw-current-line)e(\(\))315 ! 2031 y Fn(Refresh)j(the)f(curren)o(t)g(line.)22 b(By)15 ! b(default,)h(this)f(is)h(un)o(b)q(ound.)75 2138 y Fe(1.4.2)30 ! b(Commands)21 b(F)-5 b(or)19 b(Manipulating)i(The)f(History)75 ! 2244 y Fm(accept-line)14 b(\(Newline,)g(Return\))315 ! 2298 y Fn(Accept)h(the)g(line)i(regardless)e(of)g(where)g(the)g(cursor) ! f(is.)20 b(If)c(this)f(line)h(is)g(non-empt)o(y)l(,)f(add)315 ! 2353 y(it)f(to)g(the)g(history)g(list.)20 b(If)14 b(this)h(line)g(w)o ! (as)e(a)h(history)g(line,)i(then)e(restore)f(the)h(history)g(line)315 ! 2408 y(to)h(its)g(original)h(state.)75 2484 y Fm(previous-history)d ! (\(C-p\))315 2539 y Fn(Mo)o(v)o(e)h(`up')h(through)g(the)g(history)g ! (list.)75 2615 y Fm(next-history)f(\(C-n\))315 2670 y ! Fn(Mo)o(v)o(e)g(`do)o(wn')g(through)h(the)h(history)f(list.)p ! eop %%Page: 13 15 ! 13 14 bop 75 -58 a Fn(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1055 ! b(13)75 183 y Fm(beginning-of-history)12 b(\(M-<\))315 ! 238 y Fn(Mo)o(v)o(e)i(to)h(the)g(\014rst)g(line)i(in)f(the)f(history)l ! (.)75 314 y Fm(end-of-history)e(\(M->\))315 369 y Fn(Mo)o(v)o(e)h(to)h (the)g(end)h(of)f(the)g(input)h(history)l(,)f(i.e.,)g(the)g(line)i ! (curren)o(tly)f(b)q(eing)g(en)o(tered.)75 445 y Fm ! (reverse-search-history)c(\(C-r\))315 500 y Fn(Searc)o(h)k(bac)o(kw)o (ard)e(starting)h(at)g(the)h(curren)o(t)f(line)j(and)d(mo)o(ving)h ! (`up')f(through)g(the)h(his-)315 555 y(tory)e(as)h(necessary)l(.)20 ! b(This)c(is)g(an)f(incremen)o(tal)h(searc)o(h.)75 631 ! y Fm(forward-search-history)c(\(C-s\))315 686 y Fn(Searc)o(h)j(forw)o (ard)e(starting)h(at)h(the)f(curren)o(t)h(line)h(and)f(mo)o(ving)g(`do) ! o(wn')f(through)g(the)h(the)315 741 y(history)g(as)g(necessary)l(.)20 ! b(This)c(is)g(an)f(incremen)o(tal)h(searc)o(h.)75 817 ! y Fm(non-incremental-reverse-se)o(arch-hi)o(story)c(\(M-p\))315 ! 872 y Fn(Searc)o(h)k(bac)o(kw)o(ard)e(starting)h(at)g(the)h(curren)o(t) f(line)j(and)d(mo)o(ving)h(`up')f(through)g(the)h(his-)315 ! 926 y(tory)h(as)h(necessary)g(using)h(a)e(non-incremen)o(tal)j(searc)o ! (h)e(for)f(a)h(string)g(supplied)i(b)o(y)e(the)315 981 ! y(user.)75 1057 y Fm(non-incremental-forward-se)o(arch-hi)o(story)12 ! b(\(M-n\))315 1112 y Fn(Searc)o(h)j(forw)o(ard)e(starting)h(at)h(the)f (curren)o(t)h(line)h(and)f(mo)o(ving)g(`do)o(wn')f(through)g(the)h(the) ! 315 1167 y(history)e(as)g(necessary)h(using)g(a)f(non-incremen)o(tal)i (searc)o(h)e(for)g(a)g(string)g(supplied)j(b)o(y)d(the)315 ! 1222 y(user.)75 1298 y Fm(history-search-forward)f(\(\))315 ! 1353 y Fn(Searc)o(h)21 b(forw)o(ard)e(through)i(the)f(history)h(for)f (the)h(string)g(of)f(c)o(haracters)g(b)q(et)o(w)o(een)h(the)315 ! 1407 y(start)16 b(of)h(the)h(curren)o(t)g(line)h(and)e(the)h(p)q(oin)o (t.)28 b(This)18 b(is)g(a)f(non-incremen)o(tal)i(searc)o(h.)27 ! b(By)315 1462 y(default,)15 b(this)h(command)f(is)h(un)o(b)q(ound.)75 ! 1538 y Fm(history-search-backward)c(\(\))315 1593 y Fn(Searc)o(h)18 b(bac)o(kw)o(ard)e(through)h(the)h(history)f(for)g(the)g(string)h(of)f ! (c)o(haracters)f(b)q(et)o(w)o(een)i(the)315 1648 y(start)e(of)h(the)h (curren)o(t)g(line)h(and)e(the)h(p)q(oin)o(t.)28 b(This)18 b(is)g(a)f(non-incremen)o(tal)i(searc)o(h.)27 b(By)315 ! 1703 y(default,)15 b(this)h(command)f(is)h(un)o(b)q(ound.)75 ! 1779 y Fm(yank-nth-arg)e(\(M-C-y\))315 1834 y Fn(Insert)f(the)g (\014rst)g(argumen)o(t)f(to)g(the)i(previous)f(command)g(\(usually)h ! (the)f(second)h(w)o(ord)e(on)315 1889 y(the)i(previous)i(line\).)21 ! b(With)14 b(an)h(argumen)o(t)e Ff(n)p Fn(,)i(insert)f(the)h ! Ff(n)p Fn(th)f(w)o(ord)g(from)g(the)g(previous)315 1943 ! y(command)f(\(the)h(w)o(ords)f(in)h(the)g(previous)g(command)g(b)q ! (egin)h(with)f(w)o(ord)e(0\).)19 b(A)14 b(negativ)o(e)315 ! 1998 y(argumen)o(t)g(inserts)i(the)f Ff(n)p Fn(th)h(w)o(ord)e(from)h ! (the)g(end)h(of)e(the)i(previous)g(command.)75 2074 y ! Fm(yank-last-arg)d(\(M-.,)i(M-_\))315 2129 y Fn(Insert)j(last)f ! (argumen)o(t)g(to)g(the)g(previous)i(command)e(\(the)g(last)h(w)o(ord)f ! (of)g(the)g(previous)315 2184 y(history)e(en)o(try\).)20 ! b(With)15 b(an)g(argumen)o(t,)g(b)q(eha)o(v)o(e)g(exactly)h(lik)o(e)g ! Fm(yank-nth-arg)p Fn(.)j(Succes-)315 2239 y(siv)o(e)f(calls)g(to)f ! Fm(yank-last-arg)e Fn(mo)o(v)o(e)i(bac)o(k)g(through)g(the)g(history)g ! (list,)i(inserting)f(the)315 2294 y(last)d(argumen)o(t)g(of)f(eac)o(h)i ! (line)g(in)g(turn.)75 2400 y Fe(1.4.3)30 b(Commands)21 ! b(F)-5 b(or)19 b(Changing)i(T)-5 b(ext)75 2506 y Fm(delete-char)14 ! b(\(C-d\))315 2560 y Fn(Delete)j(the)f(c)o(haracter)g(under)h(the)f ! (cursor.)23 b(If)16 b(the)h(cursor)f(is)h(at)e(the)i(b)q(eginning)h(of) ! e(the)315 2615 y(line,)j(there)e(are)g(no)g(c)o(haracters)f(in)i(the)g ! (line,)h(and)e(the)g(last)g(c)o(haracter)g(t)o(yp)q(ed)g(w)o(as)f(not) ! 315 2670 y(b)q(ound)g(to)f Fm(delete-char)p Fn(,)e(then)j(return)f ! Fm(EOF)p Fn(.)p eop %%Page: 14 16 ! 14 15 bop 75 -58 a Fn(14)1299 b(GNU)15 b(Readline)i(Library)75 ! 183 y Fm(backward-delete-char)12 b(\(Rubout\))315 238 ! y Fn(Delete)k(the)f(c)o(haracter)f(b)q(ehind)j(the)f(cursor.)j(A)c(n)o ! (umeric)h(argumen)o(t)e(means)i(to)e(kill)j(the)315 293 ! y(c)o(haracters)d(instead)i(of)f(deleting)i(them.)75 ! 378 y Fm(forward-backward-delete-ch)o(ar)12 b(\(\))315 ! 432 y Fn(Delete)20 b(the)f(c)o(haracter)f(under)i(the)f(cursor,)h (unless)g(the)f(cursor)g(is)h(at)e(the)h(end)h(of)f(the)315 ! 487 y(line,)e(in)g(whic)o(h)g(case)e(the)h(c)o(haracter)g(b)q(ehind)h (the)f(cursor)g(is)g(deleted.)23 b(By)16 b(default,)h(this)315 ! 542 y(is)f(not)f(b)q(ound)h(to)e(a)h(k)o(ey)l(.)75 627 ! y Fm(quoted-insert)e(\(C-q,)i(C-v\))315 682 y Fn(Add)j(the)f(next)g(c)o ! (haracter)g(t)o(yp)q(ed)g(to)f(the)i(line)g(v)o(erbatim.)26 ! b(This)18 b(is)f(ho)o(w)g(to)g(insert)g(k)o(ey)315 736 ! y(sequences)f(lik)o(e)605 734 y Fh(h)p 617 708 56 2 v ! 617 736 a Fg(C-q)p 617 744 V 671 734 a Fh(i)685 736 y ! Fn(,)f(for)g(example.)75 821 y Fm(tab-insert)f(\(M-TAB\))315 ! 876 y Fn(Insert)h(a)g(tab)g(c)o(haracter.)75 961 y Fm(self-insert)f ! (\(a,)g(b,)h(A,)g(1,)g(!,)g(...\))315 1016 y Fn(Insert)g(y)o(ourself.) ! 75 1100 y Fm(transpose-chars)e(\(C-t\))315 1155 y Fn(Drag)i(the)h(c)o ! (haracter)f(b)q(efore)h(the)h(cursor)e(forw)o(ard)g(o)o(v)o(er)g(the)h ! (c)o(haracter)f(at)h(the)g(cursor,)315 1210 y(mo)o(ving)i(the)f(cursor) ! h(forw)o(ard)e(as)i(w)o(ell.)28 b(If)18 b(the)g(insertion)h(p)q(oin)o ! (t)f(is)g(at)f(the)h(end)h(of)e(the)315 1265 y(line,)c(then)e(this)h ! (transp)q(oses)e(the)h(last)g(t)o(w)o(o)f(c)o(haracters)g(of)h(the)g ! (line.)20 b(Negativ)o(e)11 b(argumen)o(ts)315 1320 y(ha)o(v)o(e)k(no)g ! (e\013ect.)75 1404 y Fm(transpose-words)e(\(M-t\))315 ! 1459 y Fn(Drag)i(the)h(w)o(ord)g(b)q(efore)g(p)q(oin)o(t)h(past)f(the)g ! (w)o(ord)f(after)h(p)q(oin)o(t,)g(mo)o(ving)g(p)q(oin)o(t)h(past)f ! (that)315 1514 y(w)o(ord)f(as)f(w)o(ell.)75 1599 y Fm(upcase-word)g ! (\(M-u\))315 1654 y Fn(Upp)q(ercase)j(the)f(curren)o(t)g(\(or)f(follo)o ! (wing\))h(w)o(ord.)22 b(With)16 b(a)g(negativ)o(e)g(argumen)o(t,)f(upp) ! q(er-)315 1708 y(case)g(the)g(previous)h(w)o(ord,)f(but)g(do)g(not)g ! (mo)o(v)o(e)f(the)i(cursor.)75 1793 y Fm(downcase-word)d(\(M-l\))315 ! 1848 y Fn(Lo)o(w)o(ercase)d(the)h(curren)o(t)g(\(or)f(follo)o(wing\))h (w)o(ord.)17 b(With)11 b(a)g(negativ)o(e)g(argumen)o(t,)f(lo)o(w)o ! (ercase)315 1903 y(the)15 b(previous)h(w)o(ord,)e(but)i(do)f(not)g(mo)o ! (v)o(e)f(the)h(cursor.)75 1988 y Fm(capitalize-word)e(\(M-c\))315 ! 2042 y Fn(Capitalize)f(the)f(curren)o(t)f(\(or)g(follo)o(wing\))h(w)o (ord.)18 b(With)11 b(a)f(negativ)o(e)h(argumen)o(t,)f(capitalize)315 ! 2097 y(the)15 b(previous)h(w)o(ord,)e(but)i(do)f(not)g(mo)o(v)o(e)f ! (the)h(cursor.)75 2220 y Fe(1.4.4)30 b(Killing)20 b(And)h(Y)-5 ! b(anking)75 2336 y Fm(kill-line)14 b(\(C-k\))315 2391 ! y Fn(Kill)j(the)f(text)e(from)h(p)q(oin)o(t)h(to)e(the)h(end)h(of)f ! (the)g(line.)75 2476 y Fm(backward-kill-line)e(\(C-x)h(Rubout\))315 ! 2530 y Fn(Kill)j(bac)o(kw)o(ard)e(to)f(the)i(b)q(eginning)h(of)e(the)g ! (line.)75 2615 y Fm(unix-line-discard)e(\(C-u\))315 2670 ! y Fn(Kill)k(bac)o(kw)o(ard)e(from)f(the)i(cursor)e(to)h(the)g(b)q ! (eginning)j(of)c(the)i(curren)o(t)f(line.)p eop %%Page: 15 17 ! 15 16 bop 75 -58 a Fn(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1055 ! b(15)75 183 y Fm(kill-whole-line)13 b(\(\))315 238 y ! Fn(Kill)20 b(all)f(c)o(haracters)e(on)h(the)g(curren)o(t)f(line,)j(no)e ! (matter)f(p)q(oin)o(t)h(is.)28 b(By)18 b(default,)h(this)f(is)315 ! 293 y(un)o(b)q(ound.)75 374 y Fm(kill-word)c(\(M-d\))315 ! 429 y Fn(Kill)j(from)d(p)q(oin)o(t)h(to)f(the)h(end)g(of)f(the)h ! (curren)o(t)g(w)o(ord,)e(or)i(if)g(b)q(et)o(w)o(een)g(w)o(ords,)e(to)i ! (the)f(end)315 483 y(of)h(the)g(next)g(w)o(ord.)20 b(W)l(ord)14 ! b(b)q(oundaries)j(are)e(the)g(same)g(as)g Fm(forward-word)p ! Fn(.)75 564 y Fm(backward-kill-word)e(\(M-DEL\))315 619 ! y Fn(Kill)k(the)d(w)o(ord)g(b)q(ehind)i(p)q(oin)o(t.)21 ! b(W)l(ord)14 b(b)q(oundaries)h(are)f(the)h(same)f(as)g ! Fm(backward-word)p Fn(.)75 700 y Fm(unix-word-rubout)f(\(C-w\))315 ! 755 y Fn(Kill)18 b(the)e(w)o(ord)f(b)q(ehind)j(p)q(oin)o(t,)e(using)h ! (white)f(space)g(as)g(a)f(w)o(ord)g(b)q(oundary)l(.)23 ! b(The)16 b(killed)315 810 y(text)f(is)g(sa)o(v)o(ed)g(on)g(the)h ! (kill-ring.)75 891 y Fm(delete-horizontal-space)c(\(\))315 ! 946 y Fn(Delete)k(all)g(spaces)f(and)h(tabs)e(around)i(p)q(oin)o(t.)k ! (By)15 b(default,)h(this)f(is)h(un)o(b)q(ound.)75 1027 ! y Fm(kill-region)e(\(\))315 1082 y Fn(Kill)j(the)f(text)e(in)i(the)g (curren)o(t)f(region.)20 b(By)15 b(default,)h(this)f(command)g(is)h(un) ! o(b)q(ound.)75 1163 y Fm(copy-region-as-kill)d(\(\))315 ! 1217 y Fn(Cop)o(y)j(the)i(text)e(in)i(the)f(region)g(to)g(the)g(kill)h (bu\013er,)f(so)g(it)g(can)g(b)q(e)h(y)o(ank)o(ed)f(righ)o(t)g(a)o(w)o ! (a)o(y)l(.)315 1272 y(By)e(default,)h(this)f(command)g(is)h(un)o(b)q ! (ound.)75 1353 y Fm(copy-backward-word)d(\(\))315 1408 ! y Fn(Cop)o(y)19 b(the)g(w)o(ord)g(b)q(efore)g(p)q(oin)o(t)h(to)e(the)i (kill)h(bu\013er.)32 b(The)19 b(w)o(ord)g(b)q(oundaries)h(are)f(the)315 ! 1463 y(same)c(as)g Fm(backward-word)p Fn(.)j(By)d(default,)g(this)h ! (command)f(is)h(un)o(b)q(ound.)75 1544 y Fm(copy-forward-word)d(\(\)) ! 315 1599 y Fn(Cop)o(y)i(the)h(w)o(ord)e(follo)o(wing)j(p)q(oin)o(t)f (to)f(the)g(kill)j(bu\013er.)i(The)c(w)o(ord)f(b)q(oundaries)i(are)e ! (the)315 1653 y(same)g(as)g Fm(forward-word)p Fn(.)j(By)d(default,)h ! (this)f(command)g(is)h(un)o(b)q(ound.)75 1734 y Fm(yank)f(\(C-y\))315 ! 1789 y Fn(Y)l(ank)g(the)h(top)f(of)f(the)i(kill)h(ring)e(in)o(to)g(the) ! h(bu\013er)f(at)f(the)i(curren)o(t)f(cursor)g(p)q(osition.)75 ! 1870 y Fm(yank-pop)f(\(M-y\))315 1925 y Fn(Rotate)j(the)g(kill-ring,)j ! (and)d(y)o(ank)g(the)h(new)f(top.)26 b(Y)l(ou)17 b(can)h(only)g(do)f ! (this)h(if)f(the)h(prior)315 1980 y(command)d(is)h(y)o(ank)f(or)f(y)o ! (ank-p)q(op.)75 2095 y Fe(1.4.5)30 b(Sp)r(ecifying)20 ! b(Numeric)h(Argumen)n(ts)75 2205 y Fm(digit-argument)13 ! b(\(M-0,)i(M-1,)f(...)h(M--\))315 2260 y Fn(Add)f(this)g(digit)g(to)f ! (the)h(argumen)o(t)e(already)i(accum)o(ulating,)g(or)f(start)f(a)h(new) ! h(argumen)o(t.)315 2313 y Fh(h)p 327 2287 50 2 v 327 ! 2315 a Fg(M{)p 327 2323 V 375 2313 a Fh(i)405 2315 y ! Fn(starts)g(a)h(negativ)o(e)g(argumen)o(t.)75 2396 y ! Fm(universal-argument)e(\(\))315 2451 y Fn(This)g(is)h(another)e(w)o(a) ! o(y)g(to)g(sp)q(ecify)i(an)f(argumen)o(t.)18 b(If)13 b(this)g(command)g(is)g(follo)o(w)o(ed)g(b)o(y)g(one)315 ! 2506 y(or)h(more)h(digits,)g(optionally)h(with)f(a)g(leading)h(min)o ! (us)f(sign,)g(those)g(digits)g(de\014ne)h(the)f(ar-)315 ! 2560 y(gumen)o(t.)k(If)c(the)g(command)f(is)h(follo)o(w)o(ed)g(b)o(y)g ! (digits,)g(executing)g Fm(universal-argument)315 2615 ! y Fn(again)h(ends)g(the)g(n)o(umeric)h(argumen)o(t,)e(but)h(is)h (otherwise)f(ignored.)22 b(As)16 b(a)g(sp)q(ecial)h(case,)315 ! 2670 y(if)g(this)g(command)f(is)h(immediately)h(follo)o(w)o(ed)f(b)o(y) ! f(a)g(c)o(haracter)g(that)g(is)h(neither)g(a)f(digit)p ! eop ! %%Page: 16 18 ! 16 17 bop 75 -58 a Fn(16)1299 b(GNU)15 b(Readline)i(Library)315 ! 183 y(or)c(min)o(us)i(sign,)f(the)g(argumen)o(t)g(coun)o(t)f(for)h(the) g(next)g(command)g(is)g(m)o(ultiplied)j(b)o(y)d(four.)315 ! 238 y(The)19 b(argumen)o(t)f(coun)o(t)g(is)h(initially)j(one,)d(so)f (executing)i(this)f(function)h(the)e(\014rst)h(time)315 ! 293 y(mak)o(es)c(the)h(argumen)o(t)f(coun)o(t)h(four,)f(a)h(second)g (time)g(mak)o(es)g(the)g(argumen)o(t)f(coun)o(t)g(six-)315 ! 348 y(teen,)g(and)g(so)g(on.)20 b(By)15 b(default,)h(this)f(is)h(not)f ! (b)q(ound)h(to)f(a)g(k)o(ey)l(.)75 472 y Fe(1.4.6)30 b(Letting)20 b(Readline)g(T)n(yp)r(e)h(F)-5 b(or)19 b(Y)-5 ! b(ou)75 590 y Fm(complete)14 b(\(TAB\))315 644 y Fn(A)o(ttempt)j(to)g ! (do)h(completion)g(on)g(the)g(text)f(b)q(efore)h(the)g(cursor.)27 ! b(This)18 b(is)g(application-)315 699 y(sp)q(eci\014c.)k(Generally)l(,) ! 15 b(if)g(y)o(ou)g(are)f(t)o(yping)h(a)g(\014lename)g(argumen)o(t,)f(y) ! o(ou)g(can)h(do)g(\014lename)315 754 y(completion;)h(if)g(y)o(ou)f(are) ! g(t)o(yping)h(a)f(command,)f(y)o(ou)h(can)h(do)f(command)g(completion;) ! h(if)315 809 y(y)o(ou)i(are)g(t)o(yping)g(in)h(a)f(sym)o(b)q(ol)h(to)e ! (GDB,)h(y)o(ou)g(can)g(do)g(sym)o(b)q(ol)h(name)f(completion;)i(if)315 ! 864 y(y)o(ou)13 b(are)g(t)o(yping)g(in)h(a)f(v)m(ariable)h(to)f(Bash,)g ! (y)o(ou)g(can)g(do)g(v)m(ariable)h(name)f(completion,)i(and)315 ! 918 y(so)g(on.)75 1004 y Fm(possible-completions)d(\(M-?\))315 ! 1059 y Fn(List)k(the)f(p)q(ossible)i(completions)f(of)f(the)g(text)g(b) ! q(efore)h(the)f(cursor.)75 1145 y Fm(insert-completions)e(\(M-*\))315 ! 1199 y Fn(Insert)j(all)g(completions)g(of)f(the)g(text)g(b)q(efore)h(p) q(oin)o(t)f(that)g(w)o(ould)h(ha)o(v)o(e)f(b)q(een)h(generated)315 ! 1254 y(b)o(y)f Fm(possible-completions)p Fn(.)75 1340 ! y Fm(menu-complete)e(\(\))315 1395 y Fn(Similar)g(to)f ! Fm(complete)p Fn(,)f(but)h(replaces)h(the)f(w)o(ord)f(to)g(b)q(e)i ! (completed)f(with)h(a)e(single)j(matc)o(h)315 1450 y(from)k(the)h(list) ! h(of)e(p)q(ossible)j(completions.)32 b(Rep)q(eated)20 ! b(execution)g(of)f Fm(menu-complete)315 1504 y Fn(steps)h(through)g (the)g(list)h(of)f(p)q(ossible)i(completions,)g(inserting)f(eac)o(h)f ! (matc)o(h)f(in)i(turn.)315 1559 y(A)o(t)c(the)g(end)h(of)f(the)h(list)g ! (of)f(completions,)i(the)e(b)q(ell)j(is)e(rung)f(and)h(the)f(original)i ! (text)d(is)315 1614 y(restored.)26 b(An)17 b(argumen)o(t)g(of)g ! Ff(n)g Fn(mo)o(v)o(es)g Ff(n)g Fn(p)q(ositions)h(forw)o(ard)e(in)i(the) ! g(list)g(of)f(matc)o(hes;)315 1669 y(a)j(negativ)o(e)g(argumen)o(t)f ! (ma)o(y)g(b)q(e)i(used)f(to)f(mo)o(v)o(e)h(bac)o(kw)o(ard)f(through)g ! (the)h(list.)35 b(This)315 1724 y(command)15 b(is)h(in)o(tended)g(to)f ! (b)q(e)h(b)q(ound)g(to)f Fm(TAB)p Fn(,)f(but)h(is)h(un)o(b)q(ound)g(b)o ! (y)f(default.)75 1809 y Fm(delete-char-or-list)e(\(\))315 ! 1864 y Fn(Deletes)h(the)f(c)o(haracter)g(under)h(the)g(cursor)f(if)h ! (not)f(at)g(the)g(b)q(eginning)j(or)d(end)h(of)f(the)g(line)315 ! 1919 y(\(lik)o(e)i Fm(delete-char)p Fn(\).)j(If)d(at)f(the)h(end)g(of)f ! (the)g(line,)i(b)q(eha)o(v)o(es)f(iden)o(tically)i(to)d ! Fm(possible-)315 1974 y(completions)p Fn(.)k(This)e(command)f(is)h(un)o ! (b)q(ound)g(b)o(y)f(default.)75 2098 y Fe(1.4.7)30 b(Keyb)r(oard)20 ! b(Macros)75 2216 y Fm(start-kbd-macro)13 b(\(C-x)i(\(\))315 ! 2270 y Fn(Begin)h(sa)o(ving)f(the)h(c)o(haracters)e(t)o(yp)q(ed)i(in)o ! (to)f(the)g(curren)o(t)g(k)o(eyb)q(oard)g(macro.)75 2356 ! y Fm(end-kbd-macro)e(\(C-x)i(\)\))315 2411 y Fn(Stop)f(sa)o(ving)f(the) ! h(c)o(haracters)f(t)o(yp)q(ed)h(in)o(to)f(the)h(curren)o(t)g(k)o(eyb)q ! (oard)f(macro)g(and)h(sa)o(v)o(e)f(the)315 2466 y(de\014nition.)75 ! 2552 y Fm(call-last-kbd-macro)g(\(C-x)h(e\))315 2606 ! y Fn(Re-execute)19 b(the)f(last)f(k)o(eyb)q(oard)h(macro)f(de\014ned,)i ! (b)o(y)e(making)h(the)g(c)o(haracters)e(in)j(the)315 ! 2661 y(macro)14 b(app)q(ear)i(as)f(if)g(t)o(yp)q(ed)h(at)e(the)i(k)o ! (eyb)q(oard.)p eop %%Page: 17 19 ! 17 18 bop 75 -58 a Fn(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1055 ! b(17)75 183 y Fe(1.4.8)30 b(Some)20 b(Miscellaneous)h(Commands)75 ! 298 y Fm(re-read-init-file)13 b(\(C-x)h(C-r\))315 353 ! y Fn(Read)e(in)f(the)g(con)o(ten)o(ts)g(of)f(the)h Ff(inputrc)k ! Fn(\014le,)d(and)g(incorp)q(orate)f(an)o(y)f(bindings)j(or)e(v)m ! (ariable)315 407 y(assignmen)o(ts)k(found)h(there.)75 ! 491 y Fm(abort)e(\(C-g\))315 546 y Fn(Ab)q(ort)f(the)g(curren)o(t)h (editing)g(command)f(and)h(ring)f(the)h(terminal's)f(b)q(ell)i(\(sub)s ! (ject)e(to)g(the)315 600 y(setting)i(of)g Fm(bell-style)p ! Fn(\).)75 684 y Fm(do-uppercase-version)d(\(M-a,)j(M-b,)f(M-)p ! Ff(x)p Fm(,)h Fc(:)8 b(:)g(:)n Fm(\))315 739 y Fn(If)14 ! b(the)g(meta\014ed)g(c)o(haracter)f Ff(x)k Fn(is)d(lo)o(w)o(ercase,)g ! (run)g(the)g(command)f(that)h(is)g(b)q(ound)h(to)e(the)315 ! 794 y(corresp)q(onding)j(upp)q(ercase)g(c)o(haracter.)75 ! 877 y Fm(prefix-meta)e(\(ESC\))315 932 y Fn(Mak)o(e)j(the)i(next)f(c)o ! (haracter)f(t)o(yp)q(ed)i(b)q(e)g(meta\014ed.)28 b(This)19 ! b(is)g(for)e(k)o(eyb)q(oards)h(without)g(a)315 987 y(meta)d(k)o(ey)l(.) ! 20 b(T)o(yping)15 b(`)p Fm(ESC)g(f)p Fn(')f(is)i(equiv)m(alen)o(t)h(to) ! d(t)o(yping)i(`)p Fm(M-f)p Fn('.)75 1070 y Fm(undo)f(\(C-_,)f(C-x)h ! (C-u\))315 1125 y Fn(Incremen)o(tal)h(undo,)f(separately)h(remem)o(b)q ! (ered)g(for)e(eac)o(h)h(line.)75 1209 y Fm(revert-line)f(\(M-r\))315 ! 1263 y Fn(Undo)j(all)g(c)o(hanges)g(made)f(to)g(this)h(line.)26 ! b(This)17 b(is)g(lik)o(e)h(executing)f(the)g Fm(undo)f ! Fn(command)315 1318 y(enough)g(times)f(to)g(get)f(bac)o(k)h(to)g(the)g ! (b)q(eginning.)75 1402 y Fm(tilde-expand)f(\(M-~\))315 ! 1456 y Fn(P)o(erform)g(tilde)j(expansion)f(on)f(the)g(curren)o(t)g(w)o ! (ord.)75 1540 y Fm(set-mark)f(\(C-@\))315 1595 y Fn(Set)g(the)f(mark)g ! (to)g(the)h(curren)o(t)g(p)q(oin)o(t.)19 b(If)14 b(a)g(n)o(umeric)g ! (argumen)o(t)f(is)h(supplied,)i(the)e(mark)315 1650 y(is)i(set)f(to)f ! (that)h(p)q(osition.)75 1733 y Fm(exchange-point-and-mark)d(\(C-x)j ! (C-x\))315 1788 y Fn(Sw)o(ap)g(the)h(p)q(oin)o(t)g(with)g(the)g(mark.)k ! (The)c(curren)o(t)f(cursor)h(p)q(osition)g(is)g(set)g(to)f(the)g(sa)o ! (v)o(ed)315 1843 y(p)q(osition,)h(and)f(the)h(old)f(cursor)g(p)q ! (osition)h(is)g(sa)o(v)o(ed)f(as)g(the)g(mark.)75 1926 ! y Fm(character-search)e(\(C-]\))315 1981 y Fn(A)f(c)o(haracter)g(is)h ! (read)g(and)f(p)q(oin)o(t)h(is)g(mo)o(v)o(ed)f(to)g(the)g(next)h(o)q ! (ccurrence)g(of)f(that)g(c)o(haracter.)315 2036 y(A)j(negativ)o(e)h ! (coun)o(t)f(searc)o(hes)g(for)f(previous)i(o)q(ccurrences.)75 ! 2119 y Fm(character-search-backward)c(\(M-C-]\))315 2174 ! y Fn(A)22 b(c)o(haracter)g(is)h(read)f(and)h(p)q(oin)o(t)g(is)g(mo)o(v) ! o(ed)f(to)g(the)g(previous)h(o)q(ccurrence)h(of)e(that)315 ! 2229 y(c)o(haracter.)d(A)c(negativ)o(e)h(coun)o(t)f(searc)o(hes)g(for)f ! (subsequen)o(t)i(o)q(ccurrences.)75 2312 y Fm(insert-comment)d(\(M-#\)) ! 315 2367 y Fn(The)19 b(v)m(alue)i(of)e(the)g Fm(comment-begin)e ! Fn(v)m(ariable)k(is)f(inserted)g(at)e(the)i(b)q(eginning)h(of)e(the)315 ! 2422 y(curren)o(t)c(line,)i(and)e(the)g(line)i(is)f(accepted)g(as)e(if) ! i(a)f(newline)i(had)f(b)q(een)g(t)o(yp)q(ed.)75 2506 ! y Fm(dump-functions)d(\(\))315 2560 y Fn(Prin)o(t)g(all)h(of)f(the)g ! (functions)h(and)g(their)g(k)o(ey)f(bindings)i(to)d(the)i(Readline)h ! (output)e(stream.)315 2615 y(If)j(a)g(n)o(umeric)g(argumen)o(t)f(is)i ! (supplied,)h(the)e(output)f(is)i(formatted)d(in)j(suc)o(h)f(a)g(w)o(a)o ! (y)f(that)315 2670 y(it)g(can)h(b)q(e)g(made)f(part)f(of)h(an)g ! Ff(inputrc)k Fn(\014le.)i(This)16 b(command)f(is)h(un)o(b)q(ound)g(b)o ! (y)f(default.)p eop %%Page: 18 20 ! 18 19 bop 75 -58 a Fn(18)1299 b(GNU)15 b(Readline)i(Library)75 ! 183 y Fm(dump-variables)c(\(\))315 238 y Fn(Prin)o(t)e(all)g(of)f(the)h ! (settable)g(v)m(ariables)h(and)f(their)g(v)m(alues)h(to)e(the)h ! (Readline)i(output)d(stream.)315 293 y(If)16 b(a)g(n)o(umeric)g ! (argumen)o(t)f(is)i(supplied,)h(the)e(output)f(is)i(formatted)d(in)j ! (suc)o(h)f(a)g(w)o(a)o(y)f(that)315 348 y(it)g(can)h(b)q(e)g(made)f ! (part)f(of)h(an)g Ff(inputrc)k Fn(\014le.)i(This)16 b(command)f(is)h ! (un)o(b)q(ound)g(b)o(y)f(default.)75 427 y Fm(dump-macros)f(\(\))315 ! 482 y Fn(Prin)o(t)j(all)h(of)e(the)h(Readline)i(k)o(ey)e(sequences)h(b) ! q(ound)g(to)e(macros)g(and)h(the)g(strings)g(they)315 ! 537 y(ouput.)30 b(If)19 b(a)f(n)o(umeric)i(argumen)o(t)d(is)i ! (supplied,)j(the)c(output)h(is)g(formatted)e(in)i(suc)o(h)g(a)315 ! 592 y(w)o(a)o(y)14 b(that)g(it)i(can)f(b)q(e)g(made)g(part)g(of)f(an)h ! Ff(inputrc)k Fn(\014le.)i(This)15 b(command)g(is)h(un)o(b)q(ound)g(b)o ! (y)315 647 y(default.)75 775 y Fl(1.5)33 b(Readline)23 ! b(vi)h(Mo)r(de)137 871 y Fn(While)13 b(the)f(Readline)j(library)d(do)q ! (es)g(not)g(ha)o(v)o(e)f(a)h(full)h(set)f(of)f Fm(vi)g ! Fn(editing)j(functions,)f(it)f(do)q(es)g(con)o(tain)75 ! 926 y(enough)17 b(to)g(allo)o(w)g(simple)h(editing)h(of)d(the)i(line.) ! 27 b(The)17 b(Readline)i Fm(vi)e Fn(mo)q(de)g(b)q(eha)o(v)o(es)g(as)g ! (sp)q(eci\014ed)i(in)75 981 y(the)c Fi(POSIX)h Fn(1003.2)d(standard.) ! 137 1048 y(In)i(order)g(to)f(switc)o(h)g(in)o(teractiv)o(ely)i(b)q(et)o ! (w)o(een)f Fm(emacs)e Fn(and)i Fm(vi)f Fn(editing)i(mo)q(des,)f(use)f ! (the)h(command)75 1103 y(M-C-j)g(\(toggle-editing-mo)q(de\).)21 ! b(The)15 b(Readline)j(default)d(is)h Fm(emacs)f Fn(mo)q(de.)137 ! 1170 y(When)h(y)o(ou)e(en)o(ter)h(a)g(line)i(in)e Fm(vi)g ! Fn(mo)q(de,)g(y)o(ou)g(are)f(already)i(placed)g(in)g(`insertion')f(mo)q ! (de,)g(as)g(if)g(y)o(ou)75 1225 y(had)e(t)o(yp)q(ed)h(an)f(`)p ! Fm(i)p Fn('.)18 b(Pressing)608 1223 y Fh(h)p 620 1197 ! 70 2 v 620 1225 a Fg(ESC)p 620 1233 V 687 1223 a Fh(i)715 ! 1225 y Fn(switc)o(hes)13 b(y)o(ou)g(in)o(to)g(`command')f(mo)q(de,)i ! (where)f(y)o(ou)g(can)g(edit)h(the)75 1280 y(text)i(of)h(the)g(line)h ! (with)g(the)f(standard)f Fm(vi)h Fn(mo)o(v)o(emen)o(t)f(k)o(eys,)g(mo)o ! (v)o(e)g(to)h(previous)g(history)g(lines)i(with)75 1335 ! y(`)p Fm(k)p Fn(')14 b(and)i(subsequen)o(t)f(lines)i(with)f(`)p ! Fm(j)p Fn(',)e(and)h(so)g(forth.)p eop %%Page: -1 21 ! -1 20 bop 1862 -58 a Fn(i)75 183 y Fj(T)-7 b(able)27 ! b(of)f(Con)n(ten)n(ts)75 354 y Fl(1)67 b(Command)22 b(Line)i(Editing)d ! Fb(.)10 b(.)h(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)h ! (.)f(.)g(.)g(.)42 b Fl(1)224 423 y Fn(1.1)j(In)o(tro)q(duction)16 ! b(to)f(Line)h(Editing)e Fa(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)27 b Fn(1)224 478 y(1.2)45 b(Readline)17 b(In)o(teraction)8 ! b Fa(.)g(.)g(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)23 b Fn(1)374 532 y(1.2.1)44 b(Readline)17 ! b(Bare)e(Essen)o(tials)f Fa(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h (.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)27 ! b Fn(1)374 587 y(1.2.2)44 b(Readline)17 b(Mo)o(v)o(emen)o(t)d(Commands) ! 7 b Fa(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f ! (.)h(.)21 b Fn(2)374 642 y(1.2.3)44 b(Readline)17 b(Killing)h(Commands) ! 11 b Fa(.)c(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h ! (.)f(.)h(.)f(.)h(.)25 b Fn(2)374 697 y(1.2.4)44 b(Readline)17 ! b(Argumen)o(ts)12 b Fa(.)c(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)27 ! b Fn(3)374 752 y(1.2.5)44 b(Searc)o(hing)16 b(for)e(Commands)h(in)h ! (the)f(History)e Fa(.)8 b(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)27 ! b Fn(3)224 806 y(1.3)45 b(Readline)17 b(Init)g(File)e ! Fa(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)f(.)29 b Fn(4)374 861 y(1.3.1)44 b(Readline)17 ! b(Init)f(File)h(Syn)o(tax)7 b Fa(.)g(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)21 ! b Fn(4)374 916 y(1.3.2)44 b(Conditional)16 b(Init)g(Constructs)5 ! b Fa(.)i(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)g(.)f(.)19 b Fn(8)374 971 y(1.3.3)44 b(Sample)16 ! b(Init)g(File)11 b Fa(.)e(.)e(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)26 b Fn(9)224 1026 y(1.4)45 b(Bindable)17 b(Readline)h ! (Commands)6 b Fa(.)h(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)21 ! b Fn(12)374 1080 y(1.4.1)44 b(Commands)14 b(F)l(or)h(Mo)o(ving)e ! Fa(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)h(.)28 b Fn(12)374 1135 y(1.4.2)44 b(Commands)14 b(F)l(or)h(Manipulating)i(The)e(History)9 ! b Fa(.)e(.)h(.)f(.)h(.)f(.)h(.)24 b Fn(12)374 1190 y(1.4.3)44 ! b(Commands)14 b(F)l(or)h(Changing)h(T)l(ext)e Fa(.)8 b(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)30 ! b Fn(13)374 1245 y(1.4.4)44 b(Killing)18 b(And)e(Y)l(anking)9 ! b Fa(.)e(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)24 b Fn(14)374 ! 1299 y(1.4.5)44 b(Sp)q(ecifying)17 b(Numeric)f(Argumen)o(ts)c ! Fa(.)c(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)27 ! b Fn(15)374 1354 y(1.4.6)44 b(Letting)15 b(Readline)j(T)o(yp)q(e)d(F)l ! (or)g(Y)l(ou)10 b Fa(.)d(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)25 b Fn(16)374 1409 y(1.4.7)44 b(Keyb)q(oard)15 ! b(Macros)6 b Fa(.)h(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f (.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)21 ! b Fn(16)374 1464 y(1.4.8)44 b(Some)15 b(Miscellaneous)i(Commands)7 ! b Fa(.)g(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! 22 b Fn(17)224 1519 y(1.5)45 b(Readline)17 b(vi)f(Mo)q(de)e ! Fa(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)28 b Fn(18)p eop %%Page: -2 22 ! -2 21 bop 75 -58 a Fn(ii)1321 b(GNU)15 b(Readline)i(Library)p eop %%Trailer --- 984,1929 ---- (t)g(\(or)g(the)g(same\))g(place)h(later.)p eop %%Page: 3 5 ! 3 4 bop 75 -58 a Fm(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1077 ! b(3)137 149 y(When)12 b(y)o(ou)g(use)g(a)f(kill)i(command,)f(the)g ! (text)f(is)h(sa)o(v)o(ed)f(in)i(a)e Fc(kill-ring)p Fm(.)21 b(An)o(y)12 b(n)o(um)o(b)q(er)g(of)f(consecutiv)o(e)75 ! 204 y(kills)17 b(sa)o(v)o(e)e(all)h(of)f(the)h(killed)i(text)d (together,)f(so)h(that)g(when)h(y)o(ou)f(y)o(ank)g(it)h(bac)o(k,)f(y)o ! (ou)g(get)g(it)h(all.)22 b(The)75 259 y(kill)c(ring)f(is)f(not)g(line)i (sp)q(eci\014c;)g(the)e(text)g(that)f(y)o(ou)h(killed)j(on)d(a)g (previously)h(t)o(yp)q(ed)g(line)h(is)e(a)o(v)m(ailable)75 ! 314 y(to)f(b)q(e)g(y)o(ank)o(ed)g(bac)o(k)h(later,)e(when)i(y)o(ou)f ! (are)g(t)o(yping)g(another)g(line.)137 380 y(Here)h(is)f(the)h(list)g ! (of)e(commands)h(for)g(killing)j(text.)75 458 y Fg(C-k)168 ! b Fm(Kill)17 b(the)f(text)e(from)h(the)g(curren)o(t)g(cursor)g(p)q ! (osition)h(to)f(the)g(end)h(of)f(the)g(line.)75 535 y ! Fg(M-d)168 b Fm(Kill)15 b(from)e(the)g(cursor)g(to)f(the)i(end)g(of)e (the)i(curren)o(t)f(w)o(ord,)f(or,)h(if)g(b)q(et)o(w)o(een)h(w)o(ords,) ! e(to)h(the)315 590 y(end)j(of)f(the)g(next)g(w)o(ord.)k(W)l(ord)c(b)q ! (oundaries)i(are)e(the)g(same)g(as)g(those)f(used)i(b)o(y)f ! Fg(M-f)p Fm(.)75 668 y Fg(M-)123 666 y Ff(h)p 135 640 ! 73 2 v 135 668 a Fe(DEL)p 135 675 V 206 666 a Ff(i)315 ! 668 y Fm(Kill)21 b(from)e(the)g(cursor)f(the)h(start)f(of)h(the)g ! (previous)h(w)o(ord,)f(or,)g(if)g(b)q(et)o(w)o(een)h(w)o(ords,)f(to)315 ! 723 y(the)14 b(start)f(of)g(the)h(previous)g(w)o(ord.)19 b(W)l(ord)14 b(b)q(oundaries)h(are)e(the)h(same)g(as)f(those)h(used)g ! (b)o(y)315 777 y Fg(M-b)p Fm(.)75 855 y Fg(C-w)168 b ! Fm(Kill)18 b(from)d(the)g(cursor)h(to)f(the)g(previous)i(whitespace.)22 ! b(This)16 b(is)g(di\013eren)o(t)g(than)f Fg(M-)1777 853 ! y Ff(h)p 1789 827 V 1789 855 a Fe(DEL)p 1789 863 V 1860 ! 853 a Ff(i)315 910 y Fm(b)q(ecause)h(the)f(w)o(ord)g(b)q(oundaries)h ! (di\013er.)137 987 y(Here)21 b(is)h(ho)o(w)e(to)g Fc(y)o(ank)j ! Fm(the)e(text)f(bac)o(k)h(in)o(to)g(the)f(line.)39 b(Y)l(anking)21 ! b(means)g(to)f(cop)o(y)h(the)g(most-)75 1042 y(recen)o(tly-killed)d ! (text)d(from)f(the)i(kill)h(bu\013er.)75 1120 y Fg(C-y)168 ! b Fm(Y)l(ank)15 b(the)h(most)e(recen)o(tly)i(killed)h(text)e(bac)o(k)g ! (in)o(to)g(the)h(bu\013er)f(at)f(the)i(cursor.)75 1198 ! y Fg(M-y)168 b Fm(Rotate)16 b(the)h(kill-ring,)j(and)d(y)o(ank)g(the)h ! (new)f(top.)26 b(Y)l(ou)17 b(can)h(only)g(do)f(this)h(if)f(the)h(prior) ! 315 1252 y(command)d(is)h Fg(C-y)f Fm(or)f Fg(M-y)p Fm(.)75 ! 1361 y Fb(1.2.4)30 b(Readline)20 b(Argumen)n(ts)137 1457 ! y Fm(Y)l(ou)15 b(can)g(pass)f(n)o(umeric)i(argumen)o(ts)e(to)g ! (Readline)h(commands.)20 b(Sometimes)15 b(the)g(argumen)o(t)e(acts)75 ! 1511 y(as)20 b(a)f(rep)q(eat)i(coun)o(t,)f(other)g(times)g(it)h(is)f ! (the)g Fd(sign)j Fm(of)c(the)h(argumen)o(t)g(that)f(is)i(signi\014can)o ! (t.)35 b(If)20 b(y)o(ou)75 1566 y(pass)d(a)f(negativ)o(e)h(argumen)o(t) ! f(to)g(a)g(command)h(whic)o(h)h(normally)f(acts)f(in)i(a)e(forw)o(ard)g ! (direction,)i(that)75 1621 y(command)g(will)h(act)e(in)i(a)e(bac)o(kw)o ! (ard)g(direction.)28 b(F)l(or)17 b(example,)i(to)e(kill)j(text)d(bac)o ! (k)g(to)g(the)h(start)e(of)75 1676 y(the)f(line,)i(y)o(ou)e(migh)o(t)g ! (t)o(yp)q(e)g(`)p Fl(M--)f(C-k)p Fm('.)137 1742 y(The)h(general)f(w)o ! (a)o(y)f(to)h(pass)g(n)o(umeric)h(argumen)o(ts)e(to)g(a)h(command)g(is) ! h(to)e(t)o(yp)q(e)h(meta)g(digits)h(b)q(efore)75 1797 ! y(the)h(command.)k(If)c(the)f(\014rst)g(`digit')h(t)o(yp)q(ed)f(is)h(a) ! g(min)o(us)g(sign)g(\(`)p Fl(-)p Fm('\),)d(then)j(the)f(sign)h(of)f ! (the)h(argumen)o(t)75 1852 y(will)21 b(b)q(e)f(negativ)o(e.)31 ! b(Once)20 b(y)o(ou)f(ha)o(v)o(e)g(t)o(yp)q(ed)g(one)g(meta)g(digit)h ! (to)e(get)h(the)g(argumen)o(t)f(started,)h(y)o(ou)75 ! 1906 y(can)c(t)o(yp)q(e)f(the)h(remainder)g(of)f(the)g(digits,)h(and)g ! (then)g(the)f(command.)20 b(F)l(or)13 b(example,)i(to)f(giv)o(e)h(the)f ! Fg(C-d)75 1961 y Fm(command)19 b(an)f(argumen)o(t)g(of)g(10,)h(y)o(ou)f ! (could)i(t)o(yp)q(e)f(`)p Fl(M-1)14 b(0)h(C-d)p Fm(',)k(whic)o(h)g ! (will)h(delete)g(the)f(next)g(ten)75 2016 y(c)o(haracters)14 ! b(on)i(the)f(input)h(line.)75 2125 y Fb(1.2.5)30 b(Searc)n(hing)21 ! b(for)f(Commands)h(in)f(the)h(History)137 2220 y Fm(Readline)d(pro)o ! (vides)e(commands)g(for)g(searc)o(hing)g(through)g(the)g(command)g ! (history)g(for)g(lines)i(con-)75 2275 y(taining)e(a)f(sp)q(eci\014ed)i ! (string.)j(There)c(are)e(t)o(w)o(o)g(searc)o(h)h(mo)q(des:)20 ! b Fc(incremen)o(tal)e Fm(and)e Fc(non-incremen)o(tal)p ! Fm(.)137 2341 y(Incremen)o(tal)e(searc)o(hes)f(b)q(egin)h(b)q(efore)f ! (the)g(user)g(has)g(\014nished)h(t)o(yping)f(the)g(searc)o(h)g(string.) ! 19 b(As)13 b(eac)o(h)75 2396 y(c)o(haracter)k(of)g(the)h(searc)o(h)g ! (string)f(is)h(t)o(yp)q(ed,)h(Readline)g(displa)o(ys)f(the)g(next)g(en) ! o(try)f(from)g(the)h(history)75 2451 y(matc)o(hing)12 ! b(the)g(string)g(t)o(yp)q(ed)g(so)g(far.)18 b(An)13 b(incremen)o(tal)g ! (searc)o(h)f(requires)g(only)h(as)f(man)o(y)f(c)o(haracters)g(as)75 ! 2506 y(needed)16 b(to)d(\014nd)j(the)e(desired)i(history)e(en)o(try)l ! (.)19 b(T)l(o)c(searc)o(h)f(bac)o(kw)o(ard)f(in)j(the)e(history)g(for)g ! (a)g(particular)75 2560 y(string,)g(t)o(yp)q(e)h Fg(C-r)p ! Fm(.)k(T)o(yping)d Fg(C-s)e Fm(searc)o(hes)h(forw)o(ard)e(through)h ! (the)h(history)l(.)20 b(The)15 b(c)o(haracters)f(presen)o(t)75 ! 2615 y(in)20 b(the)f(v)m(alue)h(of)f(the)g Fl(isearch-terminators)d ! Fm(v)m(ariable)k(are)f(used)h(to)e(terminate)h(an)g(incremen)o(tal)75 ! 2670 y(searc)o(h.)31 b(If)19 b(that)f(v)m(ariable)i(has)f(not)f(b)q ! (een)i(assigned)g(a)e(v)m(alue,)j(the)1289 2668 y Ff(h)p ! 1301 2642 70 2 v 1301 2670 a Fe(ESC)p 1301 2678 V 1368 ! 2668 a Ff(i)1402 2670 y Fm(and)e Fg(C-J)f Fm(c)o(haracters)g(will)p ! eop %%Page: 4 6 ! 4 5 bop 75 -58 a Fm(4)1322 b(GNU)15 b(Readline)h(Library)75 ! 149 y(terminate)21 b(an)g(incremen)o(tal)i(searc)o(h.)37 ! b Fg(C-g)21 b Fm(will)i(ab)q(ort)e(an)g(incremen)o(tal)h(searc)o(h)f ! (and)g(restore)g(the)75 204 y(original)16 b(line.)21 b(When)15 b(the)f(searc)o(h)g(is)h(terminated,)g(the)f(history)h(en)o ! (try)f(con)o(taining)h(the)g(searc)o(h)f(string)75 259 ! y(b)q(ecomes)i(the)f(curren)o(t)g(line.)137 324 y(T)l(o)g(\014nd)i ! (other)e(matc)o(hing)g(en)o(tries)h(in)h(the)e(history)h(list,)g(t)o ! (yp)q(e)f Fg(C-r)g Fm(or)g Fg(C-s)g Fm(as)h(appropriate.)k(This)75 ! 379 y(will)15 b(searc)o(h)e(bac)o(kw)o(ard)f(or)g(forw)o(ard)g(in)i ! (the)f(history)g(for)g(the)g(next)g(en)o(try)g(matc)o(hing)g(the)g ! (searc)o(h)g(string)75 434 y(t)o(yp)q(ed)19 b(so)g(far.)30 ! b(An)o(y)19 b(other)f(k)o(ey)h(sequence)h(b)q(ound)g(to)e(a)h(Readline) ! h(command)e(will)j(terminate)e(the)75 489 y(searc)o(h)10 ! b(and)h(execute)g(that)f(command.)18 b(F)l(or)10 b(instance,)i(a)1063 ! 487 y Ff(h)p 1076 461 76 2 v 1076 489 a Fe(RET)p 1076 ! 496 V 1149 487 a Ff(i)1174 489 y Fm(will)g(terminate)f(the)g(searc)o(h) ! f(and)h(accept)75 543 y(the)k(line,)h(thereb)o(y)f(executing)g(the)g ! (command)g(from)f(the)g(history)h(list.)20 b(A)15 b(mo)o(v)o(emen)o(t)f ! (command)g(will)75 598 y(terminate)h(the)g(searc)o(h,)g(mak)o(e)g(the)g ! (last)g(line)i(found)f(the)f(curren)o(t)g(line,)h(and)g(b)q(egin)g ! (editing.)137 664 y(Non-incremen)o(tal)25 b(searc)o(hes)e(read)h(the)f ! (en)o(tire)h(searc)o(h)f(string)g(b)q(efore)h(starting)f(to)f(searc)o ! (h)i(for)75 718 y(matc)o(hing)d(history)h(lines.)39 b(The)22 ! b(searc)o(h)f(string)g(ma)o(y)g(b)q(e)h(t)o(yp)q(ed)f(b)o(y)h(the)f ! (user)h(or)e(b)q(e)i(part)f(of)g(the)75 773 y(con)o(ten)o(ts)15 ! b(of)f(the)i(curren)o(t)f(line.)75 896 y Fk(1.3)33 b(Readline)23 ! b(Init)h(File)137 990 y Fm(Although)f(the)g(Readline)h(library)f(comes) ! g(with)g(a)f(set)g(of)g(Emacs-lik)o(e)i(k)o(eybindings)g(installed)75 ! 1045 y(b)o(y)d(default,)h(it)f(is)h(p)q(ossible)g(to)e(use)i(a)e ! (di\013eren)o(t)h(set)g(of)f(k)o(eybindings.)39 b(An)o(y)20 ! b(user)h(can)g(customize)75 1100 y(programs)15 b(that)h(use)g(Readline) ! i(b)o(y)e(putting)g(commands)g(in)i(an)e Fc(inputrc)k ! Fm(\014le,)d(con)o(v)o(en)o(tionally)g(in)g(his)75 1155 ! y(home)g(directory)l(.)24 b(The)17 b(name)g(of)f(this)h(\014le)g(is)g ! (tak)o(en)g(from)e(the)i(v)m(alue)h(of)e(the)h(en)o(vironmen)o(t)g(v)m ! (ariable)75 1209 y Fl(INPUTRC)p Fm(.)i(If)c(that)g(v)m(ariable)h(is)g ! (unset,)f(the)g(default)h(is)g(`)p Fl(~/.inputrc)p Fm('.)137 ! 1275 y(When)f(a)g(program)f(whic)o(h)h(uses)g(the)g(Readline)h(library) ! g(starts)d(up,)i(the)g(init)h(\014le)g(is)f(read,)g(and)g(the)75 ! 1329 y(k)o(ey)g(bindings)i(are)e(set.)137 1395 y(In)f(addition,)h(the)e ! Fl(C-x)i(C-r)e Fm(command)g(re-reads)h(this)g(init)g(\014le,)h(th)o(us) ! e(incorp)q(orating)h(an)o(y)f(c)o(hanges)75 1450 y(that)h(y)o(ou)h ! (migh)o(t)g(ha)o(v)o(e)g(made)g(to)g(it.)75 1556 y Fb(1.3.1)30 ! b(Readline)20 b(Init)g(File)h(Syn)n(tax)137 1650 y Fm(There)c(are)g (only)g(a)g(few)f(basic)i(constructs)e(allo)o(w)o(ed)i(in)f(the)g ! (Readline)h(init)g(\014le.)26 b(Blank)18 b(lines)g(are)75 ! 1705 y(ignored.)36 b(Lines)22 b(b)q(eginning)h(with)d(a)h(`)p ! Fl(#)p Fm(')e(are)h(commen)o(ts.)35 b(Lines)22 b(b)q(eginning)h(with)e ! (a)f(`)p Fl($)p Fm(')f(indicate)75 1760 y(conditional)c(constructs)f (\(see)g(Section)g(1.3.2)f([Conditional)h(Init)h(Constructs],)e(page)h ! (8\).)k(Other)c(lines)75 1814 y(denote)h(v)m(ariable)i(settings)e(and)h ! (k)o(ey)f(bindings.)75 1890 y(V)l(ariable)h(Settings)315 ! 1945 y(Y)l(ou)k(can)h(mo)q(dify)g(the)f(run-time)h(b)q(eha)o(vior)g(of) ! e(Readline)j(b)o(y)e(altering)h(the)f(v)m(alues)h(of)315 ! 2000 y(v)m(ariables)d(in)g(Readline)g(using)f(the)g Fl(set)g ! Fm(command)f(within)i(the)f(init)h(\014le.)26 b(The)17 ! b(syn)o(tax)315 2055 y(is)f(simple:)435 2117 y Fl(set)23 ! b Fc(v)m(ariable)28 b(v)m(alue)315 2182 y Fm(Here,)14 ! b(for)f(example,)h(is)g(ho)o(w)f(to)g(c)o(hange)h(from)f(the)h(default) ! g(Emacs-lik)o(e)h(k)o(ey)e(binding)j(to)315 2237 y(use)g ! Fl(vi)e Fm(line)j(editing)g(commands:)435 2299 y Fl(set)23 ! b(editing-mode)g(vi)315 2365 y Fm(V)l(ariable)c(names)e(and)h(v)m ! (alues,)h(where)e(appropriate,)h(are)f(recognized)i(without)e(regard) ! 315 2419 y(to)e(case.)315 2485 y(A)g(great)g(deal)g(of)g(run-time)h(b)q ! (eha)o(vior)g(is)g(c)o(hangeable)g(with)f(the)h(follo)o(wing)f(v)m ! (ariables.)315 2560 y Fl(bell-style)555 2615 y Fm(Con)o(trols)21 ! b(what)h(happ)q(ens)h(when)f(Readline)h(w)o(an)o(ts)e(to)g(ring)i(the)f ! (termi-)555 2670 y(nal)d(b)q(ell.)32 b(If)19 b(set)f(to)g(`)p ! Fl(none)p Fm(',)g(Readline)i(nev)o(er)f(rings)g(the)f(b)q(ell.)32 ! b(If)19 b(set)g(to)p eop %%Page: 5 7 ! 5 6 bop 75 -58 a Fm(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1077 ! b(5)555 149 y(`)p Fl(visible)p Fm(',)15 b(Readline)i(uses)g(a)f ! (visible)j(b)q(ell)g(if)e(one)f(is)h(a)o(v)m(ailable.)26 ! b(If)16 b(set)h(to)555 204 y(`)p Fl(audible)p Fm(')g(\(the)h ! (default\),)i(Readline)g(attempts)e(to)g(ring)h(the)g(terminal's)555 ! 259 y(b)q(ell.)315 338 y Fl(comment-begin)555 393 y Fm(The)c(string)f ! (to)g(insert)i(at)d(the)i(b)q(eginning)i(of)d(the)h(line)h(when)f(the)g ! Fl(insert-)555 448 y(comment)f Fm(command)h(is)h(executed.)21 ! b(The)15 b(default)h(v)m(alue)g(is)g Fl("#")p Fm(.)315 ! 527 y Fl(completion-ignore-case)555 582 y Fm(If)e(set)f(to)g(`)p ! Fl(on)p Fm(',)g(Readline)i(p)q(erforms)e(\014lename)i(matc)o(hing)f ! (and)g(completion)555 637 y(in)i(a)f(case-insensitiv)o(e)i(fashion.)k ! (The)15 b(default)h(v)m(alue)g(is)g(`)p Fl(off)p Fm('.)315 ! 716 y Fl(completion-query-items)555 770 y Fm(The)d(n)o(um)o(b)q(er)h ! (of)e(p)q(ossible)j(completions)g(that)d(determines)i(when)g(the)f ! (user)555 825 y(is)21 b(ask)o(ed)g(whether)g(he)h(w)o(an)o(ts)d(to)i ! (see)g(the)g(list)h(of)e(p)q(ossibilitie)q(s.)40 b(If)21 ! b(the)555 880 y(n)o(um)o(b)q(er)14 b(of)f(p)q(ossible)i(completions)f ! (is)g(greater)f(than)g(this)h(v)m(alue,)h(Readline)555 ! 935 y(will)g(ask)e(the)g(user)h(whether)f(or)g(not)g(he)g(wishes)h(to)f ! (view)h(them;)f(otherwise,)555 990 y(they)f(are)g(simply)i(listed.)20 ! b(This)13 b(v)m(ariable)g(m)o(ust)f(b)q(e)h(set)f(to)f(an)h(in)o(teger) ! h(v)m(alue)555 1044 y(greater)h(than)h(or)g(equal)h(to)f(0.)k(The)d ! (default)f(limit)i(is)f Fl(100)p Fm(.)315 1124 y Fl(convert-meta)555 ! 1178 y Fm(If)11 b(set)g(to)g(`)p Fl(on)p Fm(',)f(Readline)i(will)h(con) ! o(v)o(ert)d(c)o(haracters)h(with)g(the)g(eigh)o(th)h(bit)f(set)555 ! 1233 y(to)f(an)h Fh(asci)q(i)e Fm(k)o(ey)i(sequence)g(b)o(y)g ! (stripping)h(the)e(eigh)o(th)h(bit)h(and)e(pre\014xing)i(an)555 ! 1286 y Ff(h)p 567 1260 70 2 v 567 1288 a Fe(ESC)p 567 ! 1296 V 634 1286 a Ff(i)666 1288 y Fm(c)o(haracter,)k(con)o(v)o(erting)h ! (them)g(to)f(a)h(meta-pre\014xed)g(k)o(ey)g(sequence.)555 ! 1343 y(The)e(default)h(v)m(alue)h(is)e(`)p Fl(on)p Fm('.)315 ! 1422 y Fl(disable-completion)555 1477 y Fm(If)k(set)f(to)f(`)p ! Fl(On)p Fm(',)h(Readline)i(will)g(inhibit)g(w)o(ord)e(completion.)30 ! b(Completion)555 1531 y(c)o(haracters)12 b(will)j(b)q(e)f(inserted)g ! (in)o(to)f(the)g(line)h(as)f(if)h(they)f(had)g(b)q(een)h(mapp)q(ed)555 ! 1586 y(to)h Fl(self-insert)p Fm(.)j(The)d(default)h(is)g(`)p ! Fl(off)p Fm('.)315 1665 y Fl(editing-mode)555 1720 y ! Fm(The)f Fl(editing-mode)d Fm(v)m(ariable)k(con)o(trols)e(whic)o(h)h ! (default)g(set)f(of)g(k)o(ey)g(bind-)555 1775 y(ings)f(is)g(used.)20 ! b(By)12 b(default,)i(Readline)f(starts)f(up)h(in)g(Emacs)f(editing)i ! (mo)q(de,)555 1830 y(where)h(the)f(k)o(eystrok)o(es)g(are)g(most)g ! (similar)i(to)d(Emacs.)20 b(This)15 b(v)m(ariable)h(can)555 ! 1885 y(b)q(e)g(set)f(to)f(either)i(`)p Fl(emacs)p Fm(')e(or)h(`)p ! Fl(vi)p Fm('.)315 1964 y Fl(enable-keypad)555 2019 y ! Fm(When)d(set)f(to)h(`)p Fl(on)p Fm(',)e(Readline)j(will)h(try)d(to)g ! (enable)i(the)f(application)h(k)o(eypad)555 2073 y(when)h(it)f(is)h ! (called.)21 b(Some)13 b(systems)g(need)h(this)g(to)f(enable)h(the)g ! (arro)o(w)e(k)o(eys.)555 2128 y(The)j(default)h(is)g(`)p ! Fl(off)p Fm('.)315 2207 y Fl(expand-tilde)555 2262 y ! Fm(If)e(set)g(to)f(`)p Fl(on)p Fm(',)f(tilde)k(expansion)e(is)h(p)q ! (erformed)f(when)g(Readline)h(attempts)555 2317 y(w)o(ord)g ! (completion.)21 b(The)15 b(default)h(is)f(`)p Fl(off)p ! Fm('.)315 2396 y Fl(horizontal-scroll-mode)555 2451 y ! Fm(This)k(v)m(ariable)g(can)f(b)q(e)g(set)g(to)f(either)i(`)p ! Fl(on)p Fm(')e(or)g(`)p Fl(off)p Fm('.)27 b(Setting)19 ! b(it)f(to)f(`)p Fl(on)p Fm(')555 2506 y(means)c(that)f(the)i(text)e(of) ! h(the)g(lines)i(b)q(eing)f(edited)g(will)h(scroll)f(horizon)o(tally)555 ! 2560 y(on)i(a)f(single)i(screen)g(line)g(when)g(they)f(are)f(longer)h ! (than)g(the)g(width)g(of)g(the)555 2615 y(screen,)e(instead)f(of)g (wrapping)g(on)o(to)f(a)h(new)g(screen)h(line.)21 b(By)13 ! b(default,)h(this)555 2670 y(v)m(ariable)j(is)e(set)g(to)g(`)p ! Fl(off)p Fm('.)p eop %%Page: 6 8 ! 6 7 bop 75 -58 a Fm(6)1322 b(GNU)15 b(Readline)h(Library)315 ! 149 y Fl(input-meta)555 204 y Fm(If)g(set)f(to)g(`)p ! Fl(on)p Fm(',)f(Readline)j(will)h(enable)e(eigh)o(t-bit)h(input)f(\(it) ! g(will)h(not)e(clear)555 259 y(the)20 b(eigh)o(th)g(bit)g(in)h(the)f(c) ! o(haracters)f(it)h(reads\),)g(regardless)g(of)g(what)f(the)555 ! 314 y(terminal)i(claims)g(it)f(can)g(supp)q(ort.)34 b(The)20 ! b(default)h(v)m(alue)g(is)g(`)p Fl(off)p Fm('.)33 b(The)555 ! 369 y(name)15 b Fl(meta-flag)f Fm(is)i(a)f(synon)o(ym)g(for)f(this)i(v) ! m(ariable.)315 448 y Fl(isearch-terminators)555 503 y ! Fm(The)26 b(string)g(of)f(c)o(haracters)g(that)g(should)i(terminate)f ! (an)g(incremen)o(tal)555 557 y(searc)o(h)12 b(without)h(subsequen)o ! (tly)g(executing)h(the)e(c)o(haracter)g(as)g(a)g(command)555 ! 612 y(\(see)22 b(Section)h(1.2.5)e([Searc)o(hing],)j(page)e(3\).)40 ! b(If)23 b(this)g(v)m(ariable)g(has)f(not)555 667 y(b)q(een)17 ! b(giv)o(en)f(a)g(v)m(alue,)g(the)g(c)o(haracters)1247 ! 665 y Ff(h)p 1259 639 70 2 v 1259 667 a Fe(ESC)p 1259 ! 675 V 1326 665 a Ff(i)1357 667 y Fm(and)g Fg(C-J)f Fm(will)i(terminate) ! f(an)555 722 y(incremen)o(tal)g(searc)o(h.)315 801 y ! Fl(keymap)96 b Fm(Sets)19 b(Readline's)i(idea)f(of)f(the)g(curren)o(t)h ! (k)o(eymap)f(for)f(k)o(ey)i(binding)h(com-)555 856 y(mands.)41 ! b(Acceptable)23 b Fl(keymap)f Fm(names)g(are)f Fl(emacs)p ! Fm(,)i Fl(emacs-standard)p Fm(,)555 910 y Fl(emacs-meta)p ! Fm(,)49 b Fl(emacs-ctlx)p Fm(,)g Fl(vi)p Fm(,)h Fl(vi-move)p ! Fm(,)f Fl(vi-command)p Fm(,)g(and)555 965 y Fl(vi-insert)p ! Fm(.)31 b Fl(vi)20 b Fm(is)g(equiv)m(alen)o(t)h(to)e ! Fl(vi-command)p Fm(;)g Fl(emacs)g Fm(is)h(equiv)m(alen)o(t)555 ! 1020 y(to)15 b Fl(emacs-standard)p Fm(.)20 b(The)d(default)f(v)m(alue)h ! (is)g Fl(emacs)p Fm(.)k(The)16 b(v)m(alue)h(of)f(the)555 ! 1075 y Fl(editing-mode)e Fm(v)m(ariable)i(also)f(a\013ects)g(the)g ! (default)h(k)o(eymap.)315 1154 y Fl(mark-directories)555 ! 1209 y Fm(If)j(set)g(to)g(`)p Fl(on)p Fm(',)f(completed)i(directory)g ! (names)f(ha)o(v)o(e)f(a)h(slash)h(app)q(ended.)555 1264 ! y(The)15 b(default)h(is)g(`)p Fl(on)p Fm('.)315 1343 ! y Fl(mark-modified-lines)555 1398 y Fm(This)j(v)m(ariable,)g(when)g ! (set)e(to)h(`)p Fl(on)p Fm(',)f(causes)h(Readline)h(to)e(displa)o(y)i ! (an)f(as-)555 1452 y(terisk)f(\(`)p Fl(*)p Fm('\))e(at)i(the)f(start)g ! (of)h(history)f(lines)j(whic)o(h)e(ha)o(v)o(e)g(b)q(een)h(mo)q ! (di\014ed.)555 1507 y(This)e(v)m(ariable)g(is)g(`)p Fl(off)p ! Fm(')e(b)o(y)h(default.)315 1586 y Fl(output-meta)555 ! 1641 y Fm(If)j(set)f(to)g(`)p Fl(on)p Fm(',)g(Readline)i(will)h(displa) ! o(y)f(c)o(haracters)d(with)j(the)e(eigh)o(th)h(bit)555 ! 1696 y(set)g(directly)i(rather)d(than)h(as)g(a)g(meta-pre\014xed)h ! (escap)q(e)g(sequence.)30 b(The)555 1751 y(default)16 ! b(is)f(`)p Fl(off)p Fm('.)315 1830 y Fl(print-completions-horizont)o ! (ally)555 1885 y Fm(If)d(set)g(to)f(`)p Fl(on)p Fm(',)h(Readline)h ! (will)g(displa)o(y)h(completions)f(with)f(matc)o(hes)f(sorted)555 ! 1939 y(horizon)o(tally)23 b(in)f(alphab)q(etical)i(order,)f(rather)e ! (than)g(do)o(wn)h(the)g(screen.)555 1994 y(The)15 b(default)h(is)g(`)p ! Fl(off)p Fm('.)315 2073 y Fl(show-all-if-ambiguous)555 ! 2128 y Fm(This)g(alters)e(the)i(default)f(b)q(eha)o(vior)h(of)e(the)h ! (completion)h(functions.)21 b(If)15 b(set)555 2183 y(to)e(`)p ! Fl(on)p Fm(',)g(w)o(ords)g(whic)o(h)h(ha)o(v)o(e)g(more)f(than)g(one)h ! (p)q(ossible)i(completion)f(cause)555 2238 y(the)20 b(matc)o(hes)f(to)f ! (b)q(e)j(listed)f(immediately)h(instead)f(of)f(ringing)i(the)e(b)q ! (ell.)555 2293 y(The)c(default)h(v)m(alue)h(is)e(`)p ! Fl(off)p Fm('.)315 2372 y Fl(visible-stats)555 2426 y ! Fm(If)h(set)g(to)f(`)p Fl(on)p Fm(',)g(a)h(c)o(haracter)f(denoting)h(a) ! g(\014le's)h(t)o(yp)q(e)f(is)g(app)q(ended)i(to)d(the)555 ! 2481 y(\014lename)h(when)g(listing)h(p)q(ossible)g(completions.)j(The)c ! (default)g(is)f(`)p Fl(off)p Fm('.)75 2560 y(Key)h(Bindings)315 ! 2615 y(The)21 b(syn)o(tax)f(for)h(con)o(trolling)h(k)o(ey)f(bindings)h (in)g(the)f(init)h(\014le)g(is)g(simple.)39 b(First)20 ! b(y)o(ou)315 2670 y(need)15 b(to)e(\014nd)h(the)g(name)g(of)g(the)f (command)h(that)f(y)o(ou)h(w)o(an)o(t)f(to)g(c)o(hange.)19 ! b(The)14 b(follo)o(wing)p eop %%Page: 7 9 ! 7 8 bop 75 -58 a Fm(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1077 ! b(7)315 149 y(sections)18 b(con)o(tain)h(tables)f(of)f(the)h(command)g ! (name,)g(the)g(default)h(k)o(eybinding,)h(if)e(an)o(y)l(,)315 ! 204 y(and)d(a)g(short)g(description)i(of)d(what)h(the)g(command)g(do)q ! (es.)315 273 y(Once)k(y)o(ou)f(kno)o(w)f(the)h(name)g(of)g(the)g ! (command,)g(simply)h(place)g(on)f(a)f(line)j(in)f(the)f(init)315 ! 328 y(\014le)g(the)f(name)g(of)f(the)h(k)o(ey)g(y)o(ou)f(wish)i(to)e ! (bind)i(the)f(command)g(to,)f(a)g(colon,)i(and)f(then)315 ! 382 y(the)f(name)g(of)g(the)g(command.)22 b(The)16 b(name)g(of)g(the)g ! (k)o(ey)f(can)i(b)q(e)f(expressed)h(in)g(di\013eren)o(t)315 ! 437 y(w)o(a)o(ys,)d(dep)q(ending)j(on)e(what)g(y)o(ou)g(\014nd)h(most)e ! (comfortable.)315 506 y(In)19 b(addition)g(to)e(command)h(names,)g ! (readline)i(allo)o(ws)e(k)o(eys)g(to)f(b)q(e)i(b)q(ound)g(to)e(a)h ! (string)315 561 y(that)c(is)i(inserted)g(when)g(the)f(k)o(ey)g(is)h ! (pressed)g(\(a)e Fc(macro)r Fm(\).)315 643 y Fc(k)o(eyname)s ! Fm(:)19 b Fc(function-name)g Fm(or)c Fc(macro)555 698 ! y(k)o(eyname)i Fm(is)e(the)f(name)h(of)f(a)g(k)o(ey)g(sp)q(elled)j(out) ! d(in)h(English.)21 b(F)l(or)13 b(example:)675 764 y Fl(Control-u:)22 ! b(universal-argument)675 816 y(Meta-Rubout:)g(backward-kill-word)675 ! 867 y(Control-o:)g(">)i(output")555 936 y Fm(In)c(the)f(ab)q(o)o(v)o(e) ! g(example,)i Fg(C-u)e Fm(is)h(b)q(ound)g(to)f(the)g(function)h ! Fl(universal-)555 991 y(argument)p Fm(,)e Fg(M-DEL)h ! Fm(is)g(b)q(ound)h(to)e(the)h(function)h Fl(backward-kill-word)p ! Fm(,)555 1046 y(and)g Fg(C-o)f Fm(is)h(b)q(ound)g(to)f(run)h(the)f ! (macro)g(expressed)h(on)g(the)f(righ)o(t)h(hand)555 1101 ! y(side)c(\(that)e(is,)i(to)e(insert)i(the)f(text)g(`)p ! Fl(>)f(output)p Fm(')g(in)o(to)i(the)f(line\).)555 1169 ! y(A)k(n)o(um)o(b)q(er)f(of)g(sym)o(b)q(olic)i(c)o(haracter)e(names)g ! (are)g(recognized)i(while)g(pro-)555 1224 y(cessing)13 ! b(this)f(k)o(ey)g(binding)h(syn)o(tax:)18 b Fc(DEL)p ! Fm(,)11 b Fc(ESC)p Fm(,)h Fc(ESCAPE)p Fm(,)f Fc(LFD)p ! Fm(,)g Fc(NEW-)555 1279 y(LINE)p Fm(,)16 b Fc(RET)p Fm(,)e ! Fc(RETURN)p Fm(,)f Fc(R)o(UBOUT)p Fm(,)i Fc(SP)l(A)o(CE)p ! Fm(,)g Fc(SPC)p Fm(,)f(and)i Fc(T)l(AB)p Fm(.)315 1361 ! y Fl(")p Fc(k)o(eyseq)q Fl(")p Fm(:)k Fc(function-name)e ! Fm(or)d Fc(macro)555 1416 y(k)o(eyseq)i Fm(di\013ers)e(from)g ! Fc(k)o(eyname)j Fm(ab)q(o)o(v)o(e)d(in)i(that)d(strings)i(denoting)g ! (an)f(en-)555 1471 y(tire)i(k)o(ey)g(sequence)h(can)f(b)q(e)g(sp)q ! (eci\014ed,)i(b)o(y)e(placing)h(the)f(k)o(ey)g(sequence)h(in)555 ! 1526 y(double)e(quotes.)j(Some)c Fh(gnu)g Fm(Emacs)f(st)o(yle)h(k)o(ey) ! g(escap)q(es)g(can)g(b)q(e)g(used,)g(as)555 1580 y(in)j(the)f(follo)o ! (wing)g(example,)h(but)f(the)g(sp)q(ecial)i(c)o(haracter)d(names)h(are) ! f(not)555 1635 y(recognized.)675 1701 y Fl("\\C-u":)23 ! b(universal-argument)675 1753 y("\\C-x\\C-r":)f(re-read-init-file)675 ! 1805 y("\\e[11~":)h("Function)f(Key)i(1")555 1873 y Fm(In)33 ! b(the)f(ab)q(o)o(v)o(e)g(example,)37 b Fg(C-u)32 b Fm(is)h(again)f(b)q ! (ound)h(to)f(the)g(function)555 1928 y Fl(universal-argument)19 ! b Fm(\(just)j(as)f(it)h(w)o(as)f(in)i(the)f(\014rst)f(example\),)j(`)p ! Fg(C-x)555 1983 y(C-r)p Fm(')c(is)h(b)q(ound)g(to)f(the)h(function)g ! Fl(re-read-init-file)p Fm(,)f(and)g(`)1731 1981 y Ff(h)p ! 1743 1955 70 2 v 1743 1983 a Fe(ESC)p 1743 1991 V 1810 ! 1981 a Ff(i)15 b(h)p 1852 1955 10 2 v 1852 1983 a Fe([)p ! 1852 1991 V 1860 1981 a Ff(i)555 2036 y(h)p 567 2010 ! 18 2 v 567 2038 a Fe(1)p 567 2045 V 583 2036 a Ff(i)g(h)p ! 625 2010 V 625 2038 a Fe(1)p 625 2045 V 640 2036 a Ff(i)g(h)p ! 683 2010 24 2 v 683 2038 a Fl(~)p 683 2045 V 704 2036 ! a Ff(i)719 2038 y Fm(')g(is)h(b)q(ound)g(to)e(insert)i(the)f(text)g(`)p ! Fl(Function)f(Key)g(1)p Fm('.)315 2120 y(The)h(follo)o(wing)h ! Fh(gnu)e Fm(Emacs)h(st)o(yle)g(escap)q(e)h(sequences)g(are)e(a)o(v)m ! (ailable)j(when)e(sp)q(ecifying)315 2175 y(k)o(ey)g(sequences:)315 ! 2258 y Fg(\\C-)168 b Fm(con)o(trol)15 b(pre\014x)315 ! 2340 y Fg(\\M-)168 b Fm(meta)15 b(pre\014x)315 2423 y ! Fg(\\e)192 b Fm(an)15 b(escap)q(e)h(c)o(haracter)315 ! 2505 y Fg(\\\\)192 b Fm(bac)o(kslash)315 2587 y Fg(\\)p ! Fl(")555 2585 y Ff(h)p 567 2559 V 567 2587 a Fl(")p 567 ! 2595 V 589 2585 a Ff(i)604 2587 y Fm(,)15 b(a)f(double)j(quotation)e ! (mark)315 2670 y Fg(\\')555 2668 y Ff(h)p 567 2642 10 ! 2 v 567 2670 a Fe(')p 567 2678 V 575 2668 a Ff(i)590 ! 2670 y Fm(,)g(a)f(single)j(quote)e(or)g(ap)q(ostrophe)p eop %%Page: 8 10 ! 8 9 bop 75 -58 a Fm(8)1322 b(GNU)15 b(Readline)h(Library)315 ! 149 y(In)e(addition)h(to)f(the)f Fh(gnu)h Fm(Emacs)g(st)o(yle)f(escap)q ! (e)i(sequences,)g(a)e(second)i(set)e(of)h(bac)o(kslash)315 ! 204 y(escap)q(es)i(is)g(a)o(v)m(ailable:)315 286 y Fl(\\a)192 ! b Fm(alert)15 b(\(b)q(ell\))315 368 y Fl(\\b)192 b Fm(bac)o(kspace)315 ! 449 y Fl(\\d)g Fm(delete)315 531 y Fl(\\f)g Fm(form)14 ! b(feed)315 613 y Fl(\\n)192 b Fm(newline)315 694 y Fl(\\r)g ! Fm(carriage)15 b(return)315 776 y Fl(\\t)192 b Fm(horizon)o(tal)16 ! b(tab)315 858 y Fl(\\v)192 b Fm(v)o(ertical)16 b(tab)315 ! 940 y Fl(\\)p Fc(nnn)141 b Fm(the)14 b(c)o(haracter)f(whose)h ! Fh(asci)q(i)e Fm(co)q(de)j(is)f(the)g(o)q(ctal)g(v)m(alue)h ! Fc(nnn)f Fm(\(one)g(to)f(three)555 994 y(digits\))315 ! 1076 y Fl(\\x)p Fc(nnn)117 b Fm(the)16 b(c)o(haracter)f(whose)h ! Fh(asci)q(i)f Fm(co)q(de)i(is)f(the)h(hexadecimal)g(v)m(alue)g ! Fc(nnn)g Fm(\(one)555 1131 y(to)e(three)g(digits\))315 ! 1213 y(When)k(en)o(tering)g(the)g(text)f(of)g(a)h(macro,)f(single)i(or) ! e(double)i(quotes)f(m)o(ust)f(b)q(e)h(used)h(to)315 1267 ! y(indicate)12 b(a)f(macro)f(de\014nition.)20 b(Unquoted)11 ! b(text)f(is)i(assumed)e(to)h(b)q(e)g(a)f(function)i(name.)18 ! b(In)315 1322 y(the)11 b(macro)f(b)q(o)q(dy)l(,)i(the)f(bac)o(kslash)g ! (escap)q(es)g(describ)q(ed)i(ab)q(o)o(v)o(e)d(are)g(expanded.)20 ! b(Bac)o(kslash)315 1377 y(will)i(quote)d(an)o(y)h(other)g(c)o(haracter) ! f(in)i(the)f(macro)f(text,)h(including)j(`)p Fl(")p Fm(')c(and)h(`)p ! Fl(')p Fm('.)34 b(F)l(or)315 1432 y(example,)14 b(the)f(follo)o(wing)g ! (binding)i(will)g(mak)o(e)d(`)p Fg(C-x)i Fl(\\)p Fm(')f(insert)g(a)g ! (single)h(`)p Fl(\\)p Fm(')e(in)o(to)h(the)g(line:)435 ! 1497 y Fl("\\C-x\\\\":)23 b("\\\\")75 1613 y Fb(1.3.2)30 ! b(Conditional)20 b(Init)g(Constructs)137 1712 y Fm(Readline)f(implemen) ! o(ts)g(a)f(facilit)o(y)g(similar)h(in)g(spirit)f(to)f(the)h ! (conditional)h(compilation)g(features)75 1766 y(of)e(the)g(C)g(prepro)q ! (cessor)g(whic)o(h)i(allo)o(ws)e(k)o(ey)g(bindings)i(and)f(v)m(ariable) ! g(settings)f(to)g(b)q(e)h(p)q(erformed)f(as)75 1821 y(the)e(result)h ! (of)f(tests.)k(There)c(are)g(four)g(parser)g(directiv)o(es)h(used.)75 ! 1904 y Fl($if)168 b Fm(The)16 b Fl($if)f Fm(construct)g(allo)o(ws)h ! (bindings)i(to)d(b)q(e)h(made)g(based)g(on)f(the)h(editing)h(mo)q(de,)f ! (the)315 1959 y(terminal)k(b)q(eing)g(used,)g(or)f(the)g(application)i ! (using)e(Readline.)33 b(The)19 b(text)g(of)f(the)i(test)315 ! 2013 y(extends)c(to)e(the)h(end)h(of)f(the)g(line;)i(no)e(c)o ! (haracters)f(are)h(required)i(to)d(isolate)i(it.)315 ! 2095 y Fl(mode)144 b Fm(The)11 b Fl(mode=)e Fm(form)h(of)g(the)h ! Fl($if)f Fm(directiv)o(e)h(is)g(used)g(to)f(test)g(whether)h(Readline) ! 555 2150 y(is)k(in)h Fl(emacs)e Fm(or)g Fl(vi)g Fm(mo)q(de.)20 b(This)c(ma)o(y)e(b)q(e)h(used)g(in)h(conjunction)g(with)f(the)555 ! 2205 y(`)p Fl(set)f(keymap)p Fm(')f(command,)g(for)h(instance,)g(to)f ! (set)h(bindings)h(in)g(the)f Fl(emacs-)555 2260 y(standard)d ! Fm(and)i Fl(emacs-ctlx)e Fm(k)o(eymaps)h(only)i(if)f(Readline)g(is)g ! (starting)f(out)555 2314 y(in)k Fl(emacs)f Fm(mo)q(de.)315 ! 2396 y Fl(term)144 b Fm(The)14 b Fl(term=)e Fm(form)h(ma)o(y)g(b)q(e)h (used)g(to)f(include)j(terminal-sp)q(eci\014c)g(k)o(ey)d(bind-)555 ! 2451 y(ings,)19 b(p)q(erhaps)g(to)e(bind)i(the)g(k)o(ey)e(sequences)j ! (output)e(b)o(y)g(the)g(terminal's)555 2506 y(function)13 b(k)o(eys.)18 b(The)13 b(w)o(ord)e(on)h(the)g(righ)o(t)g(side)g(of)g ! (the)g(`)p Fl(=)p Fm(')f(is)h(tested)g(against)555 2560 y(b)q(oth)j(the)g(full)i(name)e(of)f(the)h(terminal)h(and)f(the)g(p)q ! (ortion)h(of)e(the)h(terminal)555 2615 y(name)i(b)q(efore)g(the)g ! (\014rst)f(`)p Fl(-)p Fm('.)24 b(This)17 b(allo)o(ws)g ! Fl(sun)f Fm(to)g(matc)o(h)h(b)q(oth)f Fl(sun)h Fm(and)555 ! 2670 y Fl(sun-cmd)p Fm(,)d(for)g(instance.)p eop %%Page: 9 11 ! 9 10 bop 75 -58 a Fm(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1077 ! b(9)315 149 y Fl(application)555 204 y Fm(The)11 b Fc(application)i ! Fm(construct)e(is)g(used)h(to)e(include)j(application-sp)q(eci)q(\014c) ! h(set-)555 259 y(tings.)19 b(Eac)o(h)12 b(program)f(using)j(the)e ! (Readline)i(library)f(sets)f(the)g Fc(application)555 ! 314 y(name)p Fm(,)g(and)g(y)o(ou)f(can)h(test)f(for)g(a)g(particular)h ! (v)m(alue.)20 b(This)12 b(could)h(b)q(e)f(used)h(to)555 ! 369 y(bind)18 b(k)o(ey)e(sequences)i(to)d(functions)j(useful)f(for)f(a) ! g(sp)q(eci\014c)i(program.)23 b(F)l(or)555 423 y(instance,)17 ! b(the)g(follo)o(wing)g(command)g(adds)f(a)g(k)o(ey)h(sequence)g(that)f ! (quotes)555 478 y(the)f(curren)o(t)g(or)g(previous)h(w)o(ord)e(in)j ! (Bash:)675 543 y Fl($if)23 b(Bash)675 594 y(#)h(Quote)f(the)g(current)g ! (or)h(previous)f(word)675 646 y("\\C-xq":)g("\\eb\\"\\ef\\"")675 ! 698 y($endif)75 778 y($endif)96 b Fm(This)16 b(command,)e(as)h(seen)h ! (in)g(the)f(previous)h(example,)g(terminates)f(an)g Fl($if)f ! Fm(command.)75 858 y Fl($else)120 b Fm(Commands)15 b(in)h(this)f(branc) ! o(h)h(of)e(the)i Fl($if)e Fm(directiv)o(e)j(are)e(executed)h(if)g(the)f ! (test)g(fails.)75 937 y Fl($include)48 b Fm(This)22 b(directiv)o(e)h ! (tak)o(es)e(a)h(single)h(\014lename)g(as)e(an)h(argumen)o(t)f(and)h ! (reads)f(commands)315 992 y(and)e(bindings)j(from)c(that)h(\014le.)33 ! b(F)l(or)19 b(example,)i(the)e(follo)o(wing)h(directiv)o(e)h(reads)e ! (from)315 1047 y(`)p Fl(/etc/inputrc)p Fm(':)435 1111 ! y Fl($include)k(/etc/inputrc)75 1223 y Fb(1.3.3)30 b(Sample)20 ! b(Init)h(File)137 1320 y Fm(Here)16 b(is)g(an)f(example)h(of)f(an)g ! Fc(inputrc)k Fm(\014le.)i(This)16 b(illustrates)g(k)o(ey)f(binding,)i ! (v)m(ariable)f(assignmen)o(t,)75 1374 y(and)f(conditional)i(syn)o(tax.) ! p eop %%Page: 10 12 ! 10 11 bop 75 -58 a Fm(10)1299 b(GNU)15 b(Readline)h(Library)195 ! 201 y Fl(#)24 b(This)f(file)g(controls)g(the)h(behaviour)e(of)i(line)f ! (input)g(editing)g(for)195 253 y(#)h(programs)e(that)i(use)f(the)h(Gnu) f(Readline)g(library.)47 b(Existing)22 b(programs)195 ! 305 y(#)i(include)f(FTP,)g(Bash,)g(and)h(Gdb.)195 357 ! y(#)195 409 y(#)g(You)f(can)h(re-read)f(the)g(inputrc)g(file)g(with)h ! (C-x)f(C-r.)195 461 y(#)h(Lines)f(beginning)g(with)g('#')g(are)h ! (comments.)195 513 y(#)195 565 y(#)g(First,)f(include)g(any)g (systemwide)g(bindings)f(and)i(variable)f(assignments)f(from)195 ! 616 y(#)i(/etc/Inputrc)195 668 y($include)f(/etc/Inputrc)195 ! 772 y(#)195 824 y(#)h(Set)f(various)g(bindings)g(for)g(emacs)g(mode.) ! 195 928 y(set)g(editing-mode)g(emacs)195 1032 y($if)g(mode=emacs)195 ! 1135 y(Meta-Control-h:)46 b(backward-kill-word)21 b(Text)i(after)h(the) ! f(function)g(name)g(is)h(ignored)p 1986 1145 21 38 v ! 195 1239 a(#)195 1291 y(#)g(Arrow)f(keys)g(in)h(keypad)f(mode)195 ! 1343 y(#)195 1395 y(#"\\M-OD":)190 b(backward-char)195 ! 1447 y(#"\\M-OC":)g(forward-char)195 1499 y(#"\\M-OA":)g ! (previous-history)195 1550 y(#"\\M-OB":)g(next-history)195 ! 1602 y(#)195 1654 y(#)24 b(Arrow)f(keys)g(in)h(ANSI)f(mode)195 ! 1706 y(#)195 1758 y("\\M-[D":)190 b(backward-char)195 ! 1810 y("\\M-[C":)g(forward-char)195 1862 y("\\M-[A":)g ! (previous-history)195 1914 y("\\M-[B":)g(next-history)195 ! 1966 y(#)195 2017 y(#)24 b(Arrow)f(keys)g(in)h(8)g(bit)f(keypad)g(mode) ! 195 2069 y(#)195 2121 y(#"\\M-\\C-OD":)165 b(backward-char)195 ! 2173 y(#"\\M-\\C-OC":)g(forward-char)195 2225 y(#"\\M-\\C-OA":)g ! (previous-history)195 2277 y(#"\\M-\\C-OB":)g(next-history)195 ! 2329 y(#)195 2381 y(#)24 b(Arrow)f(keys)g(in)h(8)g(bit)f(ANSI)g(mode) ! 195 2433 y(#)195 2484 y(#"\\M-\\C-[D":)165 b(backward-char)195 ! 2536 y(#"\\M-\\C-[C":)g(forward-char)195 2588 y(#"\\M-\\C-[A":)g ! (previous-history)195 2640 y(#"\\M-\\C-[B":)g(next-history)p ! eop %%Page: 11 13 ! 11 12 bop 75 -58 a Fm(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1055 ! b(11)195 201 y Fl(C-q:)23 b(quoted-insert)195 305 y($endif)195 ! 409 y(#)h(An)f(old-style)g(binding.)47 b(This)23 b(happens)g(to)g(be)h ! (the)f(default.)195 461 y(TAB:)g(complete)195 565 y(#)h(Macros)f(that)g ! (are)h(convenient)e(for)h(shell)h(interaction)195 616 ! y($if)f(Bash)195 668 y(#)h(edit)f(the)g(path)195 720 ! y("\\C-xp":)g("PATH=${PATH}\\e\\C-e\\C-a\\)o(ef\\C-f")195 ! 772 y(#)h(prepare)f(to)g(type)h(a)f(quoted)g(word)h(--)f(insert)g(open) ! h(and)f(close)g(double)g(quotes)195 824 y(#)h(and)f(move)g(to)h(just)f ! (after)h(the)f(open)g(quote)195 876 y("\\C-x\\"":)g("\\"\\"\\C-b")195 ! 928 y(#)h(insert)f(a)g(backslash)g(\(testing)g(backslash)g(escapes)f ! (in)i(sequences)f(and)g(macros\))195 980 y("\\C-x\\\\":)g("\\\\")195 ! 1032 y(#)h(Quote)f(the)g(current)g(or)h(previous)f(word)195 ! 1083 y("\\C-xq":)g("\\eb\\"\\ef\\"")195 1135 y(#)h(Add)f(a)h(binding)f (to)g(refresh)g(the)h(line,)f(which)g(is)h(unbound)195 ! 1187 y("\\C-xr":)f(redraw-current-line)195 1239 y(#)h(Edit)f(variable)g ! (on)g(current)g(line.)195 1291 y("\\M-\\C-v":)f ! ("\\C-a\\C-k$\\C-y\\M-\\C-e\\C-a\\C-y=)o(")195 1343 y($endif)195 ! 1447 y(#)i(use)f(a)h(visible)f(bell)g(if)h(one)f(is)h(available)195 ! 1499 y(set)f(bell-style)g(visible)195 1602 y(#)h(don't)f(strip)g ! (characters)g(to)g(7)h(bits)f(when)h(reading)195 1654 ! y(set)f(input-meta)g(on)195 1758 y(#)h(allow)f(iso-latin1)f(characters) h(to)g(be)h(inserted)f(rather)g(than)g(converted)g(to)195 ! 1810 y(#)h(prefix-meta)e(sequences)195 1862 y(set)h(convert-meta)g(off) ! 195 1966 y(#)h(display)f(characters)f(with)h(the)h(eighth)f(bit)g(set)h ! (directly)f(rather)g(than)195 2017 y(#)h(as)f(meta-prefixed)f ! (characters)195 2069 y(set)h(output-meta)g(on)195 2173 y(#)h(if)f(there)g(are)h(more)f(than)h(150)f(possible)g(completions)f ! (for)i(a)f(word,)h(ask)f(the)195 2225 y(#)h(user)f(if)h(he)f(wants)g ! (to)h(see)f(all)h(of)f(them)195 2277 y(set)g(completion-query-items)e ! (150)195 2381 y(#)j(For)f(FTP)195 2433 y($if)g(Ftp)195 ! 2484 y("\\C-xg":)g("get)g(\\M-?")195 2536 y("\\C-xt":)g("put)g(\\M-?") ! 195 2588 y("\\M-.":)g(yank-last-arg)195 2640 y($endif)p eop %%Page: 12 14 ! 12 13 bop 75 -58 a Fm(12)1299 b(GNU)15 b(Readline)h(Library)75 ! 149 y Fk(1.4)33 b(Bindable)24 b(Readline)f(Commands)137 ! 247 y Fm(This)17 b(section)f(describ)q(es)h(Readline)g(commands)f(that) ! e(ma)o(y)h(b)q(e)i(b)q(ound)f(to)f(k)o(ey)h(sequences.)22 ! b(Com-)75 301 y(mand)15 b(names)g(without)h(an)f(accompan)o(ying)g(k)o ! (ey)g(sequence)i(are)e(un)o(b)q(ound)h(b)o(y)f(default.)137 ! 369 y(In)f(the)f(follo)o(wing)h(descriptions,)h Fc(p)q(oin)o(t)f ! Fm(refers)f(to)g(the)g(curren)o(t)g(cursor)f(p)q(osition,)j(and)e ! Fc(mark)i Fm(refers)75 424 y(to)k(a)g(cursor)g(p)q(osition)h(sa)o(v)o ! (ed)f(b)o(y)h(the)f Fl(set-mark)g Fm(command.)32 b(The)20 ! b(text)f(b)q(et)o(w)o(een)g(the)h(p)q(oin)o(t)g(and)75 ! 479 y(mark)15 b(is)g(referred)h(to)e(as)h(the)g Fc(region)p ! Fm(.)75 593 y Fb(1.4.1)30 b(Commands)21 b(F)-5 b(or)19 ! b(Mo)n(ving)75 716 y Fl(beginning-of-line)13 b(\(C-a\))315 ! 771 y Fm(Mo)o(v)o(e)h(to)h(the)g(start)f(of)h(the)g(curren)o(t)g(line.) ! 75 864 y Fl(end-of-line)f(\(C-e\))315 919 y Fm(Mo)o(v)o(e)g(to)h(the)g ! (end)h(of)f(the)g(line.)75 1012 y Fl(forward-char)f(\(C-f\))315 ! 1067 y Fm(Mo)o(v)o(e)g(forw)o(ard)g(a)h(c)o(haracter.)75 ! 1160 y Fl(backward-char)e(\(C-b\))315 1215 y Fm(Mo)o(v)o(e)h(bac)o(k)h ! (a)g(c)o(haracter.)75 1309 y Fl(forward-word)f(\(M-f\))315 ! 1363 y Fm(Mo)o(v)o(e)g(forw)o(ard)g(to)g(the)i(end)g(of)e(the)h(next)h ! (w)o(ord.)j(W)l(ords)c(are)f(comp)q(osed)i(of)f(letters)g(and)315 ! 1418 y(digits.)75 1512 y Fl(backward-word)e(\(M-b\))315 ! 1566 y Fm(Mo)o(v)o(e)j(bac)o(k)g(to)h(the)f(start)g(of)g(the)h(curren)o ! (t)g(or)f(previous)i(w)o(ord.)24 b(W)l(ords)16 b(are)h(comp)q(osed)315 ! 1621 y(of)e(letters)g(and)g(digits.)75 1715 y Fl(clear-screen)f ! (\(C-l\))315 1769 y Fm(Clear)f(the)h(screen)g(and)f(redra)o(w)g(the)g ! (curren)o(t)g(line,)i(lea)o(ving)g(the)e(curren)o(t)g(line)i(at)e(the)g ! (top)315 1824 y(of)i(the)g(screen.)75 1918 y Fl(redraw-current-line)e ! (\(\))315 1972 y Fm(Refresh)i(the)g(curren)o(t)g(line.)22 ! b(By)15 b(default,)h(this)f(is)h(un)o(b)q(ound.)75 2086 ! y Fb(1.4.2)30 b(Commands)21 b(F)-5 b(or)19 b(Manipulating)i(The)f ! (History)75 2209 y Fl(accept-line)14 b(\(Newline)g(or)h(Return\))315 ! 2264 y Fm(Accept)j(the)g(line)h(regardless)f(of)f(where)h(the)g(cursor) ! f(is.)27 b(If)18 b(this)g(line)h(is)g(non-empt)o(y)l(,)f(it)315 ! 2319 y(ma)o(y)d(b)q(e)i(added)f(to)g(the)g(history)g(list)g(for)g ! (future)g(recall)h(with)f Fl(add_history\(\))p Fm(.)k(If)d(this)315 ! 2374 y(line)g(is)f(a)e(mo)q(di\014ed)j(history)e(line,)i(the)e(history) ! g(line)i(is)f(restored)e(to)h(its)g(original)i(state.)75 ! 2467 y Fl(previous-history)c(\(C-p\))315 2522 y Fm(Mo)o(v)o(e)h(`bac)o ! (k')h(through)f(the)i(history)f(list,)g(fetc)o(hing)h(the)f(previous)h ! (command.)75 2615 y Fl(next-history)e(\(C-n\))315 2670 ! y Fm(Mo)o(v)o(e)g(`forw)o(ard')f(through)i(the)h(history)f(list,)g ! (fetc)o(hing)h(the)f(next)h(command.)p eop %%Page: 13 15 ! 13 14 bop 75 -58 a Fm(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1055 ! b(13)75 149 y Fl(beginning-of-history)12 b(\(M-<\))315 ! 204 y Fm(Mo)o(v)o(e)i(to)h(the)g(\014rst)g(line)i(in)f(the)f(history)l ! (.)75 307 y Fl(end-of-history)e(\(M->\))315 362 y Fm(Mo)o(v)o(e)h(to)h (the)g(end)h(of)f(the)g(input)h(history)l(,)f(i.e.,)g(the)g(line)i ! (curren)o(tly)f(b)q(eing)g(en)o(tered.)75 466 y Fl ! (reverse-search-history)c(\(C-r\))315 520 y Fm(Searc)o(h)k(bac)o(kw)o (ard)e(starting)h(at)g(the)h(curren)o(t)f(line)j(and)d(mo)o(ving)h ! (`up')f(through)g(the)h(his-)315 575 y(tory)e(as)h(necessary)l(.)20 ! b(This)c(is)g(an)f(incremen)o(tal)h(searc)o(h.)75 678 ! y Fl(forward-search-history)c(\(C-s\))315 733 y Fm(Searc)o(h)j(forw)o (ard)e(starting)h(at)h(the)f(curren)o(t)h(line)h(and)f(mo)o(ving)g(`do) ! o(wn')f(through)g(the)h(the)315 788 y(history)g(as)g(necessary)l(.)20 ! b(This)c(is)g(an)f(incremen)o(tal)h(searc)o(h.)75 891 ! y Fl(non-incremental-reverse-se)o(arch-hi)o(story)c(\(M-p\))315 ! 946 y Fm(Searc)o(h)k(bac)o(kw)o(ard)e(starting)h(at)g(the)h(curren)o(t) f(line)j(and)d(mo)o(ving)h(`up')f(through)g(the)h(his-)315 ! 1001 y(tory)h(as)h(necessary)g(using)h(a)e(non-incremen)o(tal)j(searc)o ! (h)e(for)f(a)h(string)g(supplied)i(b)o(y)e(the)315 1056 ! y(user.)75 1159 y Fl(non-incremental-forward-se)o(arch-hi)o(story)12 ! b(\(M-n\))315 1214 y Fm(Searc)o(h)j(forw)o(ard)e(starting)h(at)h(the)f (curren)o(t)h(line)h(and)f(mo)o(ving)g(`do)o(wn')f(through)g(the)h(the) ! 315 1268 y(history)e(as)g(necessary)h(using)g(a)f(non-incremen)o(tal)i (searc)o(h)e(for)g(a)g(string)g(supplied)j(b)o(y)d(the)315 ! 1323 y(user.)75 1427 y Fl(history-search-forward)f(\(\))315 ! 1481 y Fm(Searc)o(h)21 b(forw)o(ard)e(through)i(the)f(history)h(for)f (the)h(string)g(of)f(c)o(haracters)g(b)q(et)o(w)o(een)h(the)315 ! 1536 y(start)16 b(of)h(the)h(curren)o(t)g(line)h(and)e(the)h(p)q(oin)o (t.)28 b(This)18 b(is)g(a)f(non-incremen)o(tal)i(searc)o(h.)27 ! b(By)315 1591 y(default,)15 b(this)h(command)f(is)h(un)o(b)q(ound.)75 ! 1694 y Fl(history-search-backward)c(\(\))315 1749 y Fm(Searc)o(h)18 b(bac)o(kw)o(ard)e(through)h(the)h(history)f(for)g(the)g(string)h(of)f ! (c)o(haracters)f(b)q(et)o(w)o(een)i(the)315 1804 y(start)e(of)h(the)h (curren)o(t)g(line)h(and)e(the)h(p)q(oin)o(t.)28 b(This)18 b(is)g(a)f(non-incremen)o(tal)i(searc)o(h.)27 b(By)315 ! 1859 y(default,)15 b(this)h(command)f(is)h(un)o(b)q(ound.)75 ! 1962 y Fl(yank-nth-arg)e(\(M-C-y\))315 2017 y Fm(Insert)f(the)g (\014rst)g(argumen)o(t)f(to)g(the)i(previous)f(command)g(\(usually)h ! (the)f(second)h(w)o(ord)e(on)315 2071 y(the)j(previous)h(line\))g(at)e ! (p)q(oin)o(t.)21 b(With)15 b(an)g(argumen)o(t)f Fc(n)p ! Fm(,)h(insert)g(the)g Fc(n)p Fm(th)g(w)o(ord)g(from)f(the)315 ! 2126 y(previous)g(command)g(\(the)f(w)o(ords)f(in)j(the)e(previous)i ! (command)e(b)q(egin)i(with)e(w)o(ord)g(0\).)19 b(A)315 ! 2181 y(negativ)o(e)13 b(argumen)o(t)f(inserts)h(the)g ! Fc(n)p Fm(th)g(w)o(ord)f(from)g(the)h(end)h(of)e(the)h(previous)g ! (command.)75 2284 y Fl(yank-last-arg)g(\(M-.)i(or)g(M-_\))315 ! 2339 y Fm(Insert)j(last)f(argumen)o(t)g(to)g(the)g(previous)i(command)e ! (\(the)g(last)h(w)o(ord)f(of)g(the)g(previous)315 2394 ! y(history)e(en)o(try\).)20 b(With)15 b(an)g(argumen)o(t,)g(b)q(eha)o(v) ! o(e)g(exactly)h(lik)o(e)g Fl(yank-nth-arg)p Fm(.)j(Succes-)315 ! 2449 y(siv)o(e)f(calls)g(to)f Fl(yank-last-arg)e Fm(mo)o(v)o(e)i(bac)o ! (k)g(through)g(the)g(history)g(list,)i(inserting)f(the)315 ! 2503 y(last)d(argumen)o(t)g(of)f(eac)o(h)i(line)g(in)g(turn.)75 ! 2630 y Fb(1.4.3)30 b(Commands)21 b(F)-5 b(or)19 b(Changing)i(T)-5 ! b(ext)p eop %%Page: 14 16 ! 14 15 bop 75 -58 a Fm(14)1299 b(GNU)15 b(Readline)h(Library)75 ! 149 y Fl(delete-char)e(\(C-d\))315 204 y Fm(Delete)20 ! b(the)g(c)o(haracter)e(at)h(p)q(oin)o(t.)33 b(If)20 b(p)q(oin)o(t)g(is) ! g(at)e(the)i(b)q(eginning)i(of)d(the)g(line,)j(there)315 ! 259 y(are)c(no)h(c)o(haracters)e(in)j(the)e(line,)j(and)e(the)f(last)h ! (c)o(haracter)e(t)o(yp)q(ed)i(w)o(as)f(not)g(b)q(ound)i(to)315 ! 314 y Fl(delete-char)p Fm(,)13 b(then)j(return)f Fh(eof)p ! Fm(.)75 406 y Fl(backward-delete-char)d(\(Rubout\))315 ! 460 y Fm(Delete)k(the)f(c)o(haracter)f(b)q(ehind)j(the)f(cursor.)j(A)c ! (n)o(umeric)h(argumen)o(t)e(means)i(to)e(kill)j(the)315 ! 515 y(c)o(haracters)d(instead)i(of)f(deleting)i(them.)75 ! 607 y Fl(forward-backward-delete-ch)o(ar)12 b(\(\))315 ! 662 y Fm(Delete)20 b(the)f(c)o(haracter)f(under)i(the)f(cursor,)h (unless)g(the)f(cursor)g(is)h(at)e(the)h(end)h(of)f(the)315 ! 717 y(line,)e(in)g(whic)o(h)g(case)e(the)h(c)o(haracter)g(b)q(ehind)h (the)f(cursor)g(is)g(deleted.)23 b(By)16 b(default,)h(this)315 ! 771 y(is)f(not)f(b)q(ound)h(to)e(a)h(k)o(ey)l(.)75 863 ! y Fl(quoted-insert)e(\(C-q)i(or)g(C-v\))315 918 y Fm(Add)j(the)f(next)g ! (c)o(haracter)g(t)o(yp)q(ed)g(to)f(the)i(line)g(v)o(erbatim.)26 ! b(This)18 b(is)f(ho)o(w)g(to)g(insert)g(k)o(ey)315 973 ! y(sequences)f(lik)o(e)h Fg(C-q)p Fm(,)d(for)h(example.)75 ! 1065 y Fl(tab-insert)f(\(M-)401 1063 y Ff(h)p 412 1037 ! 74 2 v 412 1065 a Fe(T)m(AB)p 412 1072 V 484 1063 a Ff(i)499 ! 1065 y Fl(\))315 1119 y Fm(Insert)h(a)g(tab)g(c)o(haracter.)75 ! 1211 y Fl(self-insert)f(\(a,)g(b,)h(A,)g(1,)g(!,)g(...)o(\))315 ! 1266 y Fm(Insert)g(y)o(ourself.)75 1358 y Fl(transpose-chars)e(\(C-t\)) ! 315 1413 y Fm(Drag)i(the)h(c)o(haracter)f(b)q(efore)h(the)h(cursor)e ! (forw)o(ard)g(o)o(v)o(er)g(the)h(c)o(haracter)f(at)h(the)g(cursor,)315 ! 1467 y(mo)o(ving)i(the)f(cursor)h(forw)o(ard)e(as)i(w)o(ell.)28 ! b(If)18 b(the)g(insertion)h(p)q(oin)o(t)f(is)g(at)f(the)h(end)h(of)e ! (the)315 1522 y(line,)c(then)e(this)h(transp)q(oses)e(the)h(last)g(t)o ! (w)o(o)f(c)o(haracters)g(of)h(the)g(line.)20 b(Negativ)o(e)11 ! b(argumen)o(ts)315 1577 y(ha)o(v)o(e)k(no)g(e\013ect.)75 ! 1669 y Fl(transpose-words)e(\(M-t\))315 1724 y Fm(Drag)i(the)h(w)o(ord) ! g(b)q(efore)g(p)q(oin)o(t)h(past)f(the)g(w)o(ord)f(after)h(p)q(oin)o ! (t,)g(mo)o(ving)g(p)q(oin)o(t)h(past)f(that)315 1778 ! y(w)o(ord)f(as)f(w)o(ell.)75 1870 y Fl(upcase-word)g(\(M-u\))315 ! 1925 y Fm(Upp)q(ercase)j(the)f(curren)o(t)g(\(or)f(follo)o(wing\))h(w)o ! (ord.)22 b(With)16 b(a)g(negativ)o(e)g(argumen)o(t,)f(upp)q(er-)315 ! 1980 y(case)g(the)g(previous)h(w)o(ord,)f(but)g(do)g(not)g(mo)o(v)o(e)f ! (the)i(cursor.)75 2072 y Fl(downcase-word)d(\(M-l\))315 ! 2126 y Fm(Lo)o(w)o(ercase)d(the)h(curren)o(t)g(\(or)f(follo)o(wing\))h (w)o(ord.)17 b(With)11 b(a)g(negativ)o(e)g(argumen)o(t,)f(lo)o(w)o ! (ercase)315 2181 y(the)15 b(previous)h(w)o(ord,)e(but)i(do)f(not)g(mo)o ! (v)o(e)f(the)h(cursor.)75 2273 y Fl(capitalize-word)e(\(M-c\))315 ! 2328 y Fm(Capitalize)f(the)f(curren)o(t)f(\(or)g(follo)o(wing\))h(w)o (ord.)18 b(With)11 b(a)f(negativ)o(e)h(argumen)o(t,)f(capitalize)315 ! 2383 y(the)15 b(previous)h(w)o(ord,)e(but)i(do)f(not)g(mo)o(v)o(e)f ! (the)h(cursor.)75 2494 y Fb(1.4.4)30 b(Killing)20 b(And)h(Y)-5 ! b(anking)75 2615 y Fl(kill-line)14 b(\(C-k\))315 2670 ! y Fm(Kill)j(the)f(text)e(from)h(p)q(oin)o(t)h(to)e(the)h(end)h(of)f ! (the)g(line.)p eop %%Page: 15 17 ! 15 16 bop 75 -58 a Fm(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1055 ! b(15)75 149 y Fl(backward-kill-line)13 b(\(C-x)h(Rubout\))315 ! 204 y Fm(Kill)j(bac)o(kw)o(ard)e(to)f(the)i(b)q(eginning)h(of)e(the)g ! (line.)75 295 y Fl(unix-line-discard)e(\(C-u\))315 349 ! y Fm(Kill)k(bac)o(kw)o(ard)e(from)f(the)i(cursor)e(to)h(the)g(b)q ! (eginning)j(of)c(the)i(curren)o(t)f(line.)75 440 y Fl(kill-whole-line)e ! (\(\))315 495 y Fm(Kill)20 b(all)g(c)o(haracters)d(on)h(the)h(curren)o ! (t)f(line,)i(no)e(matter)g(where)g(p)q(oin)o(t)h(is.)29 ! b(By)19 b(default,)315 549 y(this)d(is)f(un)o(b)q(ound.)75 ! 640 y Fl(kill-word)f(\(M-d\))315 695 y Fm(Kill)j(from)d(p)q(oin)o(t)h ! (to)f(the)h(end)g(of)f(the)h(curren)o(t)g(w)o(ord,)e(or)i(if)g(b)q(et)o ! (w)o(een)g(w)o(ords,)e(to)i(the)f(end)315 750 y(of)h(the)g(next)g(w)o ! (ord.)20 b(W)l(ord)14 b(b)q(oundaries)j(are)e(the)g(same)g(as)g ! Fl(forward-word)p Fm(.)75 840 y Fl(backward-kill-word)e(\(M-)592 ! 838 y Ff(h)p 603 812 73 2 v 603 840 a Fe(DEL)p 603 848 ! V 674 838 a Ff(i)689 840 y Fl(\))315 895 y Fm(Kill)k(the)d(w)o(ord)g(b) ! q(ehind)i(p)q(oin)o(t.)21 b(W)l(ord)14 b(b)q(oundaries)h(are)f(the)h ! (same)f(as)g Fl(backward-word)p Fm(.)75 985 y Fl(unix-word-rubout)f ! (\(C-w\))315 1040 y Fm(Kill)18 b(the)e(w)o(ord)f(b)q(ehind)j(p)q(oin)o ! (t,)e(using)h(white)f(space)g(as)g(a)f(w)o(ord)g(b)q(oundary)l(.)23 ! b(The)16 b(killed)315 1095 y(text)f(is)g(sa)o(v)o(ed)g(on)g(the)h ! (kill-ring.)75 1185 y Fl(delete-horizontal-space)c(\(\))315 ! 1240 y Fm(Delete)k(all)g(spaces)f(and)h(tabs)e(around)i(p)q(oin)o(t.)k ! (By)15 b(default,)h(this)f(is)h(un)o(b)q(ound.)75 1330 ! y Fl(kill-region)e(\(\))315 1385 y Fm(Kill)j(the)f(text)e(in)i(the)g (curren)o(t)f(region.)20 b(By)15 b(default,)h(this)f(command)g(is)h(un) ! o(b)q(ound.)75 1476 y Fl(copy-region-as-kill)d(\(\))315 ! 1530 y Fm(Cop)o(y)j(the)i(text)e(in)i(the)f(region)g(to)g(the)g(kill)h (bu\013er,)f(so)g(it)g(can)g(b)q(e)h(y)o(ank)o(ed)f(righ)o(t)g(a)o(w)o ! (a)o(y)l(.)315 1585 y(By)e(default,)h(this)f(command)g(is)h(un)o(b)q ! (ound.)75 1676 y Fl(copy-backward-word)d(\(\))315 1730 ! y Fm(Cop)o(y)19 b(the)g(w)o(ord)g(b)q(efore)g(p)q(oin)o(t)h(to)e(the)i (kill)h(bu\013er.)32 b(The)19 b(w)o(ord)g(b)q(oundaries)h(are)f(the)315 ! 1785 y(same)c(as)g Fl(backward-word)p Fm(.)j(By)d(default,)g(this)h ! (command)f(is)h(un)o(b)q(ound.)75 1876 y Fl(copy-forward-word)d(\(\)) ! 315 1930 y Fm(Cop)o(y)i(the)h(w)o(ord)e(follo)o(wing)j(p)q(oin)o(t)f (to)f(the)g(kill)j(bu\013er.)i(The)c(w)o(ord)f(b)q(oundaries)i(are)e ! (the)315 1985 y(same)g(as)g Fl(forward-word)p Fm(.)j(By)d(default,)h ! (this)f(command)g(is)h(un)o(b)q(ound.)75 2076 y Fl(yank)f(\(C-y\))315 ! 2131 y Fm(Y)l(ank)g(the)h(top)f(of)f(the)i(kill)h(ring)e(in)o(to)g(the) ! h(bu\013er)f(at)f(p)q(oin)o(t.)75 2221 y Fl(yank-pop)g(\(M-y\))315 ! 2276 y Fm(Rotate)i(the)h(kill-ring,)j(and)d(y)o(ank)g(the)h(new)f(top.) ! 26 b(Y)l(ou)17 b(can)h(only)g(do)f(this)h(if)f(the)h(prior)315 ! 2331 y(command)d(is)h Fl(yank)e Fm(or)h Fl(yank-pop)p ! Fm(.)75 2441 y Fb(1.4.5)30 b(Sp)r(ecifying)20 b(Numeric)h(Argumen)n(ts) ! 75 2560 y Fl(digit-argument)13 b(\()p Fg(M-0)p Fl(,)i ! Fg(M-1)p Fl(,)f(...)h Fg(M--)p Fl(\))315 2615 y Fm(Add)f(this)g(digit)g ! (to)f(the)h(argumen)o(t)e(already)i(accum)o(ulating,)g(or)f(start)f(a)h ! (new)h(argumen)o(t.)315 2670 y Fg(M--)h Fm(starts)f(a)h(negativ)o(e)g ! (argumen)o(t.)p eop ! %%Page: 16 18 ! 16 17 bop 75 -58 a Fm(16)1299 b(GNU)15 b(Readline)h(Library)75 ! 149 y Fl(universal-argument)d(\(\))315 204 y Fm(This)g(is)h(another)e ! (w)o(a)o(y)g(to)g(sp)q(ecify)i(an)f(argumen)o(t.)18 b(If)13 b(this)g(command)g(is)g(follo)o(w)o(ed)g(b)o(y)g(one)315 ! 259 y(or)h(more)h(digits,)g(optionally)h(with)f(a)g(leading)h(min)o(us) ! f(sign,)g(those)g(digits)g(de\014ne)h(the)f(ar-)315 314 ! y(gumen)o(t.)k(If)c(the)g(command)f(is)h(follo)o(w)o(ed)g(b)o(y)g ! (digits,)g(executing)g Fl(universal-argument)315 369 ! y Fm(again)h(ends)g(the)g(n)o(umeric)h(argumen)o(t,)e(but)h(is)h (otherwise)f(ignored.)22 b(As)16 b(a)g(sp)q(ecial)h(case,)315 ! 423 y(if)g(this)g(command)f(is)h(immediately)h(follo)o(w)o(ed)f(b)o(y)f ! (a)g(c)o(haracter)g(that)g(is)h(neither)g(a)f(digit)315 ! 478 y(or)d(min)o(us)i(sign,)f(the)g(argumen)o(t)g(coun)o(t)f(for)h(the) g(next)g(command)g(is)g(m)o(ultiplied)j(b)o(y)d(four.)315 ! 533 y(The)19 b(argumen)o(t)f(coun)o(t)g(is)h(initially)j(one,)d(so)f (executing)i(this)f(function)h(the)e(\014rst)h(time)315 ! 588 y(mak)o(es)c(the)h(argumen)o(t)f(coun)o(t)h(four,)f(a)h(second)g (time)g(mak)o(es)g(the)g(argumen)o(t)f(coun)o(t)g(six-)315 ! 643 y(teen,)g(and)g(so)g(on.)20 b(By)15 b(default,)h(this)f(is)h(not)f ! (b)q(ound)h(to)f(a)g(k)o(ey)l(.)75 762 y Fb(1.4.6)30 b(Letting)20 b(Readline)g(T)n(yp)r(e)h(F)-5 b(or)19 b(Y)-5 ! b(ou)75 892 y Fl(complete)14 b(\()305 890 y Ff(h)p 317 ! 864 74 2 v 317 892 a Fe(T)m(AB)p 317 900 V 389 890 a ! Ff(i)404 892 y Fl(\))315 947 y Fm(A)o(ttempt)c(to)h(p)q(erform)g ! (completion)i(on)e(the)g(text)g(b)q(efore)h(p)q(oin)o(t.)19 ! b(The)11 b(actual)h(completion)315 1002 y(p)q(erformed)j(is)h ! (application-sp)q(eci\014)q(c.)23 b(The)15 b(default)h(is)g(\014lename) ! g(completion.)75 1099 y Fl(possible-completions)c(\(M-?\))315 ! 1154 y Fm(List)k(the)f(p)q(ossible)i(completions)f(of)f(the)g(text)g(b) ! q(efore)h(p)q(oin)o(t.)75 1251 y Fl(insert-completions)d(\(M-*\))315 ! 1306 y Fm(Insert)j(all)g(completions)g(of)f(the)g(text)g(b)q(efore)h(p) q(oin)o(t)f(that)g(w)o(ould)h(ha)o(v)o(e)f(b)q(een)h(generated)315 ! 1361 y(b)o(y)f Fl(possible-completions)p Fm(.)75 1458 ! y Fl(menu-complete)e(\(\))315 1513 y Fm(Similar)g(to)f ! Fl(complete)p Fm(,)f(but)h(replaces)h(the)f(w)o(ord)f(to)g(b)q(e)i ! (completed)f(with)h(a)e(single)j(matc)o(h)315 1568 y(from)k(the)h(list) ! h(of)e(p)q(ossible)j(completions.)32 b(Rep)q(eated)19 ! b(execution)h(of)f Fl(menu-complete)315 1623 y Fm(steps)h(through)g (the)g(list)h(of)f(p)q(ossible)i(completions,)g(inserting)f(eac)o(h)f ! (matc)o(h)f(in)i(turn.)315 1678 y(A)o(t)d(the)g(end)h(of)f(the)h(list)g ! (of)f(completions,)i(the)e(b)q(ell)j(is)d(rung)h(\(sub)s(ject)f(to)f ! (the)i(setting)315 1732 y(of)f Fl(bell-style)p Fm(\))e(and)i(the)g ! (original)h(text)f(is)g(restored.)28 b(An)19 b(argumen)o(t)e(of)g ! Fc(n)i Fm(mo)o(v)o(es)e Fc(n)315 1787 y Fm(p)q(ositions)h(forw)o(ard)e ! (in)j(the)e(list)h(of)f(matc)o(hes;)h(a)f(negativ)o(e)g(argumen)o(t)g ! (ma)o(y)g(b)q(e)h(used)g(to)315 1842 y(mo)o(v)o(e)g(bac)o(kw)o(ard)h ! (through)g(the)g(list.)32 b(This)20 b(command)f(is)h(in)o(tended)g(to)f ! (b)q(e)h(b)q(ound)g(to)315 1895 y Ff(h)p 327 1869 V 327 ! 1897 a Fe(T)m(AB)p 327 1905 V 399 1895 a Ff(i)414 1897 ! y Fm(,)15 b(but)g(is)h(un)o(b)q(ound)g(b)o(y)f(default.)75 ! 1994 y Fl(delete-char-or-list)e(\(\))315 2049 y Fm(Deletes)h(the)f(c)o ! (haracter)g(under)h(the)g(cursor)f(if)h(not)f(at)g(the)g(b)q(eginning)j ! (or)d(end)h(of)f(the)g(line)315 2104 y(\(lik)o(e)i Fl(delete-char)p ! Fm(\).)j(If)d(at)f(the)h(end)g(of)f(the)g(line,)i(b)q(eha)o(v)o(es)f ! (iden)o(tically)i(to)d Fl(possible-)315 2159 y(completions)p ! Fm(.)k(This)e(command)f(is)h(un)o(b)q(ound)g(b)o(y)f(default.)75 ! 2278 y Fb(1.4.7)30 b(Keyb)r(oard)20 b(Macros)75 2408 ! y Fl(start-kbd-macro)13 b(\(C-x)i(\(\))315 2463 y Fm(Begin)h(sa)o(ving) ! f(the)h(c)o(haracters)e(t)o(yp)q(ed)i(in)o(to)f(the)g(curren)o(t)g(k)o ! (eyb)q(oard)g(macro.)75 2560 y Fl(end-kbd-macro)e(\(C-x)i(\)\))315 ! 2615 y Fm(Stop)f(sa)o(ving)f(the)h(c)o(haracters)f(t)o(yp)q(ed)h(in)o ! (to)f(the)h(curren)o(t)g(k)o(eyb)q(oard)f(macro)g(and)h(sa)o(v)o(e)f ! (the)315 2670 y(de\014nition.)p eop %%Page: 17 19 ! 17 18 bop 75 -58 a Fm(Chapter)15 b(1:)k(Command)c(Line)i(Editing)1055 ! b(17)75 149 y Fl(call-last-kbd-macro)13 b(\(C-x)h(e\))315 ! 204 y Fm(Re-execute)k(the)g(last)f(k)o(eyb)q(oard)h(macro)f(de\014ned,) ! i(b)o(y)e(making)h(the)g(c)o(haracters)e(in)j(the)315 ! 259 y(macro)14 b(app)q(ear)i(as)f(if)g(t)o(yp)q(ed)h(at)e(the)i(k)o ! (eyb)q(oard.)75 368 y Fb(1.4.8)30 b(Some)20 b(Miscellaneous)h(Commands) ! 75 486 y Fl(re-read-init-file)13 b(\(C-x)h(C-r\))315 ! 541 y Fm(Read)d(in)g(the)g(con)o(ten)o(ts)g(of)f(the)h ! Fc(inputrc)k Fm(\014le,)d(and)g(incorp)q(orate)f(an)o(y)f(bindings)j ! (or)e(v)m(ariable)315 596 y(assignmen)o(ts)k(found)h(there.)75 ! 684 y Fl(abort)e(\(C-g\))315 739 y Fm(Ab)q(ort)f(the)g(curren)o(t)h (editing)g(command)f(and)h(ring)f(the)h(terminal's)f(b)q(ell)i(\(sub)s ! (ject)e(to)g(the)315 794 y(setting)i(of)g Fl(bell-style)p ! Fm(\).)75 883 y Fl(do-uppercase-version)d(\(M-a,)j(M-b,)f(M-)p ! Fc(x)p Fl(,)h(...\))315 938 y Fm(If)f(the)g(meta\014ed)g(c)o(haracter)f ! Fc(x)k Fm(is)d(lo)o(w)o(ercase,)g(run)g(the)g(command)f(that)h(is)g(b)q ! (ound)h(to)e(the)315 993 y(corresp)q(onding)j(upp)q(ercase)g(c)o ! (haracter.)75 1082 y Fl(prefix-meta)e(\()377 1080 y Ff(h)p ! 389 1054 70 2 v 389 1082 a Fe(ESC)p 389 1089 V 456 1080 ! a Ff(i)471 1082 y Fl(\))315 1136 y Fm(Metafy)k(the)h(next)g(c)o ! (haracter)f(t)o(yp)q(ed.)30 b(This)20 b(is)f(for)f(k)o(eyb)q(oards)h ! (without)g(a)f(meta)g(k)o(ey)l(.)315 1191 y(T)o(yping)e(`)485 ! 1189 y Ff(h)p 496 1163 V 496 1191 a Fe(ESC)p 496 1199 ! V 563 1189 a Ff(i)593 1191 y Fl(f)p Fm(')f(is)h(equiv)m(alen)o(t)h(to)d ! (t)o(yping)i Fg(M-f)p Fm(.)75 1280 y Fl(undo)f(\(C-_)f(or)h(C-x)g ! (C-u\))315 1335 y Fm(Incremen)o(tal)h(undo,)f(separately)h(remem)o(b)q ! (ered)g(for)e(eac)o(h)h(line.)75 1424 y Fl(revert-line)f(\(M-r\))315 ! 1479 y Fm(Undo)j(all)g(c)o(hanges)g(made)f(to)g(this)h(line.)26 ! b(This)17 b(is)g(lik)o(e)h(executing)f(the)g Fl(undo)f ! Fm(command)315 1533 y(enough)g(times)f(to)g(get)f(bac)o(k)h(to)g(the)g ! (b)q(eginning.)75 1622 y Fl(tilde-expand)f(\(M-~\))315 ! 1677 y Fm(P)o(erform)g(tilde)j(expansion)f(on)f(the)g(curren)o(t)g(w)o ! (ord.)75 1766 y Fl(set-mark)f(\(C-@\))315 1821 y Fm(Set)i(the)h(mark)f ! (to)f(the)i(p)q(oin)o(t.)24 b(If)17 b(a)f(n)o(umeric)h(argumen)o(t)f ! (is)g(supplied,)j(the)e(mark)e(is)i(set)315 1876 y(to)e(that)f(p)q ! (osition.)75 1965 y Fl(exchange-point-and-mark)e(\(C-x)j(C-x\))315 ! 2020 y Fm(Sw)o(ap)g(the)h(p)q(oin)o(t)g(with)g(the)g(mark.)k(The)c ! (curren)o(t)f(cursor)h(p)q(osition)g(is)g(set)g(to)f(the)g(sa)o(v)o(ed) ! 315 2074 y(p)q(osition,)h(and)f(the)h(old)f(cursor)g(p)q(osition)h(is)g ! (sa)o(v)o(ed)f(as)g(the)g(mark.)75 2163 y Fl(character-search)e ! (\(C-]\))315 2218 y Fm(A)f(c)o(haracter)g(is)h(read)g(and)f(p)q(oin)o ! (t)h(is)g(mo)o(v)o(ed)f(to)g(the)g(next)h(o)q(ccurrence)g(of)f(that)g ! (c)o(haracter.)315 2273 y(A)j(negativ)o(e)h(coun)o(t)f(searc)o(hes)g ! (for)f(previous)i(o)q(ccurrences.)75 2362 y Fl ! (character-search-backward)c(\(M-C-]\))315 2417 y Fm(A)22 ! b(c)o(haracter)g(is)h(read)f(and)h(p)q(oin)o(t)g(is)g(mo)o(v)o(ed)f(to) ! g(the)g(previous)h(o)q(ccurrence)h(of)e(that)315 2471 ! y(c)o(haracter.)d(A)c(negativ)o(e)h(coun)o(t)f(searc)o(hes)g(for)f ! (subsequen)o(t)i(o)q(ccurrences.)75 2560 y Fl(insert-comment)d(\(M-#\)) ! 315 2615 y Fm(The)19 b(v)m(alue)i(of)e(the)g Fl(comment-begin)e ! Fm(v)m(ariable)k(is)f(inserted)g(at)e(the)i(b)q(eginning)h(of)e(the)315 ! 2670 y(curren)o(t)c(line,)i(and)e(the)g(line)i(is)f(accepted)g(as)e(if) ! i(a)f(newline)i(had)f(b)q(een)g(t)o(yp)q(ed.)p eop %%Page: 18 20 ! 18 19 bop 75 -58 a Fm(18)1299 b(GNU)15 b(Readline)h(Library)75 ! 149 y Fl(dump-functions)d(\(\))315 204 y Fm(Prin)o(t)g(all)h(of)f(the)g ! (functions)h(and)g(their)g(k)o(ey)f(bindings)i(to)d(the)i(Readline)g ! (output)f(stream.)315 259 y(If)j(a)g(n)o(umeric)g(argumen)o(t)f(is)i ! (supplied,)h(the)e(output)f(is)i(formatted)d(in)j(suc)o(h)f(a)g(w)o(a)o ! (y)f(that)315 314 y(it)g(can)h(b)q(e)g(made)f(part)f(of)h(an)g ! Fc(inputrc)k Fm(\014le.)i(This)16 b(command)f(is)h(un)o(b)q(ound)g(b)o ! (y)f(default.)75 406 y Fl(dump-variables)e(\(\))315 461 ! y Fm(Prin)o(t)e(all)g(of)f(the)h(settable)g(v)m(ariables)h(and)f(their) ! g(v)m(alues)h(to)e(the)h(Readline)h(output)e(stream.)315 ! 516 y(If)16 b(a)g(n)o(umeric)g(argumen)o(t)f(is)i(supplied,)h(the)e ! (output)f(is)i(formatted)d(in)j(suc)o(h)f(a)g(w)o(a)o(y)f(that)315 ! 570 y(it)g(can)h(b)q(e)g(made)f(part)f(of)h(an)g Fc(inputrc)k ! Fm(\014le.)i(This)16 b(command)f(is)h(un)o(b)q(ound)g(b)o(y)f(default.) ! 75 663 y Fl(dump-macros)f(\(\))315 717 y Fm(Prin)o(t)j(all)h(of)e(the)h ! (Readline)h(k)o(ey)f(sequences)h(b)q(ound)g(to)e(macros)g(and)h(the)g ! (strings)g(they)315 772 y(output.)26 b(If)18 b(a)f(n)o(umeric)h ! (argumen)o(t)f(is)h(supplied,)i(the)d(output)g(is)h(formatted)e(in)j ! (suc)o(h)e(a)315 827 y(w)o(a)o(y)d(that)g(it)i(can)f(b)q(e)g(made)g ! (part)g(of)f(an)h Fc(inputrc)k Fm(\014le.)i(This)15 b(command)g(is)h ! (un)o(b)q(ound)g(b)o(y)315 882 y(default.)75 1010 y Fk(1.5)33 ! b(Readline)23 b(vi)h(Mo)r(de)137 1107 y Fm(While)13 b(the)f(Readline)i ! (library)e(do)q(es)g(not)g(ha)o(v)o(e)f(a)h(full)h(set)f(of)f ! Fl(vi)g Fm(editing)j(functions,)f(it)f(do)q(es)g(con)o(tain)75 ! 1161 y(enough)17 b(to)g(allo)o(w)g(simple)h(editing)h(of)d(the)i(line.) ! 27 b(The)17 b(Readline)h Fl(vi)f Fm(mo)q(de)g(b)q(eha)o(v)o(es)g(as)g ! (sp)q(eci\014ed)i(in)75 1216 y(the)c Fh(posix)g Fm(1003.2)f(standard.) ! 137 1284 y(In)h(order)g(to)f(switc)o(h)g(in)o(teractiv)o(ely)i(b)q(et)o ! (w)o(een)f Fl(emacs)e Fm(and)i Fl(vi)f Fm(editing)i(mo)q(des,)f(use)f ! (the)h(command)75 1338 y Fg(M-C-j)j Fm(\(b)q(ound)i(to)e ! (emacs-editing-mo)q(de)j(when)e(in)h Fl(vi)f Fm(mo)q(de)g(and)g(to)f ! (vi-editing-mo)q(de)k(in)e Fl(emacs)75 1393 y Fm(mo)q(de\).)g(The)15 ! b(Readline)i(default)f(is)f Fl(emacs)g Fm(mo)q(de.)137 ! 1460 y(When)h(y)o(ou)e(en)o(ter)h(a)g(line)i(in)e Fl(vi)g ! Fm(mo)q(de,)g(y)o(ou)g(are)f(already)i(placed)g(in)g(`insertion')f(mo)q ! (de,)g(as)g(if)g(y)o(ou)75 1515 y(had)e(t)o(yp)q(ed)h(an)f(`)p ! Fl(i)p Fm('.)18 b(Pressing)608 1513 y Ff(h)p 620 1487 ! 70 2 v 620 1515 a Fe(ESC)p 620 1523 V 687 1513 a Ff(i)715 ! 1515 y Fm(switc)o(hes)13 b(y)o(ou)g(in)o(to)g(`command')f(mo)q(de,)i ! (where)f(y)o(ou)g(can)g(edit)h(the)75 1570 y(text)i(of)h(the)g(line)h ! (with)g(the)f(standard)f Fl(vi)h Fm(mo)o(v)o(emen)o(t)f(k)o(eys,)g(mo)o ! (v)o(e)g(to)h(previous)g(history)g(lines)i(with)75 1625 ! y(`)p Fl(k)p Fm(')14 b(and)i(subsequen)o(t)f(lines)i(with)f(`)p ! Fl(j)p Fm(',)e(and)h(so)g(forth.)p eop %%Page: -1 21 ! -1 20 bop 1862 -58 a Fm(i)75 149 y Fi(T)-7 b(able)27 ! b(of)f(Con)n(ten)n(ts)75 320 y Fk(1)67 b(Command)22 b(Line)i(Editing)d ! Fa(.)10 b(.)h(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)g(.)h(.)f(.)g(.)g(.)h ! (.)f(.)g(.)g(.)42 b Fk(1)224 389 y Fm(1.1)j(In)o(tro)q(duction)16 ! b(to)f(Line)h(Editing)e Fd(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)27 b Fm(1)224 444 y(1.2)45 b(Readline)16 b(In)o(teraction)8 ! b Fd(.)g(.)g(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)23 b Fm(1)374 499 y(1.2.1)44 b(Readline)16 ! b(Bare)f(Essen)o(tials)f Fd(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h (.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)27 ! b Fm(1)374 553 y(1.2.2)44 b(Readline)16 b(Mo)o(v)o(emen)o(t)e(Commands) ! 7 b Fd(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f ! (.)h(.)21 b Fm(2)374 608 y(1.2.3)44 b(Readline)16 b(Killing)i(Commands) ! 11 b Fd(.)c(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h ! (.)f(.)h(.)f(.)h(.)25 b Fm(2)374 663 y(1.2.4)44 b(Readline)16 ! b(Argumen)o(ts)c Fd(.)c(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h ! (.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)27 ! b Fm(3)374 718 y(1.2.5)44 b(Searc)o(hing)16 b(for)e(Commands)h(in)h ! (the)f(History)e Fd(.)8 b(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)27 ! b Fm(3)224 773 y(1.3)45 b(Readline)16 b(Init)h(File)e ! Fd(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)f(.)29 b Fm(4)374 827 y(1.3.1)44 b(Readline)16 ! b(Init)g(File)h(Syn)o(tax)7 b Fd(.)g(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)21 ! b Fm(4)374 882 y(1.3.2)44 b(Conditional)16 b(Init)g(Constructs)5 ! b Fd(.)i(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)g(.)f(.)19 b Fm(8)374 937 y(1.3.3)44 b(Sample)16 ! b(Init)g(File)11 b Fd(.)e(.)e(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)26 b Fm(9)224 992 y(1.4)45 b(Bindable)17 b(Readline)g(Commands) ! 6 b Fd(.)h(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h ! (.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)21 b Fm(12)374 ! 1046 y(1.4.1)44 b(Commands)14 b(F)l(or)h(Mo)o(ving)e ! Fd(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)h(.)28 b Fm(12)374 1101 y(1.4.2)44 b(Commands)14 b(F)l(or)h(Manipulating)i(The)e(History)9 ! b Fd(.)e(.)h(.)f(.)h(.)f(.)h(.)24 b Fm(12)374 1156 y(1.4.3)44 ! b(Commands)14 b(F)l(or)h(Changing)h(T)l(ext)e Fd(.)8 b(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)30 ! b Fm(13)374 1211 y(1.4.4)44 b(Killing)18 b(And)e(Y)l(anking)9 ! b Fd(.)e(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)24 b Fm(14)374 ! 1266 y(1.4.5)44 b(Sp)q(ecifying)17 b(Numeric)f(Argumen)o(ts)c ! Fd(.)c(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)27 ! b Fm(15)374 1320 y(1.4.6)44 b(Letting)15 b(Readline)i(T)o(yp)q(e)e(F)l ! (or)g(Y)l(ou)10 b Fd(.)d(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! h(.)f(.)h(.)f(.)25 b Fm(16)374 1375 y(1.4.7)44 b(Keyb)q(oard)15 ! b(Macros)6 b Fd(.)h(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f (.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)21 ! b Fm(16)374 1430 y(1.4.8)44 b(Some)15 b(Miscellaneous)i(Commands)7 ! b Fd(.)g(.)g(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.) ! 22 b Fm(17)224 1485 y(1.5)45 b(Readline)16 b(vi)g(Mo)q(de)e ! Fd(.)7 b(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.) f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)f(.)h(.)g(.)f(.)h(.)f(.)h(.)f ! (.)h(.)f(.)h(.)28 b Fm(18)p eop %%Page: -2 22 ! -2 21 bop 75 -58 a Fm(ii)1321 b(GNU)15 b(Readline)h(Library)p eop %%Trailer diff -Nrc2 readline-4.1/doc/rluserman.texinfo readline-4.2/doc/rluserman.texinfo *** readline-4.1/doc/rluserman.texinfo Thu Aug 5 08:25:28 1999 --- readline-4.2/doc/rluserman.texinfo Fri Feb 2 11:59:01 2001 *************** *** 11,15 **** @dircategory Libraries @direntry ! * Readline: (readline). The GNU readline library API @end direntry --- 11,15 ---- @dircategory Libraries @direntry ! * RLuserman: (rluserman). The GNU readline library User's Manual. @end direntry *************** *** 18,22 **** programs that need to provide a command line interface. ! Copyright (C) 1988-1999 Free Software Foundation, Inc. Permission is granted to make and distribute verbatim copies of --- 18,22 ---- programs that need to provide a command line interface. ! Copyright (C) 1988-2001 Free Software Foundation, Inc. Permission is granted to make and distribute verbatim copies of *************** *** 73,77 **** @vskip 0pt plus 1filll ! Copyright @copyright{} 1988-1999 Free Software Foundation, Inc. @end titlepage --- 73,77 ---- @vskip 0pt plus 1filll ! Copyright @copyright{} 1988-2001 Free Software Foundation, Inc. @end titlepage diff -Nrc2 readline-4.1/doc/texinfo.tex readline-4.2/doc/texinfo.tex *** readline-4.1/doc/texinfo.tex Tue Jul 1 15:36:48 1997 --- readline-4.2/doc/texinfo.tex Thu Nov 2 09:50:52 2000 *************** *** 1,50 **** ! %% TeX macros to handle texinfo files ! ! % Copyright (C) 1985, 86, 88, 90, 91, 92, 93, ! % 94, 95, 1996 Free Software Foundation, Inc. ! ! %This texinfo.tex file 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. ! ! %This texinfo.tex file 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 this texinfo.tex file; see the file COPYING. If not, write ! %to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, ! %Boston, MA 02111-1307, USA. ! ! ! %In other words, you are welcome to use, share and improve this program. ! %You are forbidden to forbid anyone else to use, share and improve ! %what you give them. Help stamp out software-hoarding! ! ! ! % Send bug reports to bug-texinfo@prep.ai.mit.edu. ! % Please include a *precise* test case in each bug report. ! ! ! % Make it possible to create a .fmt file just by loading this file: ! % if the underlying format is not loaded, start by loading it now. ! % Added by gildea November 1993. \expandafter\ifx\csname fmtname\endcsname\relax\input plain\fi ! % This automatically updates the version number based on RCS. ! \def\deftexinfoversion$#1: #2 ${\def\texinfoversion{#2}} ! \deftexinfoversion$Revision: 2.185 $ ! \message{Loading texinfo package [Version \texinfoversion]:} % If in a .fmt file, print the version number % and turn on active characters that we couldn't do earlier because % they might have appeared in the input file name. ! \everyjob{\message{[Texinfo version \texinfoversion]}\message{} \catcode`+=\active \catcode`\_=\active} % Save some parts of plain tex whose names we will redefine. - \let\ptexb=\b \let\ptexbullet=\bullet --- 1,71 ---- ! % texinfo.tex -- TeX macros to handle Texinfo files. ! % ! % Load plain if necessary, i.e., if running under initex. \expandafter\ifx\csname fmtname\endcsname\relax\input plain\fi + % + \def\texinfoversion{1999-09-25.10} + % + % Copyright (C) 1985, 86, 88, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99 + % Free Software Foundation, Inc. + % + % This texinfo.tex file 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. + % + % This texinfo.tex file 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 this texinfo.tex file; see the file COPYING. If not, write + % to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, + % Boston, MA 02111-1307, USA. + % + % In other words, you are welcome to use, share and improve this program. + % You are forbidden to forbid anyone else to use, share and improve + % what you give them. Help stamp out software-hoarding! + % + % Please try the latest version of texinfo.tex before submitting bug + % reports; you can get the latest version from: + % ftp://ftp.gnu.org/gnu/texinfo.tex + % (and all GNU mirrors, see http://www.gnu.org/order/ftp.html) + % ftp://texinfo.org/tex/texinfo.tex + % ftp://us.ctan.org/macros/texinfo/texinfo.tex + % (and all CTAN mirrors, finger ctan@us.ctan.org for a list). + % /home/gd/gnu/doc/texinfo.tex on the GNU machines. + % The texinfo.tex in any given Texinfo distribution could well be out + % of date, so if that's what you're using, please check. + % Texinfo has a small home page at http://texinfo.org/. + % + % Send bug reports to bug-texinfo@gnu.org. Please include including a + % complete document in each bug report with which we can reproduce the + % problem. Patches are, of course, greatly appreciated. + % + % To process a Texinfo manual with TeX, it's most reliable to use the + % texi2dvi shell script that comes with the distribution. For a simple + % manual foo.texi, however, you can get away with this: + % tex foo.texi + % texindex foo.?? + % tex foo.texi + % tex foo.texi + % dvips foo.dvi -o # or whatever, to process the dvi file; this makes foo.ps. + % The extra runs of TeX get the cross-reference information correct. + % Sometimes one run after texindex suffices, and sometimes you need more + % than two; texi2dvi does it as many times as necessary. + % + % It is possible to adapt texinfo.tex for other languages. You can get + % the existing language-specific files from ftp://ftp.gnu.org/gnu/texinfo/. ! \message{Loading texinfo [version \texinfoversion]:} % If in a .fmt file, print the version number % and turn on active characters that we couldn't do earlier because % they might have appeared in the input file name. ! \everyjob{\message{[Texinfo version \texinfoversion]}% \catcode`+=\active \catcode`\_=\active} % Save some parts of plain tex whose names we will redefine. \let\ptexb=\b \let\ptexbullet=\bullet *************** *** 54,58 **** \let\ptexdots=\dots \let\ptexend=\end ! \let\ptexequiv = \equiv \let\ptexi=\i \let\ptexlbrace=\{ --- 75,80 ---- \let\ptexdots=\dots \let\ptexend=\end ! \let\ptexequiv=\equiv ! \let\ptexexclam=\! \let\ptexi=\i \let\ptexlbrace=\{ *************** *** 60,78 **** \let\ptexstar=\* \let\ptext=\t - \let\ptextilde=\~ - - % Be sure we're in horizontal mode when doing a tie, since we make space - % equivalent to this in @example-like environments. Otherwise, a space - % at the beginning of a line will start with \penalty -- and - % since \penalty is valid in vertical mode, we'd end up putting the - % penalty on the vertical list instead of in the new paragraph. - {\catcode`@ = 11 - % Avoid using \@M directly, because that causes trouble - % if the definition is written into an index file. - \global\let\tiepenalty = \@M - \gdef\tie{\leavevmode\penalty\tiepenalty\ } - } - \let\~ = \tie % And make it available as @~. \message{Basics,} --- 82,89 ---- \let\ptexstar=\* \let\ptext=\t + % We never want plain's outer \+ definition in Texinfo. + % For @tex, we can use \tabalign. + \let\+ = \relax \message{Basics,} *************** *** 83,98 **** \newlinechar = `^^J ! % Set up fixed words for English. ! \ifx\putwordChapter\undefined{\gdef\putwordChapter{Chapter}}\fi% ! \def\putwordInfo{Info}% ! \ifx\putwordSee\undefined{\gdef\putwordSee{See}}\fi% ! \ifx\putwordsee\undefined{\gdef\putwordsee{see}}\fi% ! \ifx\putwordfile\undefined{\gdef\putwordfile{file}}\fi% ! \ifx\putwordpage\undefined{\gdef\putwordpage{page}}\fi% ! \ifx\putwordsection\undefined{\gdef\putwordsection{section}}\fi% ! \ifx\putwordSection\undefined{\gdef\putwordSection{Section}}\fi% ! \ifx\putwordTableofContents\undefined{\gdef\putwordTableofContents{Table of Contents}}\fi% ! \ifx\putwordShortContents\undefined{\gdef\putwordShortContents{Short Contents}}\fi% ! \ifx\putwordAppendix\undefined{\gdef\putwordAppendix{Appendix}}\fi% % Ignore a token. --- 94,138 ---- \newlinechar = `^^J ! % Set up fixed words for English if not already set. ! \ifx\putwordAppendix\undefined \gdef\putwordAppendix{Appendix}\fi ! \ifx\putwordChapter\undefined \gdef\putwordChapter{Chapter}\fi ! \ifx\putwordfile\undefined \gdef\putwordfile{file}\fi ! \ifx\putwordin\undefined \gdef\putwordin{in}\fi ! \ifx\putwordIndexIsEmpty\undefined \gdef\putwordIndexIsEmpty{(Index is empty)}\fi ! \ifx\putwordIndexNonexistent\undefined \gdef\putwordIndexNonexistent{(Index is nonexistent)}\fi ! \ifx\putwordInfo\undefined \gdef\putwordInfo{Info}\fi ! \ifx\putwordInstanceVariableof\undefined \gdef\putwordInstanceVariableof{Instance Variable of}\fi ! \ifx\putwordMethodon\undefined \gdef\putwordMethodon{Method on}\fi ! \ifx\putwordNoTitle\undefined \gdef\putwordNoTitle{No Title}\fi ! \ifx\putwordof\undefined \gdef\putwordof{of}\fi ! \ifx\putwordon\undefined \gdef\putwordon{on}\fi ! \ifx\putwordpage\undefined \gdef\putwordpage{page}\fi ! \ifx\putwordsection\undefined \gdef\putwordsection{section}\fi ! \ifx\putwordSection\undefined \gdef\putwordSection{Section}\fi ! \ifx\putwordsee\undefined \gdef\putwordsee{see}\fi ! \ifx\putwordSee\undefined \gdef\putwordSee{See}\fi ! \ifx\putwordShortTOC\undefined \gdef\putwordShortTOC{Short Contents}\fi ! \ifx\putwordTOC\undefined \gdef\putwordTOC{Table of Contents}\fi ! % ! \ifx\putwordMJan\undefined \gdef\putwordMJan{January}\fi ! \ifx\putwordMFeb\undefined \gdef\putwordMFeb{February}\fi ! \ifx\putwordMMar\undefined \gdef\putwordMMar{March}\fi ! \ifx\putwordMApr\undefined \gdef\putwordMApr{April}\fi ! \ifx\putwordMMay\undefined \gdef\putwordMMay{May}\fi ! \ifx\putwordMJun\undefined \gdef\putwordMJun{June}\fi ! \ifx\putwordMJul\undefined \gdef\putwordMJul{July}\fi ! \ifx\putwordMAug\undefined \gdef\putwordMAug{August}\fi ! \ifx\putwordMSep\undefined \gdef\putwordMSep{September}\fi ! \ifx\putwordMOct\undefined \gdef\putwordMOct{October}\fi ! \ifx\putwordMNov\undefined \gdef\putwordMNov{November}\fi ! \ifx\putwordMDec\undefined \gdef\putwordMDec{December}\fi ! % ! \ifx\putwordDefmac\undefined \gdef\putwordDefmac{Macro}\fi ! \ifx\putwordDefspec\undefined \gdef\putwordDefspec{Special Form}\fi ! \ifx\putwordDefvar\undefined \gdef\putwordDefvar{Variable}\fi ! \ifx\putwordDefopt\undefined \gdef\putwordDefopt{User Option}\fi ! \ifx\putwordDeftypevar\undefined\gdef\putwordDeftypevar{Variable}\fi ! \ifx\putwordDeffunc\undefined \gdef\putwordDeffunc{Function}\fi ! \ifx\putwordDeftypefun\undefined\gdef\putwordDeftypefun{Function}\fi % Ignore a token. *************** *** 103,110 **** \hyphenation{mini-buf-fer mini-buf-fers} \hyphenation{eshell} % Margin to add to right of even pages, to left of odd pages. ! \newdimen \bindingoffset ! \newdimen \normaloffset \newdimen\pagewidth \newdimen\pageheight --- 143,151 ---- \hyphenation{mini-buf-fer mini-buf-fers} \hyphenation{eshell} + \hyphenation{white-space} % Margin to add to right of even pages, to left of odd pages. ! \newdimen \bindingoffset ! \newdimen \normaloffset \newdimen\pagewidth \newdimen\pageheight *************** *** 114,117 **** --- 155,159 ---- % \def\gloggingall{\begingroup \globaldefs = 1 \loggingall \endgroup}% + \ifx\eTeXversion\undefined \def\loggingall{\tracingcommands2 \tracingstats2 \tracingpages1 \tracingoutput1 \tracinglostchars1 *************** *** 119,198 **** \showboxbreadth\maxdimen\showboxdepth\maxdimen }% ! %---------------------Begin change----------------------- % ! %%%% For @cropmarks command. ! % Dimensions to add cropmarks at corners Added by P. A. MacKay, 12 Nov. 1986 % ! \newdimen\cornerlong \newdimen\cornerthick ! \newdimen \topandbottommargin ! \newdimen \outerhsize \newdimen \outervsize ! \cornerlong=1pc\cornerthick=.3pt % These set size of cropmarks ! \outerhsize=7in ! %\outervsize=9.5in ! % Alternative @smallbook page size is 9.25in ! \outervsize=9.25in ! \topandbottommargin=.75in % ! %---------------------End change----------------------- % \onepageout takes a vbox as an argument. Note that \pagecontents % does insertions, but you have to call it yourself. - \chardef\PAGE=255 \output={\onepageout{\pagecontents\PAGE}} \def\onepageout#1{% ! \hoffset=\normaloffset \ifodd\pageno \advance\hoffset by \bindingoffset \else \advance\hoffset by -\bindingoffset\fi {% ! \escapechar = `\\ % use backslash in output files. ! \indexdummies \shipout\vbox{% ! {\let\hsize=\pagewidth \makeheadline}% \pagebody{#1}% ! {\let\hsize=\pagewidth \makefootline}% ! }% ! }% \advancepageno \ifnum\outputpenalty>-20000 \else\dosupereject\fi } - %%%% For @cropmarks command %%%% - - % Here is a modification of the main output routine for Near East Publications - % This provides right-angle cropmarks at all four corners. - % The contents of the page are centerlined into the cropmarks, - % and any desired binding offset is added as an \hskip on either - % site of the centerlined box. (P. A. MacKay, 12 November, 1986) - % - \def\croppageout#1{\hoffset=0pt % make sure this doesn't mess things up - {\escapechar=`\\\relax % makes sure backslash is used in output files. - \shipout - \vbox to \outervsize{\hsize=\outerhsize - \vbox{\line{\ewtop\hfill\ewtop}} - \nointerlineskip - \line{\vbox{\moveleft\cornerthick\nstop} - \hfill - \vbox{\moveright\cornerthick\nstop}} - \vskip \topandbottommargin - \centerline{\ifodd\pageno\hskip\bindingoffset\fi - \vbox{ - {\let\hsize=\pagewidth \makeheadline} - \pagebody{#1} - {\let\hsize=\pagewidth \makefootline}} - \ifodd\pageno\else\hskip\bindingoffset\fi} - \vskip \topandbottommargin plus1fill minus1fill - \boxmaxdepth\cornerthick - \line{\vbox{\moveleft\cornerthick\nsbot} - \hfill - \vbox{\moveright\cornerthick\nsbot}} - \nointerlineskip - \vbox{\line{\ewbot\hfill\ewbot}} - }} - \advancepageno - \ifnum\outputpenalty>-20000 \else\dosupereject\fi} - % - % Do @cropmarks to get crop marks - \def\cropmarks{\let\onepageout=\croppageout } - \newinsert\margin \dimen\margin=\maxdimen --- 161,271 ---- \showboxbreadth\maxdimen\showboxdepth\maxdimen }% + \else + \def\loggingall{\tracingcommands3 \tracingstats2 + \tracingpages1 \tracingoutput1 \tracinglostchars1 + \tracingmacros2 \tracingparagraphs1 \tracingrestores1 + \tracingscantokens1 \tracingassigns1 \tracingifs1 + \tracinggroups1 \tracingnesting2 + \showboxbreadth\maxdimen\showboxdepth\maxdimen + }% + \fi ! % For @cropmarks command. ! % Do @cropmarks to get crop marks. % ! \newif\ifcropmarks ! \let\cropmarks = \cropmarkstrue % ! % Dimensions to add cropmarks at corners. ! % Added by P. A. MacKay, 12 Nov. 1986 % ! \newdimen\outerhsize \newdimen\outervsize % set by the paper size routines ! \newdimen\cornerlong \cornerlong=1pc ! \newdimen\cornerthick \cornerthick=.3pt ! \newdimen\topandbottommargin \topandbottommargin=.75in ! ! % Main output routine. ! \chardef\PAGE = 255 ! \output = {\onepageout{\pagecontents\PAGE}} ! ! \newbox\headlinebox ! \newbox\footlinebox % \onepageout takes a vbox as an argument. Note that \pagecontents % does insertions, but you have to call it yourself. \def\onepageout#1{% ! \ifcropmarks \hoffset=0pt \else \hoffset=\normaloffset \fi ! % \ifodd\pageno \advance\hoffset by \bindingoffset \else \advance\hoffset by -\bindingoffset\fi + % + % Do this outside of the \shipout so @code etc. will be expanded in + % the headline as they should be, not taken literally (outputting ''code). + \setbox\headlinebox = \vbox{\let\hsize=\pagewidth \makeheadline}% + \setbox\footlinebox = \vbox{\let\hsize=\pagewidth \makefootline}% + % {% ! % Have to do this stuff outside the \shipout because we want it to ! % take effect in \write's, yet the group defined by the \vbox ends ! % before the \shipout runs. ! % ! \escapechar = `\\ % use backslash in output files. ! \indexdummies % don't expand commands in the output. ! \normalturnoffactive % \ in index entries must not stay \, e.g., if ! % the page break happens to be in the middle of an example. \shipout\vbox{% ! \ifcropmarks \vbox to \outervsize\bgroup ! \hsize = \outerhsize ! \vskip-\topandbottommargin ! \vtop to0pt{% ! \line{\ewtop\hfil\ewtop}% ! \nointerlineskip ! \line{% ! \vbox{\moveleft\cornerthick\nstop}% ! \hfill ! \vbox{\moveright\cornerthick\nstop}% ! }% ! \vss}% ! \vskip\topandbottommargin ! \line\bgroup ! \hfil % center the page within the outer (page) hsize. ! \ifodd\pageno\hskip\bindingoffset\fi ! \vbox\bgroup ! \fi ! % ! \unvbox\headlinebox \pagebody{#1}% ! \ifdim\ht\footlinebox > 0pt ! % Only leave this space if the footline is nonempty. ! % (We lessened \vsize for it in \oddfootingxxx.) ! % The \baselineskip=24pt in plain's \makefootline has no effect. ! \vskip 2\baselineskip ! \unvbox\footlinebox ! \fi ! % ! \ifpdfmakepagedest \pdfmkdest{\the\pageno} \fi ! % ! \ifcropmarks ! \egroup % end of \vbox\bgroup ! \hfil\egroup % end of (centering) \line\bgroup ! \vskip\topandbottommargin plus1fill minus1fill ! \boxmaxdepth = \cornerthick ! \vbox to0pt{\vss ! \line{% ! \vbox{\moveleft\cornerthick\nsbot}% ! \hfill ! \vbox{\moveright\cornerthick\nsbot}% ! }% ! \nointerlineskip ! \line{\ewbot\hfil\ewbot}% ! }% ! \egroup % \vbox from first cropmarks clause ! \fi ! }% end of \shipout\vbox ! }% end of group with \turnoffactive \advancepageno \ifnum\outputpenalty>-20000 \else\dosupereject\fi } \newinsert\margin \dimen\margin=\maxdimen *************** *** 208,212 **** } - % % Here are the rules for the cropmarks. Note that they are % offset so that the space between them is truly \outerhsize or \outervsize --- 281,284 ---- *************** *** 303,311 **** \newif\ifENV \ENVfalse \def\inENV{\ifENV\relax\else\ENVtrue\fi} \def\ENVcheck{% ! \ifENV\errmessage{Still within an environment. Type Return to continue.} \endgroup\fi} % This is not perfect, but it should reduce lossage % @begin foo is the same as @foo, for now. ! \newhelp\EMsimple{Type to continue.} \outer\def\begin{\parsearg\beginxxx} --- 375,383 ---- \newif\ifENV \ENVfalse \def\inENV{\ifENV\relax\else\ENVtrue\fi} \def\ENVcheck{% ! \ifENV\errmessage{Still within an environment; press RETURN to continue} \endgroup\fi} % This is not perfect, but it should reduce lossage % @begin foo is the same as @foo, for now. ! \newhelp\EMsimple{Press RETURN to continue.} \outer\def\begin{\parsearg\beginxxx} *************** *** 366,370 **** % @@ prints an @ % Kludge this until the fonts are right (grr). ! \def\@{{\tt \char '100}} % This is turned off because it was never documented --- 438,442 ---- % @@ prints an @ % Kludge this until the fonts are right (grr). ! \def\@{{\tt\char64}} % This is turned off because it was never documented *************** *** 376,381 **** % Used to generate quoted braces. ! \def\mylbrace {{\tt \char '173}} ! \def\myrbrace {{\tt \char '175}} \let\{=\mylbrace \let\}=\myrbrace --- 448,453 ---- % Used to generate quoted braces. ! \def\mylbrace {{\tt\char123}} ! \def\myrbrace {{\tt\char125}} \let\{=\mylbrace \let\}=\myrbrace *************** *** 414,417 **** --- 486,501 ---- } + % Be sure we're in horizontal mode when doing a tie, since we make space + % equivalent to this in @example-like environments. Otherwise, a space + % at the beginning of a line will start with \penalty -- and + % since \penalty is valid in vertical mode, we'd end up putting the + % penalty on the vertical list instead of in the new paragraph. + {\catcode`@ = 11 + % Avoid using \@M directly, because that causes trouble + % if the definition is written into an index file. + \global\let\tiepenalty = \@M + \gdef\tie{\leavevmode\penalty\tiepenalty\ } + } + % @: forces normal size whitespace following. \def\:{\spacefactor=1000 } *************** *** 423,434 **** \def\.{.\spacefactor=3000 } - % @enddots{} is an end-of-sentence ellipsis. - \gdef\enddots{$\mathinner{\ldotp\ldotp\ldotp\ldotp}$\spacefactor=3000} - % @! is an end-of-sentence bang. ! \gdef\!{!\spacefactor=3000 } % @? is an end-of-sentence query. ! \gdef\?{?\spacefactor=3000 } % @w prevents a word break. Without the \leavevmode, @w at the --- 507,515 ---- \def\.{.\spacefactor=3000 } % @! is an end-of-sentence bang. ! \def\!{!\spacefactor=3000 } % @? is an end-of-sentence query. ! \def\?{?\spacefactor=3000 } % @w prevents a word break. Without the \leavevmode, @w at the *************** *** 514,552 **** %% if the depth of the box does not fit. %{\baselineskip=0pt% ! %\vtop to #1\mil{\vfil}\kern -#1\mil\penalty 10000 %\prevdepth=-1000pt %}} \def\needx#1{% ! % Go into vertical mode, so we don't make a big box in the middle of a % paragraph. \par % ! % Don't add any leading before our big empty box, but allow a page ! % break, since the best break might be right here. ! \allowbreak ! \nointerlineskip ! \vtop to #1\mil{\vfil}% ! % ! % TeX does not even consider page breaks if a penalty added to the ! % main vertical list is 10000 or more. But in order to see if the ! % empty box we just added fits on the page, we must make it consider ! % page breaks. On the other hand, we don't want to actually break the ! % page after the empty box. So we use a penalty of 9999. ! % ! % There is an extremely small chance that TeX will actually break the ! % page at this \penalty, if there are no other feasible breakpoints in ! % sight. (If the user is using lots of big @group commands, which ! % almost-but-not-quite fill up a page, TeX will have a hard time doing ! % good page breaking, for example.) However, I could not construct an ! % example where a page broke at this \penalty; if it happens in a real ! % document, then we can reconsider our strategy. ! \penalty9999 ! % ! % Back up by the size of the box, whether we did a page break or not. ! \kern -#1\mil ! % ! % Do not allow a page break right after this kern. ! \nobreak } --- 595,639 ---- %% if the depth of the box does not fit. %{\baselineskip=0pt% ! %\vtop to #1\mil{\vfil}\kern -#1\mil\nobreak %\prevdepth=-1000pt %}} \def\needx#1{% ! % Ensure vertical mode, so we don't make a big box in the middle of a % paragraph. \par % ! % If the @need value is less than one line space, it's useless. ! \dimen0 = #1\mil ! \dimen2 = \ht\strutbox ! \advance\dimen2 by \dp\strutbox ! \ifdim\dimen0 > \dimen2 ! % ! % Do a \strut just to make the height of this box be normal, so the ! % normal leading is inserted relative to the preceding line. ! % And a page break here is fine. ! \vtop to #1\mil{\strut\vfil}% ! % ! % TeX does not even consider page breaks if a penalty added to the ! % main vertical list is 10000 or more. But in order to see if the ! % empty box we just added fits on the page, we must make it consider ! % page breaks. On the other hand, we don't want to actually break the ! % page after the empty box. So we use a penalty of 9999. ! % ! % There is an extremely small chance that TeX will actually break the ! % page at this \penalty, if there are no other feasible breakpoints in ! % sight. (If the user is using lots of big @group commands, which ! % almost-but-not-quite fill up a page, TeX will have a hard time doing ! % good page breaking, for example.) However, I could not construct an ! % example where a page broke at this \penalty; if it happens in a real ! % document, then we can reconsider our strategy. ! \penalty9999 ! % ! % Back up by the size of the box, whether we did a page break or not. ! \kern -#1\mil ! % ! % Do not allow a page break right after this kern. ! \nobreak ! \fi } *************** *** 555,564 **** \let\br = \par ! % @dots{} output some dots - \def\dots{$\ldots$} % @page forces the start of a new page ! \def\page{\par\vfill\supereject} --- 642,673 ---- \let\br = \par ! % @dots{} output an ellipsis using the current font. ! % We do .5em per period so that it has the same spacing in a typewriter ! % font as three actual period characters. ! % ! \def\dots{% ! \leavevmode ! \hbox to 1.5em{% ! \hskip 0pt plus 0.25fil minus 0.25fil ! .\hss.\hss.% ! \hskip 0pt plus 0.5fil minus 0.5fil ! }% ! } ! ! % @enddots{} is an end-of-sentence ellipsis. ! % ! \def\enddots{% ! \leavevmode ! \hbox to 2em{% ! \hskip 0pt plus 0.25fil minus 0.25fil ! .\hss.\hss.\hss.% ! \hskip 0pt plus 0.5fil minus 0.5fil ! }% ! \spacefactor=3000 ! } % @page forces the start of a new page ! % \def\page{\par\vfill\supereject} *************** *** 627,1017 **** % @ignore ... @end ignore is another way to write a comment ! \def\comment{\catcode 64=\other \catcode 123=\other \catcode 125=\other% ! \parsearg \commentxxx} ! ! \def\commentxxx #1{\catcode 64=0 \catcode 123=1 \catcode 125=2 } \let\c=\comment ! % @paragraphindent is defined for the Info formatting commands only. ! \let\paragraphindent=\comment ! ! % Prevent errors for section commands. ! % Used in @ignore and in failing conditionals. ! \def\ignoresections{% ! \let\chapter=\relax ! \let\unnumbered=\relax ! \let\top=\relax ! \let\unnumberedsec=\relax ! \let\unnumberedsection=\relax ! \let\unnumberedsubsec=\relax ! \let\unnumberedsubsection=\relax ! \let\unnumberedsubsubsec=\relax ! \let\unnumberedsubsubsection=\relax ! \let\section=\relax ! \let\subsec=\relax ! \let\subsubsec=\relax ! \let\subsection=\relax ! \let\subsubsection=\relax ! \let\appendix=\relax ! \let\appendixsec=\relax ! \let\appendixsection=\relax ! \let\appendixsubsec=\relax ! \let\appendixsubsection=\relax ! \let\appendixsubsubsec=\relax ! \let\appendixsubsubsection=\relax ! \let\contents=\relax ! \let\smallbook=\relax ! \let\titlepage=\relax } ! % Used in nested conditionals, where we have to parse the Texinfo source ! % and so want to turn off most commands, in case they are used ! % incorrectly. ! % ! \def\ignoremorecommands{% ! \let\defcodeindex = \relax ! \let\defcv = \relax ! \let\deffn = \relax ! \let\deffnx = \relax ! \let\defindex = \relax ! \let\defivar = \relax ! \let\defmac = \relax ! \let\defmethod = \relax ! \let\defop = \relax ! \let\defopt = \relax ! \let\defspec = \relax ! \let\deftp = \relax ! \let\deftypefn = \relax ! \let\deftypefun = \relax ! \let\deftypevar = \relax ! \let\deftypevr = \relax ! \let\defun = \relax ! \let\defvar = \relax ! \let\defvr = \relax ! \let\ref = \relax ! \let\xref = \relax ! \let\printindex = \relax ! \let\pxref = \relax ! \let\settitle = \relax ! \let\setchapternewpage = \relax ! \let\setchapterstyle = \relax ! \let\everyheading = \relax ! \let\evenheading = \relax ! \let\oddheading = \relax ! \let\everyfooting = \relax ! \let\evenfooting = \relax ! \let\oddfooting = \relax ! \let\headings = \relax ! \let\include = \relax ! \let\lowersections = \relax ! \let\down = \relax ! \let\raisesections = \relax ! \let\up = \relax ! \let\set = \relax ! \let\clear = \relax ! \let\item = \relax } ! % Ignore @ignore ... @end ignore. % ! \def\ignore{\doignore{ignore}} ! % Also ignore @ifinfo, @ifhtml, @html, @menu, and @direntry text. % ! \def\ifinfo{\doignore{ifinfo}} ! \def\ifhtml{\doignore{ifhtml}} ! \def\html{\doignore{html}} ! \def\menu{\doignore{menu}} ! \def\direntry{\doignore{direntry}} ! ! % Also ignore @macro ... @end macro. The user must run texi2dvi, ! % which runs makeinfo to do macro expansion. Ignore @unmacro, too. ! \def\macro{\doignore{macro}} ! \let\unmacro = \comment ! % @dircategory CATEGORY -- specify a category of the dir file ! % which this file should belong to. Ignore this in TeX. ! \let\dircategory = \comment ! % Ignore text until a line `@end #1'. % ! \def\doignore#1{\begingroup ! % Don't complain about control sequences we have declared \outer. ! \ignoresections ! % ! % Define a command to swallow text until we reach `@end #1'. ! \long\def\doignoretext##1\end #1{\enddoignore}% ! % ! % Make sure that spaces turn into tokens that match what \doignoretext wants. ! \catcode32 = 10 ! % ! % And now expand that command. ! \doignoretext } ! % What we do to finish off ignored text. % ! \def\enddoignore{\endgroup\ignorespaces}% ! \newif\ifwarnedobs\warnedobsfalse ! \def\obstexwarn{% ! \ifwarnedobs\relax\else ! % We need to warn folks that they may have trouble with TeX 3.0. ! % This uses \immediate\write16 rather than \message to get newlines. ! \immediate\write16{} ! \immediate\write16{***WARNING*** for users of Unix TeX 3.0!} ! \immediate\write16{This manual trips a bug in TeX version 3.0 (tex hangs).} ! \immediate\write16{If you are running another version of TeX, relax.} ! \immediate\write16{If you are running Unix TeX 3.0, kill this TeX process.} ! \immediate\write16{ Then upgrade your TeX installation if you can.} ! \immediate\write16{ (See ftp://ftp.gnu.ai.mit.edu/pub/gnu/TeX.README.)} ! \immediate\write16{If you are stuck with version 3.0, run the} ! \immediate\write16{ script ``tex3patch'' from the Texinfo distribution} ! \immediate\write16{ to use a workaround.} ! \immediate\write16{} ! \global\warnedobstrue \fi ! } ! ! % **In TeX 3.0, setting text in \nullfont hangs tex. For a ! % workaround (which requires the file ``dummy.tfm'' to be installed), ! % uncomment the following line: ! %%%%%\font\nullfont=dummy\let\obstexwarn=\relax ! ! % Ignore text, except that we keep track of conditional commands for ! % purposes of nesting, up to an `@end #1' command. ! % ! \def\nestedignore#1{% ! \obstexwarn ! % We must actually expand the ignored text to look for the @end ! % command, so that nested ignore constructs work. Thus, we put the ! % text into a \vbox and then do nothing with the result. To minimize ! % the change of memory overflow, we follow the approach outlined on ! % page 401 of the TeXbook: make the current font be a dummy font. ! % ! \setbox0 = \vbox\bgroup ! % Don't complain about control sequences we have declared \outer. ! \ignoresections ! % ! % Define `@end #1' to end the box, which will in turn undefine the ! % @end command again. ! \expandafter\def\csname E#1\endcsname{\egroup\ignorespaces}% ! % ! % We are going to be parsing Texinfo commands. Most cause no ! % trouble when they are used incorrectly, but some commands do ! % complicated argument parsing or otherwise get confused, so we ! % undefine them. ! % ! % We can't do anything about stray @-signs, unfortunately; ! % they'll produce `undefined control sequence' errors. ! \ignoremorecommands ! % ! % Set the current font to be \nullfont, a TeX primitive, and define ! % all the font commands to also use \nullfont. We don't use ! % dummy.tfm, as suggested in the TeXbook, because not all sites ! % might have that installed. Therefore, math mode will still ! % produce output, but that should be an extremely small amount of ! % stuff compared to the main input. ! % ! \nullfont ! \let\tenrm = \nullfont \let\tenit = \nullfont \let\tensl = \nullfont ! \let\tenbf = \nullfont \let\tentt = \nullfont \let\smallcaps = \nullfont ! \let\tensf = \nullfont ! % Similarly for index fonts (mostly for their use in ! % smallexample) ! \let\indrm = \nullfont \let\indit = \nullfont \let\indsl = \nullfont ! \let\indbf = \nullfont \let\indtt = \nullfont \let\indsc = \nullfont ! \let\indsf = \nullfont ! % ! % Don't complain when characters are missing from the fonts. ! \tracinglostchars = 0 ! % ! % Don't bother to do space factor calculations. ! \frenchspacing ! % ! % Don't report underfull hboxes. ! \hbadness = 10000 ! % ! % Do minimal line-breaking. ! \pretolerance = 10000 ! % ! % Do not execute instructions in @tex ! \def\tex{\doignore{tex}} ! } ! ! % @set VAR sets the variable VAR to an empty value. ! % @set VAR REST-OF-LINE sets VAR to the value REST-OF-LINE. ! % ! % Since we want to separate VAR from REST-OF-LINE (which might be ! % empty), we can't just use \parsearg; we have to insert a space of our ! % own to delimit the rest of the line, and then take it out again if we ! % didn't need it. Make sure the catcode of space is correct to avoid ! % losing inside @example, for instance. ! % ! \def\set{\begingroup\catcode` =10 \parsearg\setxxx} ! \def\setxxx#1{\setyyy#1 \endsetyyy} ! \def\setyyy#1 #2\endsetyyy{% ! \def\temp{#2}% ! \ifx\temp\empty \global\expandafter\let\csname SET#1\endcsname = \empty ! \else \setzzz{#1}#2\endsetzzz % Remove the trailing space \setxxx inserted. ! \fi ! \endgroup ! } ! % Can't use \xdef to pre-expand #2 and save some time, since \temp or ! % \next or other control sequences that we've defined might get us into ! % an infinite loop. Consider `@set foo @cite{bar}'. ! \def\setzzz#1#2 \endsetzzz{\expandafter\gdef\csname SET#1\endcsname{#2}} ! ! % @clear VAR clears (i.e., unsets) the variable VAR. ! % ! \def\clear{\parsearg\clearxxx} ! \def\clearxxx#1{\global\expandafter\let\csname SET#1\endcsname=\relax} ! ! % @value{foo} gets the text saved in variable foo. ! % ! \def\value#1{\expandafter ! \ifx\csname SET#1\endcsname\relax ! {\{No value for ``#1''\}} ! \else \csname SET#1\endcsname \fi} ! ! % @ifset VAR ... @end ifset reads the `...' iff VAR has been defined ! % with @set. ! % ! \def\ifset{\parsearg\ifsetxxx} ! \def\ifsetxxx #1{% ! \expandafter\ifx\csname SET#1\endcsname\relax ! \expandafter\ifsetfail ! \else ! \expandafter\ifsetsucceed ! \fi ! } ! \def\ifsetsucceed{\conditionalsucceed{ifset}} ! \def\ifsetfail{\nestedignore{ifset}} ! \defineunmatchedend{ifset} ! ! % @ifclear VAR ... @end ifclear reads the `...' iff VAR has never been ! % defined with @set, or has been undefined with @clear. ! % ! \def\ifclear{\parsearg\ifclearxxx} ! \def\ifclearxxx #1{% ! \expandafter\ifx\csname SET#1\endcsname\relax ! \expandafter\ifclearsucceed ! \else ! \expandafter\ifclearfail ! \fi ! } ! \def\ifclearsucceed{\conditionalsucceed{ifclear}} ! \def\ifclearfail{\nestedignore{ifclear}} ! \defineunmatchedend{ifclear} ! ! % @iftex always succeeds; we read the text following, through @end ! % iftex). But `@end iftex' should be valid only after an @iftex. ! % ! \def\iftex{\conditionalsucceed{iftex}} ! \defineunmatchedend{iftex} ! ! % We can't just want to start a group at @iftex (for example) and end it ! % at @end iftex, since then @set commands inside the conditional have no ! % effect (they'd get reverted at the end of the group). So we must ! % define \Eiftex to redefine itself to be its previous value. (We can't ! % just define it to fail again with an ``unmatched end'' error, since ! % the @ifset might be nested.) ! % ! \def\conditionalsucceed#1{% ! \edef\temp{% ! % Remember the current value of \E#1. ! \let\nece{prevE#1} = \nece{E#1}% ! % ! % At the `@end #1', redefine \E#1 to be its previous value. ! \def\nece{E#1}{\let\nece{E#1} = \nece{prevE#1}}% ! }% ! \temp ! } ! ! % We need to expand lots of \csname's, but we don't want to expand the ! % control sequences after we've constructed them. ! % ! \def\nece#1{\expandafter\noexpand\csname#1\endcsname} ! ! % @asis just yields its argument. Used with @table, for example. ! % ! \def\asis#1{#1} ! ! % @math means output in math mode. ! % We don't use $'s directly in the definition of \math because control ! % sequences like \math are expanded when the toc file is written. Then, ! % we read the toc file back, the $'s will be normal characters (as they ! % should be, according to the definition of Texinfo). So we must use a ! % control sequence to switch into and out of math mode. ! % ! % This isn't quite enough for @math to work properly in indices, but it ! % seems unlikely it will ever be needed there. ! % ! \let\implicitmath = $ ! \def\math#1{\implicitmath #1\implicitmath} ! ! % @bullet and @minus need the same treatment as @math, just above. ! \def\bullet{\implicitmath\ptexbullet\implicitmath} ! \def\minus{\implicitmath-\implicitmath} ! ! \def\node{\ENVcheck\parsearg\nodezzz} ! \def\nodezzz#1{\nodexxx [#1,]} ! \def\nodexxx[#1,#2]{\gdef\lastnode{#1}} ! \let\nwnode=\node ! \let\lastnode=\relax ! ! \def\donoderef{\ifx\lastnode\relax\else ! \expandafter\expandafter\expandafter\setref{\lastnode}\fi ! \global\let\lastnode=\relax} ! ! \def\unnumbnoderef{\ifx\lastnode\relax\else ! \expandafter\expandafter\expandafter\unnumbsetref{\lastnode}\fi ! \global\let\lastnode=\relax} ! ! \def\appendixnoderef{\ifx\lastnode\relax\else ! \expandafter\expandafter\expandafter\appendixsetref{\lastnode}\fi ! \global\let\lastnode=\relax} ! ! % @refill is a no-op. ! \let\refill=\relax ! ! % @setfilename is done at the beginning of every texinfo file. ! % So open here the files we need to have open while reading the input. ! % This makes it possible to make a .fmt file for texinfo. ! \def\setfilename{% ! \readauxfile ! \opencontents ! \openindices ! \fixbackslash % Turn off hack to swallow `\input texinfo'. ! \global\let\setfilename=\comment % Ignore extra @setfilename cmds. ! \comment % Ignore the actual filename. ! } ! ! % @bye. ! \outer\def\bye{\pagealignmacro\tracingstats=1\ptexend} ! ! % \def\macro#1{\begingroup\ignoresections\catcode`\#=6\def\macrotemp{#1}\parsearg\macroxxx} ! % \def\macroxxx#1#2 \end macro{% ! % \expandafter\gdef\macrotemp#1{#2}% ! % \endgroup} ! ! %\def\linemacro#1{\begingroup\ignoresections\catcode`\#=6\def\macrotemp{#1}\parsearg\linemacroxxx} ! %\def\linemacroxxx#1#2 \end linemacro{% ! %\let\parsearg=\relax ! %\edef\macrotempx{\csname M\butfirst\expandafter\string\macrotemp\endcsname}% ! %\expandafter\xdef\macrotemp{\parsearg\macrotempx}% ! %\expandafter\gdef\macrotempx#1{#2}% ! %\endgroup} ! ! %\def\butfirst#1{} \message{fonts,} - % Font-change commands. ! % Texinfo supports the sans serif font style, which plain TeX does not. % So we set up a \sf analogous to plain's \rm, etc. \newfam\sffam --- 736,1028 ---- % @ignore ... @end ignore is another way to write a comment ! \def\comment{\begingroup \catcode`\^^M=\other% ! \catcode`\@=\other \catcode`\{=\other \catcode`\}=\other% ! \commentxxx} ! {\catcode`\^^M=\other \gdef\commentxxx#1^^M{\endgroup}} \let\c=\comment ! % @paragraphindent NCHARS ! % We'll use ems for NCHARS, close enough. ! % We cannot implement @paragraphindent asis, though. ! % ! \def\asisword{asis} % no translation, these are keywords ! \def\noneword{none} ! % ! \def\paragraphindent{\parsearg\doparagraphindent} ! \def\doparagraphindent#1{% ! \def\temp{#1}% ! \ifx\temp\asisword ! \else ! \ifx\temp\noneword ! \defaultparindent = 0pt ! \else ! \defaultparindent = #1em ! \fi ! \fi ! \parindent = \defaultparindent } ! % @exampleindent NCHARS ! % We'll use ems for NCHARS like @paragraphindent. ! % It seems @exampleindent asis isn't necessary, but ! % I preserve it to make it similar to @paragraphindent. ! \def\exampleindent{\parsearg\doexampleindent} ! \def\doexampleindent#1{% ! \def\temp{#1}% ! \ifx\temp\asisword ! \else ! \ifx\temp\noneword ! \lispnarrowing = 0pt ! \else ! \lispnarrowing = #1em ! \fi ! \fi } ! % @asis just yields its argument. Used with @table, for example. % ! \def\asis#1{#1} ! % @math means output in math mode. ! % We don't use $'s directly in the definition of \math because control ! % sequences like \math are expanded when the toc file is written. Then, ! % we read the toc file back, the $'s will be normal characters (as they ! % should be, according to the definition of Texinfo). So we must use a ! % control sequence to switch into and out of math mode. % ! % This isn't quite enough for @math to work properly in indices, but it ! % seems unlikely it will ever be needed there. ! % ! \let\implicitmath = $ ! \def\math#1{\implicitmath #1\implicitmath} + % @bullet and @minus need the same treatment as @math, just above. + \def\bullet{\implicitmath\ptexbullet\implicitmath} + \def\minus{\implicitmath-\implicitmath} ! % @refill is a no-op. ! \let\refill=\relax ! % If working on a large document in chapters, it is convenient to ! % be able to disable indexing, cross-referencing, and contents, for test runs. ! % This is done with @novalidate (before @setfilename). % ! \newif\iflinks \linkstrue % by default we want the aux files. ! \let\novalidate = \linksfalse ! ! % @setfilename is done at the beginning of every texinfo file. ! % So open here the files we need to have open while reading the input. ! % This makes it possible to make a .fmt file for texinfo. ! \def\setfilename{% ! \iflinks ! \readauxfile ! \fi % \openindices needs to do some work in any case. ! \openindices ! \fixbackslash % Turn off hack to swallow `\input texinfo'. ! \global\let\setfilename=\comment % Ignore extra @setfilename cmds. ! % ! % If texinfo.cnf is present on the system, read it. ! % Useful for site-wide @afourpaper, etc. ! % Just to be on the safe side, close the input stream before the \input. ! \openin 1 texinfo.cnf ! \ifeof1 \let\temp=\relax \else \def\temp{\input texinfo.cnf }\fi ! \closein1 ! \temp ! % ! \comment % Ignore the actual filename. } ! % Called from \setfilename. % ! \def\openindices{% ! \newindex{cp}% ! \newcodeindex{fn}% ! \newcodeindex{vr}% ! \newcodeindex{tp}% ! \newcodeindex{ky}% ! \newcodeindex{pg}% ! } ! % @bye. ! \outer\def\bye{\pagealignmacro\tracingstats=1\ptexend} ! ! ! \message{pdf,} ! % adobe `portable' document format ! \newcount\tempnum ! \newcount\lnkcount ! \newtoks\filename ! \newcount\filenamelength ! \newcount\pgn ! \newtoks\toksA ! \newtoks\toksB ! \newtoks\toksC ! \newtoks\toksD ! \newbox\boxA ! \newcount\countA ! \newif\ifpdf ! \newif\ifpdfmakepagedest ! ! \ifx\pdfoutput\undefined ! \pdffalse ! \let\pdfmkdest = \gobble ! \let\pdfurl = \gobble ! \let\endlink = \relax ! \let\linkcolor = \relax ! \let\pdfmakeoutlines = \relax ! \else ! \pdftrue ! \pdfoutput = 1 ! \input pdfcolor ! \def\dopdfimage#1#2#3{% ! \def\imagewidth{#2}% ! \def\imageheight{#3}% ! \ifnum\pdftexversion < 14 ! \pdfimage ! \else ! \pdfximage \fi ! \ifx\empty\imagewidth\else width \imagewidth \fi ! \ifx\empty\imageheight\else height \imageheight \fi ! {#1.pdf}% ! \ifnum\pdftexversion < 14 \else ! \pdfrefximage \pdflastximage ! \fi} ! \def\pdfmkdest#1{\pdfdest name{#1@} xyz} ! \def\pdfmkpgn#1{#1@} ! \let\linkcolor = \Cyan ! \def\endlink{\Black\pdfendlink} ! % Adding outlines to PDF; macros for calculating structure of outlines ! % come from Petr Olsak ! \def\expnumber#1{\expandafter\ifx\csname#1\endcsname\relax 0% ! \else \csname#1\endcsname \fi} ! \def\advancenumber#1{\tempnum=\expnumber{#1}\relax ! \advance\tempnum by1 ! \expandafter\xdef\csname#1\endcsname{\the\tempnum}} ! \def\pdfmakeoutlines{{% ! \openin 1 \jobname.toc ! \ifeof 1\else\bgroup ! \closein 1 ! \indexnofonts ! \def\tt{} ! % thanh's hack / proper braces in bookmarks ! \edef\mylbrace{\iftrue \string{\else}\fi}\let\{=\mylbrace ! \edef\myrbrace{\iffalse{\else\string}\fi}\let\}=\myrbrace ! % ! \def\chapentry ##1##2##3{} ! \def\unnumbchapentry ##1##2{} ! \def\secentry ##1##2##3##4{\advancenumber{chap##2}} ! \def\unnumbsecentry ##1##2{} ! \def\subsecentry ##1##2##3##4##5{\advancenumber{sec##2.##3}} ! \def\unnumbsubsecentry ##1##2{} ! \def\subsubsecentry ##1##2##3##4##5##6{\advancenumber{subsec##2.##3.##4}} ! \def\unnumbsubsubsecentry ##1##2{} ! \input \jobname.toc ! \def\chapentry ##1##2##3{% ! \pdfoutline goto name{\pdfmkpgn{##3}}count-\expnumber{chap##2}{##1}} ! \def\unnumbchapentry ##1##2{% ! \pdfoutline goto name{\pdfmkpgn{##2}}{##1}} ! \def\secentry ##1##2##3##4{% ! \pdfoutline goto name{\pdfmkpgn{##4}}count-\expnumber{sec##2.##3}{##1}} ! \def\unnumbsecentry ##1##2{% ! \pdfoutline goto name{\pdfmkpgn{##2}}{##1}} ! \def\subsecentry ##1##2##3##4##5{% ! \pdfoutline goto name{\pdfmkpgn{##5}}count-\expnumber{subsec##2.##3.##4}{##1}} ! \def\unnumbsubsecentry ##1##2{% ! \pdfoutline goto name{\pdfmkpgn{##2}}{##1}} ! \def\subsubsecentry ##1##2##3##4##5##6{% ! \pdfoutline goto name{\pdfmkpgn{##6}}{##1}} ! \def\unnumbsubsubsecentry ##1##2{% ! \pdfoutline goto name{\pdfmkpgn{##2}}{##1}} ! \input \jobname.toc ! \egroup\fi ! }} ! \def\makelinks #1,{% ! \def\params{#1}\def\E{END}% ! \ifx\params\E ! \let\nextmakelinks=\relax ! \else ! \let\nextmakelinks=\makelinks ! \ifnum\lnkcount>0,\fi ! \picknum{#1}% ! \startlink attr{/Border [0 0 0]} ! goto name{\pdfmkpgn{\the\pgn}}% ! \linkcolor #1% ! \advance\lnkcount by 1% ! \endlink ! \fi ! \nextmakelinks ! } ! \def\picknum#1{\expandafter\pn#1} ! \def\pn#1{% ! \def\p{#1}% ! \ifx\p\lbrace ! \let\nextpn=\ppn ! \else ! \let\nextpn=\ppnn ! \def\first{#1} ! \fi ! \nextpn ! } ! \def\ppn#1{\pgn=#1\gobble} ! \def\ppnn{\pgn=\first} ! \def\pdfmklnk#1{\lnkcount=0\makelinks #1,END,} ! \def\addtokens#1#2{\edef\addtoks{\noexpand#1={\the#1#2}}\addtoks} ! \def\skipspaces#1{\def\PP{#1}\def\D{|}% ! \ifx\PP\D\let\nextsp\relax ! \else\let\nextsp\skipspaces ! \ifx\p\space\else\addtokens{\filename}{\PP}% ! \advance\filenamelength by 1 ! \fi ! \fi ! \nextsp} ! \def\getfilename#1{\filenamelength=0\expandafter\skipspaces#1|\relax} ! \ifnum\pdftexversion < 14 ! \let \startlink \pdfannotlink ! \else ! \let \startlink \pdfstartlink ! \fi ! \def\pdfurl#1{% ! \begingroup ! \normalturnoffactive\def\@{@}% ! \leavevmode\Red ! \startlink attr{/Border [0 0 0]}% ! user{/Subtype /Link /A << /S /URI /URI (#1) >>}% ! % #1 ! \endgroup} ! \def\pdfgettoks#1.{\setbox\boxA=\hbox{\toksA={#1.}\toksB={}\maketoks}} ! \def\addtokens#1#2{\edef\addtoks{\noexpand#1={\the#1#2}}\addtoks} ! \def\adn#1{\addtokens{\toksC}{#1}\global\countA=1\let\next=\maketoks} ! \def\poptoks#1#2|ENDTOKS|{\let\first=#1\toksD={#1}\toksA={#2}} ! \def\maketoks{% ! \expandafter\poptoks\the\toksA|ENDTOKS| ! \ifx\first0\adn0 ! \else\ifx\first1\adn1 \else\ifx\first2\adn2 \else\ifx\first3\adn3 ! \else\ifx\first4\adn4 \else\ifx\first5\adn5 \else\ifx\first6\adn6 ! \else\ifx\first7\adn7 \else\ifx\first8\adn8 \else\ifx\first9\adn9 ! \else ! \ifnum0=\countA\else\makelink\fi ! \ifx\first.\let\next=\done\else ! \let\next=\maketoks ! \addtokens{\toksB}{\the\toksD} ! \ifx\first,\addtokens{\toksB}{\space}\fi ! \fi ! \fi\fi\fi\fi\fi\fi\fi\fi\fi\fi ! \next} ! \def\makelink{\addtokens{\toksB}% ! {\noexpand\pdflink{\the\toksC}}\toksC={}\global\countA=0} ! \def\pdflink#1{% ! \startlink attr{/Border [0 0 0]} goto name{\mkpgn{#1}} ! \linkcolor #1\endlink} ! \def\mkpgn#1{#1@} ! \def\done{\edef\st{\global\noexpand\toksA={\the\toksB}}\st} ! \fi % \ifx\pdfoutput \message{fonts,} % Font-change commands. ! % Texinfo sort of supports the sans serif font style, which plain TeX does not. % So we set up a \sf analogous to plain's \rm, etc. \newfam\sffam *************** *** 1022,1027 **** \def\ttsl{\tenttsl} ! %% Try out Computer Modern fonts at \magstephalf ! \let\mainmagstep=\magstephalf % Set the font macro #1 to the font named #2, adding on the --- 1033,1039 ---- \def\ttsl{\tenttsl} ! % Use Computer Modern fonts at \magstephalf (11pt). ! \newcount\mainmagstep ! \mainmagstep=\magstephalf % Set the font macro #1 to the font named #2, adding on the *************** *** 1078,1097 **** \def\df{\let\tentt=\deftt \let\tenbf = \defbf \bf} ! % Fonts for indices and small examples (9pt). ! % We actually use the slanted font rather than the italic, ! % because texinfo normally uses the slanted fonts for that. ! % Do not make many font distinctions in general in the index, since they ! % aren't very useful. ! \setfont\ninett\ttshape{9}{1000} ! \setfont\indrm\rmshape{9}{1000} ! \setfont\indit\slshape{9}{1000} ! \let\indsl=\indit ! \let\indtt=\ninett ! \let\indttsl=\ninett ! \let\indsf=\indrm ! \let\indbf=\indrm ! \setfont\indsc\scshape{10}{900} ! \font\indi=cmmi9 ! \font\indsy=cmsy9 % Chapter (and unnumbered) fonts (17.28pt). --- 1090,1117 ---- \def\df{\let\tentt=\deftt \let\tenbf = \defbf \bf} ! % Fonts for indices, footnotes, small examples (9pt). ! \setfont\smallrm\rmshape{9}{1000} ! \setfont\smalltt\ttshape{9}{1000} ! \setfont\smallbf\bfshape{10}{900} ! \setfont\smallit\itshape{9}{1000} ! \setfont\smallsl\slshape{9}{1000} ! \setfont\smallsf\sfshape{9}{1000} ! \setfont\smallsc\scshape{10}{900} ! \setfont\smallttsl\ttslshape{10}{900} ! \font\smalli=cmmi9 ! \font\smallsy=cmsy9 ! ! % Fonts for title page: ! \setfont\titlerm\rmbshape{12}{\magstep3} ! \setfont\titleit\itbshape{10}{\magstep4} ! \setfont\titlesl\slbshape{10}{\magstep4} ! \setfont\titlett\ttbshape{12}{\magstep3} ! \setfont\titlettsl\ttslshape{10}{\magstep4} ! \setfont\titlesf\sfbshape{17}{\magstep1} ! \let\titlebf=\titlerm ! \setfont\titlesc\scbshape{10}{\magstep4} ! \font\titlei=cmmi12 scaled \magstep3 ! \font\titlesy=cmsy10 scaled \magstep4 ! \def\authorrm{\secrm} % Chapter (and unnumbered) fonts (17.28pt). *************** *** 1101,1105 **** \setfont\chaptt\ttbshape{12}{\magstep2} \setfont\chapttsl\ttslshape{10}{\magstep3} ! \setfont\chapsf\sfbshape{12}{\magstep2} \let\chapbf=\chaprm \setfont\chapsc\scbshape{10}{\magstep3} --- 1121,1125 ---- \setfont\chaptt\ttbshape{12}{\magstep2} \setfont\chapttsl\ttslshape{10}{\magstep3} ! \setfont\chapsf\sfbshape{17}{1000} \let\chapbf=\chaprm \setfont\chapsc\scbshape{10}{\magstep3} *************** *** 1138,1154 **** \setfont\ssecsl\slbshape{10}{1315} \setfont\ssectt\ttbshape{12}{\magstephalf} ! \setfont\ssecttsl\ttslshape{10}{\magstep1} \setfont\ssecsf\sfbshape{12}{\magstephalf} \let\ssecbf\ssecrm \setfont\ssecsc\scbshape{10}{\magstep1} \font\sseci=cmmi12 scaled \magstephalf ! \font\ssecsy=cmsy10 scaled \magstep1 % The smallcaps and symbol fonts should actually be scaled \magstep1.5, % but that is not a standard magnification. - % Fonts for title page: - \setfont\titlerm\rmbshape{12}{\magstep3} - \let\authorrm = \secrm - % In order for the font changes to affect most math symbols and letters, % we have to define the \textfont of the standard families. Since --- 1158,1170 ---- \setfont\ssecsl\slbshape{10}{1315} \setfont\ssectt\ttbshape{12}{\magstephalf} ! \setfont\ssecttsl\ttslshape{10}{1315} \setfont\ssecsf\sfbshape{12}{\magstephalf} \let\ssecbf\ssecrm \setfont\ssecsc\scbshape{10}{\magstep1} \font\sseci=cmmi12 scaled \magstephalf ! \font\ssecsy=cmsy10 scaled 1315 % The smallcaps and symbol fonts should actually be scaled \magstep1.5, % but that is not a standard magnification. % In order for the font changes to affect most math symbols and letters, % we have to define the \textfont of the standard families. Since *************** *** 1175,1178 **** --- 1191,1201 ---- \let\tensf=\textsf \let\teni=\texti \let\tensy=\textsy \let\tenttsl=\textttsl \resetmathfonts} + \def\titlefonts{% + \let\tenrm=\titlerm \let\tenit=\titleit \let\tensl=\titlesl + \let\tenbf=\titlebf \let\tentt=\titlett \let\smallcaps=\titlesc + \let\tensf=\titlesf \let\teni=\titlei \let\tensy=\titlesy + \let\tenttsl=\titlettsl + \resetmathfonts \setleading{25pt}} + \def\titlefont#1{{\titlefonts\rm #1}} \def\chapfonts{% \let\tenrm=\chaprm \let\tenit=\chapit \let\tensl=\chapsl *************** *** 1191,1199 **** \resetmathfonts \setleading{15pt}} \let\subsubsecfonts = \subsecfonts % Maybe make sssec fonts scaled magstephalf? ! \def\indexfonts{% ! \let\tenrm=\indrm \let\tenit=\indit \let\tensl=\indsl ! \let\tenbf=\indbf \let\tentt=\indtt \let\smallcaps=\indsc ! \let\tensf=\indsf \let\teni=\indi \let\tensy=\indsy \let\tenttsl=\indttsl ! \resetmathfonts \setleading{12pt}} % Set up the default fonts, so we can use them for creating boxes. --- 1214,1223 ---- \resetmathfonts \setleading{15pt}} \let\subsubsecfonts = \subsecfonts % Maybe make sssec fonts scaled magstephalf? ! \def\smallfonts{% ! \let\tenrm=\smallrm \let\tenit=\smallit \let\tensl=\smallsl ! \let\tenbf=\smallbf \let\tentt=\smalltt \let\smallcaps=\smallsc ! \let\tensf=\smallsf \let\teni=\smalli \let\tensy=\smallsy ! \let\tenttsl=\smallttsl ! \resetmathfonts \setleading{11pt}} % Set up the default fonts, so we can use them for creating boxes. *************** *** 1201,1204 **** --- 1225,1232 ---- \textfonts + % Define these so they can be easily changed for other fonts. + \def\angleleft{$\langle$} + \def\angleright{$\rangle$} + % Count depth in font-changes, for error checks \newcount\fontdepth \fontdepth=0 *************** *** 1215,1225 **** % unless the following character is such as not to need one. \def\smartitalicx{\ifx\next,\else\ifx\next-\else\ifx\next.\else\/\fi\fi\fi} ! \def\smartitalic#1{{\sl #1}\futurelet\next\smartitalicx} \let\i=\smartitalic ! \let\var=\smartitalic ! \let\dfn=\smartitalic \let\emph=\smartitalic ! \let\cite=\smartitalic \def\b#1{{\bf #1}} --- 1243,1254 ---- % unless the following character is such as not to need one. \def\smartitalicx{\ifx\next,\else\ifx\next-\else\ifx\next.\else\/\fi\fi\fi} ! \def\smartslanted#1{{\sl #1}\futurelet\next\smartitalicx} ! \def\smartitalic#1{{\it #1}\futurelet\next\smartitalicx} \let\i=\smartitalic ! \let\var=\smartslanted ! \let\dfn=\smartslanted \let\emph=\smartitalic ! \let\cite=\smartslanted \def\b#1{{\bf #1}} *************** *** 1238,1257 **** } \let\ttfont=\t ! \def\samp #1{`\tclose{#1}'\null} ! \setfont\smallrm\rmshape{8}{1000} ! \font\smallsy=cmsy9 ! \def\key#1{{\smallrm\textfont2=\smallsy \leavevmode\hbox{% ! \raise0.4pt\hbox{$\langle$}\kern-.08em\vtop{% \vbox{\hrule\kern-0.4pt ! \hbox{\raise0.4pt\hbox{\vphantom{$\langle$}}#1}}% \kern-0.4pt\hrule}% ! \kern-.06em\raise0.4pt\hbox{$\rangle$}}}} % The old definition, with no lozenge: %\def\key #1{{\ttsl \nohyphenation \uppercase{#1}}\null} \def\ctrl #1{{\tt \rawbackslash \hat}#1} \let\file=\samp ! \let\url=\samp % perhaps include a hypertex \special eventually ! \def\email#1{$\langle${\tt #1}$\rangle$} % @code is a modification of @t, --- 1267,1286 ---- } \let\ttfont=\t ! \def\samp#1{`\tclose{#1}'\null} ! \setfont\keyrm\rmshape{8}{1000} ! \font\keysy=cmsy9 ! \def\key#1{{\keyrm\textfont2=\keysy \leavevmode\hbox{% ! \raise0.4pt\hbox{\angleleft}\kern-.08em\vtop{% \vbox{\hrule\kern-0.4pt ! \hbox{\raise0.4pt\hbox{\vphantom{\angleleft}}#1}}% \kern-0.4pt\hrule}% ! \kern-.06em\raise0.4pt\hbox{\angleright}}}} % The old definition, with no lozenge: %\def\key #1{{\ttsl \nohyphenation \uppercase{#1}}\null} \def\ctrl #1{{\tt \rawbackslash \hat}#1} + % @file, @option are the same as @samp. \let\file=\samp ! \let\option=\samp % @code is a modification of @t, *************** *** 1288,1305 **** % -- rms. { ! \catcode`\-=\active ! \catcode`\_=\active ! \global\def\code{\begingroup \catcode`\-=\active \let-\codedash \catcode`\_=\active \let_\codeunder \codex} ! % The following is used by \doprintindex to insure that long function names ! % wrap around. It is necessary for - and _ to be active before the index is ! % read from the file, as \entry parses the arguments long before \code is ! % ever called. -- mycroft ! \global\def\indexbreaks{\catcode`\-=\active \let-\realdash \catcode`\_=\active \let_\realunder} } \def\realdash{-} - \def\realunder{_} \def\codedash{-\discretionary{}{}{}} ! \def\codeunder{\normalunderscore\discretionary{}{}{}} \def\codex #1{\tclose{#1}\endgroup} --- 1317,1337 ---- % -- rms. { ! \catcode`\-=\active ! \catcode`\_=\active ! % ! \global\def\code{\begingroup ! \catcode`\-=\active \let-\codedash ! \catcode`\_=\active \let_\codeunder ! \codex ! } ! % ! % If we end up with any active - characters when handling the index, ! % just treat them as a normal -. ! \global\def\indexbreaks{\catcode`\-=\active \let-\realdash} } \def\realdash{-} \def\codedash{-\discretionary{}{}{}} ! \def\codeunder{\ifusingtt{\normalunderscore\discretionary{}{}{}}{\_}} \def\codex #1{\tclose{#1}\endgroup} *************** *** 1308,1317 **** % @kbd is like @code, except that if the argument is just one @key command, % then @kbd has no effect. ! % \def\xkey{\key} \def\kbdfoo#1#2#3\par{\def\one{#1}\def\three{#3}\def\threex{??}% \ifx\one\xkey\ifx\threex\three \key{#2}% ! \else{\tclose{\ttsl\look}}\fi ! \else{\tclose{\ttsl\look}}\fi} % Check if we are currently using a typewriter font. Since all the --- 1340,1421 ---- % @kbd is like @code, except that if the argument is just one @key command, % then @kbd has no effect. ! ! % @kbdinputstyle -- arg is `distinct' (@kbd uses slanted tty font always), ! % `example' (@kbd uses ttsl only inside of @example and friends), ! % or `code' (@kbd uses normal tty font always). ! \def\kbdinputstyle{\parsearg\kbdinputstylexxx} ! \def\kbdinputstylexxx#1{% ! \def\arg{#1}% ! \ifx\arg\worddistinct ! \gdef\kbdexamplefont{\ttsl}\gdef\kbdfont{\ttsl}% ! \else\ifx\arg\wordexample ! \gdef\kbdexamplefont{\ttsl}\gdef\kbdfont{\tt}% ! \else\ifx\arg\wordcode ! \gdef\kbdexamplefont{\tt}\gdef\kbdfont{\tt}% ! \fi\fi\fi ! } ! \def\worddistinct{distinct} ! \def\wordexample{example} ! \def\wordcode{code} ! ! % Default is kbdinputdistinct. (Too much of a hassle to call the macro, ! % the catcodes are wrong for parsearg to work.) ! \gdef\kbdexamplefont{\ttsl}\gdef\kbdfont{\ttsl} ! \def\xkey{\key} \def\kbdfoo#1#2#3\par{\def\one{#1}\def\three{#3}\def\threex{??}% \ifx\one\xkey\ifx\threex\three \key{#2}% ! \else{\tclose{\kbdfont\look}}\fi ! \else{\tclose{\kbdfont\look}}\fi} ! ! % For @url, @env, @command quotes seem unnecessary, so use \code. ! \let\url=\code ! \let\env=\code ! \let\command=\code ! ! % @uref (abbreviation for `urlref') takes an optional (comma-separated) ! % second argument specifying the text to display and an optional third ! % arg as text to display instead of (rather than in addition to) the url ! % itself. First (mandatory) arg is the url. Perhaps eventually put in ! % a hypertex \special here. ! % ! \def\uref#1{\douref #1,,,\finish} ! \def\douref#1,#2,#3,#4\finish{\begingroup ! \unsepspaces ! \pdfurl{#1}% ! \setbox0 = \hbox{\ignorespaces #3}% ! \ifdim\wd0 > 0pt ! \unhbox0 % third arg given, show only that ! \else ! \setbox0 = \hbox{\ignorespaces #2}% ! \ifdim\wd0 > 0pt ! \ifpdf ! \unhbox0 % PDF: 2nd arg given, show only it ! \else ! \unhbox0\ (\code{#1})% DVI: 2nd arg given, show both it and url ! \fi ! \else ! \code{#1}% only url given, so show it ! \fi ! \fi ! \endlink ! \endgroup} ! ! % rms does not like angle brackets --karl, 17may97. ! % So now @email is just like @uref, unless we are pdf. ! % ! %\def\email#1{\angleleft{\tt #1}\angleright} ! \ifpdf ! \def\email#1{\doemail#1,,\finish} ! \def\doemail#1,#2,#3\finish{\begingroup ! \unsepspaces ! \pdfurl{mailto:#1}% ! \setbox0 = \hbox{\ignorespaces #2}% ! \ifdim\wd0>0pt\unhbox0\else\code{#1}\fi ! \endlink ! \endgroup} ! \else ! \let\email=\uref ! \fi % Check if we are currently using a typewriter font. Since all the *************** *** 1319,1328 **** % shrink), and it is reasonable to expect all typewriter fonts to have % this property, we can check that font parameter. ! % \def\ifmonospace{\ifdim\fontdimen3\font=0pt } % Typeset a dimension, e.g., `in' or `pt'. The only reason for the ! % argument is to make the input look right: @dmn{pt} instead of ! % @dmn{}pt. % \def\dmn#1{\thinspace #1} --- 1423,1431 ---- % shrink), and it is reasonable to expect all typewriter fonts to have % this property, we can check that font parameter. ! % \def\ifmonospace{\ifdim\fontdimen3\font=0pt } % Typeset a dimension, e.g., `in' or `pt'. The only reason for the ! % argument is to make the input look right: @dmn{pt} instead of @dmn{}pt. % \def\dmn#1{\thinspace #1} *************** *** 1335,1343 **** %\def\l#1{{\li #1}\null} \def\r#1{{\rm #1}} % roman font - % Use of \lowercase was suggested. \def\sc#1{{\smallcaps#1}} % smallcaps font \def\ii#1{{\it #1}} % italic font % @pounds{} is a sterling sign. \def\pounds{{\it\$}} --- 1438,1449 ---- %\def\l#1{{\li #1}\null} + % Explicit font changes: @r, @sc, undocumented @ii. \def\r#1{{\rm #1}} % roman font \def\sc#1{{\smallcaps#1}} % smallcaps font \def\ii#1{{\it #1}} % italic font + % @acronym downcases the argument and prints in smallcaps. + \def\acronym#1{{\smallcaps \lowercase{#1}}} + % @pounds{} is a sterling sign. \def\pounds{{\it\$}} *************** *** 1350,1358 **** % First the title page. Must do @settitle before @titlepage. - \def\titlefont#1{{\titlerm #1}} - \newif\ifseenauthor \newif\iffinishedtitlepage \def\shorttitlepage{\parsearg\shorttitlepagezzz} \def\shorttitlepagezzz #1{\begingroup\hbox{}\vskip 1.5in \chaprm \centerline{#1}% --- 1456,1470 ---- % First the title page. Must do @settitle before @titlepage. \newif\ifseenauthor \newif\iffinishedtitlepage + % Do an implicit @contents or @shortcontents after @end titlepage if the + % user says @setcontentsaftertitlepage or @setshortcontentsaftertitlepage. + % + \newif\ifsetcontentsaftertitlepage + \let\setcontentsaftertitlepage = \setcontentsaftertitlepagetrue + \newif\ifsetshortcontentsaftertitlepage + \let\setshortcontentsaftertitlepage = \setshortcontentsaftertitlepagetrue + \def\shorttitlepage{\parsearg\shorttitlepagezzz} \def\shorttitlepagezzz #1{\begingroup\hbox{}\vskip 1.5in \chaprm \centerline{#1}% *************** *** 1361,1367 **** \def\titlepage{\begingroup \parindent=0pt \textfonts \let\subtitlerm=\tenrm - % I deinstalled the following change because \cmr12 is undefined. - % This change was not in the ChangeLog anyway. --rms. - % \let\subtitlerm=\cmr12 \def\subtitlefont{\subtitlerm \normalbaselineskip = 13pt \normalbaselines}% % --- 1473,1476 ---- *************** *** 1373,1377 **** % Now you can print the title using @title. \def\title{\parsearg\titlezzz}% ! \def\titlezzz##1{\leftline{\titlefont{##1}} % print a rule at the page bottom also. \finishedtitlepagefalse --- 1482,1486 ---- % Now you can print the title using @title. \def\title{\parsearg\titlezzz}% ! \def\titlezzz##1{\leftline{\titlefonts\rm ##1} % print a rule at the page bottom also. \finishedtitlepagefalse *************** *** 1412,1415 **** --- 1521,1541 ---- \oldpage \endgroup + % + % If they want short, they certainly want long too. + \ifsetshortcontentsaftertitlepage + \shortcontents + \contents + \global\let\shortcontents = \relax + \global\let\contents = \relax + \fi + % + \ifsetcontentsaftertitlepage + \contents + \global\let\contents = \relax + \global\let\shortcontents = \relax + \fi + % + \ifpdf \pdfmakepagedesttrue \fi + % \HEADINGSon } *************** *** 1425,1432 **** \let\thispage=\folio ! \newtoks \evenheadline % Token sequence for heading line of even pages ! \newtoks \oddheadline % Token sequence for heading line of odd pages ! \newtoks \evenfootline % Token sequence for footing line of even pages ! \newtoks \oddfootline % Token sequence for footing line of odd pages % Now make Tex use those variables --- 1551,1558 ---- \let\thispage=\folio ! \newtoks\evenheadline % headline on even pages ! \newtoks\oddheadline % headline on odd pages ! \newtoks\evenfootline % footline on even pages ! \newtoks\oddfootline % footline on odd pages % Now make Tex use those variables *************** *** 1462,1469 **** \global\oddheadline={\rlap{\centerline{#2}}\line{#1\hfil#3}}} ! \gdef\everyheadingxxx #1{\everyheadingyyy #1@|@|@|@|\finish} ! \gdef\everyheadingyyy #1@|#2@|#3@|#4\finish{% ! \global\evenheadline={\rlap{\centerline{#2}}\line{#1\hfil#3}} ! \global\oddheadline={\rlap{\centerline{#2}}\line{#1\hfil#3}}} \gdef\evenfootingxxx #1{\evenfootingyyy #1@|@|@|@|\finish} --- 1588,1592 ---- \global\oddheadline={\rlap{\centerline{#2}}\line{#1\hfil#3}}} ! \gdef\everyheadingxxx#1{\oddheadingxxx{#1}\evenheadingxxx{#1}}% \gdef\evenfootingxxx #1{\evenfootingyyy #1@|@|@|@|\finish} *************** *** 1473,1482 **** \gdef\oddfootingxxx #1{\oddfootingyyy #1@|@|@|@|\finish} \gdef\oddfootingyyy #1@|#2@|#3@|#4\finish{% ! \global\oddfootline={\rlap{\centerline{#2}}\line{#1\hfil#3}}} ! \gdef\everyfootingxxx #1{\everyfootingyyy #1@|@|@|@|\finish} ! \gdef\everyfootingyyy #1@|#2@|#3@|#4\finish{% ! \global\evenfootline={\rlap{\centerline{#2}}\line{#1\hfil#3}} ! \global\oddfootline={\rlap{\centerline{#2}}\line{#1\hfil#3}}} % }% unbind the catcode of @. --- 1596,1608 ---- \gdef\oddfootingxxx #1{\oddfootingyyy #1@|@|@|@|\finish} \gdef\oddfootingyyy #1@|#2@|#3@|#4\finish{% ! \global\oddfootline = {\rlap{\centerline{#2}}\line{#1\hfil#3}}% ! % ! % Leave some space for the footline. Hopefully ok to assume ! % @evenfooting will not be used by itself. ! \global\advance\pageheight by -\baselineskip ! \global\advance\vsize by -\baselineskip ! } ! \gdef\everyfootingxxx#1{\oddfootingxxx{#1}\evenfootingxxx{#1}} % }% unbind the catcode of @. *************** *** 1546,1565 **** % Subroutines used in generating headings % Produces Day Month Year style of output. ! \def\today{\number\day\space ! \ifcase\month\or ! January\or February\or March\or April\or May\or June\or ! July\or August\or September\or October\or November\or December\fi ! \space\number\year} ! ! % Use this if you want the Month Day, Year style of output. ! %\def\today{\ifcase\month\or ! %January\or February\or March\or April\or May\or June\or ! %July\or August\or September\or October\or November\or December\fi ! %\space\number\day, \number\year} ! ! % @settitle line... specifies the title of the document, for headings ! % It generates no output of its own ! \def\thistitle{No Title} \def\settitle{\parsearg\settitlezzz} \def\settitlezzz #1{\gdef\thistitle{#1}} --- 1672,1687 ---- % Subroutines used in generating headings % Produces Day Month Year style of output. ! \def\today{% ! \number\day\space ! \ifcase\month ! \or\putwordMJan\or\putwordMFeb\or\putwordMMar\or\putwordMApr ! \or\putwordMMay\or\putwordMJun\or\putwordMJul\or\putwordMAug ! \or\putwordMSep\or\putwordMOct\or\putwordMNov\or\putwordMDec ! \fi ! \space\number\year} ! % @settitle line... specifies the title of the document, for headings. ! % It generates no output of its own. ! \def\thistitle{\putwordNoTitle} \def\settitle{\parsearg\settitlezzz} \def\settitlezzz #1{\gdef\thistitle{#1}} *************** *** 1567,1582 **** \message{tables,} - - % @tabs -- simple alignment - - % These don't work. For one thing, \+ is defined as outer. - % So these macros cannot even be defined. - - %\def\tabs{\parsearg\tabszzz} - %\def\tabszzz #1{\settabs\+#1\cr} - %\def\tabline{\parsearg\tablinezzz} - %\def\tablinezzz #1{\+#1\cr} - %\def\&{&} - % Tables -- @table, @ftable, @vtable, @item(x), @kitem(x), @xitem(x). --- 1689,1692 ---- *************** *** 1622,1630 **** \nobreak % This prevents a break before @itemx. % - % Be sure we are not still in the middle of a paragraph. - %{\parskip = 0in - %\par - %}% - % % If the item text does not fit in the space we have, put it on a line % by itself, and do not allow a page break either before or after that --- 1732,1735 ---- *************** *** 1655,1665 **** \else % The item text fits into the space. Start a paragraph, so that the ! % following text (if any) will end up on the same line. Since that ! % text will be indented by \tableindent, we make the item text be in ! % a zero-width box. \noindent ! \rlap{\hskip -\tableindent\box0}\ignorespaces% ! \endgroup% ! \itemxneedsnegativevskiptrue% \fi } --- 1760,1774 ---- \else % The item text fits into the space. Start a paragraph, so that the ! % following text (if any) will end up on the same line. \noindent ! % Do this with kerns and \unhbox so that if there is a footnote in ! % the item text, it can migrate to the main vertical list and ! % eventually be printed. ! \nobreak\kern-\tableindent ! \dimen0 = \itemmax \advance\dimen0 by \itemmargin \advance\dimen0 by -\wd0 ! \unhbox0 ! \nobreak\kern\dimen0 ! \endgroup ! \itemxneedsnegativevskiptrue \fi } *************** *** 1672,1678 **** \def\xitemx{\errmessage{@xitemx while not in a table}} ! %% Contains a kludge to get @end[description] to work \def\description{\tablez{\dontindex}{1}{}{}{}{}} \def\table{\begingroup\inENV\obeylines\obeyspaces\tablex} {\obeylines\obeyspaces% --- 1781,1788 ---- \def\xitemx{\errmessage{@xitemx while not in a table}} ! % Contains a kludge to get @end[description] to work. \def\description{\tablez{\dontindex}{1}{}{}{}{}} + % @table, @ftable, @vtable. \def\table{\begingroup\inENV\obeylines\obeyspaces\tablex} {\obeylines\obeyspaces% *************** *** 1734,1738 **** \def\itemizezzz #1{% ! \begingroup % ended by the @end itemsize \itemizey {#1}{\Eitemize} } --- 1844,1848 ---- \def\itemizezzz #1{% ! \begingroup % ended by the @end itemize \itemizey {#1}{\Eitemize} } *************** *** 1862,1866 **** \advance\itemno by 1 {\let\par=\endgraf \smallbreak}% ! \ifhmode \errmessage{\in hmode at itemizeitem}\fi {\parskip=0in \hskip 0pt \hbox to 0pt{\hss \itemcontents\hskip \itemmargin}% --- 1972,1976 ---- \advance\itemno by 1 {\let\par=\endgraf \smallbreak}% ! \ifhmode \errmessage{In hmode at itemizeitem}\fi {\parskip=0in \hskip 0pt \hbox to 0pt{\hss \itemcontents\hskip \itemmargin}% *************** *** 1880,1884 **** % To make preamble: % ! % Either define widths of columns in terms of percent of \hsize: % @multitable @columnfractions .25 .3 .45 % @item ... --- 1990,1994 ---- % To make preamble: % ! % Either define widths of columns in terms of percent of \hsize: % @multitable @columnfractions .25 .3 .45 % @item ... *************** *** 1889,2073 **** ! % Or use a template: ! % @multitable {Column 1 template} {Column 2 template} {Column 3 template} ! % @item ... ! % using the widest term desired in each column. % ! % For those who want to use more than one line's worth of words in ! % the preamble, break the line within one argument and it ! % will parse correctly, i.e., % ! % @multitable {Column 1 template} {Column 2 template} {Column 3 ! % template} ! % Not: ! % @multitable {Column 1 template} {Column 2 template} ! % {Column 3 template} ! ! % Each new table line starts with @item, each subsequent new column ! % starts with @tab. Empty columns may be produced by supplying @tab's ! % with nothing between them for as many times as empty columns are needed, ! % ie, @tab@tab@tab will produce two empty columns. ! ! % @item, @tab, @multitable or @end multitable do not need to be on their ! % own lines, but it will not hurt if they are. ! ! % Sample multitable: ! ! % @multitable {Column 1 template} {Column 2 template} {Column 3 template} ! % @item first col stuff @tab second col stuff @tab third col ! % @item ! % first col stuff ! % @tab ! % second col stuff ! % @tab ! % third col ! % @item first col stuff @tab second col stuff ! % @tab Many paragraphs of text may be used in any column. ! % ! % They will wrap at the width determined by the template. ! % @item@tab@tab This will be in third column. ! % @end multitable ! ! % Default dimensions may be reset by user. ! % @multitableparskip is vertical space between paragraphs in table. ! % @multitableparindent is paragraph indent in table. ! % @multitablecolmargin is horizontal space to be left between columns. ! % @multitablelinespace is space to leave between table items, baseline ! % to baseline. ! % 0pt means it depends on current normal line spacing. ! ! %%%% ! % Dimensions ! ! \newskip\multitableparskip ! \newskip\multitableparindent ! \newdimen\multitablecolspace ! \newskip\multitablelinespace ! \multitableparskip=0pt ! \multitableparindent=6pt ! \multitablecolspace=12pt ! \multitablelinespace=0pt ! ! %%%% ! % Macros used to set up halign preamble: ! \let\endsetuptable\relax ! \def\xendsetuptable{\endsetuptable} ! \let\columnfractions\relax ! \def\xcolumnfractions{\columnfractions} ! \newif\ifsetpercent ! %% 2/1/96, to allow fractions to be given with more than one digit. ! \def\pickupwholefraction#1 {\global\advance\colcount by1 % ! \expandafter\xdef\csname col\the\colcount\endcsname{.#1\hsize}% ! \setuptable} ! \newcount\colcount ! \def\setuptable#1{\def\firstarg{#1}% ! \ifx\firstarg\xendsetuptable\let\go\relax% ! \else ! \ifx\firstarg\xcolumnfractions\global\setpercenttrue% \else ! \ifsetpercent ! \let\go\pickupwholefraction % In this case arg of setuptable ! % is the decimal point before the ! % number given in percent of hsize. ! % We don't need this so we don't use it. ! \else ! \global\advance\colcount by1 ! \setbox0=\hbox{#1 }% Add a normal word space as a separator; ! % typically that is always in the input, anyway. ! \expandafter\xdef\csname col\the\colcount\endcsname{\the\wd0}% ! \fi% ! \fi% ! \ifx\go\pickupwholefraction\else\let\go\setuptable\fi% ! \fi\go} ! ! %%%% ! % multitable syntax ! \def\tab{&\hskip1sp\relax} % 2/2/96 ! % tiny skip here makes sure this column space is ! % maintained, even if it is never used. ! ! ! %%%% ! % @multitable ... @end multitable definitions: ! \def\multitable{\parsearg\dotable} ! \def\dotable#1{\bgroup ! \let\item\cr ! \tolerance=9500 ! \hbadness=9500 ! \setmultitablespacing ! \parskip=\multitableparskip ! \parindent=\multitableparindent ! \overfullrule=0pt ! \global\colcount=0\relax% ! \def\Emultitable{\global\setpercentfalse\global\everycr{}\cr\egroup\egroup}% ! % To parse everything between @multitable and @item : ! \setuptable#1 \endsetuptable ! % Need to reset this to 0 after \setuptable. ! \global\colcount=0\relax% ! % ! % This preamble sets up a generic column definition, which will ! % be used as many times as user calls for columns. ! % \vtop will set a single line and will also let text wrap and ! % continue for many paragraphs if desired. ! \halign\bgroup&\global\advance\colcount by 1\relax% ! \multistrut\vtop{\hsize=\expandafter\csname col\the\colcount\endcsname ! % In order to keep entries from bumping into each other ! % we will add a \leftskip of \multitablecolspace to all columns after ! % the first one. ! % If a template has been used, we will add \multitablecolspace ! % to the width of each template entry. ! % If user has set preamble in terms of percent of \hsize ! % we will use that dimension as the width of the column, and ! % the \leftskip will keep entries from bumping into each other. ! % Table will start at left margin and final column will justify at ! % right margin. ! \ifnum\colcount=1 ! \else ! \ifsetpercent \else ! % If user has set preamble in terms of percent of \hsize ! % we will advance \hsize by \multitablecolspace ! \advance\hsize by \multitablecolspace \fi - % In either case we will make \leftskip=\multitablecolspace: - \leftskip=\multitablecolspace - \fi - \noindent##\multistrut}\cr% - % \everycr will reset column counter, \colcount, at the end of - % each line. Every column entry will cause \colcount to advance by one. - % The table preamble - % looks at the current \colcount to find the correct column width. - \global\everycr{\noalign{% - \filbreak%% keeps underfull box messages off when table breaks over pages. - \global\colcount=0\relax}} } ! \def\setmultitablespacing{% test to see if user has set \multitablelinespace. ! % If so, do nothing. If not, give it an appropriate dimension based on ! % current baselineskip. ! \ifdim\multitablelinespace=0pt ! %% strut to put in table in case some entry doesn't have descenders, ! %% to keep lines equally spaced ! \let\multistrut = \strut ! %% Test to see if parskip is larger than space between lines of ! %% table. If not, do nothing. ! %% If so, set to same dimension as multitablelinespace. ! \else ! \gdef\multistrut{\vrule height\multitablelinespace depth\dp0 ! width0pt\relax} \fi ! \ifdim\multitableparskip>\multitablelinespace ! \global\multitableparskip=\multitablelinespace ! \global\advance\multitableparskip-7pt %% to keep parskip somewhat smaller ! %% than skip between lines in the table. ! \fi% ! \ifdim\multitableparskip=0pt ! \global\multitableparskip=\multitablelinespace ! \global\advance\multitableparskip-7pt %% to keep parskip somewhat smaller ! %% than skip between lines in the table. ! \fi} --- 1999,2563 ---- ! % Or use a template: ! % @multitable {Column 1 template} {Column 2 template} {Column 3 template} ! % @item ... ! % using the widest term desired in each column. ! % ! % For those who want to use more than one line's worth of words in ! % the preamble, break the line within one argument and it ! % will parse correctly, i.e., ! % ! % @multitable {Column 1 template} {Column 2 template} {Column 3 ! % template} ! % Not: ! % @multitable {Column 1 template} {Column 2 template} ! % {Column 3 template} ! ! % Each new table line starts with @item, each subsequent new column ! % starts with @tab. Empty columns may be produced by supplying @tab's ! % with nothing between them for as many times as empty columns are needed, ! % ie, @tab@tab@tab will produce two empty columns. ! ! % @item, @tab, @multitable or @end multitable do not need to be on their ! % own lines, but it will not hurt if they are. ! ! % Sample multitable: ! ! % @multitable {Column 1 template} {Column 2 template} {Column 3 template} ! % @item first col stuff @tab second col stuff @tab third col ! % @item ! % first col stuff ! % @tab ! % second col stuff ! % @tab ! % third col ! % @item first col stuff @tab second col stuff ! % @tab Many paragraphs of text may be used in any column. ! % ! % They will wrap at the width determined by the template. ! % @item@tab@tab This will be in third column. ! % @end multitable ! ! % Default dimensions may be reset by user. ! % @multitableparskip is vertical space between paragraphs in table. ! % @multitableparindent is paragraph indent in table. ! % @multitablecolmargin is horizontal space to be left between columns. ! % @multitablelinespace is space to leave between table items, baseline ! % to baseline. ! % 0pt means it depends on current normal line spacing. ! % ! \newskip\multitableparskip ! \newskip\multitableparindent ! \newdimen\multitablecolspace ! \newskip\multitablelinespace ! \multitableparskip=0pt ! \multitableparindent=6pt ! \multitablecolspace=12pt ! \multitablelinespace=0pt ! ! % Macros used to set up halign preamble: ! % ! \let\endsetuptable\relax ! \def\xendsetuptable{\endsetuptable} ! \let\columnfractions\relax ! \def\xcolumnfractions{\columnfractions} ! \newif\ifsetpercent ! ! % #1 is the part of the @columnfraction before the decimal point, which ! % is presumably either 0 or the empty string (but we don't check, we ! % just throw it away). #2 is the decimal part, which we use as the ! % percent of \hsize for this column. ! \def\pickupwholefraction#1.#2 {% ! \global\advance\colcount by 1 ! \expandafter\xdef\csname col\the\colcount\endcsname{.#2\hsize}% ! \setuptable ! } ! ! \newcount\colcount ! \def\setuptable#1{% ! \def\firstarg{#1}% ! \ifx\firstarg\xendsetuptable ! \let\go = \relax ! \else ! \ifx\firstarg\xcolumnfractions ! \global\setpercenttrue ! \else ! \ifsetpercent ! \let\go\pickupwholefraction ! \else ! \global\advance\colcount by 1 ! \setbox0=\hbox{#1\unskip }% Add a normal word space as a separator; ! % typically that is always in the input, anyway. ! \expandafter\xdef\csname col\the\colcount\endcsname{\the\wd0}% ! \fi ! \fi ! \ifx\go\pickupwholefraction ! % Put the argument back for the \pickupwholefraction call, so ! % we'll always have a period there to be parsed. ! \def\go{\pickupwholefraction#1}% ! \else ! \let\go = \setuptable ! \fi% ! \fi ! \go ! } ! ! % This used to have \hskip1sp. But then the space in a template line is ! % not enough. That is bad. So let's go back to just & until we ! % encounter the problem it was intended to solve again. ! % --karl, nathan@acm.org, 20apr99. ! \def\tab{&} ! ! % @multitable ... @end multitable definitions: ! % ! \def\multitable{\parsearg\dotable} ! \def\dotable#1{\bgroup ! \vskip\parskip ! \let\item\crcr ! \tolerance=9500 ! \hbadness=9500 ! \setmultitablespacing ! \parskip=\multitableparskip ! \parindent=\multitableparindent ! \overfullrule=0pt ! \global\colcount=0 ! \def\Emultitable{\global\setpercentfalse\cr\egroup\egroup}% ! % ! % To parse everything between @multitable and @item: ! \setuptable#1 \endsetuptable ! % ! % \everycr will reset column counter, \colcount, at the end of ! % each line. Every column entry will cause \colcount to advance by one. ! % The table preamble ! % looks at the current \colcount to find the correct column width. ! \everycr{\noalign{% ! % ! % \filbreak%% keeps underfull box messages off when table breaks over pages. ! % Maybe so, but it also creates really weird page breaks when the table ! % breaks over pages. Wouldn't \vfil be better? Wait until the problem ! % manifests itself, so it can be fixed for real --karl. ! \global\colcount=0\relax}}% ! % ! % This preamble sets up a generic column definition, which will ! % be used as many times as user calls for columns. ! % \vtop will set a single line and will also let text wrap and ! % continue for many paragraphs if desired. ! \halign\bgroup&\global\advance\colcount by 1\relax ! \multistrut\vtop{\hsize=\expandafter\csname col\the\colcount\endcsname ! % ! % In order to keep entries from bumping into each other ! % we will add a \leftskip of \multitablecolspace to all columns after ! % the first one. ! % ! % If a template has been used, we will add \multitablecolspace ! % to the width of each template entry. ! % ! % If the user has set preamble in terms of percent of \hsize we will ! % use that dimension as the width of the column, and the \leftskip ! % will keep entries from bumping into each other. Table will start at ! % left margin and final column will justify at right margin. ! % ! % Make sure we don't inherit \rightskip from the outer environment. ! \rightskip=0pt ! \ifnum\colcount=1 ! % The first column will be indented with the surrounding text. ! \advance\hsize by\leftskip ! \else ! \ifsetpercent \else ! % If user has not set preamble in terms of percent of \hsize ! % we will advance \hsize by \multitablecolspace. ! \advance\hsize by \multitablecolspace ! \fi ! % In either case we will make \leftskip=\multitablecolspace: ! \leftskip=\multitablecolspace ! \fi ! % Ignoring space at the beginning and end avoids an occasional spurious ! % blank line, when TeX decides to break the line at the space before the ! % box from the multistrut, so the strut ends up on a line by itself. ! % For example: ! % @multitable @columnfractions .11 .89 ! % @item @code{#} ! % @tab Legal holiday which is valid in major parts of the whole country. ! % Is automatically provided with highlighting sequences respectively marking ! % characters. ! \noindent\ignorespaces##\unskip\multistrut}\cr ! } ! ! \def\setmultitablespacing{% test to see if user has set \multitablelinespace. ! % If so, do nothing. If not, give it an appropriate dimension based on ! % current baselineskip. ! \ifdim\multitablelinespace=0pt ! \setbox0=\vbox{X}\global\multitablelinespace=\the\baselineskip ! \global\advance\multitablelinespace by-\ht0 ! %% strut to put in table in case some entry doesn't have descenders, ! %% to keep lines equally spaced ! \let\multistrut = \strut ! \else ! %% FIXME: what is \box0 supposed to be? ! \gdef\multistrut{\vrule height\multitablelinespace depth\dp0 ! width0pt\relax} \fi ! %% Test to see if parskip is larger than space between lines of ! %% table. If not, do nothing. ! %% If so, set to same dimension as multitablelinespace. ! \ifdim\multitableparskip>\multitablelinespace ! \global\multitableparskip=\multitablelinespace ! \global\advance\multitableparskip-7pt %% to keep parskip somewhat smaller ! %% than skip between lines in the table. ! \fi% ! \ifdim\multitableparskip=0pt ! \global\multitableparskip=\multitablelinespace ! \global\advance\multitableparskip-7pt %% to keep parskip somewhat smaller ! %% than skip between lines in the table. ! \fi} ! ! ! \message{conditionals,} ! % Prevent errors for section commands. ! % Used in @ignore and in failing conditionals. ! \def\ignoresections{% ! \let\chapter=\relax ! \let\unnumbered=\relax ! \let\top=\relax ! \let\unnumberedsec=\relax ! \let\unnumberedsection=\relax ! \let\unnumberedsubsec=\relax ! \let\unnumberedsubsection=\relax ! \let\unnumberedsubsubsec=\relax ! \let\unnumberedsubsubsection=\relax ! \let\section=\relax ! \let\subsec=\relax ! \let\subsubsec=\relax ! \let\subsection=\relax ! \let\subsubsection=\relax ! \let\appendix=\relax ! \let\appendixsec=\relax ! \let\appendixsection=\relax ! \let\appendixsubsec=\relax ! \let\appendixsubsection=\relax ! \let\appendixsubsubsec=\relax ! \let\appendixsubsubsection=\relax ! \let\contents=\relax ! \let\smallbook=\relax ! \let\titlepage=\relax ! } ! ! % Used in nested conditionals, where we have to parse the Texinfo source ! % and so want to turn off most commands, in case they are used ! % incorrectly. ! % ! \def\ignoremorecommands{% ! \let\defcodeindex = \relax ! \let\defcv = \relax ! \let\deffn = \relax ! \let\deffnx = \relax ! \let\defindex = \relax ! \let\defivar = \relax ! \let\defmac = \relax ! \let\defmethod = \relax ! \let\defop = \relax ! \let\defopt = \relax ! \let\defspec = \relax ! \let\deftp = \relax ! \let\deftypefn = \relax ! \let\deftypefun = \relax ! \let\deftypeivar = \relax ! \let\deftypeop = \relax ! \let\deftypevar = \relax ! \let\deftypevr = \relax ! \let\defun = \relax ! \let\defvar = \relax ! \let\defvr = \relax ! \let\ref = \relax ! \let\xref = \relax ! \let\printindex = \relax ! \let\pxref = \relax ! \let\settitle = \relax ! \let\setchapternewpage = \relax ! \let\setchapterstyle = \relax ! \let\everyheading = \relax ! \let\evenheading = \relax ! \let\oddheading = \relax ! \let\everyfooting = \relax ! \let\evenfooting = \relax ! \let\oddfooting = \relax ! \let\headings = \relax ! \let\include = \relax ! \let\lowersections = \relax ! \let\down = \relax ! \let\raisesections = \relax ! \let\up = \relax ! \let\set = \relax ! \let\clear = \relax ! \let\item = \relax ! } ! ! % Ignore @ignore ... @end ignore. ! % ! \def\ignore{\doignore{ignore}} ! ! % Ignore @ifinfo, @ifhtml, @ifnottex, @html, @menu, and @direntry text. ! % ! \def\ifinfo{\doignore{ifinfo}} ! \def\ifhtml{\doignore{ifhtml}} ! \def\ifnottex{\doignore{ifnottex}} ! \def\html{\doignore{html}} ! \def\menu{\doignore{menu}} ! \def\direntry{\doignore{direntry}} ! ! % @dircategory CATEGORY -- specify a category of the dir file ! % which this file should belong to. Ignore this in TeX. ! \let\dircategory = \comment ! ! % Ignore text until a line `@end #1'. ! % ! \def\doignore#1{\begingroup ! % Don't complain about control sequences we have declared \outer. ! \ignoresections ! % ! % Define a command to swallow text until we reach `@end #1'. ! % This @ is a catcode 12 token (that is the normal catcode of @ in ! % this texinfo.tex file). We change the catcode of @ below to match. ! \long\def\doignoretext##1@end #1{\enddoignore}% ! % ! % Make sure that spaces turn into tokens that match what \doignoretext wants. ! \catcode32 = 10 ! % ! % Ignore braces, too, so mismatched braces don't cause trouble. ! \catcode`\{ = 9 ! \catcode`\} = 9 ! % ! % We must not have @c interpreted as a control sequence. ! \catcode`\@ = 12 ! % ! % Make the letter c a comment character so that the rest of the line ! % will be ignored. This way, the document can have (for example) ! % @c @end ifinfo ! % and the @end ifinfo will be properly ignored. ! % (We've just changed @ to catcode 12.) ! \catcode`\c = 14 ! % ! % And now expand that command. ! \doignoretext ! } ! ! % What we do to finish off ignored text. ! % ! \def\enddoignore{\endgroup\ignorespaces}% ! ! \newif\ifwarnedobs\warnedobsfalse ! \def\obstexwarn{% ! \ifwarnedobs\relax\else ! % We need to warn folks that they may have trouble with TeX 3.0. ! % This uses \immediate\write16 rather than \message to get newlines. ! \immediate\write16{} ! \immediate\write16{WARNING: for users of Unix TeX 3.0!} ! \immediate\write16{This manual trips a bug in TeX version 3.0 (tex hangs).} ! \immediate\write16{If you are running another version of TeX, relax.} ! \immediate\write16{If you are running Unix TeX 3.0, kill this TeX process.} ! \immediate\write16{ Then upgrade your TeX installation if you can.} ! \immediate\write16{ (See ftp://ftp.gnu.org/pub/gnu/TeX.README.)} ! \immediate\write16{If you are stuck with version 3.0, run the} ! \immediate\write16{ script ``tex3patch'' from the Texinfo distribution} ! \immediate\write16{ to use a workaround.} ! \immediate\write16{} ! \global\warnedobstrue ! \fi ! } ! ! % **In TeX 3.0, setting text in \nullfont hangs tex. For a ! % workaround (which requires the file ``dummy.tfm'' to be installed), ! % uncomment the following line: ! %%%%%\font\nullfont=dummy\let\obstexwarn=\relax ! ! % Ignore text, except that we keep track of conditional commands for ! % purposes of nesting, up to an `@end #1' command. ! % ! \def\nestedignore#1{% ! \obstexwarn ! % We must actually expand the ignored text to look for the @end ! % command, so that nested ignore constructs work. Thus, we put the ! % text into a \vbox and then do nothing with the result. To minimize ! % the change of memory overflow, we follow the approach outlined on ! % page 401 of the TeXbook: make the current font be a dummy font. ! % ! \setbox0 = \vbox\bgroup ! % Don't complain about control sequences we have declared \outer. ! \ignoresections ! % ! % Define `@end #1' to end the box, which will in turn undefine the ! % @end command again. ! \expandafter\def\csname E#1\endcsname{\egroup\ignorespaces}% ! % ! % We are going to be parsing Texinfo commands. Most cause no ! % trouble when they are used incorrectly, but some commands do ! % complicated argument parsing or otherwise get confused, so we ! % undefine them. ! % ! % We can't do anything about stray @-signs, unfortunately; ! % they'll produce `undefined control sequence' errors. ! \ignoremorecommands ! % ! % Set the current font to be \nullfont, a TeX primitive, and define ! % all the font commands to also use \nullfont. We don't use ! % dummy.tfm, as suggested in the TeXbook, because not all sites ! % might have that installed. Therefore, math mode will still ! % produce output, but that should be an extremely small amount of ! % stuff compared to the main input. ! % ! \nullfont ! \let\tenrm=\nullfont \let\tenit=\nullfont \let\tensl=\nullfont ! \let\tenbf=\nullfont \let\tentt=\nullfont \let\smallcaps=\nullfont ! \let\tensf=\nullfont ! % Similarly for index fonts (mostly for their use in smallexample). ! \let\smallrm=\nullfont \let\smallit=\nullfont \let\smallsl=\nullfont ! \let\smallbf=\nullfont \let\smalltt=\nullfont \let\smallsc=\nullfont ! \let\smallsf=\nullfont ! % ! % Don't complain when characters are missing from the fonts. ! \tracinglostchars = 0 ! % ! % Don't bother to do space factor calculations. ! \frenchspacing ! % ! % Don't report underfull hboxes. ! \hbadness = 10000 ! % ! % Do minimal line-breaking. ! \pretolerance = 10000 ! % ! % Do not execute instructions in @tex ! \def\tex{\doignore{tex}}% ! % Do not execute macro definitions. ! % `c' is a comment character, so the word `macro' will get cut off. ! \def\macro{\doignore{ma}}% ! } ! ! % @set VAR sets the variable VAR to an empty value. ! % @set VAR REST-OF-LINE sets VAR to the value REST-OF-LINE. % ! % Since we want to separate VAR from REST-OF-LINE (which might be ! % empty), we can't just use \parsearg; we have to insert a space of our ! % own to delimit the rest of the line, and then take it out again if we ! % didn't need it. Make sure the catcode of space is correct to avoid ! % losing inside @example, for instance. % ! \def\set{\begingroup\catcode` =10 ! \catcode`\-=12 \catcode`\_=12 % Allow - and _ in VAR. ! \parsearg\setxxx} ! \def\setxxx#1{\setyyy#1 \endsetyyy} ! \def\setyyy#1 #2\endsetyyy{% ! \def\temp{#2}% ! \ifx\temp\empty \global\expandafter\let\csname SET#1\endcsname = \empty ! \else \setzzz{#1}#2\endsetzzz % Remove the trailing space \setxxx inserted. ! \fi ! \endgroup ! } ! % Can't use \xdef to pre-expand #2 and save some time, since \temp or ! % \next or other control sequences that we've defined might get us into ! % an infinite loop. Consider `@set foo @cite{bar}'. ! \def\setzzz#1#2 \endsetzzz{\expandafter\gdef\csname SET#1\endcsname{#2}} ! % @clear VAR clears (i.e., unsets) the variable VAR. ! % ! \def\clear{\parsearg\clearxxx} ! \def\clearxxx#1{\global\expandafter\let\csname SET#1\endcsname=\relax} ! % @value{foo} gets the text saved in variable foo. ! { ! \catcode`\_ = \active ! % ! % We might end up with active _ or - characters in the argument if ! % we're called from @code, as @code{@value{foo-bar_}}. So \let any ! % such active characters to their normal equivalents. ! \gdef\value{\begingroup ! \catcode`\-=12 \catcode`\_=12 ! \indexbreaks \let_\normalunderscore ! \valuexxx} ! } ! \def\valuexxx#1{\expandablevalue{#1}\endgroup} ! ! % We have this subroutine so that we can handle at least some @value's ! % properly in indexes (we \let\value to this in \indexdummies). Ones ! % whose names contain - or _ still won't work, but we can't do anything ! % about that. The command has to be fully expandable, since the result ! % winds up in the index file. This means that if the variable's value ! % contains other Texinfo commands, it's almost certain it will fail ! % (although perhaps we could fix that with sufficient work to do a ! % one-level expansion on the result, instead of complete). ! % ! \def\expandablevalue#1{% ! \expandafter\ifx\csname SET#1\endcsname\relax ! {[No value for ``#1'']}% \else ! \csname SET#1\endcsname ! \fi ! } ! % @ifset VAR ... @end ifset reads the `...' iff VAR has been defined ! % with @set. ! % ! \def\ifset{\parsearg\ifsetxxx} ! \def\ifsetxxx #1{% ! \expandafter\ifx\csname SET#1\endcsname\relax ! \expandafter\ifsetfail ! \else ! \expandafter\ifsetsucceed ! \fi ! } ! \def\ifsetsucceed{\conditionalsucceed{ifset}} ! \def\ifsetfail{\nestedignore{ifset}} ! \defineunmatchedend{ifset} ! % @ifclear VAR ... @end ifclear reads the `...' iff VAR has never been ! % defined with @set, or has been undefined with @clear. ! % ! \def\ifclear{\parsearg\ifclearxxx} ! \def\ifclearxxx #1{% ! \expandafter\ifx\csname SET#1\endcsname\relax ! \expandafter\ifclearsucceed \else ! \expandafter\ifclearfail \fi } + \def\ifclearsucceed{\conditionalsucceed{ifclear}} + \def\ifclearfail{\nestedignore{ifclear}} + \defineunmatchedend{ifclear} ! % @iftex, @ifnothtml, @ifnotinfo always succeed; we read the text ! % following, through the first @end iftex (etc.). Make `@end iftex' ! % (etc.) valid only after an @iftex. ! % ! \def\iftex{\conditionalsucceed{iftex}} ! \def\ifnothtml{\conditionalsucceed{ifnothtml}} ! \def\ifnotinfo{\conditionalsucceed{ifnotinfo}} ! \defineunmatchedend{iftex} ! \defineunmatchedend{ifnothtml} ! \defineunmatchedend{ifnotinfo} ! ! % We can't just want to start a group at @iftex (for example) and end it ! % at @end iftex, since then @set commands inside the conditional have no ! % effect (they'd get reverted at the end of the group). So we must ! % define \Eiftex to redefine itself to be its previous value. (We can't ! % just define it to fail again with an ``unmatched end'' error, since ! % the @ifset might be nested.) ! % ! \def\conditionalsucceed#1{% ! \edef\temp{% ! % Remember the current value of \E#1. ! \let\nece{prevE#1} = \nece{E#1}% ! % ! % At the `@end #1', redefine \E#1 to be its previous value. ! \def\nece{E#1}{\let\nece{E#1} = \nece{prevE#1}}% ! }% ! \temp ! } ! ! % We need to expand lots of \csname's, but we don't want to expand the ! % control sequences after we've constructed them. ! % ! \def\nece#1{\expandafter\noexpand\csname#1\endcsname} ! ! % @defininfoenclose. ! \let\definfoenclose=\comment *************** *** 2087,2096 **** % The name of an index should be no more than 2 characters long % for the sake of vms. ! ! \def\newindex #1{ ! \expandafter\newwrite \csname#1indfile\endcsname% Define number for output file ! \openout \csname#1indfile\endcsname \jobname.#1 % Open the file ! \expandafter\xdef\csname#1index\endcsname{% % Define \xxxindex ! \noexpand\doindex {#1}} } --- 2577,2588 ---- % The name of an index should be no more than 2 characters long % for the sake of vms. ! % ! \def\newindex#1{% ! \iflinks ! \expandafter\newwrite \csname#1indfile\endcsname ! \openout \csname#1indfile\endcsname \jobname.#1 % Open the file ! \fi ! \expandafter\xdef\csname#1index\endcsname{% % Define @#1index ! \noexpand\doindex{#1}} } *************** *** 2101,2109 **** % Define @defcodeindex, like @defindex except put all entries in @code. ! \def\newcodeindex #1{ ! \expandafter\newwrite \csname#1indfile\endcsname% Define number for output file ! \openout \csname#1indfile\endcsname \jobname.#1 % Open the file ! \expandafter\xdef\csname#1index\endcsname{% % Define \xxxindex ! \noexpand\docodeindex {#1}} } --- 2593,2603 ---- % Define @defcodeindex, like @defindex except put all entries in @code. ! \def\newcodeindex#1{% ! \iflinks ! \expandafter\newwrite \csname#1indfile\endcsname ! \openout \csname#1indfile\endcsname \jobname.#1 ! \fi ! \expandafter\xdef\csname#1index\endcsname{% ! \noexpand\docodeindex{#1}} } *************** *** 2112,2129 **** % @synindex foo bar makes index foo feed into index bar. % Do this instead of @defindex foo if you don't want it as a separate index. ! \def\synindex #1 #2 {% ! \expandafter\let\expandafter\synindexfoo\expandafter=\csname#2indfile\endcsname ! \expandafter\let\csname#1indfile\endcsname=\synindexfoo ! \expandafter\xdef\csname#1index\endcsname{% % Define \xxxindex ! \noexpand\doindex {#2}}% } % @syncodeindex foo bar similar, but put all entries made for index foo % inside @code. ! \def\syncodeindex #1 #2 {% ! \expandafter\let\expandafter\synindexfoo\expandafter=\csname#2indfile\endcsname ! \expandafter\let\csname#1indfile\endcsname=\synindexfoo ! \expandafter\xdef\csname#1index\endcsname{% % Define \xxxindex ! \noexpand\docodeindex {#2}}% } --- 2606,2627 ---- % @synindex foo bar makes index foo feed into index bar. % Do this instead of @defindex foo if you don't want it as a separate index. ! % The \closeout helps reduce unnecessary open files; the limit on the ! % Acorn RISC OS is a mere 16 files. ! \def\synindex#1 #2 {% ! \expandafter\let\expandafter\synindexfoo\expandafter=\csname#2indfile\endcsname ! \expandafter\closeout\csname#1indfile\endcsname ! \expandafter\let\csname#1indfile\endcsname=\synindexfoo ! \expandafter\xdef\csname#1index\endcsname{% define \xxxindex ! \noexpand\doindex{#2}}% } % @syncodeindex foo bar similar, but put all entries made for index foo % inside @code. ! \def\syncodeindex#1 #2 {% ! \expandafter\let\expandafter\synindexfoo\expandafter=\csname#2indfile\endcsname ! \expandafter\closeout\csname#1indfile\endcsname ! \expandafter\let\csname#1indfile\endcsname=\synindexfoo ! \expandafter\xdef\csname#1index\endcsname{% define \xxxindex ! \noexpand\docodeindex{#2}}% } *************** *** 2146,2149 **** --- 2644,2648 ---- \def\indexdummies{% + \def\ { }% % Take care of the plain tex accent commands. \def\"{\realbackslash "}% *************** *** 2175,2180 **** % laboriously list every single command here.) \def\@{@}% will be @@ when we switch to @ as escape char. ! %\let\{ = \lbracecmd ! %\let\} = \rbracecmd \def\_{{\realbackslash _}}% \def\w{\realbackslash w }% --- 2674,2682 ---- % laboriously list every single command here.) \def\@{@}% will be @@ when we switch to @ as escape char. ! % Need these in case \tex is in effect and \{ is a \delimiter again. ! % But can't use \lbracecmd and \rbracecmd because texindex assumes ! % braces and backslashes are used only as delimiters. ! \let\{ = \mylbrace ! \let\} = \myrbrace \def\_{{\realbackslash _}}% \def\w{\realbackslash w }% *************** *** 2187,2196 **** \def\less{\realbackslash less}% \def\hat{\realbackslash hat}% - %\def\char{\realbackslash char}% \def\TeX{\realbackslash TeX}% \def\dots{\realbackslash dots }% ! \def\copyright{\realbackslash copyright }% \def\tclose##1{\realbackslash tclose {##1}}% \def\code##1{\realbackslash code {##1}}% \def\dotless##1{\realbackslash dotless {##1}}% \def\samp##1{\realbackslash samp {##1}}% --- 2689,2708 ---- \def\less{\realbackslash less}% \def\hat{\realbackslash hat}% \def\TeX{\realbackslash TeX}% \def\dots{\realbackslash dots }% ! \def\result{\realbackslash result}% ! \def\equiv{\realbackslash equiv}% ! \def\expansion{\realbackslash expansion}% ! \def\print{\realbackslash print}% ! \def\error{\realbackslash error}% ! \def\point{\realbackslash point}% ! \def\copyright{\realbackslash copyright}% \def\tclose##1{\realbackslash tclose {##1}}% \def\code##1{\realbackslash code {##1}}% + \def\uref##1{\realbackslash uref {##1}}% + \def\url##1{\realbackslash url {##1}}% + \def\env##1{\realbackslash env {##1}}% + \def\command##1{\realbackslash command {##1}}% + \def\option##1{\realbackslash option {##1}}% \def\dotless##1{\realbackslash dotless {##1}}% \def\samp##1{\realbackslash samp {##1}}% *************** *** 2200,2203 **** --- 2712,2716 ---- \def\i##1{\realbackslash i {##1}}% \def\b##1{\realbackslash b {##1}}% + \def\sc##1{\realbackslash sc {##1}}% \def\cite##1{\realbackslash cite {##1}}% \def\key##1{\realbackslash key {##1}}% *************** *** 2207,2211 **** --- 2720,2733 ---- \def\dfn##1{\realbackslash dfn {##1}}% \def\emph##1{\realbackslash emph {##1}}% + \def\acronym##1{\realbackslash acronym {##1}}% + % + % Handle some cases of @value -- where the variable name does not + % contain - or _, and the value does not contain any + % (non-fully-expandable) commands. + \let\value = \expandablevalue + % \unsepspaces + % Turn off macro expansion + \turnoffmacros } *************** *** 2264,2267 **** --- 2786,2795 ---- \let\tclose=\indexdummyfont \let\code=\indexdummyfont + \let\url=\indexdummyfont + \let\uref=\indexdummyfont + \let\env=\indexdummyfont + \let\acronym=\indexdummyfont + \let\command=\indexdummyfont + \let\option=\indexdummyfont \let\file=\indexdummyfont \let\samp=\indexdummyfont *************** *** 2279,2290 **** {\catcode`\@=0 \catcode`\\=\other ! @gdef@realbackslash{\}} \let\indexbackslash=0 %overridden during \printindex. ! \let\SETmarginindex=\relax %initialize! ! % workhorse for all \fooindexes ! % #1 is name of index, #2 is stuff to put there ! \def\doind #1#2{% % Put the index entry in the margin if desired. \ifx\SETmarginindex\relax\else --- 2807,2828 ---- {\catcode`\@=0 \catcode`\\=\other ! @gdef@realbackslash{\}} \let\indexbackslash=0 %overridden during \printindex. + \let\SETmarginindex=\relax % put index entries in margin (undocumented)? + + % For \ifx comparisons. + \def\emptymacro{\empty} + + % Most index entries go through here, but \dosubind is the general case. + % + \def\doind#1#2{\dosubind{#1}{#2}\empty} ! % Workhorse for all \fooindexes. ! % #1 is name of index, #2 is stuff to put there, #3 is subentry -- ! % \empty if called from \doind, as we usually are. The main exception ! % is with defuns, which call us directly. ! % ! \def\dosubind#1#2#3{% % Put the index entry in the margin if desired. \ifx\SETmarginindex\relax\else *************** *** 2297,2316 **** \escapechar=`\\ {% ! \let\folio=0 % We will expand all macros now EXCEPT \folio. \def\rawbackslashxx{\indexbackslash}% \indexbackslash isn't defined now % so it will be output as is; and it will print as backslash. % ! % First process the index-string with all font commands turned off ! % to get the string to sort by. ! {\indexnofonts \xdef\indexsorttmp{#2}}% % ! % Now produce the complete index entry, with both the sort key and the ! % original text, including any font commands. \toks0 = {#2}% \edef\temp{% \write\csname#1indfile\endcsname{% \realbackslash entry{\indexsorttmp}{\folio}{\the\toks0}}% }% ! \temp }% }% --- 2835,2901 ---- \escapechar=`\\ {% ! \let\folio = 0% We will expand all macros now EXCEPT \folio. \def\rawbackslashxx{\indexbackslash}% \indexbackslash isn't defined now % so it will be output as is; and it will print as backslash. % ! \def\thirdarg{#3}% ! % ! % If third arg is present, precede it with space in sort key. ! \ifx\thirdarg\emptymacro ! \let\subentry = \empty ! \else ! \def\subentry{ #3}% ! \fi ! % ! % First process the index entry with all font commands turned ! % off to get the string to sort by. ! {\indexnofonts \xdef\indexsorttmp{#2\subentry}}% % ! % Now the real index entry with the fonts. \toks0 = {#2}% + % + % If third (subentry) arg is present, add it to the index + % string. And include a space. + \ifx\thirdarg\emptymacro \else + \toks0 = \expandafter{\the\toks0 \space #3}% + \fi + % + % Set up the complete index entry, with both the sort key + % and the original text, including any font commands. We write + % three arguments to \entry to the .?? file, texindex reduces to + % two when writing the .??s sorted result. \edef\temp{% \write\csname#1indfile\endcsname{% \realbackslash entry{\indexsorttmp}{\folio}{\the\toks0}}% }% ! % ! % If a skip is the last thing on the list now, preserve it ! % by backing up by \lastskip, doing the \write, then inserting ! % the skip again. Otherwise, the whatsit generated by the ! % \write will make \lastskip zero. The result is that sequences ! % like this: ! % @end defun ! % @tindex whatever ! % @defun ... ! % will have extra space inserted, because the \medbreak in the ! % start of the @defun won't see the skip inserted by the @end of ! % the previous defun. ! % ! % But don't do any of this if we're not in vertical mode. We ! % don't want to do a \vskip and prematurely end a paragraph. ! % ! % Avoid page breaks due to these extra skips, too. ! % ! \iflinks ! \ifvmode ! \skip0 = \lastskip ! \ifdim\lastskip = 0pt \else \nobreak\vskip-\lastskip \fi ! \fi ! % ! \temp % do the write ! % ! % ! \ifvmode \ifdim\skip0 = 0pt \else \nobreak\vskip\skip0 \fi \fi ! \fi }% }% *************** *** 2319,2342 **** } - \def\dosubind #1#2#3{% - {\count10=\lastpenalty % - {\indexdummies % Must do this here, since \bf, etc expand at this stage - \escapechar=`\\% - {\let\folio=0% - \def\rawbackslashxx{\indexbackslash}% - % - % Now process the index-string once, with all font commands turned off, - % to get the string to sort the index by. - {\indexnofonts - \xdef\temp1{#2 #3}% - }% - % Now produce the complete index entry. We process the index-string again, - % this time with font commands expanded, to get what to print in the index. - \edef\temp{% - \write \csname#1indfile\endcsname{% - \realbackslash entry {\temp1}{\folio}{#2}{#3}}}% - \temp }% - }\penalty\count10}} - % The index entry written in the file actually looks like % \entry {sortstring}{page}{topic} --- 2904,2907 ---- *************** *** 2371,2397 **** % Define the macros used in formatting output of the sorted index material. ! % This is what you call to cause a particular index to get printed. ! % Write ! % @unnumbered Function Index ! % @printindex fn ! \def\printindex{\parsearg\doprintindex} - \def\doprintindex#1{\begingroup \dobreak \chapheadingskip{10000}% % ! \indexfonts \rm \tolerance = 9500 \indexbreaks - \def\indexbackslash{\rawbackslashxx}% - % Index files are almost Texinfo source, but we use \ as the escape - % character. It would be better to use @, but that's too big a change - % to make right now. - \catcode`\\ = 0 - \catcode`\@ = 11 - \escapechar = `\\ - \begindoublecolumns % % See if the index file exists and is nonempty. \openin 1 \jobname.#1s \ifeof 1 --- 2936,2956 ---- % Define the macros used in formatting output of the sorted index material. ! % @printindex causes a particular index (the ??s file) to get printed. ! % It does not print any chapter heading (usually an @unnumbered). ! % \def\printindex{\parsearg\doprintindex} \def\doprintindex#1{\begingroup \dobreak \chapheadingskip{10000}% % ! \smallfonts \rm \tolerance = 9500 \indexbreaks % % See if the index file exists and is nonempty. + % Change catcode of @ here so that if the index file contains + % \initial {@} + % as its first line, TeX doesn't complain about mismatched braces + % (because it thinks @} is a control sequence). + \catcode`\@ = 11 \openin 1 \jobname.#1s \ifeof 1 *************** *** 2400,2404 **** % index. The easiest way to prevent this problem is to make sure % there is some text. ! (Index is nonexistent) \else % --- 2959,2963 ---- % index. The easiest way to prevent this problem is to make sure % there is some text. ! \putwordIndexNonexistent \else % *************** *** 2408,2418 **** \read 1 to \temp \ifeof 1 ! (Index is empty) \else \input \jobname.#1s \fi \fi \closein 1 - \enddoublecolumns \endgroup} --- 2967,2984 ---- \read 1 to \temp \ifeof 1 ! \putwordIndexIsEmpty \else + % Index files are almost Texinfo source, but we use \ as the escape + % character. It would be better to use @, but that's too big a change + % to make right now. + \def\indexbackslash{\rawbackslashxx}% + \catcode`\\ = 0 + \escapechar = `\\ + \begindoublecolumns \input \jobname.#1s + \enddoublecolumns \fi \fi \closein 1 \endgroup} *************** *** 2420,2432 **** % Change them to control the appearance of the index. ! % Same as \bigskipamount except no shrink. ! % \balancecolumns gets confused if there is any shrink. ! \newskip\initialskipamount \initialskipamount 12pt plus4pt ! ! \def\initial #1{% ! {\let\tentt=\sectt \let\tt=\sectt \let\sf=\sectt ! \ifdim\lastskip<\initialskipamount ! \removelastskip \penalty-200 \vskip \initialskipamount\fi ! \line{\secbf#1\hfill}\kern 2pt\penalty10000}} % This typesets a paragraph consisting of #1, dot leaders, and then #2 --- 2986,3012 ---- % Change them to control the appearance of the index. ! \def\initial#1{{% ! % Some minor font changes for the special characters. ! \let\tentt=\sectt \let\tt=\sectt \let\sf=\sectt ! % ! % Remove any glue we may have, we'll be inserting our own. ! \removelastskip ! % ! % We like breaks before the index initials, so insert a bonus. ! \penalty -300 ! % ! % Typeset the initial. Making this add up to a whole number of ! % baselineskips increases the chance of the dots lining up from column ! % to column. It still won't often be perfect, because of the stretch ! % we need before each entry, but it's better. ! % ! % No shrink because it confuses \balancecolumns. ! \vskip 1.67\baselineskip plus .5\baselineskip ! \leftline{\secbf #1}% ! \vskip .33\baselineskip plus .1\baselineskip ! % ! % Do our best not to break after the initial. ! \nobreak ! }} % This typesets a paragraph consisting of #1, dot leaders, and then #2 *************** *** 2434,2438 **** % entries. The paragraph is indented by \leftskip. % ! \def\entry #1#2{\begingroup % % Start a new paragraph if necessary, so our assignments below can't --- 3014,3018 ---- % entries. The paragraph is indented by \leftskip. % ! \def\entry#1#2{\begingroup % % Start a new paragraph if necessary, so our assignments below can't *************** *** 2457,2461 **** % \hangafter is reset to 1 (which is the value we want) at the start % of each paragraph, so we need not do anything with that. ! \hangindent=2em % % When the entry text needs to be broken, just fill out the first line --- 3037,3041 ---- % \hangafter is reset to 1 (which is the value we want) at the start % of each paragraph, so we need not do anything with that. ! \hangindent = 2em % % When the entry text needs to be broken, just fill out the first line *************** *** 2463,2466 **** --- 3043,3049 ---- \rightskip = 0pt plus1fil % + % A bit of stretch before each entry for the benefit of balancing columns. + \vskip 0pt plus1pt + % % Start a ``paragraph'' for the index entry so the line breaking % parameters we've set above will have an effect. *************** *** 2487,2491 **** % part of (the primitive) \par. Without it, a spurious underfull % \hbox ensues. ! \ #2% The page number ends the paragraph. \fi% \par --- 3070,3078 ---- % part of (the primitive) \par. Without it, a spurious underfull % \hbox ensues. ! \ifpdf ! \pdfgettoks#2.\ \the\toksA % The page number ends the paragraph. ! \else ! \ #2% The page number ends the paragraph. ! \fi \fi% \par *************** *** 2516,2525 **** \def\begindoublecolumns{\begingroup % ended by \enddoublecolumns % Grab any single-column material above us. ! \output = {\global\setbox\partialpage ! =\vbox{\unvbox255\kern -\topskip \kern \baselineskip}}% ! \eject % ! % Now switch to the double-column output routine. ! \output={\doublecolumnout}% % % Change the page size parameters. We could do this once outside this --- 3103,3129 ---- \def\begindoublecolumns{\begingroup % ended by \enddoublecolumns % Grab any single-column material above us. ! \output = {% ! % ! % Here is a possibility not foreseen in manmac: if we accumulate a ! % whole lot of material, we might end up calling this \output ! % routine twice in a row (see the doublecol-lose test, which is ! % essentially a couple of indexes with @setchapternewpage off). In ! % that case we just ship out what is in \partialpage with the normal ! % output routine. Generally, \partialpage will be empty when this ! % runs and this will be a no-op. See the indexspread.tex test case. ! \ifvoid\partialpage \else ! \onepageout{\pagecontents\partialpage}% ! \fi ! % ! \global\setbox\partialpage = \vbox{% ! % Unvbox the main output page. ! \unvbox\PAGE ! \kern-\topskip \kern\baselineskip ! }% ! }% ! \eject % run that output routine to set \partialpage % ! % Use the double-column output routine for subsequent pages. ! \output = {\doublecolumnout}% % % Change the page size parameters. We could do this once outside this *************** *** 2527,2537 **** % format, but then we repeat the same computation. Repeating a couple % of assignments once per index is clearly meaningless for the ! % execution time, so we may as well do it once. % % First we halve the line length, less a little for the gutter between % the columns. We compute the gutter based on the line length, so it % changes automatically with the paper format. The magic constant ! % below is chosen so that the gutter has the same value (well, +- < ! % 1pt) as it did when we hard-coded it. % % We put the result in a separate register, \doublecolumhsize, so we --- 3131,3141 ---- % format, but then we repeat the same computation. Repeating a couple % of assignments once per index is clearly meaningless for the ! % execution time, so we may as well do it in one place. % % First we halve the line length, less a little for the gutter between % the columns. We compute the gutter based on the line length, so it % changes automatically with the paper format. The magic constant ! % below is chosen so that the gutter has the same value (well, +-<1pt) ! % as it did when we hard-coded it. % % We put the result in a separate register, \doublecolumhsize, so we *************** *** 2546,2551 **** --- 3150,3160 ---- % Double the \vsize as well. (We don't need a separate register here, % since nobody clobbers \vsize.) + \advance\vsize by -\ht\partialpage \vsize = 2\vsize } + + % The double-column output routine for all double-column pages except + % the last. + % \def\doublecolumnout{% \splittopskip=\topskip \splitmaxdepth=\maxdepth *************** *** 2553,2652 **** % (undoubled) page height minus any material left over from the % previous page. ! \dimen@=\pageheight \advance\dimen@ by-\ht\partialpage ! % box0 will be the left-hand column, box1 the right. \setbox0=\vsplit255 to\dimen@ \setbox2=\vsplit255 to\dimen@ \onepageout\pagesofar ! \unvbox255 \penalty\outputpenalty } \def\pagesofar{% ! % The contents of the output page -- any previous material, ! % followed by the two boxes we just split. \unvbox\partialpage \hsize = \doublecolumnhsize ! \wd0=\hsize \wd2=\hsize \hbox to\pagewidth{\box0\hfil\box2}% } \def\enddoublecolumns{% ! \output={\balancecolumns}\eject % split what we have ! \endgroup ! % Back to normal single-column typesetting, but take account of the ! % fact that we just accumulated some stuff on the output page. ! \pagegoal=\vsize } \def\balancecolumns{% ! % Called on the last page of the double column material. ! \setbox0=\vbox{\unvbox255}% \dimen@ = \ht0 \advance\dimen@ by \topskip \advance\dimen@ by-\baselineskip ! \divide\dimen@ by 2 \splittopskip = \topskip % Loop until we get a decent breakpoint. ! {\vbadness=10000 \loop \global\setbox3=\copy0 ! \global\setbox1=\vsplit3 to\dimen@ ! \ifdim\ht3>\dimen@ \global\advance\dimen@ by1pt \repeat}% \setbox0=\vbox to\dimen@{\unvbox1}% \setbox2=\vbox to\dimen@{\unvbox3}% \pagesofar } ! \catcode `\@=\other \message{sectioning,} ! % Define chapters, sections, etc. ! \newcount \chapno ! \newcount \secno \secno=0 ! \newcount \subsecno \subsecno=0 ! \newcount \subsubsecno \subsubsecno=0 % This counter is funny since it counts through charcodes of letters A, B, ... ! \newcount \appendixno \appendixno = `\@ ! \def\appendixletter{\char\the\appendixno} ! ! \newwrite \contentsfile ! % This is called from \setfilename. ! \def\opencontents{\openout \contentsfile = \jobname.toc} % Each @chapter defines this as the name of the chapter. ! % page headings and footings can use it. @section does likewise ! ! \def\thischapter{} \def\thissection{} ! \def\seccheck#1{\if \pageno<0 % ! \errmessage{@#1 not allowed after generating table of contents}\fi ! % ! } ! ! \def\chapternofonts{% ! \let\rawbackslash=\relax% ! \let\frenchspacing=\relax% ! \def\result{\realbackslash result} ! \def\equiv{\realbackslash equiv} ! \def\expansion{\realbackslash expansion} ! \def\print{\realbackslash print} ! \def\TeX{\realbackslash TeX} ! \def\dots{\realbackslash dots} ! \def\copyright{\realbackslash copyright} ! \def\tt{\realbackslash tt} ! \def\bf{\realbackslash bf } ! \def\w{\realbackslash w} ! \def\less{\realbackslash less} ! \def\gtr{\realbackslash gtr} ! \def\hat{\realbackslash hat} ! \def\char{\realbackslash char} ! \def\tclose##1{\realbackslash tclose {##1}} ! \def\code##1{\realbackslash code {##1}} ! \def\samp##1{\realbackslash samp {##1}} ! \def\r##1{\realbackslash r {##1}} ! \def\b##1{\realbackslash b {##1}} ! \def\key##1{\realbackslash key {##1}} ! \def\file##1{\realbackslash file {##1}} ! \def\kbd##1{\realbackslash kbd {##1}} ! % These are redefined because @smartitalic wouldn't work inside xdef. ! \def\i##1{\realbackslash i {##1}} ! \def\cite##1{\realbackslash cite {##1}} ! \def\var##1{\realbackslash var {##1}} ! \def\emph##1{\realbackslash emph {##1}} ! \def\dfn##1{\realbackslash dfn {##1}} ! } \newcount\absseclevel % used to calculate proper heading level --- 3162,3287 ---- % (undoubled) page height minus any material left over from the % previous page. ! \dimen@ = \vsize ! \divide\dimen@ by 2 ! % ! % box0 will be the left-hand column, box2 the right. \setbox0=\vsplit255 to\dimen@ \setbox2=\vsplit255 to\dimen@ \onepageout\pagesofar ! \unvbox255 ! \penalty\outputpenalty } \def\pagesofar{% ! % Re-output the contents of the output page -- any previous material, ! % followed by the two boxes we just split, in box0 and box2. \unvbox\partialpage + % \hsize = \doublecolumnhsize ! \wd0=\hsize \wd2=\hsize ! \hbox to\pagewidth{\box0\hfil\box2}% } \def\enddoublecolumns{% ! \output = {% ! % Split the last of the double-column material. Leave it on the ! % current page, no automatic page break. ! \balancecolumns ! % ! % If we end up splitting too much material for the current page, ! % though, there will be another page break right after this \output ! % invocation ends. Having called \balancecolumns once, we do not ! % want to call it again. Therefore, reset \output to its normal ! % definition right away. (We hope \balancecolumns will never be ! % called on to balance too much material, but if it is, this makes ! % the output somewhat more palatable.) ! \global\output = {\onepageout{\pagecontents\PAGE}}% ! }% ! \eject ! \endgroup % started in \begindoublecolumns ! % ! % \pagegoal was set to the doubled \vsize above, since we restarted ! % the current page. We're now back to normal single-column ! % typesetting, so reset \pagegoal to the normal \vsize (after the ! % \endgroup where \vsize got restored). ! \pagegoal = \vsize } \def\balancecolumns{% ! % Called at the end of the double column material. ! \setbox0 = \vbox{\unvbox255}% like \box255 but more efficient, see p.120. \dimen@ = \ht0 \advance\dimen@ by \topskip \advance\dimen@ by-\baselineskip ! \divide\dimen@ by 2 % target to split to ! %debug\message{final 2-column material height=\the\ht0, target=\the\dimen@.}% \splittopskip = \topskip % Loop until we get a decent breakpoint. ! {% ! \vbadness = 10000 ! \loop ! \global\setbox3 = \copy0 ! \global\setbox1 = \vsplit3 to \dimen@ ! \ifdim\ht3>\dimen@ ! \global\advance\dimen@ by 1pt ! \repeat ! }% ! %debug\message{split to \the\dimen@, column heights: \the\ht1, \the\ht3.}% \setbox0=\vbox to\dimen@{\unvbox1}% \setbox2=\vbox to\dimen@{\unvbox3}% + % \pagesofar } ! \catcode`\@ = \other \message{sectioning,} ! % Chapters, sections, etc. ! \newcount\chapno ! \newcount\secno \secno=0 ! \newcount\subsecno \subsecno=0 ! \newcount\subsubsecno \subsubsecno=0 % This counter is funny since it counts through charcodes of letters A, B, ... ! \newcount\appendixno \appendixno = `\@ ! % \def\appendixletter{\char\the\appendixno} ! % We do the following for the sake of pdftex, which needs the actual ! % letter in the expansion, not just typeset. ! \def\appendixletter{% ! \ifnum\appendixno=`A A% ! \else\ifnum\appendixno=`B B% ! \else\ifnum\appendixno=`C C% ! \else\ifnum\appendixno=`D D% ! \else\ifnum\appendixno=`E E% ! \else\ifnum\appendixno=`F F% ! \else\ifnum\appendixno=`G G% ! \else\ifnum\appendixno=`H H% ! \else\ifnum\appendixno=`I I% ! \else\ifnum\appendixno=`J J% ! \else\ifnum\appendixno=`K K% ! \else\ifnum\appendixno=`L L% ! \else\ifnum\appendixno=`M M% ! \else\ifnum\appendixno=`N N% ! \else\ifnum\appendixno=`O O% ! \else\ifnum\appendixno=`P P% ! \else\ifnum\appendixno=`Q Q% ! \else\ifnum\appendixno=`R R% ! \else\ifnum\appendixno=`S S% ! \else\ifnum\appendixno=`T T% ! \else\ifnum\appendixno=`U U% ! \else\ifnum\appendixno=`V V% ! \else\ifnum\appendixno=`W W% ! \else\ifnum\appendixno=`X X% ! \else\ifnum\appendixno=`Y Y% ! \else\ifnum\appendixno=`Z Z% ! % The \the is necessary, despite appearances, because \appendixletter is ! % expanded while writing the .toc file. \char\appendixno is not ! % expandable, thus it is written literally, thus all appendixes come out ! % with the same letter (or @) in the toc without it. ! \else\char\the\appendixno ! \fi\fi\fi\fi\fi\fi\fi\fi\fi\fi\fi\fi\fi ! \fi\fi\fi\fi\fi\fi\fi\fi\fi\fi\fi\fi\fi} % Each @chapter defines this as the name of the chapter. ! % page headings and footings can use it. @section does likewise. ! \def\thischapter{} ! \def\thissection{} \newcount\absseclevel % used to calculate proper heading level *************** *** 2720,2730 **** } ! \def\thischaptername{No Chapter Title} \outer\def\chapter{\parsearg\chapteryyy} \def\chapteryyy #1{\numhead0{#1}} % normally numhead0 calls chapterzzz ! \def\chapterzzz #1{\seccheck{chapter}% \secno=0 \subsecno=0 \subsubsecno=0 ! \global\advance \chapno by 1 \message{\putwordChapter \the\chapno}% \chapmacro {#1}{\the\chapno}% \gdef\thissection{#1}% --- 3355,3365 ---- } ! % @chapter, @appendix, @unnumbered. \def\thischaptername{No Chapter Title} \outer\def\chapter{\parsearg\chapteryyy} \def\chapteryyy #1{\numhead0{#1}} % normally numhead0 calls chapterzzz ! \def\chapterzzz #1{% \secno=0 \subsecno=0 \subsubsecno=0 ! \global\advance \chapno by 1 \message{\putwordChapter\space \the\chapno}% \chapmacro {#1}{\the\chapno}% \gdef\thissection{#1}% *************** *** 2733,2765 **** % because we don't want its macros evaluated now. \xdef\thischapter{\putwordChapter{} \the\chapno: \noexpand\thischaptername}% ! {\chapternofonts% ! \edef\temp{{\realbackslash chapentry {#1}{\the\chapno}{\noexpand\folio}}}% ! \escapechar=`\\% ! \write \contentsfile \temp % ! \donoderef % \global\let\section = \numberedsec \global\let\subsection = \numberedsubsec \global\let\subsubsection = \numberedsubsubsec ! }} \outer\def\appendix{\parsearg\appendixyyy} \def\appendixyyy #1{\apphead0{#1}} % normally apphead0 calls appendixzzz ! \def\appendixzzz #1{\seccheck{appendix}% \secno=0 \subsecno=0 \subsubsecno=0 ! \global\advance \appendixno by 1 \message{Appendix \appendixletter}% \chapmacro {#1}{\putwordAppendix{} \appendixletter}% \gdef\thissection{#1}% \gdef\thischaptername{#1}% \xdef\thischapter{\putwordAppendix{} \appendixletter: \noexpand\thischaptername}% ! {\chapternofonts% ! \edef\temp{{\realbackslash chapentry ! {#1}{\putwordAppendix{} \appendixletter}{\noexpand\folio}}}% ! \escapechar=`\\% ! \write \contentsfile \temp % ! \appendixnoderef % \global\let\section = \appendixsec \global\let\subsection = \appendixsubsec \global\let\subsubsection = \appendixsubsubsec ! }} % @centerchap is like @unnumbered, but the heading is centered. --- 3368,3400 ---- % because we don't want its macros evaluated now. \xdef\thischapter{\putwordChapter{} \the\chapno: \noexpand\thischaptername}% ! \toks0 = {#1}% ! \edef\temp{\noexpand\writetocentry{\realbackslash chapentry{\the\toks0}% ! {\the\chapno}}}% ! \temp ! \donoderef \global\let\section = \numberedsec \global\let\subsection = \numberedsubsec \global\let\subsubsection = \numberedsubsubsec ! } \outer\def\appendix{\parsearg\appendixyyy} \def\appendixyyy #1{\apphead0{#1}} % normally apphead0 calls appendixzzz ! \def\appendixzzz #1{% \secno=0 \subsecno=0 \subsubsecno=0 ! \global\advance \appendixno by 1 ! \message{\putwordAppendix\space \appendixletter}% \chapmacro {#1}{\putwordAppendix{} \appendixletter}% \gdef\thissection{#1}% \gdef\thischaptername{#1}% \xdef\thischapter{\putwordAppendix{} \appendixletter: \noexpand\thischaptername}% ! \toks0 = {#1}% ! \edef\temp{\noexpand\writetocentry{\realbackslash chapentry{\the\toks0}% ! {\putwordAppendix{} \appendixletter}}}% ! \temp ! \appendixnoderef \global\let\section = \appendixsec \global\let\subsection = \appendixsubsec \global\let\subsubsection = \appendixsubsubsec ! } % @centerchap is like @unnumbered, but the heading is centered. *************** *** 2767,2774 **** \def\centerchapyyy #1{{\let\unnumbchapmacro=\centerchapmacro \unnumberedyyy{#1}}} \outer\def\top{\parsearg\unnumberedyyy} \outer\def\unnumbered{\parsearg\unnumberedyyy} \def\unnumberedyyy #1{\unnmhead0{#1}} % normally unnmhead0 calls unnumberedzzz ! \def\unnumberedzzz #1{\seccheck{unnumbered}% \secno=0 \subsecno=0 \subsubsecno=0 % --- 3402,3411 ---- \def\centerchapyyy #1{{\let\unnumbchapmacro=\centerchapmacro \unnumberedyyy{#1}}} + % @top is like @unnumbered. \outer\def\top{\parsearg\unnumberedyyy} + \outer\def\unnumbered{\parsearg\unnumberedyyy} \def\unnumberedyyy #1{\unnmhead0{#1}} % normally unnmhead0 calls unnumberedzzz ! \def\unnumberedzzz #1{% \secno=0 \subsecno=0 \subsubsecno=0 % *************** *** 2782,2925 **** % as a result of the \message, we just want `@cite' itself. We use % \the to achieve this: TeX expands \the only once, ! % simply yielding the contents of the . \toks0 = {#1}\message{(\the\toks0)}% % \unnumbchapmacro {#1}% \gdef\thischapter{#1}\gdef\thissection{#1}% ! {\chapternofonts% ! \edef\temp{{\realbackslash unnumbchapentry {#1}{\noexpand\folio}}}% ! \escapechar=`\\% ! \write \contentsfile \temp % ! \unnumbnoderef % \global\let\section = \unnumberedsec \global\let\subsection = \unnumberedsubsec \global\let\subsubsection = \unnumberedsubsubsec ! }} \outer\def\numberedsec{\parsearg\secyyy} \def\secyyy #1{\numhead1{#1}} % normally calls seczzz ! \def\seczzz #1{\seccheck{section}% \subsecno=0 \subsubsecno=0 \global\advance \secno by 1 % \gdef\thissection{#1}\secheading {#1}{\the\chapno}{\the\secno}% ! {\chapternofonts% ! \edef\temp{{\realbackslash secentry % ! {#1}{\the\chapno}{\the\secno}{\noexpand\folio}}}% ! \escapechar=`\\% ! \write \contentsfile \temp % ! \donoderef % ! \penalty 10000 % ! }} \outer\def\appendixsection{\parsearg\appendixsecyyy} \outer\def\appendixsec{\parsearg\appendixsecyyy} \def\appendixsecyyy #1{\apphead1{#1}} % normally calls appendixsectionzzz ! \def\appendixsectionzzz #1{\seccheck{appendixsection}% \subsecno=0 \subsubsecno=0 \global\advance \secno by 1 % \gdef\thissection{#1}\secheading {#1}{\appendixletter}{\the\secno}% ! {\chapternofonts% ! \edef\temp{{\realbackslash secentry % ! {#1}{\appendixletter}{\the\secno}{\noexpand\folio}}}% ! \escapechar=`\\% ! \write \contentsfile \temp % ! \appendixnoderef % ! \penalty 10000 % ! }} \outer\def\unnumberedsec{\parsearg\unnumberedsecyyy} \def\unnumberedsecyyy #1{\unnmhead1{#1}} % normally calls unnumberedseczzz ! \def\unnumberedseczzz #1{\seccheck{unnumberedsec}% \plainsecheading {#1}\gdef\thissection{#1}% ! {\chapternofonts% ! \edef\temp{{\realbackslash unnumbsecentry{#1}{\noexpand\folio}}}% ! \escapechar=`\\% ! \write \contentsfile \temp % ! \unnumbnoderef % ! \penalty 10000 % ! }} \outer\def\numberedsubsec{\parsearg\numberedsubsecyyy} \def\numberedsubsecyyy #1{\numhead2{#1}} % normally calls numberedsubseczzz ! \def\numberedsubseczzz #1{\seccheck{subsection}% \gdef\thissection{#1}\subsubsecno=0 \global\advance \subsecno by 1 % \subsecheading {#1}{\the\chapno}{\the\secno}{\the\subsecno}% ! {\chapternofonts% ! \edef\temp{{\realbackslash subsecentry % ! {#1}{\the\chapno}{\the\secno}{\the\subsecno}{\noexpand\folio}}}% ! \escapechar=`\\% ! \write \contentsfile \temp % ! \donoderef % ! \penalty 10000 % ! }} \outer\def\appendixsubsec{\parsearg\appendixsubsecyyy} \def\appendixsubsecyyy #1{\apphead2{#1}} % normally calls appendixsubseczzz ! \def\appendixsubseczzz #1{\seccheck{appendixsubsec}% \gdef\thissection{#1}\subsubsecno=0 \global\advance \subsecno by 1 % \subsecheading {#1}{\appendixletter}{\the\secno}{\the\subsecno}% ! {\chapternofonts% ! \edef\temp{{\realbackslash subsecentry % ! {#1}{\appendixletter}{\the\secno}{\the\subsecno}{\noexpand\folio}}}% ! \escapechar=`\\% ! \write \contentsfile \temp % ! \appendixnoderef % ! \penalty 10000 % ! }} \outer\def\unnumberedsubsec{\parsearg\unnumberedsubsecyyy} \def\unnumberedsubsecyyy #1{\unnmhead2{#1}} %normally calls unnumberedsubseczzz ! \def\unnumberedsubseczzz #1{\seccheck{unnumberedsubsec}% \plainsubsecheading {#1}\gdef\thissection{#1}% ! {\chapternofonts% ! \edef\temp{{\realbackslash unnumbsubsecentry{#1}{\noexpand\folio}}}% ! \escapechar=`\\% ! \write \contentsfile \temp % ! \unnumbnoderef % ! \penalty 10000 % ! }} \outer\def\numberedsubsubsec{\parsearg\numberedsubsubsecyyy} \def\numberedsubsubsecyyy #1{\numhead3{#1}} % normally numberedsubsubseczzz ! \def\numberedsubsubseczzz #1{\seccheck{subsubsection}% \gdef\thissection{#1}\global\advance \subsubsecno by 1 % \subsubsecheading {#1} {\the\chapno}{\the\secno}{\the\subsecno}{\the\subsubsecno}% ! {\chapternofonts% ! \edef\temp{{\realbackslash subsubsecentry % ! {#1} ! {\the\chapno}{\the\secno}{\the\subsecno}{\the\subsubsecno} ! {\noexpand\folio}}}% ! \escapechar=`\\% ! \write \contentsfile \temp % ! \donoderef % ! \penalty 10000 % ! }} \outer\def\appendixsubsubsec{\parsearg\appendixsubsubsecyyy} \def\appendixsubsubsecyyy #1{\apphead3{#1}} % normally appendixsubsubseczzz ! \def\appendixsubsubseczzz #1{\seccheck{appendixsubsubsec}% \gdef\thissection{#1}\global\advance \subsubsecno by 1 % \subsubsecheading {#1} {\appendixletter}{\the\secno}{\the\subsecno}{\the\subsubsecno}% ! {\chapternofonts% ! \edef\temp{{\realbackslash subsubsecentry{#1}% ! {\appendixletter} ! {\the\secno}{\the\subsecno}{\the\subsubsecno}{\noexpand\folio}}}% ! \escapechar=`\\% ! \write \contentsfile \temp % ! \appendixnoderef % ! \penalty 10000 % ! }} \outer\def\unnumberedsubsubsec{\parsearg\unnumberedsubsubsecyyy} \def\unnumberedsubsubsecyyy #1{\unnmhead3{#1}} %normally unnumberedsubsubseczzz ! \def\unnumberedsubsubseczzz #1{\seccheck{unnumberedsubsubsec}% \plainsubsubsecheading {#1}\gdef\thissection{#1}% ! {\chapternofonts% ! \edef\temp{{\realbackslash unnumbsubsubsecentry{#1}{\noexpand\folio}}}% ! \escapechar=`\\% ! \write \contentsfile \temp % ! \unnumbnoderef % ! \penalty 10000 % ! }} % These are variants which are not "outer", so they can appear in @ifinfo. --- 3419,3555 ---- % as a result of the \message, we just want `@cite' itself. We use % \the to achieve this: TeX expands \the only once, ! % simply yielding the contents of . (We also do this for ! % the toc entries.) \toks0 = {#1}\message{(\the\toks0)}% % \unnumbchapmacro {#1}% \gdef\thischapter{#1}\gdef\thissection{#1}% ! \toks0 = {#1}% ! \edef\temp{\noexpand\writetocentry{\realbackslash unnumbchapentry{\the\toks0}}}% ! \temp ! \unnumbnoderef \global\let\section = \unnumberedsec \global\let\subsection = \unnumberedsubsec \global\let\subsubsection = \unnumberedsubsubsec ! } + % Sections. \outer\def\numberedsec{\parsearg\secyyy} \def\secyyy #1{\numhead1{#1}} % normally calls seczzz ! \def\seczzz #1{% \subsecno=0 \subsubsecno=0 \global\advance \secno by 1 % \gdef\thissection{#1}\secheading {#1}{\the\chapno}{\the\secno}% ! \toks0 = {#1}% ! \edef\temp{\noexpand\writetocentry{\realbackslash secentry{\the\toks0}% ! {\the\chapno}{\the\secno}}}% ! \temp ! \donoderef ! \nobreak ! } \outer\def\appendixsection{\parsearg\appendixsecyyy} \outer\def\appendixsec{\parsearg\appendixsecyyy} \def\appendixsecyyy #1{\apphead1{#1}} % normally calls appendixsectionzzz ! \def\appendixsectionzzz #1{% \subsecno=0 \subsubsecno=0 \global\advance \secno by 1 % \gdef\thissection{#1}\secheading {#1}{\appendixletter}{\the\secno}% ! \toks0 = {#1}% ! \edef\temp{\noexpand\writetocentry{\realbackslash secentry{\the\toks0}% ! {\appendixletter}{\the\secno}}}% ! \temp ! \appendixnoderef ! \nobreak ! } \outer\def\unnumberedsec{\parsearg\unnumberedsecyyy} \def\unnumberedsecyyy #1{\unnmhead1{#1}} % normally calls unnumberedseczzz ! \def\unnumberedseczzz #1{% \plainsecheading {#1}\gdef\thissection{#1}% ! \toks0 = {#1}% ! \edef\temp{\noexpand\writetocentry{\realbackslash unnumbsecentry{\the\toks0}}}% ! \temp ! \unnumbnoderef ! \nobreak ! } + % Subsections. \outer\def\numberedsubsec{\parsearg\numberedsubsecyyy} \def\numberedsubsecyyy #1{\numhead2{#1}} % normally calls numberedsubseczzz ! \def\numberedsubseczzz #1{% \gdef\thissection{#1}\subsubsecno=0 \global\advance \subsecno by 1 % \subsecheading {#1}{\the\chapno}{\the\secno}{\the\subsecno}% ! \toks0 = {#1}% ! \edef\temp{\noexpand\writetocentry{\realbackslash subsecentry{\the\toks0}% ! {\the\chapno}{\the\secno}{\the\subsecno}}}% ! \temp ! \donoderef ! \nobreak ! } \outer\def\appendixsubsec{\parsearg\appendixsubsecyyy} \def\appendixsubsecyyy #1{\apphead2{#1}} % normally calls appendixsubseczzz ! \def\appendixsubseczzz #1{% \gdef\thissection{#1}\subsubsecno=0 \global\advance \subsecno by 1 % \subsecheading {#1}{\appendixletter}{\the\secno}{\the\subsecno}% ! \toks0 = {#1}% ! \edef\temp{\noexpand\writetocentry{\realbackslash subsecentry{\the\toks0}% ! {\appendixletter}{\the\secno}{\the\subsecno}}}% ! \temp ! \appendixnoderef ! \nobreak ! } \outer\def\unnumberedsubsec{\parsearg\unnumberedsubsecyyy} \def\unnumberedsubsecyyy #1{\unnmhead2{#1}} %normally calls unnumberedsubseczzz ! \def\unnumberedsubseczzz #1{% \plainsubsecheading {#1}\gdef\thissection{#1}% ! \toks0 = {#1}% ! \edef\temp{\noexpand\writetocentry{\realbackslash unnumbsubsecentry% ! {\the\toks0}}}% ! \temp ! \unnumbnoderef ! \nobreak ! } + % Subsubsections. \outer\def\numberedsubsubsec{\parsearg\numberedsubsubsecyyy} \def\numberedsubsubsecyyy #1{\numhead3{#1}} % normally numberedsubsubseczzz ! \def\numberedsubsubseczzz #1{% \gdef\thissection{#1}\global\advance \subsubsecno by 1 % \subsubsecheading {#1} {\the\chapno}{\the\secno}{\the\subsecno}{\the\subsubsecno}% ! \toks0 = {#1}% ! \edef\temp{\noexpand\writetocentry{\realbackslash subsubsecentry{\the\toks0}% ! {\the\chapno}{\the\secno}{\the\subsecno}{\the\subsubsecno}}}% ! \temp ! \donoderef ! \nobreak ! } \outer\def\appendixsubsubsec{\parsearg\appendixsubsubsecyyy} \def\appendixsubsubsecyyy #1{\apphead3{#1}} % normally appendixsubsubseczzz ! \def\appendixsubsubseczzz #1{% \gdef\thissection{#1}\global\advance \subsubsecno by 1 % \subsubsecheading {#1} {\appendixletter}{\the\secno}{\the\subsecno}{\the\subsubsecno}% ! \toks0 = {#1}% ! \edef\temp{\noexpand\writetocentry{\realbackslash subsubsecentry{\the\toks0}% ! {\appendixletter}{\the\secno}{\the\subsecno}{\the\subsubsecno}}}% ! \temp ! \appendixnoderef ! \nobreak ! } \outer\def\unnumberedsubsubsec{\parsearg\unnumberedsubsubsecyyy} \def\unnumberedsubsubsecyyy #1{\unnmhead3{#1}} %normally unnumberedsubsubseczzz ! \def\unnumberedsubsubseczzz #1{% \plainsubsubsecheading {#1}\gdef\thissection{#1}% ! \toks0 = {#1}% ! \edef\temp{\noexpand\writetocentry{\realbackslash unnumbsubsubsecentry% ! {\the\toks0}}}% ! \temp ! \unnumbnoderef ! \nobreak ! } % These are variants which are not "outer", so they can appear in @ifinfo. *************** *** 2950,2955 **** % Define @majorheading, @heading and @subheading ! % NOTE on use of \vbox for chapter headings, section headings, and ! % such: % 1) We use \vbox rather than the earlier \line to permit % overlong headings to fold. --- 3580,3584 ---- % Define @majorheading, @heading and @subheading ! % NOTE on use of \vbox for chapter headings, section headings, and such: % 1) We use \vbox rather than the earlier \line to permit % overlong headings to fold. *************** *** 2998,3007 **** \def\setchapternewpage #1 {\csname CHAPPAG#1\endcsname} ! \def\CHAPPAGoff{ \global\let\contentsalignmacro = \chappager \global\let\pchapsepmacro=\chapbreak \global\let\pagealignmacro=\chappager} ! \def\CHAPPAGon{ \global\let\contentsalignmacro = \chappager \global\let\pchapsepmacro=\chappager --- 3627,3636 ---- \def\setchapternewpage #1 {\csname CHAPPAG#1\endcsname} ! \def\CHAPPAGoff{% \global\let\contentsalignmacro = \chappager \global\let\pchapsepmacro=\chapbreak \global\let\pagealignmacro=\chappager} ! \def\CHAPPAGon{% \global\let\contentsalignmacro = \chappager \global\let\pchapsepmacro=\chappager *************** *** 3057,3061 **** \chapoddpage {\chapfonts \vbox{\hyphenpenalty=10000\tolerance=5000 \parindent=0pt\raggedright ! \rm #1\hfill}}\bigskip \par\penalty 10000 % } --- 3686,3690 ---- \chapoddpage {\chapfonts \vbox{\hyphenpenalty=10000\tolerance=5000 \parindent=0pt\raggedright ! \rm #1\hfill}}\bigskip \par\nobreak } *************** *** 3068,3072 **** \chapoddpage {\chapfonts \vbox{\hyphenpenalty=10000\tolerance=5000 \parindent=0pt ! \hfill {\rm #1}\hfill}}\bigskip \par\penalty 10000 % } --- 3697,3701 ---- \chapoddpage {\chapfonts \vbox{\hyphenpenalty=10000\tolerance=5000 \parindent=0pt ! \hfill {\rm #1}\hfill}}\bigskip \par\nobreak } *************** *** 3097,3101 **** % Print any size section title. ! % % #1 is the section type (sec/subsec/subsubsec), #2 is the section % number (maybe empty), #3 the text. --- 3726,3730 ---- % Print any size section title. ! % % #1 is the section type (sec/subsec/subsubsec), #2 is the section % number (maybe empty), #3 the text. *************** *** 3121,3129 **** ! \message{toc printing,} ! % Finish up the main text and prepare to read what we've written ! % to \contentsfile. \newskip\contentsrightmargin \contentsrightmargin=1in \def\startcontents#1{% % If @setchapternewpage on, and @headings double, the contents should --- 3750,3780 ---- ! \message{toc,} ! % Table of contents. ! \newwrite\tocfile ! ! % Write an entry to the toc file, opening it if necessary. ! % Called from @chapter, etc. We supply {\folio} at the end of the ! % argument, which will end up as the last argument to the \...entry macro. ! % ! % We open the .toc file here instead of at @setfilename or any other ! % given time so that @contents can be put in the document anywhere. ! % ! \newif\iftocfileopened ! \def\writetocentry#1{% ! \iftocfileopened\else ! \immediate\openout\tocfile = \jobname.toc ! \global\tocfileopenedtrue ! \fi ! \iflinks \write\tocfile{#1{\folio}}\fi ! } \newskip\contentsrightmargin \contentsrightmargin=1in + \newcount\savepageno + \newcount\lastnegativepageno \lastnegativepageno = -1 + + % Finish up the main text and prepare to read what we've written + % to \tocfile. + % \def\startcontents#1{% % If @setchapternewpage on, and @headings double, the contents should *************** *** 3132,3161 **** % From: Torbjorn Granlund \contentsalignmacro ! \immediate\closeout \contentsfile ! \ifnum \pageno>0 ! \pageno = -1 % Request roman numbered pages. ! \fi % Don't need to put `Contents' or `Short Contents' in the headline. % It is abundantly clear what they are. \unnumbchapmacro{#1}\def\thischapter{}% \begingroup % Set up to handle contents files properly. \catcode`\\=0 \catcode`\{=1 \catcode`\}=2 \catcode`\@=11 ! \catcode`\^=7 % to see ^^e4 as \"a etc. juha@piuha.ydi.vtt.fi \raggedbottom % Worry more about breakpoints than the bottom. \advance\hsize by -\contentsrightmargin % Don't use the full line length. } % Normal (long) toc. ! \outer\def\contents{% ! \startcontents{\putwordTableofContents}% ! \input \jobname.toc \endgroup ! \vfill \eject } % And just the chapters. ! \outer\def\summarycontents{% ! \startcontents{\putwordShortContents}% % \let\chapentry = \shortchapentry --- 3783,3824 ---- % From: Torbjorn Granlund \contentsalignmacro ! \immediate\closeout\tocfile ! % % Don't need to put `Contents' or `Short Contents' in the headline. % It is abundantly clear what they are. \unnumbchapmacro{#1}\def\thischapter{}% + \savepageno = \pageno \begingroup % Set up to handle contents files properly. \catcode`\\=0 \catcode`\{=1 \catcode`\}=2 \catcode`\@=11 ! % We can't do this, because then an actual ^ in a section ! % title fails, e.g., @chapter ^ -- exponentiation. --karl, 9jul97. ! %\catcode`\^=7 % to see ^^e4 as \"a etc. juha@piuha.ydi.vtt.fi \raggedbottom % Worry more about breakpoints than the bottom. \advance\hsize by -\contentsrightmargin % Don't use the full line length. + % + % Roman numerals for page numbers. + \ifnum \pageno>0 \pageno = \lastnegativepageno \fi } % Normal (long) toc. ! \def\contents{% ! \startcontents{\putwordTOC}% ! \openin 1 \jobname.toc ! \ifeof 1 \else ! \closein 1 ! \input \jobname.toc ! \fi ! \vfill \eject ! \contentsalignmacro % in case @setchapternewpage odd is in effect ! \pdfmakeoutlines \endgroup ! \lastnegativepageno = \pageno ! \pageno = \savepageno } % And just the chapters. ! \def\summarycontents{% ! \startcontents{\putwordShortTOC}% % \let\chapentry = \shortchapentry *************** *** 3173,3182 **** \def\subsubsecentry ##1##2##3##4##5##6{} \def\unnumbsubsubsecentry ##1##2{} ! \input \jobname.toc \endgroup ! \vfill \eject } \let\shortcontents = \summarycontents % These macros generate individual entries in the table of contents. % The first argument is the chapter or section name. --- 3836,3856 ---- \def\subsubsecentry ##1##2##3##4##5##6{} \def\unnumbsubsubsecentry ##1##2{} ! \openin 1 \jobname.toc ! \ifeof 1 \else ! \closein 1 ! \input \jobname.toc ! \fi ! \vfill \eject ! \contentsalignmacro % in case @setchapternewpage odd is in effect \endgroup ! \lastnegativepageno = \pageno ! \pageno = \savepageno } \let\shortcontents = \summarycontents + \ifpdf + \pdfcatalog{/PageMode /UseOutlines}% + \fi + % These macros generate individual entries in the table of contents. % The first argument is the chapter or section name. *************** *** 3189,3193 **** % See comments in \dochapentry re vbox and related settings \def\shortchapentry#1#2#3{% ! \tocentry{\shortchaplabel{#2}\labelspace #1}{\doshortpageno{#3}}% } --- 3863,3867 ---- % See comments in \dochapentry re vbox and related settings \def\shortchapentry#1#2#3{% ! \tocentry{\shortchaplabel{#2}\labelspace #1}{\doshortpageno\bgroup#3\egroup}% } *************** *** 3197,3204 **** % command in the toc file for appendices, instead of using \chapentry % for both, but it doesn't seem worth it. ! \setbox0 = \hbox{\shortcontrm \putwordAppendix } ! \newdimen\shortappendixwidth \shortappendixwidth = \wd0 ! \def\shortchaplabel#1{% % We typeset #1 in a box of constant width, regardless of the text of % #1, so the chapter titles will come out aligned. --- 3871,3882 ---- % command in the toc file for appendices, instead of using \chapentry % for both, but it doesn't seem worth it. ! % ! \newdimen\shortappendixwidth ! % \def\shortchaplabel#1{% + % Compute width of word "Appendix", may change with language. + \setbox0 = \hbox{\shortcontrm \putwordAppendix}% + \shortappendixwidth = \wd0 + % % We typeset #1 in a box of constant width, regardless of the text of % #1, so the chapter titles will come out aligned. *************** *** 3215,3219 **** \def\unnumbchapentry#1#2{\dochapentry{#1}{#2}} ! \def\shortunnumberedentry#1#2{\tocentry{#1}{\doshortpageno{#2}}} % Sections. --- 3893,3897 ---- \def\unnumbchapentry#1#2{\dochapentry{#1}{#2}} ! \def\shortunnumberedentry#1#2{\tocentry{#1}{\doshortpageno\bgroup#2\egroup}} % Sections. *************** *** 3242,3246 **** \begingroup \chapentryfonts ! \tocentry{#1}{\dopageno{#2}}% \endgroup \nobreak\vskip .25\baselineskip plus.1\baselineskip --- 3920,3924 ---- \begingroup \chapentryfonts ! \tocentry{#1}{\dopageno\bgroup#2\egroup}% \endgroup \nobreak\vskip .25\baselineskip plus.1\baselineskip *************** *** 3249,3263 **** \def\dosecentry#1#2{\begingroup \secentryfonts \leftskip=\tocindent ! \tocentry{#1}{\dopageno{#2}}% \endgroup} \def\dosubsecentry#1#2{\begingroup \subsecentryfonts \leftskip=2\tocindent ! \tocentry{#1}{\dopageno{#2}}% \endgroup} \def\dosubsubsecentry#1#2{\begingroup \subsubsecentryfonts \leftskip=3\tocindent ! \tocentry{#1}{\dopageno{#2}}% \endgroup} --- 3927,3941 ---- \def\dosecentry#1#2{\begingroup \secentryfonts \leftskip=\tocindent ! \tocentry{#1}{\dopageno\bgroup#2\egroup}% \endgroup} \def\dosubsecentry#1#2{\begingroup \subsecentryfonts \leftskip=2\tocindent ! \tocentry{#1}{\dopageno\bgroup#2\egroup}% \endgroup} \def\dosubsubsecentry#1#2{\begingroup \subsubsecentryfonts \leftskip=3\tocindent ! \tocentry{#1}{\dopageno\bgroup#2\egroup}% \endgroup} *************** *** 3266,3274 **** % can't do that in the \entry macro, since index entries might consist % of hyphenated-identifiers-that-do-not-fit-on-a-line-and-nothing-else.) - % - % \turnoffactive is for the sake of @" used for umlauts. \def\tocentry#1#2{\begingroup \vskip 0pt plus1pt % allow a little stretch for the sake of nice page breaks ! \entry{\turnoffactive #1}{\turnoffactive #2}% \endgroup} --- 3944,3953 ---- % can't do that in the \entry macro, since index entries might consist % of hyphenated-identifiers-that-do-not-fit-on-a-line-and-nothing-else.) \def\tocentry#1#2{\begingroup \vskip 0pt plus1pt % allow a little stretch for the sake of nice page breaks ! % Do not use \turnoffactive in these arguments. Since the toc is ! % typeset in cmr, so characters such as _ would come out wrong; we ! % have to do the usual translation tricks. ! \entry{#1}{#2}% \endgroup} *************** *** 3286,3289 **** --- 3965,3969 ---- \message{environments,} + % @foo ... @end foo. % Since these characters are used in examples, it should be an even number of *************** *** 3336,3364 **** \def\tex{\begingroup ! \catcode `\\=0 \catcode `\{=1 \catcode `\}=2 ! \catcode `\$=3 \catcode `\&=4 \catcode `\#=6 ! \catcode `\^=7 \catcode `\_=8 \catcode `\~=13 \let~=\tie ! \catcode `\%=14 ! \catcode 43=12 % plus ! \catcode`\"=12 ! \catcode`\==12 ! \catcode`\|=12 ! \catcode`\<=12 ! \catcode`\>=12 ! \escapechar=`\\ ! % ! \let\,=\ptexcomma ! \let\~=\ptextilde ! \let\{=\ptexlbrace ! \let\}=\ptexrbrace ! \let\.=\ptexdot ! \let\*=\ptexstar ! \let\dots=\ptexdots ! \def\endldots{\mathinner{\ldots\ldots\ldots\ldots}} ! \def\enddots{\relax\ifmmode\endldots\else$\mathsurround=0pt \endldots\,$\fi} ! \def\@{@}% ! \let\bullet=\ptexbullet ! \let\b=\ptexb \let\c=\ptexc \let\i=\ptexi \let\t=\ptext ! % \let\Etex=\endgroup} --- 4016,4049 ---- \def\tex{\begingroup ! \catcode `\\=0 \catcode `\{=1 \catcode `\}=2 ! \catcode `\$=3 \catcode `\&=4 \catcode `\#=6 ! \catcode `\^=7 \catcode `\_=8 \catcode `\~=13 \let~=\tie ! \catcode `\%=14 ! \catcode 43=12 % plus ! \catcode`\"=12 ! \catcode`\==12 ! \catcode`\|=12 ! \catcode`\<=12 ! \catcode`\>=12 ! \escapechar=`\\ ! % ! \let\b=\ptexb ! \let\bullet=\ptexbullet ! \let\c=\ptexc ! \let\,=\ptexcomma ! \let\.=\ptexdot ! \let\dots=\ptexdots ! \let\equiv=\ptexequiv ! \let\!=\ptexexclam ! \let\i=\ptexi ! \let\{=\ptexlbrace ! \let\+=\tabalign ! \let\}=\ptexrbrace ! \let\*=\ptexstar ! \let\t=\ptext ! % ! \def\endldots{\mathinner{\ldots\ldots\ldots\ldots}}% ! \def\enddots{\relax\ifmmode\endldots\else$\mathsurround=0pt \endldots\,$\fi}% ! \def\@{@}% \let\Etex=\endgroup} *************** *** 3405,3410 **** \let\nonarrowing=\relax ! %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% ! % \cartouche: draw rectangle w/rounded corners around argument \font\circle=lcircle10 \newdimen\circthick --- 4090,4095 ---- \let\nonarrowing=\relax ! % @cartouche ... @end cartouche: draw rectangle w/rounded corners around ! % environment contents. \font\circle=lcircle10 \newdimen\circthick *************** *** 3433,3439 **** \advance\cartinner by-\rskip \cartouter=\hsize ! \advance\cartouter by 18pt % allow for 3pt kerns on either % side, and for 6pt waste from ! % each corner char \normbskip=\baselineskip \normpskip=\parskip \normlskip=\lineskip % Flag to tell @lisp, etc., not to narrow margin. --- 4118,4124 ---- \advance\cartinner by-\rskip \cartouter=\hsize ! \advance\cartouter by 18.4pt % allow for 3pt kerns on either % side, and for 6pt waste from ! % each corner char, and rule thickness \normbskip=\baselineskip \normpskip=\parskip \normlskip=\lineskip % Flag to tell @lisp, etc., not to narrow margin. *************** *** 3489,3534 **** } ! % To ending an @example-like environment, we first end the paragraph ! % (via \afterenvbreak's vertical glue), and then the group. That way we ! % keep the zero \parskip that the environments set -- \parskip glue ! % will be inserted at the beginning of the next paragraph in the ! % document, after the environment. % ! \def\nonfillfinish{\afterenvbreak\endgroup}% ! % This macro is \def\lisp{\begingroup \nonfillstart \let\Elisp = \nonfillfinish \tt ! \rawbackslash % have \ input char produce \ char from current font ! \gobble } ! % Define the \E... control sequence only if we are inside the ! % environment, so the error checking in \end will work. ! % ! % We must call \lisp last in the definition, since it reads the ! % return following the @example (or whatever) command. ! % \def\example{\begingroup \def\Eexample{\nonfillfinish\endgroup}\lisp} - \def\smallexample{\begingroup \def\Esmallexample{\nonfillfinish\endgroup}\lisp} - \def\smalllisp{\begingroup \def\Esmalllisp{\nonfillfinish\endgroup}\lisp} ! % @smallexample and @smalllisp. This is not used unless the @smallbook ! % command is given. Originally contributed by Pavel@xerox. ! % \def\smalllispx{\begingroup ! \nonfillstart ! \let\Esmalllisp = \nonfillfinish ! \let\Esmallexample = \nonfillfinish ! % ! % Smaller fonts for small examples. ! \indexfonts \tt ! \rawbackslash % make \ output the \ character from the current font (tt) ! \gobble } ! % This is @display; same as @lisp except use roman font. % \def\display{\begingroup --- 4174,4223 ---- } ! % Define the \E... control sequence only if we are inside the particular ! % environment, so the error checking in \end will work. % ! % To end an @example-like environment, we first end the paragraph (via ! % \afterenvbreak's vertical glue), and then the group. That way we keep ! % the zero \parskip that the environments set -- \parskip glue will be ! % inserted at the beginning of the next paragraph in the document, after ! % the environment. ! % ! \def\nonfillfinish{\afterenvbreak\endgroup} ! % @lisp: indented, narrowed, typewriter font. \def\lisp{\begingroup \nonfillstart \let\Elisp = \nonfillfinish \tt ! \let\kbdfont = \kbdexamplefont % Allow @kbd to do something special. ! \gobble % eat return } ! % @example: Same as @lisp. \def\example{\begingroup \def\Eexample{\nonfillfinish\endgroup}\lisp} ! % @small... is usually equivalent to the non-small (@smallbook ! % redefines). We must call \example (or whatever) last in the ! % definition, since it reads the return following the @example (or ! % whatever) command. ! % ! % This actually allows (for example) @end display inside an ! % @smalldisplay. Too bad, but makeinfo will catch the error anyway. ! % ! \def\smalldisplay{\begingroup\def\Esmalldisplay{\nonfillfinish\endgroup}\display} ! \def\smallexample{\begingroup\def\Esmallexample{\nonfillfinish\endgroup}\lisp} ! \def\smallformat{\begingroup\def\Esmallformat{\nonfillfinish\endgroup}\format} ! \def\smalllisp{\begingroup\def\Esmalllisp{\nonfillfinish\endgroup}\lisp} ! ! % Real @smallexample and @smalllisp (when @smallbook): use smaller fonts. ! % Originally contributed by Pavel@xerox. \def\smalllispx{\begingroup ! \def\Esmalllisp{\nonfillfinish\endgroup}% ! \def\Esmallexample{\nonfillfinish\endgroup}% ! \smallfonts ! \lisp } ! % @display: same as @lisp except keep current font. % \def\display{\begingroup *************** *** 3538,3542 **** } ! % This is @format; same as @display except don't narrow margins. % \def\format{\begingroup --- 4227,4239 ---- } ! % @smalldisplay (when @smallbook): @display plus smaller fonts. ! % ! \def\smalldisplayx{\begingroup ! \def\Esmalldisplay{\nonfillfinish\endgroup}% ! \smallfonts \rm ! \display ! } ! ! % @format: same as @display except don't narrow margins. % \def\format{\begingroup *************** *** 3547,3558 **** } ! % @flushleft (same as @format) and @flushright. % ! \def\flushleft{\begingroup ! \let\nonarrowing = t ! \nonfillstart ! \let\Eflushleft = \nonfillfinish ! \gobble } \def\flushright{\begingroup \let\nonarrowing = t --- 4244,4261 ---- } ! % @smallformat (when @smallbook): @format plus smaller fonts. % ! \def\smallformatx{\begingroup ! \def\Esmallformat{\nonfillfinish\endgroup}% ! \smallfonts \rm ! \format } + + % @flushleft (same as @format). + % + \def\flushleft{\begingroup \def\Eflushleft{\nonfillfinish\endgroup}\format} + + % @flushright. + % \def\flushright{\begingroup \let\nonarrowing = t *************** *** 3560,3564 **** \let\Eflushright = \nonfillfinish \advance\leftskip by 0pt plus 1fill ! \gobble} % @quotation does normal linebreaking (hence we can't use \nonfillstart) --- 4263,4268 ---- \let\Eflushright = \nonfillfinish \advance\leftskip by 0pt plus 1fill ! \gobble ! } % @quotation does normal linebreaking (hence we can't use \nonfillstart) *************** *** 3583,3589 **** } \message{defuns,} ! % Define formatter for defuns ! % First, allow user to change definition object font (\df) internally \def\setdeffont #1 {\csname DEF#1\endcsname} --- 4287,4295 ---- } + \message{defuns,} ! % @defun etc. ! ! % Allow user to change definition object font (\df) internally \def\setdeffont #1 {\csname DEF#1\endcsname} *************** *** 3619,3624 **** % Definitions of (, ) and & used in args for functions. % This is the definition of ( outside of all parentheses. ! \gdef\oprm#1 {{\rm\char`\(}#1 \bf \let(=\opnested % ! \global\advance\parencount by 1 } % % This is the definition of ( when already inside a level of parens. --- 4325,4331 ---- % Definitions of (, ) and & used in args for functions. % This is the definition of ( outside of all parentheses. ! \gdef\oprm#1 {{\rm\char`\(}#1 \bf \let(=\opnested ! \global\advance\parencount by 1 ! } % % This is the definition of ( when already inside a level of parens. *************** *** 3626,3632 **** % \gdef\clrm{% Print a paren in roman if it is taking us back to depth of 0. ! % also in that case restore the outer-level definition of (. ! \ifnum \parencount=1 {\rm \char `\)}\sl \let(=\oprm \else \char `\) \fi ! \global\advance \parencount by -1 } % If we encounter &foo, then turn on ()-hacking afterwards \gdef\amprm#1 {{\rm\}\let(=\oprm \let)=\clrm\ } --- 4333,4339 ---- % \gdef\clrm{% Print a paren in roman if it is taking us back to depth of 0. ! % also in that case restore the outer-level definition of (. ! \ifnum \parencount=1 {\rm \char `\)}\sl \let(=\oprm \else \char `\) \fi ! \global\advance \parencount by -1 } % If we encounter &foo, then turn on ()-hacking afterwards \gdef\amprm#1 {{\rm\}\let(=\oprm \let)=\clrm\ } *************** *** 3636,3641 **** %% These parens (in \boldbrax) actually are a little bolder than the %% contained text. This is especially needed for [ and ] ! \def\opnr{{\sf\char`\(}} \def\clnr{{\sf\char`\)}} \def\ampnr{\&} ! \def\lbrb{{\bf\char`\[}} \def\rbrb{{\bf\char`\]}} % First, defname, which formats the header line itself. --- 4343,4357 ---- %% These parens (in \boldbrax) actually are a little bolder than the %% contained text. This is especially needed for [ and ] ! \def\opnr{{\sf\char`\(}\global\advance\parencount by 1 } ! \def\clnr{{\sf\char`\)}\global\advance\parencount by -1 } ! \let\ampnr = \& ! \def\lbrb{{\bf\char`\[}} ! \def\rbrb{{\bf\char`\]}} ! ! % Active &'s sneak into the index arguments, so make sure it's defined. ! { ! \catcode`& = 13 ! \global\let& = \ampnr ! } % First, defname, which formats the header line itself. *************** *** 3648,3658 **** \dimen2=\leftskip \advance\dimen2 by -\defbodyindent ! \dimen3=\rightskip ! \advance\dimen3 by -\defbodyindent ! \noindent % \setbox0=\hbox{\hskip \deflastargmargin{\rm #2}\hskip \deftypemargin}% \dimen0=\hsize \advance \dimen0 by -\wd0 % compute size for first line \dimen1=\hsize \advance \dimen1 by -\defargsindent %size for continuations ! \parshape 2 0in \dimen0 \defargsindent \dimen1 % % Now output arg 2 ("Function" or some such) % ending at \deftypemargin from the right margin, --- 4364,4372 ---- \dimen2=\leftskip \advance\dimen2 by -\defbodyindent ! \noindent \setbox0=\hbox{\hskip \deflastargmargin{\rm #2}\hskip \deftypemargin}% \dimen0=\hsize \advance \dimen0 by -\wd0 % compute size for first line \dimen1=\hsize \advance \dimen1 by -\defargsindent %size for continuations ! \parshape 2 0in \dimen0 \defargsindent \dimen1 % Now output arg 2 ("Function" or some such) % ending at \deftypemargin from the right margin, *************** *** 3660,3665 **** {% Adjust \hsize to exclude the ambient margins, % so that \rightline will obey them. ! \advance \hsize by -\dimen2 \advance \hsize by -\dimen3 ! \rlap{\rightline{{\rm #2}\hskip \deftypemargin}}}% % Make all lines underfull and no complaints: \tolerance=10000 \hbadness=10000 --- 4374,4379 ---- {% Adjust \hsize to exclude the ambient margins, % so that \rightline will obey them. ! \advance \hsize by -\dimen2 ! \rlap{\rightline{{\rm #2}\hskip -1.25pc }}}% % Make all lines underfull and no complaints: \tolerance=10000 \hbadness=10000 *************** *** 3682,3686 **** \def#2{\begingroup\obeylines\activeparens\spacesplit#3}% \parindent=0in ! \advance\leftskip by \defbodyindent \advance \rightskip by \defbodyindent \exdentamount=\defbodyindent \begingroup % --- 4396,4400 ---- \def#2{\begingroup\obeylines\activeparens\spacesplit#3}% \parindent=0in ! \advance\leftskip by \defbodyindent \exdentamount=\defbodyindent \begingroup % *************** *** 3688,3692 **** \obeylines\activeparens\spacesplit#3} ! \def\defmethparsebody #1#2#3#4 {\begingroup\inENV % \medbreak % % Define the end token that this defining construct specifies --- 4402,4411 ---- \obeylines\activeparens\spacesplit#3} ! % #1 is the \E... control sequence to end the definition (which we define). ! % #2 is the \...x control sequence for consecutive fns (which we define). ! % #3 is the control sequence to call to resume processing. ! % #4, delimited by the space, is the class name. ! % ! \def\defmethparsebody#1#2#3#4 {\begingroup\inENV % \medbreak % % Define the end token that this defining construct specifies *************** *** 3695,3702 **** \def#2##1 {\begingroup\obeylines\activeparens\spacesplit{#3{##1}}}% \parindent=0in ! \advance\leftskip by \defbodyindent \advance \rightskip by \defbodyindent \exdentamount=\defbodyindent \begingroup\obeylines\activeparens\spacesplit{#3{#4}}} \def\defopparsebody #1#2#3#4#5 {\begingroup\inENV % \medbreak % --- 4414,4455 ---- \def#2##1 {\begingroup\obeylines\activeparens\spacesplit{#3{##1}}}% \parindent=0in ! \advance\leftskip by \defbodyindent \exdentamount=\defbodyindent \begingroup\obeylines\activeparens\spacesplit{#3{#4}}} + % Used for @deftypemethod and @deftypeivar. + % #1 is the \E... control sequence to end the definition (which we define). + % #2 is the \...x control sequence for consecutive fns (which we define). + % #3 is the control sequence to call to resume processing. + % #4, delimited by a space, is the class name. + % #5 is the method's return type. + % + \def\deftypemethparsebody#1#2#3#4 #5 {\begingroup\inENV + \medbreak + \def#1{\endgraf\endgroup\medbreak}% + \def#2##1 ##2 {\begingroup\obeylines\activeparens\spacesplit{#3{##1}{##2}}}% + \parindent=0in + \advance\leftskip by \defbodyindent + \exdentamount=\defbodyindent + \begingroup\obeylines\activeparens\spacesplit{#3{#4}{#5}}} + + % Used for @deftypeop. The change from \deftypemethparsebody is an + % extra argument at the beginning which is the `category', instead of it + % being the hardwired string `Method' or `Instance Variable'. We have + % to account for this both in the \...x definition and in parsing the + % input at hand. Thus also need a control sequence (passed as #5) for + % the \E... definition to assign the category name to. + % + \def\deftypeopparsebody#1#2#3#4#5 #6 {\begingroup\inENV + \medbreak + \def#1{\endgraf\endgroup\medbreak}% + \def#2##1 ##2 ##3 {% + \def#4{##1}% + \begingroup\obeylines\activeparens\spacesplit{#3{##2}{##3}}}% + \parindent=0in + \advance\leftskip by \defbodyindent + \exdentamount=\defbodyindent + \begingroup\obeylines\activeparens\spacesplit{#3{#5}{#6}}} + \def\defopparsebody #1#2#3#4#5 {\begingroup\inENV % \medbreak % *************** *** 3707,3711 **** \begingroup\obeylines\activeparens\spacesplit{#3{##2}}}% \parindent=0in ! \advance\leftskip by \defbodyindent \advance \rightskip by \defbodyindent \exdentamount=\defbodyindent \begingroup\obeylines\activeparens\spacesplit{#3{#5}}} --- 4460,4464 ---- \begingroup\obeylines\activeparens\spacesplit{#3{##2}}}% \parindent=0in ! \advance\leftskip by \defbodyindent \exdentamount=\defbodyindent \begingroup\obeylines\activeparens\spacesplit{#3{#5}}} *************** *** 3722,3726 **** \def#2{\begingroup\obeylines\spacesplit#3}% \parindent=0in ! \advance\leftskip by \defbodyindent \advance \rightskip by \defbodyindent \exdentamount=\defbodyindent \begingroup % --- 4475,4479 ---- \def#2{\begingroup\obeylines\spacesplit#3}% \parindent=0in ! \advance\leftskip by \defbodyindent \exdentamount=\defbodyindent \begingroup % *************** *** 3730,3734 **** % This is used for \def{tp,vr}parsebody. It could probably be used for % some of the others, too, with some judicious conditionals. ! % \def\parsebodycommon#1#2#3{% \begingroup\inENV % --- 4483,4487 ---- % This is used for \def{tp,vr}parsebody. It could probably be used for % some of the others, too, with some judicious conditionals. ! % \def\parsebodycommon#1#2#3{% \begingroup\inENV % *************** *** 3739,3743 **** \def#2##1 {\begingroup\obeylines\spacesplit{#3{##1}}}% \parindent=0in ! \advance\leftskip by \defbodyindent \advance \rightskip by \defbodyindent \exdentamount=\defbodyindent \begingroup\obeylines --- 4492,4496 ---- \def#2##1 {\begingroup\obeylines\spacesplit{#3{##1}}}% \parindent=0in ! \advance\leftskip by \defbodyindent \exdentamount=\defbodyindent \begingroup\obeylines *************** *** 3764,3778 **** % Fine, but then we have to eventually remove the \empty *and* the ! % braces (if any). That's what this does, putting the result in \tptemp. ! % ! \def\removeemptybraces\empty#1\relax{\def\tptemp{#1}}% % After \spacesplit has done its work, this is called -- #1 is the final % thing to call, #2 the type name (which starts with \empty), and #3 % (which might be empty) the arguments. ! % \def\parsetpheaderline#1#2#3{% ! \removeemptybraces#2\relax ! #1{\tptemp}{#3}% }% --- 4517,4530 ---- % Fine, but then we have to eventually remove the \empty *and* the ! % braces (if any). That's what this does. ! % ! \def\removeemptybraces\empty#1\relax{#1} % After \spacesplit has done its work, this is called -- #1 is the final % thing to call, #2 the type name (which starts with \empty), and #3 % (which might be empty) the arguments. ! % \def\parsetpheaderline#1#2#3{% ! #1{\removeemptybraces#2\relax}{#3}% }% *************** *** 3785,3789 **** \begingroup\obeylines\spacesplit{#3{##2}}}% \parindent=0in ! \advance\leftskip by \defbodyindent \advance \rightskip by \defbodyindent \exdentamount=\defbodyindent \begingroup\obeylines\spacesplit{#3{#5}}} --- 4537,4541 ---- \begingroup\obeylines\spacesplit{#3{##2}}}% \parindent=0in ! \advance\leftskip by \defbodyindent \exdentamount=\defbodyindent \begingroup\obeylines\spacesplit{#3{#5}}} *************** *** 3809,3822 **** % Use this to expand the args and terminate the paragraph they make up ! \def\defunargs #1{\functionparens \sl % Expand, preventing hyphenation at `-' chars. % Note that groups don't affect changes in \hyphenchar. ! \hyphenchar\tensl=0 #1% ! \hyphenchar\tensl=45 ! \ifnum\parencount=0 \else \errmessage{unbalanced parens in @def arguments}\fi% \interlinepenalty=10000 \advance\rightskip by 0pt plus 1fil ! \endgraf\penalty 10000\vskip -\parskip\penalty 10000% } --- 4561,4575 ---- % Use this to expand the args and terminate the paragraph they make up ! \def\defunargs#1{\functionparens \sl % Expand, preventing hyphenation at `-' chars. % Note that groups don't affect changes in \hyphenchar. ! % Set the font temporarily and use \font in case \setfont made \tensl a macro. ! {\tensl\hyphenchar\font=0}% #1% ! {\tensl\hyphenchar\font=45}% ! \ifnum\parencount=0 \else \errmessage{Unbalanced parentheses in @def}\fi% \interlinepenalty=10000 \advance\rightskip by 0pt plus 1fil ! \endgraf\nobreak\vskip -\parskip\nobreak } *************** *** 3829,3833 **** \interlinepenalty=10000 \advance\rightskip by 0pt plus 1fil ! \endgraf\penalty 10000\vskip -\parskip\penalty 10000% } --- 4582,4586 ---- \interlinepenalty=10000 \advance\rightskip by 0pt plus 1fil ! \endgraf\nobreak\vskip -\parskip\nobreak } *************** *** 3848,3852 **** \def\defunheader #1#2{\doind {fn}{\code{#1}}% Make entry in function index ! \begingroup\defname {#1}{Function}% \defunargs {#2}\endgroup % \catcode 61=\other % Turn off change made in \defparsebody --- 4601,4605 ---- \def\defunheader #1#2{\doind {fn}{\code{#1}}% Make entry in function index ! \begingroup\defname {#1}{\putwordDeffunc}% \defunargs {#2}\endgroup % \catcode 61=\other % Turn off change made in \defparsebody *************** *** 3862,3866 **** \def\deftypefunheaderx #1#2 #3\relax{% \doind {fn}{\code{#2}}% Make entry in function index ! \begingroup\defname {\defheaderxcond#1\relax$$$#2}{Function}% \deftypefunargs {#3}\endgroup % \catcode 61=\other % Turn off change made in \defparsebody --- 4615,4619 ---- \def\deftypefunheaderx #1#2 #3\relax{% \doind {fn}{\code{#2}}% Make entry in function index ! \begingroup\defname {\defheaderxcond#1\relax$$$#2}{\putwordDeftypefun}% \deftypefunargs {#3}\endgroup % \catcode 61=\other % Turn off change made in \defparsebody *************** *** 3893,3897 **** \def\defmacheader #1#2{\doind {fn}{\code{#1}}% Make entry in function index ! \begingroup\defname {#1}{Macro}% \defunargs {#2}\endgroup % \catcode 61=\other % Turn off change made in \defparsebody --- 4646,4650 ---- \def\defmacheader #1#2{\doind {fn}{\code{#1}}% Make entry in function index ! \begingroup\defname {#1}{\putwordDefmac}% \defunargs {#2}\endgroup % \catcode 61=\other % Turn off change made in \defparsebody *************** *** 3903,3942 **** \def\defspecheader #1#2{\doind {fn}{\code{#1}}% Make entry in function index ! \begingroup\defname {#1}{Special Form}% \defunargs {#2}\endgroup % \catcode 61=\other % Turn off change made in \defparsebody } ! % This definition is run if you use @defunx ! % anywhere other than immediately after a @defun or @defunx. ! ! \def\deffnx #1 {\errmessage{@deffnx in invalid context}} ! \def\defunx #1 {\errmessage{@defunx in invalid context}} ! \def\defmacx #1 {\errmessage{@defmacx in invalid context}} ! \def\defspecx #1 {\errmessage{@defspecx in invalid context}} ! \def\deftypefnx #1 {\errmessage{@deftypefnx in invalid context}} ! \def\deftypeunx #1 {\errmessage{@deftypeunx in invalid context}} ! ! % @defmethod, and so on ! ! % @defop {Funny Method} foo-class frobnicate argument ! \def\defop #1 {\def\defoptype{#1}% \defopparsebody\Edefop\defopx\defopheader\defoptype} ! ! \def\defopheader #1#2#3{% ! \dosubind {fn}{\code{#2}}{on #1}% Make entry in function index ! \begingroup\defname {#2}{\defoptype{} on #1}% \defunargs {#3}\endgroup % } ! % @defmethod == @defop Method ! \def\defmethod{\defmethparsebody\Edefmethod\defmethodx\defmethodheader} ! \def\defmethodheader #1#2#3{% ! \dosubind {fn}{\code{#2}}{on #1}% entry in function index ! \begingroup\defname {#2}{Method on #1}% ! \defunargs {#3}\endgroup % } --- 4656,4730 ---- \def\defspecheader #1#2{\doind {fn}{\code{#1}}% Make entry in function index ! \begingroup\defname {#1}{\putwordDefspec}% \defunargs {#2}\endgroup % \catcode 61=\other % Turn off change made in \defparsebody } ! % @defop CATEGORY CLASS OPERATION ARG... ! % \def\defop #1 {\def\defoptype{#1}% \defopparsebody\Edefop\defopx\defopheader\defoptype} ! % ! \def\defopheader#1#2#3{% ! \dosubind {fn}{\code{#2}}{\putwordon\ #1}% Make entry in function index ! \begingroup\defname {#2}{\defoptype\ \putwordon\ #1}% \defunargs {#3}\endgroup % } ! % @deftypeop CATEGORY CLASS TYPE OPERATION ARG... ! % ! \def\deftypeop #1 {\def\deftypeopcategory{#1}% ! \deftypeopparsebody\Edeftypeop\deftypeopx\deftypeopheader ! \deftypeopcategory} ! % ! % #1 is the class name, #2 the data type, #3 the operation name, #4 the args. ! \def\deftypeopheader#1#2#3#4{% ! \dosubind{fn}{\code{#3}}{\putwordon\ \code{#1}}% entry in function index ! \begingroup ! \defname{\defheaderxcond#2\relax$$$#3} ! {\deftypeopcategory\ \putwordon\ \code{#1}}% ! \deftypefunargs{#4}% ! \endgroup ! } ! % @deftypemethod CLASS TYPE METHOD ARG... ! % ! \def\deftypemethod{% ! \deftypemethparsebody\Edeftypemethod\deftypemethodx\deftypemethodheader} ! % ! % #1 is the class name, #2 the data type, #3 the method name, #4 the args. ! \def\deftypemethodheader#1#2#3#4{% ! \dosubind{fn}{\code{#3}}{\putwordon\ \code{#1}}% entry in function index ! \begingroup ! \defname{\defheaderxcond#2\relax$$$#3}{\putwordMethodon\ \code{#1}}% ! \deftypefunargs{#4}% ! \endgroup ! } ! % @deftypeivar CLASS TYPE VARNAME ! % ! \def\deftypeivar{% ! \deftypemethparsebody\Edeftypeivar\deftypeivarx\deftypeivarheader} ! % ! % #1 is the class name, #2 the data type, #3 the variable name. ! \def\deftypeivarheader#1#2#3{% ! \dosubind{vr}{\code{#3}}{\putwordof\ \code{#1}}% entry in variable index ! \begingroup ! \defname{#3}{\putwordInstanceVariableof\ \code{#1}}% ! \defvarargs{#3}% ! \endgroup ! } ! ! % @defmethod == @defop Method ! % ! \def\defmethod{\defmethparsebody\Edefmethod\defmethodx\defmethodheader} ! % ! % #1 is the class name, #2 the method name, #3 the args. ! \def\defmethodheader#1#2#3{% ! \dosubind{fn}{\code{#2}}{\putwordon\ \code{#1}}% entry in function index ! \begingroup ! \defname{#2}{\putwordMethodon\ \code{#1}}% ! \defunargs{#3}% ! \endgroup } *************** *** 3947,3975 **** \def\defcvarheader #1#2#3{% ! \dosubind {vr}{\code{#2}}{of #1}% Make entry in var index ! \begingroup\defname {#2}{\defcvtype{} of #1}% \defvarargs {#3}\endgroup % } ! % @defivar == @defcv {Instance Variable} ! \def\defivar{\defvrparsebody\Edefivar\defivarx\defivarheader} ! ! \def\defivarheader #1#2#3{% ! \dosubind {vr}{\code{#2}}{of #1}% Make entry in var index ! \begingroup\defname {#2}{Instance Variable of #1}% ! \defvarargs {#3}\endgroup % } ! % These definitions are run if you use @defmethodx, etc., ! % anywhere other than immediately after a @defmethod, etc. ! ! \def\defopx #1 {\errmessage{@defopx in invalid context}} ! \def\defmethodx #1 {\errmessage{@defmethodx in invalid context}} ! \def\defcvx #1 {\errmessage{@defcvx in invalid context}} ! \def\defivarx #1 {\errmessage{@defivarx in invalid context}} ! ! % Now @defvar ! % First, define the processing that is wanted for arguments of @defvar. % This is actually simple: just print them in roman. --- 4735,4756 ---- \def\defcvarheader #1#2#3{% ! \dosubind {vr}{\code{#2}}{\putwordof\ #1}% Make entry in var index ! \begingroup\defname {#2}{\defcvtype\ \putwordof\ #1}% \defvarargs {#3}\endgroup % } ! % @defivar CLASS VARNAME == @defcv {Instance Variable} CLASS VARNAME ! % \def\defivar{\defvrparsebody\Edefivar\defivarx\defivarheader} ! % ! \def\defivarheader#1#2#3{% ! \dosubind {vr}{\code{#2}}{\putwordof\ #1}% entry in var index ! \begingroup ! \defname{#2}{\putwordInstanceVariableof\ #1}% ! \defvarargs{#3}% ! \endgroup } ! % @defvar % First, define the processing that is wanted for arguments of @defvar. % This is actually simple: just print them in roman. *************** *** 3977,3981 **** \def\defvarargs #1{\normalparens #1% \interlinepenalty=10000 ! \endgraf\penalty 10000\vskip -\parskip\penalty 10000} % @defvr Counter foo-count --- 4758,4762 ---- \def\defvarargs #1{\normalparens #1% \interlinepenalty=10000 ! \endgraf\nobreak\vskip -\parskip\nobreak} % @defvr Counter foo-count *************** *** 3991,3995 **** \def\defvarheader #1#2{\doind {vr}{\code{#1}}% Make entry in var index ! \begingroup\defname {#1}{Variable}% \defvarargs {#2}\endgroup % } --- 4772,4776 ---- \def\defvarheader #1#2{\doind {vr}{\code{#1}}% Make entry in var index ! \begingroup\defname {#1}{\putwordDefvar}% \defvarargs {#2}\endgroup % } *************** *** 4000,4004 **** \def\defoptheader #1#2{\doind {vr}{\code{#1}}% Make entry in var index ! \begingroup\defname {#1}{User Option}% \defvarargs {#2}\endgroup % } --- 4781,4785 ---- \def\defoptheader #1#2{\doind {vr}{\code{#1}}% Make entry in var index ! \begingroup\defname {#1}{\putwordDefopt}% \defvarargs {#2}\endgroup % } *************** *** 4008,4018 **** \def\deftypevar{\defvarparsebody\Edeftypevar\deftypevarx\deftypevarheader} ! % #1 is the data type. #2 is the name. \def\deftypevarheader #1#2{% ! \doind {vr}{\code{#2}}% Make entry in variables index ! \begingroup\defname {\defheaderxcond#1\relax$$$#2}{Variable}% \interlinepenalty=10000 ! \endgraf\penalty 10000\vskip -\parskip\penalty 10000 \endgroup} % @deftypevr {Global Flag} int enable --- 4789,4801 ---- \def\deftypevar{\defvarparsebody\Edeftypevar\deftypevarx\deftypevarheader} ! % #1 is the data type. #2 is the name, perhaps followed by text that ! % is actually part of the data type, which should not be put into the index. \def\deftypevarheader #1#2{% ! \dovarind#2 \relax% Make entry in variables index ! \begingroup\defname {\defheaderxcond#1\relax$$$#2}{\putwordDeftypevar}% \interlinepenalty=10000 ! \endgraf\nobreak\vskip -\parskip\nobreak \endgroup} + \def\dovarind#1 #2\relax{\doind{vr}{\code{#1}}} % @deftypevr {Global Flag} int enable *************** *** 4020,4038 **** \def\deftypevr{\defvrparsebody\Edeftypevr\deftypevrx\deftypevrheader} ! \def\deftypevrheader #1#2#3{\doind {vr}{\code{#3}}% \begingroup\defname {\defheaderxcond#2\relax$$$#3}{#1} \interlinepenalty=10000 ! \endgraf\penalty 10000\vskip -\parskip\penalty 10000 \endgroup} - % This definition is run if you use @defvarx - % anywhere other than immediately after a @defvar or @defvarx. - - \def\defvrx #1 {\errmessage{@defvrx in invalid context}} - \def\defvarx #1 {\errmessage{@defvarx in invalid context}} - \def\defoptx #1 {\errmessage{@defoptx in invalid context}} - \def\deftypevarx #1 {\errmessage{@deftypevarx in invalid context}} - \def\deftypevrx #1 {\errmessage{@deftypevrx in invalid context}} - % Now define @deftp % Args are printed in bold, a slight difference from @defvar. --- 4803,4812 ---- \def\deftypevr{\defvrparsebody\Edeftypevr\deftypevrx\deftypevrheader} ! \def\deftypevrheader #1#2#3{\dovarind#3 \relax% \begingroup\defname {\defheaderxcond#2\relax$$$#3}{#1} \interlinepenalty=10000 ! \endgraf\nobreak\vskip -\parskip\nobreak \endgroup} % Now define @deftp % Args are printed in bold, a slight difference from @defvar. *************** *** 4047,4090 **** \begingroup\defname {#2}{#1}\deftpargs{#3}\endgroup} ! % This definition is run if you use @deftpx, etc ! % anywhere other than immediately after a @deftp, etc. ! \def\deftpx #1 {\errmessage{@deftpx in invalid context}} ! \message{cross reference,} ! % Define cross-reference macros ! \newwrite \auxfile ! \newif\ifhavexrefs % True if xref values are known. \newif\ifwarnedxrefs % True if we warned once that they aren't known. ! % @inforef is simple. \def\inforef #1{\inforefzzz #1,,,,**} \def\inforefzzz #1,#2,#3,#4**{\putwordSee{} \putwordInfo{} \putwordfile{} \file{\ignorespaces #3{}}, node \samp{\ignorespaces#1{}}} ! % \setref{foo} defines a cross-reference point named foo. ! \def\setref#1{% ! \dosetq{#1-title}{Ytitle}% ! \dosetq{#1-pg}{Ypagenumber}% ! \dosetq{#1-snt}{Ysectionnumberandtype}} ! ! \def\unnumbsetref#1{% ! \dosetq{#1-title}{Ytitle}% ! \dosetq{#1-pg}{Ypagenumber}% ! \dosetq{#1-snt}{Ynothing}} ! ! \def\appendixsetref#1{% ! \dosetq{#1-title}{Ytitle}% ! \dosetq{#1-pg}{Ypagenumber}% ! \dosetq{#1-snt}{Yappendixletterandtype}} ! ! % \xref, \pxref, and \ref generate cross-references to specified points. ! % For \xrefX, #1 is the node name, #2 the name of the Info ! % cross-reference, #3 the printed node name, #4 the name of the Info ! % file, #5 the name of the printed manual. All but the node name can be ! % omitted. % \def\pxref#1{\putwordsee{} \xrefX[#1,,,,,,,]} --- 4821,5206 ---- \begingroup\defname {#2}{#1}\deftpargs{#3}\endgroup} ! % These definitions are used if you use @defunx (etc.) ! % anywhere other than immediately after a @defun or @defunx. ! % ! \def\defcvx#1 {\errmessage{@defcvx in invalid context}} ! \def\deffnx#1 {\errmessage{@deffnx in invalid context}} ! \def\defivarx#1 {\errmessage{@defivarx in invalid context}} ! \def\defmacx#1 {\errmessage{@defmacx in invalid context}} ! \def\defmethodx#1 {\errmessage{@defmethodx in invalid context}} ! \def\defoptx #1 {\errmessage{@defoptx in invalid context}} ! \def\defopx#1 {\errmessage{@defopx in invalid context}} ! \def\defspecx#1 {\errmessage{@defspecx in invalid context}} ! \def\deftpx#1 {\errmessage{@deftpx in invalid context}} ! \def\deftypefnx#1 {\errmessage{@deftypefnx in invalid context}} ! \def\deftypefunx#1 {\errmessage{@deftypefunx in invalid context}} ! \def\deftypeivarx#1 {\errmessage{@deftypeivarx in invalid context}} ! \def\deftypemethodx#1 {\errmessage{@deftypemethodx in invalid context}} ! \def\deftypeopx#1 {\errmessage{@deftypeopx in invalid context}} ! \def\deftypevarx#1 {\errmessage{@deftypevarx in invalid context}} ! \def\deftypevrx#1 {\errmessage{@deftypevrx in invalid context}} ! \def\defunx#1 {\errmessage{@defunx in invalid context}} ! \def\defvarx#1 {\errmessage{@defvarx in invalid context}} ! \def\defvrx#1 {\errmessage{@defvrx in invalid context}} ! ! ! \message{macros,} ! % @macro. ! ! % To do this right we need a feature of e-TeX, \scantokens, ! % which we arrange to emulate with a temporary file in ordinary TeX. ! \ifx\eTeXversion\undefined ! \newwrite\macscribble ! \def\scanmacro#1{% ! \begingroup \newlinechar`\^^M ! % Undo catcode changes of \startcontents and \doprintindex ! \catcode`\@=0 \catcode`\\=12 \escapechar=`\@ ! % Append \endinput to make sure that TeX does not see the ending newline. ! \toks0={#1\endinput}% ! \immediate\openout\macscribble=\jobname.tmp ! \immediate\write\macscribble{\the\toks0}% ! \immediate\closeout\macscribble ! \let\xeatspaces\eatspaces ! \input \jobname.tmp ! \endgroup ! } ! \else ! \def\scanmacro#1{% ! \begingroup \newlinechar`\^^M ! % Undo catcode changes of \startcontents and \doprintindex ! \catcode`\@=0 \catcode`\\=12 \escapechar=`\@ ! \let\xeatspaces\eatspaces\scantokens{#1\endinput}\endgroup} ! \fi ! ! \newcount\paramno % Count of parameters ! \newtoks\macname % Macro name ! \newif\ifrecursive % Is it recursive? ! \def\macrolist{} % List of all defined macros in the form ! % \do\macro1\do\macro2... ! ! % Utility routines. ! % Thisdoes \let #1 = #2, except with \csnames. ! \def\cslet#1#2{% ! \expandafter\expandafter ! \expandafter\let ! \expandafter\expandafter ! \csname#1\endcsname ! \csname#2\endcsname} ! % Trim leading and trailing spaces off a string. ! % Concepts from aro-bend problem 15 (see CTAN). ! {\catcode`\@=11 ! \gdef\eatspaces #1{\expandafter\trim@\expandafter{#1 }} ! \gdef\trim@ #1{\trim@@ @#1 @ #1 @ @@} ! \gdef\trim@@ #1@ #2@ #3@@{\trim@@@\empty #2 @} ! \def\unbrace#1{#1} ! \unbrace{\gdef\trim@@@ #1 } #2@{#1} ! } ! ! % Trim a single trailing ^^M off a string. ! {\catcode`\^^M=12\catcode`\Q=3% ! \gdef\eatcr #1{\eatcra #1Q^^MQ}% ! \gdef\eatcra#1^^MQ{\eatcrb#1Q}% ! \gdef\eatcrb#1Q#2Q{#1}% ! } ! ! % Macro bodies are absorbed as an argument in a context where ! % all characters are catcode 10, 11 or 12, except \ which is active ! % (as in normal texinfo). It is necessary to change the definition of \. ! ! % It's necessary to have hard CRs when the macro is executed. This is ! % done by making ^^M (\endlinechar) catcode 12 when reading the macro ! % body, and then making it the \newlinechar in \scanmacro. ! ! \def\macrobodyctxt{% ! \catcode`\~=12 ! \catcode`\^=12 ! \catcode`\_=12 ! \catcode`\|=12 ! \catcode`\<=12 ! \catcode`\>=12 ! \catcode`\+=12 ! \catcode`\{=12 ! \catcode`\}=12 ! \catcode`\@=12 ! \catcode`\^^M=12 ! \usembodybackslash} ! ! \def\macroargctxt{% ! \catcode`\~=12 ! \catcode`\^=12 ! \catcode`\_=12 ! \catcode`\|=12 ! \catcode`\<=12 ! \catcode`\>=12 ! \catcode`\+=12 ! \catcode`\@=12 ! \catcode`\\=12} ! ! % \mbodybackslash is the definition of \ in @macro bodies. ! % It maps \foo\ => \csname macarg.foo\endcsname => #N ! % where N is the macro parameter number. ! % We define \csname macarg.\endcsname to be \realbackslash, so ! % \\ in macro replacement text gets you a backslash. ! ! {\catcode`@=0 @catcode`@\=@active ! @gdef@usembodybackslash{@let\=@mbodybackslash} ! @gdef@mbodybackslash#1\{@csname macarg.#1@endcsname} ! } ! \expandafter\def\csname macarg.\endcsname{\realbackslash} ! ! \def\macro{\recursivefalse\parsearg\macroxxx} ! \def\rmacro{\recursivetrue\parsearg\macroxxx} ! ! \def\macroxxx#1{% ! \getargs{#1}% now \macname is the macname and \argl the arglist ! \ifx\argl\empty % no arguments ! \paramno=0% ! \else ! \expandafter\parsemargdef \argl;% ! \fi ! \if1\csname ismacro.\the\macname\endcsname ! \message{Warning: redefining \the\macname}% ! \else ! \expandafter\ifx\csname \the\macname\endcsname \relax ! \else \errmessage{The name \the\macname\space is reserved}\fi ! \global\cslet{macsave.\the\macname}{\the\macname}% ! \global\expandafter\let\csname ismacro.\the\macname\endcsname=1% ! % Add the macroname to \macrolist ! \toks0 = \expandafter{\macrolist\do}% ! \xdef\macrolist{\the\toks0 ! \expandafter\noexpand\csname\the\macname\endcsname}% ! \fi ! \begingroup \macrobodyctxt ! \ifrecursive \expandafter\parsermacbody ! \else \expandafter\parsemacbody ! \fi} ! ! \def\unmacro{\parsearg\unmacroxxx} ! \def\unmacroxxx#1{% ! \if1\csname ismacro.#1\endcsname ! \global\cslet{#1}{macsave.#1}% ! \global\expandafter\let \csname ismacro.#1\endcsname=0% ! % Remove the macro name from \macrolist ! \begingroup ! \edef\tempa{\expandafter\noexpand\csname#1\endcsname}% ! \def\do##1{% ! \def\tempb{##1}% ! \ifx\tempa\tempb ! % remove this ! \else ! \toks0 = \expandafter{\newmacrolist\do}% ! \edef\newmacrolist{\the\toks0\expandafter\noexpand\tempa}% ! \fi}% ! \def\newmacrolist{}% ! % Execute macro list to define \newmacrolist ! \macrolist ! \global\let\macrolist\newmacrolist ! \endgroup ! \else ! \errmessage{Macro #1 not defined}% ! \fi ! } ! ! % This makes use of the obscure feature that if the last token of a ! % is #, then the preceding argument is delimited by ! % an opening brace, and that opening brace is not consumed. ! \def\getargs#1{\getargsxxx#1{}} ! \def\getargsxxx#1#{\getmacname #1 \relax\getmacargs} ! \def\getmacname #1 #2\relax{\macname={#1}} ! \def\getmacargs#1{\def\argl{#1}} ! ! % Parse the optional {params} list. Set up \paramno and \paramlist ! % so \defmacro knows what to do. Define \macarg.blah for each blah ! % in the params list, to be ##N where N is the position in that list. ! % That gets used by \mbodybackslash (above). ! ! % We need to get `macro parameter char #' into several definitions. ! % The technique used is stolen from LaTeX: let \hash be something ! % unexpandable, insert that wherever you need a #, and then redefine ! % it to # just before using the token list produced. ! % ! % The same technique is used to protect \eatspaces till just before ! % the macro is used. ! ! \def\parsemargdef#1;{\paramno=0\def\paramlist{}% ! \let\hash\relax\let\xeatspaces\relax\parsemargdefxxx#1,;,} ! \def\parsemargdefxxx#1,{% ! \if#1;\let\next=\relax ! \else \let\next=\parsemargdefxxx ! \advance\paramno by 1% ! \expandafter\edef\csname macarg.\eatspaces{#1}\endcsname ! {\xeatspaces{\hash\the\paramno}}% ! \edef\paramlist{\paramlist\hash\the\paramno,}% ! \fi\next} ! ! % These two commands read recursive and nonrecursive macro bodies. ! % (They're different since rec and nonrec macros end differently.) ! ! \long\def\parsemacbody#1@end macro% ! {\xdef\temp{\eatcr{#1}}\endgroup\defmacro}% ! \long\def\parsermacbody#1@end rmacro% ! {\xdef\temp{\eatcr{#1}}\endgroup\defmacro}% ! ! % This defines the macro itself. There are six cases: recursive and ! % nonrecursive macros of zero, one, and many arguments. ! % Much magic with \expandafter here. ! % \xdef is used so that macro definitions will survive the file ! % they're defined in; @include reads the file inside a group. ! \def\defmacro{% ! \let\hash=##% convert placeholders to macro parameter chars ! \ifrecursive ! \ifcase\paramno ! % 0 ! \expandafter\xdef\csname\the\macname\endcsname{% ! \noexpand\scanmacro{\temp}}% ! \or % 1 ! \expandafter\xdef\csname\the\macname\endcsname{% ! \bgroup\noexpand\macroargctxt ! \noexpand\braceorline ! \expandafter\noexpand\csname\the\macname xxx\endcsname}% ! \expandafter\xdef\csname\the\macname xxx\endcsname##1{% ! \egroup\noexpand\scanmacro{\temp}}% ! \else % many ! \expandafter\xdef\csname\the\macname\endcsname{% ! \bgroup\noexpand\macroargctxt ! \noexpand\csname\the\macname xx\endcsname}% ! \expandafter\xdef\csname\the\macname xx\endcsname##1{% ! \expandafter\noexpand\csname\the\macname xxx\endcsname ##1,}% ! \expandafter\expandafter ! \expandafter\xdef ! \expandafter\expandafter ! \csname\the\macname xxx\endcsname ! \paramlist{\egroup\noexpand\scanmacro{\temp}}% ! \fi ! \else ! \ifcase\paramno ! % 0 ! \expandafter\xdef\csname\the\macname\endcsname{% ! \noexpand\norecurse{\the\macname}% ! \noexpand\scanmacro{\temp}\egroup}% ! \or % 1 ! \expandafter\xdef\csname\the\macname\endcsname{% ! \bgroup\noexpand\macroargctxt ! \noexpand\braceorline ! \expandafter\noexpand\csname\the\macname xxx\endcsname}% ! \expandafter\xdef\csname\the\macname xxx\endcsname##1{% ! \egroup ! \noexpand\norecurse{\the\macname}% ! \noexpand\scanmacro{\temp}\egroup}% ! \else % many ! \expandafter\xdef\csname\the\macname\endcsname{% ! \bgroup\noexpand\macroargctxt ! \expandafter\noexpand\csname\the\macname xx\endcsname}% ! \expandafter\xdef\csname\the\macname xx\endcsname##1{% ! \expandafter\noexpand\csname\the\macname xxx\endcsname ##1,}% ! \expandafter\expandafter ! \expandafter\xdef ! \expandafter\expandafter ! \csname\the\macname xxx\endcsname ! \paramlist{% ! \egroup ! \noexpand\norecurse{\the\macname}% ! \noexpand\scanmacro{\temp}\egroup}% ! \fi ! \fi} + \def\norecurse#1{\bgroup\cslet{#1}{macsave.#1}} ! % \braceorline decides whether the next nonwhitespace character is a ! % {. If so it reads up to the closing }, if not, it reads the whole ! % line. Whatever was read is then fed to the next control sequence ! % as an argument (by \parsebrace or \parsearg) ! \def\braceorline#1{\let\next=#1\futurelet\nchar\braceorlinexxx} ! \def\braceorlinexxx{% ! \ifx\nchar\bgroup\else ! \expandafter\parsearg ! \fi \next} ! ! % We mant to disable all macros during \shipout so that they are not ! % expanded by \write. ! \def\turnoffmacros{\begingroup \def\do##1{\let\noexpand##1=\relax}% ! \edef\next{\macrolist}\expandafter\endgroup\next} ! ! ! % @alias. ! % We need some trickery to remove the optional spaces around the equal ! % sign. Just make them active and then expand them all to nothing. ! \def\alias{\begingroup\obeyspaces\parsearg\aliasxxx} ! \def\aliasxxx #1{\aliasyyy#1\relax} ! \def\aliasyyy #1=#2\relax{\ignoreactivespaces ! \edef\next{\global\let\expandafter\noexpand\csname#1\endcsname=% ! \expandafter\noexpand\csname#2\endcsname}% ! \expandafter\endgroup\next} ! ! \message{cross references,} ! % @xref etc. ! ! \newwrite\auxfile ! ! \newif\ifhavexrefs % True if xref values are known. \newif\ifwarnedxrefs % True if we warned once that they aren't known. ! % @inforef is relatively simple. \def\inforef #1{\inforefzzz #1,,,,**} \def\inforefzzz #1,#2,#3,#4**{\putwordSee{} \putwordInfo{} \putwordfile{} \file{\ignorespaces #3{}}, node \samp{\ignorespaces#1{}}} ! % @node's job is to define \lastnode. ! \def\node{\ENVcheck\parsearg\nodezzz} ! \def\nodezzz#1{\nodexxx [#1,]} ! \def\nodexxx[#1,#2]{\gdef\lastnode{#1}} ! \let\nwnode=\node ! \let\lastnode=\relax ! ! % The sectioning commands (@chapter, etc.) call these. ! \def\donoderef{% ! \ifx\lastnode\relax\else ! \expandafter\expandafter\expandafter\setref{\lastnode}% ! {Ysectionnumberandtype}% ! \global\let\lastnode=\relax ! \fi ! } ! \def\unnumbnoderef{% ! \ifx\lastnode\relax\else ! \expandafter\expandafter\expandafter\setref{\lastnode}{Ynothing}% ! \global\let\lastnode=\relax ! \fi ! } ! \def\appendixnoderef{% ! \ifx\lastnode\relax\else ! \expandafter\expandafter\expandafter\setref{\lastnode}% ! {Yappendixletterandtype}% ! \global\let\lastnode=\relax ! \fi ! } ! ! % @anchor{NAME} -- define xref target at arbitrary point. ! % ! \newcount\savesfregister ! \gdef\savesf{\relax \ifhmode \savesfregister=\spacefactor \fi} ! \gdef\restoresf{\relax \ifhmode \spacefactor=\savesfregister \fi} ! \gdef\anchor#1{\savesf \setref{#1}{Ynothing}\restoresf \ignorespaces} ! ! % \setref{NAME}{SNT} defines a cross-reference point NAME, namely ! % NAME-title, NAME-pg, and NAME-SNT. Called from \foonoderef. We have ! % to set \indexdummies so commands such as @code in a section title ! % aren't expanded. It would be nicer not to expand the titles in the ! % first place, but there's so many layers that that is hard to do. ! % ! \def\setref#1#2{{% ! \indexdummies ! \pdfmkdest{#1}% ! \dosetq{#1-title}{Ytitle}% ! \dosetq{#1-pg}{Ypagenumber}% ! \dosetq{#1-snt}{#2}% ! }} ! ! % @xref, @pxref, and @ref generate cross-references. For \xrefX, #1 is ! % the node name, #2 the name of the Info cross-reference, #3 the printed ! % node name, #4 the name of the Info file, #5 the name of the printed ! % manual. All but the node name can be omitted. % \def\pxref#1{\putwordsee{} \xrefX[#1,,,,,,,]} *************** *** 4092,4095 **** --- 5208,5212 ---- \def\ref#1{\xrefX[#1,,,,,,,]} \def\xrefX[#1,#2,#3,#4,#5,#6]{\begingroup + \unsepspaces \def\printedmanual{\ignorespaces #5}% \def\printednodename{\ignorespaces #3}% *************** *** 4104,4108 **** % Use the actual chapter/section title appear inside % the square brackets. Use the real section title if we have it. ! \ifdim \wd1>0pt% % It is in another manual, so we don't have it. \def\printednodename{\ignorespaces #1}% --- 5221,5225 ---- % Use the actual chapter/section title appear inside % the square brackets. Use the real section title if we have it. ! \ifdim \wd1 > 0pt % It is in another manual, so we don't have it. \def\printednodename{\ignorespaces #1}% *************** *** 4125,4130 **** % is a loss. Therefore, we give the text of the node name again, so it % is as if TeX is seeing it for the first time. \ifdim \wd1 > 0pt ! \putwordsection{} ``\printednodename'' in \cite{\printedmanual}% \else % _ (for example) has to be the character _ for the purposes of the --- 5242,5260 ---- % is a loss. Therefore, we give the text of the node name again, so it % is as if TeX is seeing it for the first time. + \ifpdf + \leavevmode + \getfilename{#4}% + \ifnum\filenamelength>0 + \startlink attr{/Border [0 0 0]}% + goto file{\the\filename.pdf} name{#1@}% + \else + \startlink attr{/Border [0 0 0]}% + goto name{#1@}% + \fi + \linkcolor + \fi + % \ifdim \wd1 > 0pt ! \putwordsection{} ``\printednodename'' \putwordin{} \cite{\printedmanual}% \else % _ (for example) has to be the character _ for the purposes of the *************** *** 4133,4149 **** % printing. So we \turnoffactive for the \refx-snt, back on for the % printing, back off for the \refx-pg. ! {\turnoffactive \refx{#1-snt}{}}% ! \space [\printednodename],\space \turnoffactive \putwordpage\tie\refx{#1-pg}{}% \fi \endgroup} % \dosetq is the interface for calls from other macros ! % Use \turnoffactive so that punctuation chars such as underscore ! % work in node names. ! \def\dosetq #1#2{{\let\folio=0 \turnoffactive \auxhat% ! \edef\next{\write\auxfile{\internalsetq {#1}{#2}}}% ! \next}} % \internalsetq {foo}{page} expands into --- 5263,5293 ---- % printing. So we \turnoffactive for the \refx-snt, back on for the % printing, back off for the \refx-pg. ! {\normalturnoffactive ! % Only output a following space if the -snt ref is nonempty; for ! % @unnumbered and @anchor, it won't be. ! \setbox2 = \hbox{\ignorespaces \refx{#1-snt}{}}% ! \ifdim \wd2 > 0pt \refx{#1-snt}\space\fi ! }% ! % [mynode], ! [\printednodename],\space ! % page 3 \turnoffactive \putwordpage\tie\refx{#1-pg}{}% \fi + \endlink \endgroup} % \dosetq is the interface for calls from other macros ! % Use \normalturnoffactive so that punctuation chars such as underscore ! % and backslash work in node names. (\turnoffactive doesn't do \.) ! \def\dosetq#1#2{% ! {\let\folio=0% ! \normalturnoffactive ! \edef\next{\write\auxfile{\internalsetq{#1}{#2}}}% ! \iflinks ! \next ! \fi ! }% ! } % \internalsetq {foo}{page} expands into *************** *** 4196,4206 **** \expandafter\ifx\csname X#1\endcsname\relax % If not defined, say something at least. ! $\langle$un\-de\-fined$\rangle$% ! \ifhavexrefs ! \message{\linenumber Undefined cross reference `#1'.}% ! \else ! \ifwarnedxrefs\else ! \global\warnedxrefstrue ! \message{Cross reference values unknown; you must run TeX again.}% \fi \fi --- 5340,5352 ---- \expandafter\ifx\csname X#1\endcsname\relax % If not defined, say something at least. ! \angleleft un\-de\-fined\angleright ! \iflinks ! \ifhavexrefs ! \message{\linenumber Undefined cross reference `#1'.}% ! \else ! \ifwarnedxrefs\else ! \global\warnedxrefstrue ! \message{Cross reference values unknown; you must run TeX again.}% ! \fi \fi \fi *************** *** 4212,4293 **** } - % Read the last existing aux file, if any. No error if none exists. - % This is the macro invoked by entries in the aux file. ! \def\xrdef #1#2{ ! {\catcode`\'=\other\expandafter \gdef \csname X#1\endcsname {#2}}} ! \def\readauxfile{% ! \begingroup ! \catcode `\^^@=\other ! \catcode `\=\other ! \catcode `\=\other ! \catcode `\^^C=\other ! \catcode `\^^D=\other ! \catcode `\^^E=\other ! \catcode `\^^F=\other ! \catcode `\^^G=\other ! \catcode `\^^H=\other ! \catcode `\ =\other ! \catcode `\^^L=\other ! \catcode `\=\other ! \catcode `\=\other ! \catcode `\=\other ! \catcode `\=\other ! \catcode `\=\other ! \catcode `\=\other ! \catcode `\=\other ! \catcode `\=\other ! \catcode `\=\other ! \catcode `\=\other ! \catcode `\=\other ! \catcode `\=\other ! \catcode 26=\other ! \catcode `\^^[=\other ! \catcode `\^^\=\other ! \catcode `\^^]=\other ! \catcode `\^^^=\other ! \catcode `\^^_=\other ! \catcode `\@=\other ! \catcode `\^=\other ! \catcode `\~=\other ! \catcode `\[=\other ! \catcode `\]=\other ! \catcode`\"=\other ! \catcode`\_=\other ! \catcode`\|=\other ! \catcode`\<=\other ! \catcode`\>=\other ! \catcode `\$=\other ! \catcode `\#=\other ! \catcode `\&=\other ! % `\+ does not work, so use 43. ! \catcode 43=\other ! % Make the characters 128-255 be printing characters ! {% ! \count 1=128 ! \def\loop{% ! \catcode\count 1=\other ! \advance\count 1 by 1 ! \ifnum \count 1<256 \loop \fi }% ! }% ! % the aux file uses ' as the escape. ! % Turn off \ as an escape so we do not lose on ! % entries which were dumped with control sequences in their names. ! % For example, 'xrdef {$\leq $-fun}{page ...} made by @defun ^^ ! % Reference to such entries still does not work the way one would wish, ! % but at least they do not bomb out when the aux file is read in. ! \catcode `\{=1 \catcode `\}=2 ! \catcode `\%=\other ! \catcode `\'=0 ! \catcode`\^=7 % to make ^^e4 etc usable in xref tags ! \catcode `\\=\other ! \openin 1 \jobname.aux ! \ifeof 1 \else \closein 1 \input \jobname.aux \global\havexrefstrue ! \global\warnedobstrue ! \fi ! % Open the new aux file. Tex will close it automatically at exit. ! \openout \auxfile=\jobname.aux \endgroup} --- 5358,5456 ---- } % This is the macro invoked by entries in the aux file. ! % ! \def\xrdef#1{\begingroup ! % Reenable \ as an escape while reading the second argument. ! \catcode`\\ = 0 ! \afterassignment\endgroup ! \expandafter\gdef\csname X#1\endcsname ! } ! % Read the last existing aux file, if any. No error if none exists. ! \def\readauxfile{\begingroup ! \catcode`\^^@=\other ! \catcode`\^^A=\other ! \catcode`\^^B=\other ! \catcode`\^^C=\other ! \catcode`\^^D=\other ! \catcode`\^^E=\other ! \catcode`\^^F=\other ! \catcode`\^^G=\other ! \catcode`\^^H=\other ! \catcode`\^^K=\other ! \catcode`\^^L=\other ! \catcode`\^^N=\other ! \catcode`\^^P=\other ! \catcode`\^^Q=\other ! \catcode`\^^R=\other ! \catcode`\^^S=\other ! \catcode`\^^T=\other ! \catcode`\^^U=\other ! \catcode`\^^V=\other ! \catcode`\^^W=\other ! \catcode`\^^X=\other ! \catcode`\^^Z=\other ! \catcode`\^^[=\other ! \catcode`\^^\=\other ! \catcode`\^^]=\other ! \catcode`\^^^=\other ! \catcode`\^^_=\other ! \catcode`\@=\other ! \catcode`\^=\other ! % It was suggested to define this as 7, which would allow ^^e4 etc. ! % in xref tags, i.e., node names. But since ^^e4 notation isn't ! % supported in the main text, it doesn't seem desirable. Furthermore, ! % that is not enough: for node names that actually contain a ^ ! % character, we would end up writing a line like this: 'xrdef {'hat ! % b-title}{'hat b} and \xrdef does a \csname...\endcsname on the first ! % argument, and \hat is not an expandable control sequence. It could ! % all be worked out, but why? Either we support ^^ or we don't. ! % ! % The other change necessary for this was to define \auxhat: ! % \def\auxhat{\def^{'hat }}% extra space so ok if followed by letter ! % and then to call \auxhat in \setq. ! % ! \catcode`\~=\other ! \catcode`\[=\other ! \catcode`\]=\other ! \catcode`\"=\other ! \catcode`\_=\other ! \catcode`\|=\other ! \catcode`\<=\other ! \catcode`\>=\other ! \catcode`\$=\other ! \catcode`\#=\other ! \catcode`\&=\other ! \catcode`+=\other % avoid \+ for paranoia even though we've turned it off ! % Make the characters 128-255 be printing characters ! {% ! \count 1=128 ! \def\loop{% ! \catcode\count 1=\other ! \advance\count 1 by 1 ! \ifnum \count 1<256 \loop \fi ! }% }% ! % The aux file uses ' as the escape (for now). ! % Turn off \ as an escape so we do not lose on ! % entries which were dumped with control sequences in their names. ! % For example, 'xrdef {$\leq $-fun}{page ...} made by @defun ^^ ! % Reference to such entries still does not work the way one would wish, ! % but at least they do not bomb out when the aux file is read in. ! \catcode`\{=1 ! \catcode`\}=2 ! \catcode`\%=\other ! \catcode`\'=0 ! \catcode`\\=\other ! % ! \openin 1 \jobname.aux ! \ifeof 1 \else ! \closein 1 ! \input \jobname.aux ! \global\havexrefstrue ! \global\warnedobstrue ! \fi ! % Open the new aux file. TeX will close it automatically at exit. ! \openout\auxfile=\jobname.aux \endgroup} *************** *** 4304,4308 **** \def\supereject{\par\penalty -20000\footnoteno =0 } ! % @footnotestyle is meaningful for info output only.. \let\footnotestyle=\comment --- 5467,5471 ---- \def\supereject{\par\penalty -20000\footnoteno =0 } ! % @footnotestyle is meaningful for info output only. \let\footnotestyle=\comment *************** *** 4330,4334 **** % footnote text as a parameter. Our footnotes don't need to be so general. % ! \long\gdef\footnotezzz#1{\insert\footins{% % We want to typeset this text as a normal paragraph, even if the % footnote reference occurs in (for example) a display environment. --- 5493,5501 ---- % footnote text as a parameter. Our footnotes don't need to be so general. % ! % Oh yes, they do; otherwise, @ifset and anything else that uses ! % \parseargline fail inside footnotes because the tokens are fixed when ! % the footnote is read. --karl, 16nov96. ! % ! \long\gdef\footnotezzz{\insert\footins\bgroup % We want to typeset this text as a normal paragraph, even if the % footnote reference occurs in (for example) a display environment. *************** *** 4344,4347 **** --- 5511,5516 ---- \parindent\defaultparindent % + \smallfonts \rm + % % Hang the footnote text off the number. \hang *************** *** 4352,4357 **** % provide a place where TeX can split the footnote. \footstrut ! #1\strut}% } }%end \catcode `\@=11 --- 5521,5531 ---- % provide a place where TeX can split the footnote. \footstrut ! \futurelet\next\fo@t } + \def\fo@t{\ifcat\bgroup\noexpand\next \let\next\f@@t + \else\let\next\f@t\fi \next} + \def\f@@t{\bgroup\aftergroup\@foot\let\next} + \def\f@t#1{#1\@foot} + \def\@foot{\strut\par\egroup} }%end \catcode `\@=11 *************** *** 4410,4436 **** \def\finalout{\overfullrule=0pt} - % End of control word definitions. ! \message{and turning on texinfo input format.} ! \def\openindices{% ! \newindex{cp}% ! \newcodeindex{fn}% ! \newcodeindex{vr}% ! \newcodeindex{tp}% ! \newcodeindex{ky}% ! \newcodeindex{pg}% } ! % Set some numeric style parameters, for 8.5 x 11 format. ! \hsize = 6in ! \hoffset = .25in \newdimen\defaultparindent \defaultparindent = 15pt - \parindent = \defaultparindent - \parskip 3pt plus 2pt minus 1pt - \setleading{13.2pt} - \advance\topskip by 1.2cm \chapheadingskip = 15pt plus 4pt minus 2pt --- 5584,5688 ---- \def\finalout{\overfullrule=0pt} + % @image. We use the macros from epsf.tex to support this. + % If epsf.tex is not installed and @image is used, we complain. + % + % Check for and read epsf.tex up front. If we read it only at @image + % time, we might be inside a group, and then its definitions would get + % undone and the next image would fail. + \openin 1 = epsf.tex + \ifeof 1 \else + \closein 1 + % Do not bother showing banner with post-v2.7 epsf.tex (available in + % doc/epsf.tex until it shows up on ctan). + \def\epsfannounce{\toks0 = }% + \input epsf.tex + \fi + % + % We will only complain once about lack of epsf.tex. + \newif\ifwarnednoepsf + \newhelp\noepsfhelp{epsf.tex must be installed for images to + work. It is also included in the Texinfo distribution, or you can get + it from ftp://tug.org/tex/epsf.tex.} + % + \def\image#1{% + \ifx\epsfbox\undefined + \ifwarnednoepsf \else + \errhelp = \noepsfhelp + \errmessage{epsf.tex not found, images will be ignored}% + \global\warnednoepsftrue + \fi + \else + \imagexxx #1,,,\finish + \fi + } + % + % Arguments to @image: + % #1 is (mandatory) image filename; we tack on .eps extension. + % #2 is (optional) width, #3 is (optional) height. + % #4 is just the usual extra ignored arg for parsing this stuff. + \def\imagexxx#1,#2,#3,#4\finish{% + \ifpdf + \centerline{\dopdfimage{#1}{#2}{#3}}% + \else + % \epsfbox itself resets \epsf?size at each figure. + \setbox0 = \hbox{\ignorespaces #2}\ifdim\wd0 > 0pt \epsfxsize=#2\relax \fi + \setbox0 = \hbox{\ignorespaces #3}\ifdim\wd0 > 0pt \epsfysize=#3\relax \fi + \begingroup + \catcode`\^^M = 5 % in case we're inside an example + % If the image is by itself, center it. + \ifvmode + \nobreak\bigskip + % Usually we'll have text after the image which will insert + % \parskip glue, so insert it here too to equalize the space + % above and below. + \nobreak\vskip\parskip + \nobreak + \centerline{\epsfbox{#1.eps}}% + \bigbreak + \else + % In the middle of a paragraph, no extra space. + \epsfbox{#1.eps}% + \fi + \endgroup + \fi + } ! \message{localization,} ! % and i18n. ! % @documentlanguage is usually given very early, just after ! % @setfilename. If done too late, it may not override everything ! % properly. Single argument is the language abbreviation. ! % It would be nice if we could set up a hyphenation file here. ! % ! \def\documentlanguage{\parsearg\dodocumentlanguage} ! \def\dodocumentlanguage#1{% ! \tex % read txi-??.tex file in plain TeX. ! % Read the file if it exists. ! \openin 1 txi-#1.tex ! \ifeof1 ! \errhelp = \nolanghelp ! \errmessage{Cannot read language file txi-#1.tex}% ! \let\temp = \relax ! \else ! \def\temp{\input txi-#1.tex }% ! \fi ! \temp ! \endgroup } + \newhelp\nolanghelp{The given language definition file cannot be found or + is empty. Maybe you need to install it? In the current directory + should work if nowhere else does.} + ! % @documentencoding should change something in TeX eventually, most ! % likely, but for now just recognize it. ! \let\documentencoding = \comment ! ! % Page size parameters. ! % \newdimen\defaultparindent \defaultparindent = 15pt \chapheadingskip = 15pt plus 4pt minus 2pt *************** *** 4439,4443 **** % Prevent underfull vbox error messages. ! \vbadness=10000 % Following George Bush, just get rid of widows and orphans. --- 5691,5698 ---- % Prevent underfull vbox error messages. ! \vbadness = 10000 ! ! % Don't be so finicky about underfull hboxes, either. ! \hbadness = 2000 % Following George Bush, just get rid of widows and orphans. *************** *** 4448,4546 **** % using an old version of TeX, don't do anything. We want the amount of % stretch added to depend on the line length, hence the dependence on ! % \hsize. This makes it come to about 9pt for the 8.5x11 format. % ! \ifx\emergencystretch\thisisundefined ! % Allow us to assign to \emergencystretch anyway. ! \def\emergencystretch{\dimen0}% ! \else ! \emergencystretch = \hsize ! \divide\emergencystretch by 45 ! \fi ! ! % Use @smallbook to reset parameters for 7x9.5 format (or else 7x9.25) ! \def\smallbook{ ! \global\chapheadingskip = 15pt plus 4pt minus 2pt ! \global\secheadingskip = 12pt plus 3pt minus 2pt ! \global\subsecheadingskip = 9pt plus 2pt minus 2pt ! % ! \global\lispnarrowing = 0.3in ! \setleading{12pt} ! \advance\topskip by -1cm ! \global\parskip 2pt plus 1pt ! \global\hsize = 5in ! \global\vsize=7.5in ! \global\tolerance=700 ! \global\hfuzz=1pt ! \global\contentsrightmargin=0pt ! \global\deftypemargin=0pt ! \global\defbodyindent=.5cm ! % ! \global\pagewidth=\hsize ! \global\pageheight=\vsize ! % ! \global\let\smalllisp=\smalllispx ! \global\let\smallexample=\smalllispx ! \global\def\Esmallexample{\Esmalllisp} } % Use @afourpaper to print on European A4 paper. ! \def\afourpaper{ ! \global\tolerance=700 ! \global\hfuzz=1pt ! \setleading{12pt} ! \global\parskip 15pt plus 1pt ! ! \global\vsize= 53\baselineskip ! \advance\vsize by \topskip ! %\global\hsize= 5.85in % A4 wide 10pt ! \global\hsize= 6.5in ! \global\outerhsize=\hsize ! \global\advance\outerhsize by 0.5in ! \global\outervsize=\vsize ! \global\advance\outervsize by 0.6in ! ! \global\pagewidth=\hsize ! \global\pageheight=\vsize ! } ! ! \bindingoffset=0pt ! \normaloffset=\hoffset ! \pagewidth=\hsize ! \pageheight=\vsize ! ! % Allow control of the text dimensions. Parameters in order: textheight; ! % textwidth; voffset; hoffset; binding offset; topskip. ! % All require a dimension; ! % header is additional; added length extends the bottom of the page. ! ! \def\changepagesizes#1#2#3#4#5#6{ ! \global\vsize= #1 ! \global\topskip= #6 ! \advance\vsize by \topskip ! \global\voffset= #3 ! \global\hsize= #2 ! \global\outerhsize=\hsize ! \global\advance\outerhsize by 0.5in ! \global\outervsize=\vsize ! \global\advance\outervsize by 0.6in ! \global\pagewidth=\hsize ! \global\pageheight=\vsize ! \global\normaloffset= #4 ! \global\bindingoffset= #5} % A specific text layout, 24x15cm overall, intended for A4 paper. Top margin % 29mm, hence bottom margin 28mm, nominal side margin 3cm. ! \def\afourlatex ! {\global\tolerance=700 ! \global\hfuzz=1pt ! \setleading{12pt} ! \global\parskip 15pt plus 1pt ! \advance\baselineskip by 1.6pt ! \changepagesizes{237mm}{150mm}{3.6mm}{3.6mm}{3mm}{7mm} ! } % Use @afourwide to print on European A4 paper in wide format. ! \def\afourwide{\afourpaper ! \changepagesizes{9.5in}{6.5in}{\hoffset}{\normaloffset}{\bindingoffset}{7mm}} % Define macros to output various characters with catcode for normal text. --- 5703,5825 ---- % using an old version of TeX, don't do anything. We want the amount of % stretch added to depend on the line length, hence the dependence on ! % \hsize. We call this whenever the paper size is set. % ! \def\setemergencystretch{% ! \ifx\emergencystretch\thisisundefined ! % Allow us to assign to \emergencystretch anyway. ! \def\emergencystretch{\dimen0}% ! \else ! \emergencystretch = .15\hsize ! \fi } + % Parameters in order: 1) textheight; 2) textwidth; 3) voffset; + % 4) hoffset; 5) binding offset; 6) topskip. Then whoever calls us can + % set \parskip and call \setleading for \baselineskip. + % + \def\internalpagesizes#1#2#3#4#5#6{% + \voffset = #3\relax + \topskip = #6\relax + \splittopskip = \topskip + % + \vsize = #1\relax + \advance\vsize by \topskip + \outervsize = \vsize + \advance\outervsize by 2\topandbottommargin + \pageheight = \vsize + % + \hsize = #2\relax + \outerhsize = \hsize + \advance\outerhsize by 0.5in + \pagewidth = \hsize + % + \normaloffset = #4\relax + \bindingoffset = #5\relax + % + \parindent = \defaultparindent + \setemergencystretch + } + + % @letterpaper (the default). + \def\letterpaper{{\globaldefs = 1 + \parskip = 3pt plus 2pt minus 1pt + \setleading{13.2pt}% + % + % If page is nothing but text, make it come out even. + \internalpagesizes{46\baselineskip}{6in}{\voffset}{.25in}{\bindingoffset}{36pt}% + }} + + % Use @smallbook to reset parameters for 7x9.5 (or so) format. + \def\smallbook{{\globaldefs = 1 + \parskip = 2pt plus 1pt + \setleading{12pt}% + % + \internalpagesizes{7.5in}{5.in}{\voffset}{.25in}{\bindingoffset}{16pt}% + % + \lispnarrowing = 0.3in + \tolerance = 700 + \hfuzz = 1pt + \contentsrightmargin = 0pt + \deftypemargin = 0pt + \defbodyindent = .5cm + % + \let\smalldisplay = \smalldisplayx + \let\smallexample = \smalllispx + \let\smallformat = \smallformatx + \let\smalllisp = \smalllispx + }} + % Use @afourpaper to print on European A4 paper. ! \def\afourpaper{{\globaldefs = 1 ! \setleading{12pt}% ! \parskip = 3pt plus 2pt minus 1pt ! % ! \internalpagesizes{53\baselineskip}{160mm}{\voffset}{4mm}{\bindingoffset}{44pt}% ! % ! \tolerance = 700 ! \hfuzz = 1pt ! }} % A specific text layout, 24x15cm overall, intended for A4 paper. Top margin % 29mm, hence bottom margin 28mm, nominal side margin 3cm. ! \def\afourlatex{{\globaldefs = 1 ! \setleading{13.6pt}% ! % ! \afourpaper ! \internalpagesizes{237mm}{150mm}{3.6mm}{3.6mm}{3mm}{7mm}% ! % ! \globaldefs = 0 ! }} % Use @afourwide to print on European A4 paper in wide format. ! \def\afourwide{% ! \afourpaper ! \internalpagesizes{9.5in}{6.5in}{\hoffset}{\normaloffset}{\bindingoffset}{7mm}% ! % ! \globaldefs = 0 ! } ! ! % @pagesizes TEXTHEIGHT[,TEXTWIDTH] ! % Perhaps we should allow setting the margins, \topskip, \parskip, ! % and/or leading, also. Or perhaps we should compute them somehow. ! % ! \def\pagesizes{\parsearg\pagesizesxxx} ! \def\pagesizesxxx#1{\pagesizesyyy #1,,\finish} ! \def\pagesizesyyy#1,#2,#3\finish{{% ! \setbox0 = \hbox{\ignorespaces #2}\ifdim\wd0 > 0pt \hsize=#2\relax \fi ! \globaldefs = 1 ! % ! \parskip = 3pt plus 2pt minus 1pt ! \setleading{13.2pt}% ! % ! \internalpagesizes{#1}{\hsize}{\voffset}{\normaloffset}{\bindingoffset}{44pt}% ! }} ! ! % Set default to letter. ! % ! \letterpaper ! ! ! \message{and turning on texinfo input format.} % Define macros to output various characters with catcode for normal text. *************** *** 4553,4556 **** --- 5832,5836 ---- \catcode`\>=\other \catcode`\+=\other + \catcode`\$=\other \def\normaldoublequote{"} \def\normaltilde{~} *************** *** 4561,4564 **** --- 5841,5845 ---- \def\normalgreater{>} \def\normalplus{+} + \def\normaldollar{$} % This macro is used to make a character print one way in ttfont *************** *** 4571,4575 **** % typewriter fonts to have this, we can check that font parameter. % ! \def\ifusingtt#1#2{\ifdim \fontdimen3\the\font=0pt #1\else #2\fi} % Turn off all special characters except @ --- 5852,5862 ---- % typewriter fonts to have this, we can check that font parameter. % ! \def\ifusingtt#1#2{\ifdim \fontdimen3\font=0pt #1\else #2\fi} ! ! % Same as above, but check for italic font. Actually this also catches ! % non-italic slanted fonts since it is impossible to distinguish them from ! % italic fonts. But since this is only used by $ and it uses \sl anyway ! % this is not a problem. ! \def\ifusingit#1#2{\ifdim \fontdimen1\font>0pt #1\else #2\fi} % Turn off all special characters except @ *************** *** 4579,4589 **** \catcode`\"=\active ! \def\activedoublequote{{\tt \char '042}} \let"=\activedoublequote \catcode`\~=\active ! \def~{{\tt \char '176}} \chardef\hat=`\^ \catcode`\^=\active - \def\auxhat{\def^{'hat}} \def^{{\tt \hat}} --- 5866,5875 ---- \catcode`\"=\active ! \def\activedoublequote{{\tt\char34}} \let"=\activedoublequote \catcode`\~=\active ! \def~{{\tt\char126}} \chardef\hat=`\^ \catcode`\^=\active \def^{{\tt \hat}} *************** *** 4594,4598 **** \catcode`\|=\active ! \def|{{\tt \char '174}} \chardef \less=`\< \catcode`\<=\active --- 5880,5884 ---- \catcode`\|=\active ! \def|{{\tt\char124}} \chardef \less=`\< \catcode`\<=\active *************** *** 4603,4606 **** --- 5889,5894 ---- \catcode`\+=\active \def+{{\tt \char 43}} + \catcode`\$=\active + \def${\ifusingit{{\sl\$}}\normaldollar} %\catcode 27=\active %\def^^[{$\diamondsuit$} *************** *** 4633,4639 **** \def\normalbackslash{{\tt\rawbackslashxx}} - % Say @foo, not \foo, in error messages. - \escapechar=`\@ - % \catcode 17=0 % Define control-q \catcode`\\=\active --- 5921,5924 ---- *************** *** 4649,4653 **** @let<=@normalless @let>=@normalgreater ! @let+=@normalplus} @def@normalturnoffactive{@let"=@normaldoublequote --- 5934,5939 ---- @let<=@normalless @let>=@normalgreater ! @let+=@normalplus ! @let$=@normaldollar} @def@normalturnoffactive{@let"=@normaldoublequote *************** *** 4659,4663 **** @let<=@normalless @let>=@normalgreater ! @let+=@normalplus} % Make _ and + \other characters, temporarily. --- 5945,5950 ---- @let<=@normalless @let>=@normalgreater ! @let+=@normalplus ! @let$=@normaldollar} % Make _ and + \other characters, temporarily. *************** *** 4678,4692 **** % file name, in case not using a pre-dumped format. % ! @gdef@fixbackslash{@ifx\@eatinput @let\ = @normalbackslash @fi ! @catcode`+=@active @catcode`@_=@active} ! %% These look ok in all fonts, so just make them not special. The @rm below ! %% makes sure that the current font starts out as the newly loaded cmr10 ! @catcode`@$=@other @catcode`@%=@other @catcode`@&=@other @catcode`@#=@other @textfonts @rm @c Local variables: @c page-delimiter: "^\\\\message" @c End: --- 5965,5992 ---- % file name, in case not using a pre-dumped format. % ! @gdef@fixbackslash{% ! @ifx\@eatinput @let\ = @normalbackslash @fi ! @catcode`+=@active ! @catcode`@_=@active ! } ! ! % Say @foo, not \foo, in error messages. ! @escapechar = `@@ ! % These look ok in all fonts, so just make them not special. ! @catcode`@& = @other ! @catcode`@# = @other ! @catcode`@% = @other + @c Set initial fonts. @textfonts @rm + @c Local variables: + @c eval: (add-hook 'write-file-hooks 'time-stamp) @c page-delimiter: "^\\\\message" + @c time-stamp-start: "def\\\\texinfoversion{" + @c time-stamp-format: "%:y-%02m-%02d.%02H" + @c time-stamp-end: "}" @c End: diff -Nrc2 readline-4.1/emacs_keymap.c readline-4.2/emacs_keymap.c *** readline-4.1/emacs_keymap.c Thu Aug 5 08:03:00 1999 --- readline-4.2/emacs_keymap.c Mon Oct 30 12:01:50 2000 *************** *** 34,179 **** /* Control keys. */ ! { ISFUNC, rl_set_mark }, /* Control-@ */ ! { ISFUNC, rl_beg_of_line }, /* Control-a */ ! { ISFUNC, rl_backward }, /* Control-b */ ! { ISFUNC, (Function *)0x0 }, /* Control-c */ ! { ISFUNC, rl_delete }, /* Control-d */ ! { ISFUNC, rl_end_of_line }, /* Control-e */ ! { ISFUNC, rl_forward }, /* Control-f */ ! { ISFUNC, rl_abort }, /* Control-g */ ! { ISFUNC, rl_rubout }, /* Control-h */ ! { ISFUNC, rl_complete }, /* Control-i */ ! { ISFUNC, rl_newline }, /* Control-j */ ! { ISFUNC, rl_kill_line }, /* Control-k */ ! { ISFUNC, rl_clear_screen }, /* Control-l */ ! { ISFUNC, rl_newline }, /* Control-m */ ! { ISFUNC, rl_get_next_history }, /* Control-n */ ! { ISFUNC, (Function *)0x0 }, /* Control-o */ ! { ISFUNC, rl_get_previous_history }, /* Control-p */ ! { ISFUNC, rl_quoted_insert }, /* Control-q */ ! { ISFUNC, rl_reverse_search_history }, /* Control-r */ ! { ISFUNC, rl_forward_search_history }, /* Control-s */ ! { ISFUNC, rl_transpose_chars }, /* Control-t */ ! { ISFUNC, rl_unix_line_discard }, /* Control-u */ ! { ISFUNC, rl_quoted_insert }, /* Control-v */ ! { ISFUNC, rl_unix_word_rubout }, /* Control-w */ ! { ISKMAP, (Function *)emacs_ctlx_keymap }, /* Control-x */ ! { ISFUNC, rl_yank }, /* Control-y */ ! { ISFUNC, (Function *)0x0 }, /* Control-z */ ! { ISKMAP, (Function *)emacs_meta_keymap }, /* Control-[ */ ! { ISFUNC, (Function *)0x0 }, /* Control-\ */ ! { ISFUNC, rl_char_search }, /* Control-] */ ! { ISFUNC, (Function *)0x0 }, /* Control-^ */ ! { ISFUNC, rl_undo_command }, /* Control-_ */ /* The start of printing characters. */ ! { ISFUNC, rl_insert }, /* SPACE */ ! { ISFUNC, rl_insert }, /* ! */ ! { ISFUNC, rl_insert }, /* " */ ! { ISFUNC, rl_insert }, /* # */ ! { ISFUNC, rl_insert }, /* $ */ ! { ISFUNC, rl_insert }, /* % */ ! { ISFUNC, rl_insert }, /* & */ ! { ISFUNC, rl_insert }, /* ' */ ! { ISFUNC, rl_insert }, /* ( */ ! { ISFUNC, rl_insert }, /* ) */ ! { ISFUNC, rl_insert }, /* * */ ! { ISFUNC, rl_insert }, /* + */ ! { ISFUNC, rl_insert }, /* , */ ! { ISFUNC, rl_insert }, /* - */ ! { ISFUNC, rl_insert }, /* . */ ! { ISFUNC, rl_insert }, /* / */ ! ! /* Regular digits. */ ! { ISFUNC, rl_insert }, /* 0 */ ! { ISFUNC, rl_insert }, /* 1 */ ! { ISFUNC, rl_insert }, /* 2 */ ! { ISFUNC, rl_insert }, /* 3 */ ! { ISFUNC, rl_insert }, /* 4 */ ! { ISFUNC, rl_insert }, /* 5 */ ! { ISFUNC, rl_insert }, /* 6 */ ! { ISFUNC, rl_insert }, /* 7 */ ! { ISFUNC, rl_insert }, /* 8 */ ! { ISFUNC, rl_insert }, /* 9 */ /* A little more punctuation. */ ! { ISFUNC, rl_insert }, /* : */ ! { ISFUNC, rl_insert }, /* ; */ ! { ISFUNC, rl_insert }, /* < */ ! { ISFUNC, rl_insert }, /* = */ ! { ISFUNC, rl_insert }, /* > */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* @ */ /* Uppercase alphabet. */ ! { ISFUNC, rl_insert }, /* A */ ! { ISFUNC, rl_insert }, /* B */ ! { ISFUNC, rl_insert }, /* C */ ! { ISFUNC, rl_insert }, /* D */ ! { ISFUNC, rl_insert }, /* E */ ! { ISFUNC, rl_insert }, /* F */ ! { ISFUNC, rl_insert }, /* G */ ! { ISFUNC, rl_insert }, /* H */ ! { ISFUNC, rl_insert }, /* I */ ! { ISFUNC, rl_insert }, /* J */ ! { ISFUNC, rl_insert }, /* K */ ! { ISFUNC, rl_insert }, /* L */ ! { ISFUNC, rl_insert }, /* M */ ! { ISFUNC, rl_insert }, /* N */ ! { ISFUNC, rl_insert }, /* O */ ! { ISFUNC, rl_insert }, /* P */ ! { ISFUNC, rl_insert }, /* Q */ ! { ISFUNC, rl_insert }, /* R */ ! { ISFUNC, rl_insert }, /* S */ ! { ISFUNC, rl_insert }, /* T */ ! { ISFUNC, rl_insert }, /* U */ ! { ISFUNC, rl_insert }, /* V */ ! { ISFUNC, rl_insert }, /* W */ ! { ISFUNC, rl_insert }, /* X */ ! { ISFUNC, rl_insert }, /* Y */ ! { ISFUNC, rl_insert }, /* Z */ /* Some more punctuation. */ ! { ISFUNC, rl_insert }, /* [ */ ! { ISFUNC, rl_insert }, /* \ */ ! { ISFUNC, rl_insert }, /* ] */ ! { ISFUNC, rl_insert }, /* ^ */ ! { ISFUNC, rl_insert }, /* _ */ ! { ISFUNC, rl_insert }, /* ` */ /* Lowercase alphabet. */ ! { ISFUNC, rl_insert }, /* a */ ! { ISFUNC, rl_insert }, /* b */ ! { ISFUNC, rl_insert }, /* c */ ! { ISFUNC, rl_insert }, /* d */ ! { ISFUNC, rl_insert }, /* e */ ! { ISFUNC, rl_insert }, /* f */ ! { ISFUNC, rl_insert }, /* g */ ! { ISFUNC, rl_insert }, /* h */ ! { ISFUNC, rl_insert }, /* i */ ! { ISFUNC, rl_insert }, /* j */ ! { ISFUNC, rl_insert }, /* k */ ! { ISFUNC, rl_insert }, /* l */ ! { ISFUNC, rl_insert }, /* m */ ! { ISFUNC, rl_insert }, /* n */ ! { ISFUNC, rl_insert }, /* o */ ! { ISFUNC, rl_insert }, /* p */ ! { ISFUNC, rl_insert }, /* q */ ! { ISFUNC, rl_insert }, /* r */ ! { ISFUNC, rl_insert }, /* s */ ! { ISFUNC, rl_insert }, /* t */ ! { ISFUNC, rl_insert }, /* u */ ! { ISFUNC, rl_insert }, /* v */ ! { ISFUNC, rl_insert }, /* w */ ! { ISFUNC, rl_insert }, /* x */ ! { ISFUNC, rl_insert }, /* y */ ! { ISFUNC, rl_insert }, /* z */ /* Final punctuation. */ ! { ISFUNC, rl_insert }, /* { */ ! { ISFUNC, rl_insert }, /* | */ ! { ISFUNC, rl_insert }, /* } */ ! { ISFUNC, rl_insert }, /* ~ */ ! { ISFUNC, rl_rubout }, /* RUBOUT */ #if KEYMAP_SIZE > 128 --- 34,179 ---- /* Control keys. */ ! { ISFUNC, rl_set_mark }, /* Control-@ */ ! { ISFUNC, rl_beg_of_line }, /* Control-a */ ! { ISFUNC, rl_backward }, /* Control-b */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-c */ ! { ISFUNC, rl_delete }, /* Control-d */ ! { ISFUNC, rl_end_of_line }, /* Control-e */ ! { ISFUNC, rl_forward }, /* Control-f */ ! { ISFUNC, rl_abort }, /* Control-g */ ! { ISFUNC, rl_rubout }, /* Control-h */ ! { ISFUNC, rl_complete }, /* Control-i */ ! { ISFUNC, rl_newline }, /* Control-j */ ! { ISFUNC, rl_kill_line }, /* Control-k */ ! { ISFUNC, rl_clear_screen }, /* Control-l */ ! { ISFUNC, rl_newline }, /* Control-m */ ! { ISFUNC, rl_get_next_history }, /* Control-n */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-o */ ! { ISFUNC, rl_get_previous_history }, /* Control-p */ ! { ISFUNC, rl_quoted_insert }, /* Control-q */ ! { ISFUNC, rl_reverse_search_history }, /* Control-r */ ! { ISFUNC, rl_forward_search_history }, /* Control-s */ ! { ISFUNC, rl_transpose_chars }, /* Control-t */ ! { ISFUNC, rl_unix_line_discard }, /* Control-u */ ! { ISFUNC, rl_quoted_insert }, /* Control-v */ ! { ISFUNC, rl_unix_word_rubout }, /* Control-w */ ! { ISKMAP, (rl_command_func_t *)emacs_ctlx_keymap }, /* Control-x */ ! { ISFUNC, rl_yank }, /* Control-y */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-z */ ! { ISKMAP, (rl_command_func_t *)emacs_meta_keymap }, /* Control-[ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-\ */ ! { ISFUNC, rl_char_search }, /* Control-] */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-^ */ ! { ISFUNC, rl_undo_command }, /* Control-_ */ /* The start of printing characters. */ ! { ISFUNC, rl_insert }, /* SPACE */ ! { ISFUNC, rl_insert }, /* ! */ ! { ISFUNC, rl_insert }, /* " */ ! { ISFUNC, rl_insert }, /* # */ ! { ISFUNC, rl_insert }, /* $ */ ! { ISFUNC, rl_insert }, /* % */ ! { ISFUNC, rl_insert }, /* & */ ! { ISFUNC, rl_insert }, /* ' */ ! { ISFUNC, rl_insert }, /* ( */ ! { ISFUNC, rl_insert }, /* ) */ ! { ISFUNC, rl_insert }, /* * */ ! { ISFUNC, rl_insert }, /* + */ ! { ISFUNC, rl_insert }, /* , */ ! { ISFUNC, rl_insert }, /* - */ ! { ISFUNC, rl_insert }, /* . */ ! { ISFUNC, rl_insert }, /* / */ ! ! /* Regular digits. */ ! { ISFUNC, rl_insert }, /* 0 */ ! { ISFUNC, rl_insert }, /* 1 */ ! { ISFUNC, rl_insert }, /* 2 */ ! { ISFUNC, rl_insert }, /* 3 */ ! { ISFUNC, rl_insert }, /* 4 */ ! { ISFUNC, rl_insert }, /* 5 */ ! { ISFUNC, rl_insert }, /* 6 */ ! { ISFUNC, rl_insert }, /* 7 */ ! { ISFUNC, rl_insert }, /* 8 */ ! { ISFUNC, rl_insert }, /* 9 */ /* A little more punctuation. */ ! { ISFUNC, rl_insert }, /* : */ ! { ISFUNC, rl_insert }, /* ; */ ! { ISFUNC, rl_insert }, /* < */ ! { ISFUNC, rl_insert }, /* = */ ! { ISFUNC, rl_insert }, /* > */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* @ */ /* Uppercase alphabet. */ ! { ISFUNC, rl_insert }, /* A */ ! { ISFUNC, rl_insert }, /* B */ ! { ISFUNC, rl_insert }, /* C */ ! { ISFUNC, rl_insert }, /* D */ ! { ISFUNC, rl_insert }, /* E */ ! { ISFUNC, rl_insert }, /* F */ ! { ISFUNC, rl_insert }, /* G */ ! { ISFUNC, rl_insert }, /* H */ ! { ISFUNC, rl_insert }, /* I */ ! { ISFUNC, rl_insert }, /* J */ ! { ISFUNC, rl_insert }, /* K */ ! { ISFUNC, rl_insert }, /* L */ ! { ISFUNC, rl_insert }, /* M */ ! { ISFUNC, rl_insert }, /* N */ ! { ISFUNC, rl_insert }, /* O */ ! { ISFUNC, rl_insert }, /* P */ ! { ISFUNC, rl_insert }, /* Q */ ! { ISFUNC, rl_insert }, /* R */ ! { ISFUNC, rl_insert }, /* S */ ! { ISFUNC, rl_insert }, /* T */ ! { ISFUNC, rl_insert }, /* U */ ! { ISFUNC, rl_insert }, /* V */ ! { ISFUNC, rl_insert }, /* W */ ! { ISFUNC, rl_insert }, /* X */ ! { ISFUNC, rl_insert }, /* Y */ ! { ISFUNC, rl_insert }, /* Z */ /* Some more punctuation. */ ! { ISFUNC, rl_insert }, /* [ */ ! { ISFUNC, rl_insert }, /* \ */ ! { ISFUNC, rl_insert }, /* ] */ ! { ISFUNC, rl_insert }, /* ^ */ ! { ISFUNC, rl_insert }, /* _ */ ! { ISFUNC, rl_insert }, /* ` */ /* Lowercase alphabet. */ ! { ISFUNC, rl_insert }, /* a */ ! { ISFUNC, rl_insert }, /* b */ ! { ISFUNC, rl_insert }, /* c */ ! { ISFUNC, rl_insert }, /* d */ ! { ISFUNC, rl_insert }, /* e */ ! { ISFUNC, rl_insert }, /* f */ ! { ISFUNC, rl_insert }, /* g */ ! { ISFUNC, rl_insert }, /* h */ ! { ISFUNC, rl_insert }, /* i */ ! { ISFUNC, rl_insert }, /* j */ ! { ISFUNC, rl_insert }, /* k */ ! { ISFUNC, rl_insert }, /* l */ ! { ISFUNC, rl_insert }, /* m */ ! { ISFUNC, rl_insert }, /* n */ ! { ISFUNC, rl_insert }, /* o */ ! { ISFUNC, rl_insert }, /* p */ ! { ISFUNC, rl_insert }, /* q */ ! { ISFUNC, rl_insert }, /* r */ ! { ISFUNC, rl_insert }, /* s */ ! { ISFUNC, rl_insert }, /* t */ ! { ISFUNC, rl_insert }, /* u */ ! { ISFUNC, rl_insert }, /* v */ ! { ISFUNC, rl_insert }, /* w */ ! { ISFUNC, rl_insert }, /* x */ ! { ISFUNC, rl_insert }, /* y */ ! { ISFUNC, rl_insert }, /* z */ /* Final punctuation. */ ! { ISFUNC, rl_insert }, /* { */ ! { ISFUNC, rl_insert }, /* | */ ! { ISFUNC, rl_insert }, /* } */ ! { ISFUNC, rl_insert }, /* ~ */ ! { ISFUNC, rl_rubout }, /* RUBOUT */ #if KEYMAP_SIZE > 128 *************** *** 181,216 **** These might be used in some character sets. */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ /* ISO Latin-1 characters (160 - 255) */ --- 181,216 ---- These might be used in some character sets. */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* ? */ /* ISO Latin-1 characters (160 - 255) */ *************** *** 317,392 **** /* Meta keys. Just like above, but the high bit is set. */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-@ */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-a */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-b */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-c */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-d */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-e */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-f */ ! { ISFUNC, rl_abort }, /* Meta-Control-g */ { ISFUNC, rl_backward_kill_word }, /* Meta-Control-h */ ! { ISFUNC, rl_tab_insert }, /* Meta-Control-i */ ! { ISFUNC, rl_vi_editing_mode }, /* Meta-Control-j */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-k */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-l */ ! { ISFUNC, rl_vi_editing_mode }, /* Meta-Control-m */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-n */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-o */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-p */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-q */ ! { ISFUNC, rl_revert_line }, /* Meta-Control-r */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-s */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-t */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-u */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-v */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-w */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-x */ ! { ISFUNC, rl_yank_nth_arg }, /* Meta-Control-y */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-z */ ! { ISFUNC, rl_complete }, /* Meta-Control-[ */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-\ */ { ISFUNC, rl_backward_char_search }, /* Meta-Control-] */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-^ */ ! { ISFUNC, (Function *)0x0 }, /* Meta-Control-_ */ /* The start of printing characters. */ ! { ISFUNC, rl_set_mark }, /* Meta-SPACE */ ! { ISFUNC, (Function *)0x0 }, /* Meta-! */ ! { ISFUNC, (Function *)0x0 }, /* Meta-" */ ! { ISFUNC, rl_insert_comment },/* Meta-# */ ! { ISFUNC, (Function *)0x0 }, /* Meta-$ */ ! { ISFUNC, (Function *)0x0 }, /* Meta-% */ ! { ISFUNC, rl_tilde_expand }, /* Meta-& */ ! { ISFUNC, (Function *)0x0 }, /* Meta-' */ ! { ISFUNC, (Function *)0x0 }, /* Meta-( */ ! { ISFUNC, (Function *)0x0 }, /* Meta-) */ { ISFUNC, rl_insert_completions }, /* Meta-* */ ! { ISFUNC, (Function *)0x0 }, /* Meta-+ */ ! { ISFUNC, (Function *)0x0 }, /* Meta-, */ ! { ISFUNC, rl_digit_argument }, /* Meta-- */ ! { ISFUNC, rl_yank_last_arg}, /* Meta-. */ ! { ISFUNC, (Function *)0x0 }, /* Meta-/ */ /* Regular digits. */ ! { ISFUNC, rl_digit_argument }, /* Meta-0 */ ! { ISFUNC, rl_digit_argument }, /* Meta-1 */ ! { ISFUNC, rl_digit_argument }, /* Meta-2 */ ! { ISFUNC, rl_digit_argument }, /* Meta-3 */ ! { ISFUNC, rl_digit_argument }, /* Meta-4 */ ! { ISFUNC, rl_digit_argument }, /* Meta-5 */ ! { ISFUNC, rl_digit_argument }, /* Meta-6 */ ! { ISFUNC, rl_digit_argument }, /* Meta-7 */ ! { ISFUNC, rl_digit_argument }, /* Meta-8 */ ! { ISFUNC, rl_digit_argument }, /* Meta-9 */ /* A little more punctuation. */ ! { ISFUNC, (Function *)0x0 }, /* Meta-: */ ! { ISFUNC, (Function *)0x0 }, /* Meta-; */ { ISFUNC, rl_beginning_of_history }, /* Meta-< */ { ISFUNC, rl_possible_completions }, /* Meta-= */ { ISFUNC, rl_end_of_history }, /* Meta-> */ { ISFUNC, rl_possible_completions }, /* Meta-? */ ! { ISFUNC, (Function *)0x0 }, /* Meta-@ */ /* Uppercase alphabet. */ --- 317,392 ---- /* Meta keys. Just like above, but the high bit is set. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-@ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-a */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-b */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-c */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-d */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-e */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-f */ ! { ISFUNC, rl_abort }, /* Meta-Control-g */ { ISFUNC, rl_backward_kill_word }, /* Meta-Control-h */ ! { ISFUNC, rl_tab_insert }, /* Meta-Control-i */ ! { ISFUNC, rl_vi_editing_mode }, /* Meta-Control-j */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-k */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-l */ ! { ISFUNC, rl_vi_editing_mode }, /* Meta-Control-m */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-n */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-o */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-p */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-q */ ! { ISFUNC, rl_revert_line }, /* Meta-Control-r */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-s */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-t */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-u */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-v */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-w */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-x */ ! { ISFUNC, rl_yank_nth_arg }, /* Meta-Control-y */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-z */ ! { ISFUNC, rl_complete }, /* Meta-Control-[ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-\ */ { ISFUNC, rl_backward_char_search }, /* Meta-Control-] */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-^ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-Control-_ */ /* The start of printing characters. */ ! { ISFUNC, rl_set_mark }, /* Meta-SPACE */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-! */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-" */ ! { ISFUNC, rl_insert_comment }, /* Meta-# */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-$ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-% */ ! { ISFUNC, rl_tilde_expand }, /* Meta-& */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-' */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-( */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-) */ { ISFUNC, rl_insert_completions }, /* Meta-* */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-+ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-, */ ! { ISFUNC, rl_digit_argument }, /* Meta-- */ ! { ISFUNC, rl_yank_last_arg}, /* Meta-. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-/ */ /* Regular digits. */ ! { ISFUNC, rl_digit_argument }, /* Meta-0 */ ! { ISFUNC, rl_digit_argument }, /* Meta-1 */ ! { ISFUNC, rl_digit_argument }, /* Meta-2 */ ! { ISFUNC, rl_digit_argument }, /* Meta-3 */ ! { ISFUNC, rl_digit_argument }, /* Meta-4 */ ! { ISFUNC, rl_digit_argument }, /* Meta-5 */ ! { ISFUNC, rl_digit_argument }, /* Meta-6 */ ! { ISFUNC, rl_digit_argument }, /* Meta-7 */ ! { ISFUNC, rl_digit_argument }, /* Meta-8 */ ! { ISFUNC, rl_digit_argument }, /* Meta-9 */ /* A little more punctuation. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-: */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-; */ { ISFUNC, rl_beginning_of_history }, /* Meta-< */ { ISFUNC, rl_possible_completions }, /* Meta-= */ { ISFUNC, rl_end_of_history }, /* Meta-> */ { ISFUNC, rl_possible_completions }, /* Meta-? */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-@ */ /* Uppercase alphabet. */ *************** *** 419,594 **** /* Some more punctuation. */ ! { ISFUNC, (Function *)0x0 }, /* Meta-[ */ /* was rl_arrow_keys */ { ISFUNC, rl_delete_horizontal_space }, /* Meta-\ */ ! { ISFUNC, (Function *)0x0 }, /* Meta-] */ ! { ISFUNC, (Function *)0x0 }, /* Meta-^ */ ! { ISFUNC, rl_yank_last_arg }, /* Meta-_ */ ! { ISFUNC, (Function *)0x0 }, /* Meta-` */ /* Lowercase alphabet. */ ! { ISFUNC, (Function *)0x0 }, /* Meta-a */ ! { ISFUNC, rl_backward_word }, /* Meta-b */ ! { ISFUNC, rl_capitalize_word }, /* Meta-c */ ! { ISFUNC, rl_kill_word }, /* Meta-d */ ! { ISFUNC, (Function *)0x0 }, /* Meta-e */ ! { ISFUNC, rl_forward_word }, /* Meta-f */ ! { ISFUNC, (Function *)0x0 }, /* Meta-g */ ! { ISFUNC, (Function *)0x0 }, /* Meta-h */ ! { ISFUNC, (Function *)0x0 }, /* Meta-i */ ! { ISFUNC, (Function *)0x0 }, /* Meta-j */ ! { ISFUNC, (Function *)0x0 }, /* Meta-k */ ! { ISFUNC, rl_downcase_word }, /* Meta-l */ ! { ISFUNC, (Function *)0x0 }, /* Meta-m */ { ISFUNC, rl_noninc_forward_search }, /* Meta-n */ ! { ISFUNC, (Function *)0x0 }, /* Meta-o */ /* was rl_arrow_keys */ { ISFUNC, rl_noninc_reverse_search }, /* Meta-p */ ! { ISFUNC, (Function *)0x0 }, /* Meta-q */ ! { ISFUNC, rl_revert_line }, /* Meta-r */ ! { ISFUNC, (Function *)0x0 }, /* Meta-s */ ! { ISFUNC, rl_transpose_words }, /* Meta-t */ ! { ISFUNC, rl_upcase_word }, /* Meta-u */ ! { ISFUNC, (Function *)0x0 }, /* Meta-v */ ! { ISFUNC, (Function *)0x0 }, /* Meta-w */ ! { ISFUNC, (Function *)0x0 }, /* Meta-x */ ! { ISFUNC, rl_yank_pop }, /* Meta-y */ ! { ISFUNC, (Function *)0x0 }, /* Meta-z */ /* Final punctuation. */ ! { ISFUNC, (Function *)0x0 }, /* Meta-{ */ ! { ISFUNC, (Function *)0x0 }, /* Meta-| */ ! { ISFUNC, (Function *)0x0 }, /* Meta-} */ ! { ISFUNC, rl_tilde_expand }, /* Meta-~ */ ! { ISFUNC, rl_backward_kill_word }, /* Meta-rubout */ #if KEYMAP_SIZE > 128 /* Undefined keys. */ ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 } #endif /* KEYMAP_SIZE > 128 */ }; --- 419,594 ---- /* Some more punctuation. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-[ */ /* was rl_arrow_keys */ { ISFUNC, rl_delete_horizontal_space }, /* Meta-\ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-] */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-^ */ ! { ISFUNC, rl_yank_last_arg }, /* Meta-_ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-` */ /* Lowercase alphabet. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-a */ ! { ISFUNC, rl_backward_word }, /* Meta-b */ ! { ISFUNC, rl_capitalize_word }, /* Meta-c */ ! { ISFUNC, rl_kill_word }, /* Meta-d */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-e */ ! { ISFUNC, rl_forward_word }, /* Meta-f */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-g */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-h */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-i */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-j */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-k */ ! { ISFUNC, rl_downcase_word }, /* Meta-l */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-m */ { ISFUNC, rl_noninc_forward_search }, /* Meta-n */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-o */ /* was rl_arrow_keys */ { ISFUNC, rl_noninc_reverse_search }, /* Meta-p */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-q */ ! { ISFUNC, rl_revert_line }, /* Meta-r */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-s */ ! { ISFUNC, rl_transpose_words }, /* Meta-t */ ! { ISFUNC, rl_upcase_word }, /* Meta-u */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-v */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-w */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-x */ ! { ISFUNC, rl_yank_pop }, /* Meta-y */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-z */ /* Final punctuation. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-{ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-| */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Meta-} */ ! { ISFUNC, rl_tilde_expand }, /* Meta-~ */ ! { ISFUNC, rl_backward_kill_word }, /* Meta-rubout */ #if KEYMAP_SIZE > 128 /* Undefined keys. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 } #endif /* KEYMAP_SIZE > 128 */ }; *************** *** 597,873 **** /* Control keys. */ ! { ISFUNC, (Function *)0x0 }, /* Control-@ */ ! { ISFUNC, (Function *)0x0 }, /* Control-a */ ! { ISFUNC, (Function *)0x0 }, /* Control-b */ ! { ISFUNC, (Function *)0x0 }, /* Control-c */ ! { ISFUNC, (Function *)0x0 }, /* Control-d */ ! { ISFUNC, (Function *)0x0 }, /* Control-e */ ! { ISFUNC, (Function *)0x0 }, /* Control-f */ ! { ISFUNC, rl_abort }, /* Control-g */ ! { ISFUNC, (Function *)0x0 }, /* Control-h */ ! { ISFUNC, (Function *)0x0 }, /* Control-i */ ! { ISFUNC, (Function *)0x0 }, /* Control-j */ ! { ISFUNC, (Function *)0x0 }, /* Control-k */ ! { ISFUNC, (Function *)0x0 }, /* Control-l */ ! { ISFUNC, (Function *)0x0 }, /* Control-m */ ! { ISFUNC, (Function *)0x0 }, /* Control-n */ ! { ISFUNC, (Function *)0x0 }, /* Control-o */ ! { ISFUNC, (Function *)0x0 }, /* Control-p */ ! { ISFUNC, (Function *)0x0 }, /* Control-q */ ! { ISFUNC, rl_re_read_init_file }, /* Control-r */ ! { ISFUNC, (Function *)0x0 }, /* Control-s */ ! { ISFUNC, (Function *)0x0 }, /* Control-t */ ! { ISFUNC, rl_undo_command }, /* Control-u */ ! { ISFUNC, (Function *)0x0 }, /* Control-v */ ! { ISFUNC, (Function *)0x0 }, /* Control-w */ ! { ISFUNC, rl_exchange_point_and_mark },/* Control-x */ ! { ISFUNC, (Function *)0x0 }, /* Control-y */ ! { ISFUNC, (Function *)0x0 }, /* Control-z */ ! { ISFUNC, (Function *)0x0 }, /* Control-[ */ ! { ISFUNC, (Function *)0x0 }, /* Control-\ */ ! { ISFUNC, (Function *)0x0 }, /* Control-] */ ! { ISFUNC, (Function *)0x0 }, /* Control-^ */ ! { ISFUNC, (Function *)0x0 }, /* Control-_ */ /* The start of printing characters. */ ! { ISFUNC, (Function *)0x0 }, /* SPACE */ ! { ISFUNC, (Function *)0x0 }, /* ! */ ! { ISFUNC, (Function *)0x0 }, /* " */ ! { ISFUNC, (Function *)0x0 }, /* # */ ! { ISFUNC, (Function *)0x0 }, /* $ */ ! { ISFUNC, (Function *)0x0 }, /* % */ ! { ISFUNC, (Function *)0x0 }, /* & */ ! { ISFUNC, (Function *)0x0 }, /* ' */ ! { ISFUNC, rl_start_kbd_macro }, /* ( */ ! { ISFUNC, rl_end_kbd_macro }, /* ) */ ! { ISFUNC, (Function *)0x0 }, /* * */ ! { ISFUNC, (Function *)0x0 }, /* + */ ! { ISFUNC, (Function *)0x0 }, /* , */ ! { ISFUNC, (Function *)0x0 }, /* - */ ! { ISFUNC, (Function *)0x0 }, /* . */ ! { ISFUNC, (Function *)0x0 }, /* / */ /* Regular digits. */ ! { ISFUNC, (Function *)0x0 }, /* 0 */ ! { ISFUNC, (Function *)0x0 }, /* 1 */ ! { ISFUNC, (Function *)0x0 }, /* 2 */ ! { ISFUNC, (Function *)0x0 }, /* 3 */ ! { ISFUNC, (Function *)0x0 }, /* 4 */ ! { ISFUNC, (Function *)0x0 }, /* 5 */ ! { ISFUNC, (Function *)0x0 }, /* 6 */ ! { ISFUNC, (Function *)0x0 }, /* 7 */ ! { ISFUNC, (Function *)0x0 }, /* 8 */ ! { ISFUNC, (Function *)0x0 }, /* 9 */ /* A little more punctuation. */ ! { ISFUNC, (Function *)0x0 }, /* : */ ! { ISFUNC, (Function *)0x0 }, /* ; */ ! { ISFUNC, (Function *)0x0 }, /* < */ ! { ISFUNC, (Function *)0x0 }, /* = */ ! { ISFUNC, (Function *)0x0 }, /* > */ ! { ISFUNC, (Function *)0x0 }, /* ? */ ! { ISFUNC, (Function *)0x0 }, /* @ */ /* Uppercase alphabet. */ ! { ISFUNC, rl_do_lowercase_version }, /* A */ ! { ISFUNC, rl_do_lowercase_version }, /* B */ ! { ISFUNC, rl_do_lowercase_version }, /* C */ ! { ISFUNC, rl_do_lowercase_version }, /* D */ ! { ISFUNC, rl_do_lowercase_version }, /* E */ ! { ISFUNC, rl_do_lowercase_version }, /* F */ ! { ISFUNC, rl_do_lowercase_version }, /* G */ ! { ISFUNC, rl_do_lowercase_version }, /* H */ ! { ISFUNC, rl_do_lowercase_version }, /* I */ ! { ISFUNC, rl_do_lowercase_version }, /* J */ ! { ISFUNC, rl_do_lowercase_version }, /* K */ ! { ISFUNC, rl_do_lowercase_version }, /* L */ ! { ISFUNC, rl_do_lowercase_version }, /* M */ ! { ISFUNC, rl_do_lowercase_version }, /* N */ ! { ISFUNC, rl_do_lowercase_version }, /* O */ ! { ISFUNC, rl_do_lowercase_version }, /* P */ ! { ISFUNC, rl_do_lowercase_version }, /* Q */ ! { ISFUNC, rl_do_lowercase_version }, /* R */ ! { ISFUNC, rl_do_lowercase_version }, /* S */ ! { ISFUNC, rl_do_lowercase_version }, /* T */ ! { ISFUNC, rl_do_lowercase_version }, /* U */ ! { ISFUNC, rl_do_lowercase_version }, /* V */ ! { ISFUNC, rl_do_lowercase_version }, /* W */ ! { ISFUNC, rl_do_lowercase_version }, /* X */ ! { ISFUNC, rl_do_lowercase_version }, /* Y */ ! { ISFUNC, rl_do_lowercase_version }, /* Z */ /* Some more punctuation. */ ! { ISFUNC, (Function *)0x0 }, /* [ */ ! { ISFUNC, (Function *)0x0 }, /* \ */ ! { ISFUNC, (Function *)0x0 }, /* ] */ ! { ISFUNC, (Function *)0x0 }, /* ^ */ ! { ISFUNC, (Function *)0x0 }, /* _ */ ! { ISFUNC, (Function *)0x0 }, /* ` */ /* Lowercase alphabet. */ ! { ISFUNC, (Function *)0x0 }, /* a */ ! { ISFUNC, (Function *)0x0 }, /* b */ ! { ISFUNC, (Function *)0x0 }, /* c */ ! { ISFUNC, (Function *)0x0 }, /* d */ ! { ISFUNC, rl_call_last_kbd_macro }, /* e */ ! { ISFUNC, (Function *)0x0 }, /* f */ ! { ISFUNC, (Function *)0x0 }, /* g */ ! { ISFUNC, (Function *)0x0 }, /* h */ ! { ISFUNC, (Function *)0x0 }, /* i */ ! { ISFUNC, (Function *)0x0 }, /* j */ ! { ISFUNC, (Function *)0x0 }, /* k */ ! { ISFUNC, (Function *)0x0 }, /* l */ ! { ISFUNC, (Function *)0x0 }, /* m */ ! { ISFUNC, (Function *)0x0 }, /* n */ ! { ISFUNC, (Function *)0x0 }, /* o */ ! { ISFUNC, (Function *)0x0 }, /* p */ ! { ISFUNC, (Function *)0x0 }, /* q */ ! { ISFUNC, (Function *)0x0 }, /* r */ ! { ISFUNC, (Function *)0x0 }, /* s */ ! { ISFUNC, (Function *)0x0 }, /* t */ ! { ISFUNC, (Function *)0x0 }, /* u */ ! { ISFUNC, (Function *)0x0 }, /* v */ ! { ISFUNC, (Function *)0x0 }, /* w */ ! { ISFUNC, (Function *)0x0 }, /* x */ ! { ISFUNC, (Function *)0x0 }, /* y */ ! { ISFUNC, (Function *)0x0 }, /* z */ /* Final punctuation. */ ! { ISFUNC, (Function *)0x0 }, /* { */ ! { ISFUNC, (Function *)0x0 }, /* | */ ! { ISFUNC, (Function *)0x0 }, /* } */ ! { ISFUNC, (Function *)0x0 }, /* ~ */ ! { ISFUNC, rl_backward_kill_line }, /* RUBOUT */ #if KEYMAP_SIZE > 128 /* Undefined keys. */ ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 } #endif /* KEYMAP_SIZE > 128 */ }; --- 597,873 ---- /* Control keys. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-@ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-a */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-b */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-c */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-d */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-e */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-f */ ! { ISFUNC, rl_abort }, /* Control-g */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-h */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-i */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-j */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-k */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-l */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-m */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-n */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-o */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-p */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-q */ ! { ISFUNC, rl_re_read_init_file }, /* Control-r */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-s */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-t */ ! { ISFUNC, rl_undo_command }, /* Control-u */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-v */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-w */ ! { ISFUNC, rl_exchange_point_and_mark }, /* Control-x */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-y */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-z */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-[ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-\ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-] */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-^ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-_ */ /* The start of printing characters. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* SPACE */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ! */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* " */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* # */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* $ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* % */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* & */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ' */ ! { ISFUNC, rl_start_kbd_macro }, /* ( */ ! { ISFUNC, rl_end_kbd_macro }, /* ) */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* * */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* + */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* , */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* - */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* . */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* / */ /* Regular digits. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* 0 */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* 1 */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* 2 */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* 3 */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* 4 */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* 5 */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* 6 */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* 7 */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* 8 */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* 9 */ /* A little more punctuation. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* : */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ; */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* < */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* = */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* > */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ? */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* @ */ /* Uppercase alphabet. */ ! { ISFUNC, rl_do_lowercase_version }, /* A */ ! { ISFUNC, rl_do_lowercase_version }, /* B */ ! { ISFUNC, rl_do_lowercase_version }, /* C */ ! { ISFUNC, rl_do_lowercase_version }, /* D */ ! { ISFUNC, rl_do_lowercase_version }, /* E */ ! { ISFUNC, rl_do_lowercase_version }, /* F */ ! { ISFUNC, rl_do_lowercase_version }, /* G */ ! { ISFUNC, rl_do_lowercase_version }, /* H */ ! { ISFUNC, rl_do_lowercase_version }, /* I */ ! { ISFUNC, rl_do_lowercase_version }, /* J */ ! { ISFUNC, rl_do_lowercase_version }, /* K */ ! { ISFUNC, rl_do_lowercase_version }, /* L */ ! { ISFUNC, rl_do_lowercase_version }, /* M */ ! { ISFUNC, rl_do_lowercase_version }, /* N */ ! { ISFUNC, rl_do_lowercase_version }, /* O */ ! { ISFUNC, rl_do_lowercase_version }, /* P */ ! { ISFUNC, rl_do_lowercase_version }, /* Q */ ! { ISFUNC, rl_do_lowercase_version }, /* R */ ! { ISFUNC, rl_do_lowercase_version }, /* S */ ! { ISFUNC, rl_do_lowercase_version }, /* T */ ! { ISFUNC, rl_do_lowercase_version }, /* U */ ! { ISFUNC, rl_do_lowercase_version }, /* V */ ! { ISFUNC, rl_do_lowercase_version }, /* W */ ! { ISFUNC, rl_do_lowercase_version }, /* X */ ! { ISFUNC, rl_do_lowercase_version }, /* Y */ ! { ISFUNC, rl_do_lowercase_version }, /* Z */ /* Some more punctuation. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* [ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* \ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ] */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ^ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* _ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ` */ /* Lowercase alphabet. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* a */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* b */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* c */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* d */ ! { ISFUNC, rl_call_last_kbd_macro }, /* e */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* f */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* g */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* h */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* i */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* j */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* k */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* l */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* m */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* n */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* o */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* p */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* q */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* r */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* s */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* t */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* u */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* v */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* w */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* x */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* y */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* z */ /* Final punctuation. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* { */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* | */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* } */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ~ */ ! { ISFUNC, rl_backward_kill_line }, /* RUBOUT */ #if KEYMAP_SIZE > 128 /* Undefined keys. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 } #endif /* KEYMAP_SIZE > 128 */ }; diff -Nrc2 readline-4.1/examples/Makefile.in readline-4.2/examples/Makefile.in *** readline-4.1/examples/Makefile.in Tue Sep 21 16:45:37 1999 --- readline-4.2/examples/Makefile.in Mon Apr 2 14:27:34 2001 *************** *** 17,20 **** --- 17,21 ---- # along with this program; if not, write to the Free Software # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111 USA. + RL_LIBRARY_VERSION = @LIBVERSION@ SHELL = @MAKE_SHELL@ *************** *** 29,33 **** CC = @CC@ CFLAGS = @CFLAGS@ ! LOCAL_CFLAGS = @LOCAL_CFLAGS@ -DREADLINE_LIBRARY CPPFLAGS = @CPPFLAGS@ --- 30,34 ---- CC = @CC@ CFLAGS = @CFLAGS@ ! LOCAL_CFLAGS = @LOCAL_CFLAGS@ -DREADLINE_LIBRARY -DRL_LIBRARY_VERSION='"$(RL_LIBRARY_VERSION)"' CPPFLAGS = @CPPFLAGS@ *************** *** 46,53 **** $(CC) $(CCFLAGS) -c $< ! EXECUTABLES = fileman rltest rl rlversion ! OBJECTS = fileman.o rltest.o rl.o rlversion.o all: $(EXECUTABLES) rl: rl.o --- 47,55 ---- $(CC) $(CCFLAGS) -c $< ! EXECUTABLES = fileman rltest rl rlversion histexamp ! OBJECTS = fileman.o rltest.o rl.o rlversion.o histexamp.o all: $(EXECUTABLES) + everything: all rlfe rl: rl.o *************** *** 63,69 **** --- 65,75 ---- $(CC) $(LDFLAGS) -o $@ rlversion.o -lreadline $(TERMCAP_LIB) + histexamp: histexamp.o $(HISTORY_LIB) + $(CC) $(LDFLAGS) -o $@ histexamp.o -lhistory $(TERMCAP_LIB) + clean mostlyclean: $(RM) $(OBJECTS) $(RM) $(EXECUTABLES) *.exe + $(RM) rlfe.o rlfe distclean maintainer-clean: clean *************** *** 74,77 **** --- 80,90 ---- rl.o: rl.c rlversion.o: rlversion.c + histexamp.o: histexamp.c + + fileman.o: $(top_srcdir)/readline.h + rltest.o: $(top_srcdir)/readline.h + rl.o: $(top_srcdir)/readline.h + rlversion.o: $(top_srcdir)/readline.h + histexamp.o: $(top_srcdir)/history.h # Stuff for Per Bothner's `rlfe' program diff -Nrc2 readline-4.1/examples/excallback.c readline-4.2/examples/excallback.c *** readline-4.1/examples/excallback.c Thu Sep 2 10:57:14 1999 --- readline-4.2/examples/excallback.c Mon Jul 10 10:52:46 2000 *************** *** 154,157 **** --- 154,159 ---- fprintf(stderr, "|%s|\n", line); } + + free (line); } diff -Nrc2 readline-4.1/examples/fileman.c readline-4.2/examples/fileman.c *** readline-4.1/examples/fileman.c Thu Sep 2 16:45:52 1999 --- readline-4.2/examples/fileman.c Tue Dec 12 15:05:24 2000 *************** *** 42,47 **** /* The names of functions that actually do the manipulation. */ ! int com_list (), com_view (), com_rename (), com_stat (), com_pwd (); ! int com_delete (), com_help (), com_cd (), com_quit (); /* A structure which contains information on the commands this program --- 42,54 ---- /* The names of functions that actually do the manipulation. */ ! int com_list __P((char *)); ! int com_view __P((char *)); ! int com_rename __P((char *)); ! int com_stat __P((char *)); ! int com_pwd __P((char *)); ! int com_delete __P((char *)); ! int com_help __P((char *)); ! int com_cd __P((char *)); ! int com_quit __P((char *)); /* A structure which contains information on the commands this program *************** *** 50,54 **** typedef struct { char *name; /* User printable name of the function. */ ! Function *func; /* Function to call to do the job. */ char *doc; /* Documentation for this function. */ } COMMAND; --- 57,61 ---- typedef struct { char *name; /* User printable name of the function. */ ! rl_icpfunc_t *func; /* Function to call to do the job. */ char *doc; /* Documentation for this function. */ } COMMAND; *************** *** 66,70 **** { "stat", com_stat, "Print out statistics on FILE" }, { "view", com_view, "View the contents of FILE" }, ! { (char *)NULL, (Function *)NULL, (char *)NULL } }; --- 73,77 ---- { "stat", com_stat, "Print out statistics on FILE" }, { "view", com_view, "View the contents of FILE" }, ! { (char *)NULL, (rl_icpfunc_t *)NULL, (char *)NULL } }; *************** *** 206,211 **** /* **************************************************************** */ ! char *command_generator (); ! char **fileman_completion (); /* Tell the GNU Readline library how to complete. We want to try to complete --- 213,218 ---- /* **************************************************************** */ ! char *command_generator __P((const char *, int)); ! char **fileman_completion __P((const char *, int, int)); /* Tell the GNU Readline library how to complete. We want to try to complete *************** *** 218,222 **** /* Tell the completer that we want a crack first. */ ! rl_attempted_completion_function = (CPPFunction *)fileman_completion; } --- 225,229 ---- /* Tell the completer that we want a crack first. */ ! rl_attempted_completion_function = fileman_completion; } *************** *** 228,232 **** char ** fileman_completion (text, start, end) ! char *text; int start, end; { --- 235,239 ---- char ** fileman_completion (text, start, end) ! const char *text; int start, end; { *************** *** 239,243 **** directory. */ if (start == 0) ! matches = completion_matches (text, command_generator); return (matches); --- 246,250 ---- directory. */ if (start == 0) ! matches = rl_completion_matches (text, command_generator); return (matches); *************** *** 249,253 **** char * command_generator (text, state) ! char *text; int state; { --- 256,260 ---- char * command_generator (text, state) ! const char *text; int state; { diff -Nrc2 readline-4.1/examples/histexamp.c readline-4.2/examples/histexamp.c *** readline-4.1/examples/histexamp.c Fri Jul 29 15:44:55 1994 --- readline-4.2/examples/histexamp.c Tue Feb 6 10:35:21 2001 *************** *** 1,3 **** ! main () { char line[1024], *t; --- 1,13 ---- ! #include ! ! #ifdef READLINE_LIBRARY ! # include "history.h" ! #else ! # include ! #endif ! ! main (argc, argv) ! int argc; ! char **argv; { char line[1024], *t; diff -Nrc2 readline-4.1/examples/manexamp.c readline-4.2/examples/manexamp.c *** readline-4.1/examples/manexamp.c Tue Jul 26 12:51:42 1994 --- readline-4.2/examples/manexamp.c Fri Feb 2 12:14:15 2001 *************** *** 4,11 **** #include - /* **************************************************************** */ /* */ ! * How to Emulate gets () */ /* */ /* **************************************************************** */ --- 4,10 ---- #include /* **************************************************************** */ /* */ ! /* How to Emulate gets () */ /* */ /* **************************************************************** */ *************** *** 83,90 **** for (; start != end; start += direction) { ! if (uppercase_p (rl_line_buffer[start])) ! rl_line_buffer[start] = to_lower (rl_line_buffer[start]); ! else if (lowercase_p (rl_line_buffer[start])) ! rl_line_buffer[start] = to_upper (rl_line_buffer[start]); } --- 82,89 ---- for (; start != end; start += direction) { ! if (_rl_uppercase_p (rl_line_buffer[start])) ! rl_line_buffer[start] = _rl_to_lower (rl_line_buffer[start]); ! else if (_rl_lowercase_p (rl_line_buffer[start])) ! rl_line_buffer[start] = _rl_to_upper (rl_line_buffer[start]); } *************** *** 92,94 **** rl_point = end - direction; } - --- 91,92 ---- diff -Nrc2 readline-4.1/examples/rl.c readline-4.2/examples/rl.c *** readline-4.1/examples/rl.c Mon Nov 8 16:22:03 1999 --- readline-4.2/examples/rl.c Wed Nov 1 14:04:30 2000 *************** *** 39,43 **** rl_insert_text (deftext); deftext = (char *)NULL; ! rl_startup_hook = (Function *)NULL; } return 0; --- 39,43 ---- rl_insert_text (deftext); deftext = (char *)NULL; ! rl_startup_hook = (rl_hook_func_t *)NULL; } return 0; *************** *** 127,131 **** exit (1); ! puts (temp); exit (0); } --- 127,131 ---- exit (1); ! printf ("%s\n", temp); exit (0); } diff -Nrc2 readline-4.1/examples/rlfe.c readline-4.2/examples/rlfe.c *** readline-4.1/examples/rlfe.c Wed Sep 22 12:04:50 1999 --- readline-4.2/examples/rlfe.c Fri Nov 17 16:16:24 2000 *************** *** 65,68 **** --- 65,70 ---- #include #include + #include + #include #ifdef READLINE_LIBRARY *************** *** 82,85 **** --- 84,88 ---- #ifndef HAVE_MEMMOVE + #ifndef memmove # if __GNUC__ > 1 # define memmove(d, s, n) __builtin_memcpy(d, s, n) *************** *** 90,95 **** # define memmove(d, s, n) memcpy(d, s, n) #endif ! #define APPLICATION_NAME "Fep" static int in_from_inferior_fd; --- 93,109 ---- # define memmove(d, s, n) memcpy(d, s, n) #endif + #endif + + #define APPLICATION_NAME "Rlfe" + + #ifndef errno + extern int errno; + #endif ! extern int optind; ! extern char *optarg; ! ! static char *progname; ! static char *progversion; static int in_from_inferior_fd; *************** *** 111,121 **** int echo_suppress_limit = 0; ! #define DEBUG #ifdef DEBUG ! FILE *logfile = NULL; ! #define DPRINT0(FMT) (fprintf(logfile, FMT), fflush(logfile)) ! #define DPRINT1(FMT, V1) (fprintf(logfile, FMT, V1), fflush(logfile)) ! #define DPRINT2(FMT, V1, V2) (fprintf(logfile, FMT, V1, V2), fflush(logfile)) #else #define DPRINT0(FMT) /* Do nothing */ --- 125,137 ---- int echo_suppress_limit = 0; ! /* #define DEBUG */ ! ! static FILE *logfile = NULL; #ifdef DEBUG ! FILE *debugfile = NULL; ! #define DPRINT0(FMT) (fprintf(debugfile, FMT), fflush(debugfile)) ! #define DPRINT1(FMT, V1) (fprintf(debugfile, FMT, V1), fflush(debugfile)) ! #define DPRINT2(FMT, V1, V2) (fprintf(debugfile, FMT, V1, V2), fflush(debugfile)) #else #define DPRINT0(FMT) /* Do nothing */ *************** *** 126,129 **** --- 142,149 ---- struct termios orig_term; + static int rlfe_directory_completion_hook __P((char **)); + static int rlfe_directory_rewrite_hook __P((char **)); + static char *rlfe_filename_completion_function __P((const char *, int)); + /* Pid of child process. */ static pid_t child = -1; *************** *** 371,381 **** } int main(int argc, char** argv) { char *path; ! int i; int master; ! char *name; int in_from_tty_fd; struct sigaction act; --- 391,408 ---- } + static void + usage() + { + fprintf (stderr, "%s: usage: %s [-l filename] [-a] [-n appname] [-hv] [command [arguments...]]\n", + progname, progname); + } + int main(int argc, char** argv) { char *path; ! int i, append; int master; ! char *name, *logfname, *appname; int in_from_tty_fd; struct sigaction act; *************** *** 388,397 **** int ioctl_err = 0; #ifdef DEBUG ! logfile = fopen("LOG", "w"); #endif - rl_readline_name = APPLICATION_NAME; - if ((master = get_master_pty(&name)) < 0) { --- 415,470 ---- int ioctl_err = 0; + if ((progname = strrchr (argv[0], '/')) == 0) + progname = argv[0]; + else + progname++; + progversion = RL_LIBRARY_VERSION; + + append = 0; + appname = APPLICATION_NAME; + logfname = (char *)NULL; + + while ((i = getopt (argc, argv, "ahl:n:v")) != EOF) + { + switch (i) + { + case 'l': + logfname = optarg; + break; + case 'n': + appname = optarg; + break; + case 'a': + append = 1; + break; + case 'h': + usage (); + exit (0); + case 'v': + fprintf (stderr, "%s version %s\n", progname, progversion); + exit (0); + default: + usage (); + exit (2); + } + } + + argc -= optind; + argv += optind; + + if (logfname) + { + logfile = fopen (logfname, append ? "a" : "w"); + if (logfile == 0) + fprintf (stderr, "%s: warning: could not open log file %s: %s\n", + progname, logfname, strerror (errno)); + } + + rl_readline_name = appname; + #ifdef DEBUG ! debugfile = fopen("LOG", "w"); #endif if ((master = get_master_pty(&name)) < 0) { *************** *** 487,494 **** { static char* command_args[] = { COMMAND_ARGS, NULL }; ! if (argc <= 1) execvp(COMMAND, command_args); else ! execvp(argv[1], &argv[1]); } --- 560,567 ---- { static char* command_args[] = { COMMAND_ARGS, NULL }; ! if (argc < 1) execvp(COMMAND, command_args); else ! execvp(argv[0], &argv[0]); } *************** *** 536,539 **** --- 609,619 ---- rl_callback_handler_install (prompt, line_handler); + #if 1 + rl_directory_completion_hook = rlfe_directory_completion_hook; + rl_completion_entry_function = rlfe_filename_completion_function; + #else + rl_directory_rewrite_hook = rlfe_directory_rewrite_hook; + #endif + in_from_tty_fd = STDIN_FILENO; FD_ZERO (&in_set); *************** *** 645,648 **** --- 725,769 ---- old_count = buf_count; + /* Do some minimal carriage return translation and backspace + processing before logging the input line. */ + if (logfile) + { + #ifndef __GNUC__ + char *b; + #else + char b[count + 1]; + #endif + int i, j; + + #ifndef __GNUC__ + b = malloc (count + 1); + if (b) { + #endif + for (i = 0; i < count; i++) + b[i] = buf[buf_count + i]; + b[i] = '\0'; + for (i = j = 0; i <= count; i++) + { + if (b[i] == '\r') + { + if (b[i+1] != '\n') + b[j++] = '\n'; + } + else if (b[i] == '\b') + { + if (i) + j--; + } + else + b[j++] = b[i]; + } + fprintf (logfile, "%s", b); + + #ifndef __GNUC__ + free (b); + } + #endif + } + /* Look for any pending echo that we need to suppress. */ while (echo_suppress_start < echo_suppress_limit *************** *** 683,685 **** --- 804,1042 ---- } } + } + + /* + * + * FILENAME COMPLETION FOR RLFE + * + */ + + #ifndef PATH_MAX + # define PATH_MAX 1024 + #endif + + #define DIRSEP '/' + #define ISDIRSEP(x) ((x) == '/') + #define PATHSEP(x) (ISDIRSEP(x) || (x) == 0) + + #define DOT_OR_DOTDOT(x) \ + ((x)[0] == '.' && (PATHSEP((x)[1]) || \ + ((x)[1] == '.' && PATHSEP((x)[2])))) + + #define FREE(x) if (x) free(x) + + #define STRDUP(s, x) do { \ + s = strdup (x);\ + if (s == 0) \ + return ((char *)NULL); \ + } while (0) + + static int + get_inferior_cwd (path, psize) + char *path; + size_t psize; + { + int n; + static char procfsbuf[PATH_MAX] = { '\0' }; + + if (procfsbuf[0] == '\0') + sprintf (procfsbuf, "/proc/%d/cwd", (int)child); + n = readlink (procfsbuf, path, psize); + if (n < 0) + return n; + if (n > psize) + return -1; + path[n] = '\0'; + return n; + } + + static int + rlfe_directory_rewrite_hook (dirnamep) + char **dirnamep; + { + char *ldirname, cwd[PATH_MAX], *retdir, *ld; + int n, ldlen; + + ldirname = *dirnamep; + + if (*ldirname == '/') + return 0; + + n = get_inferior_cwd (cwd, sizeof(cwd) - 1); + if (n < 0) + return 0; + if (n == 0) /* current directory */ + { + cwd[0] = '.'; + cwd[1] = '\0'; + n = 1; + } + + /* Minimally canonicalize ldirname by removing leading `./' */ + for (ld = ldirname; *ld; ) + { + if (ISDIRSEP (ld[0])) + ld++; + else if (ld[0] == '.' && PATHSEP(ld[1])) + ld++; + else + break; + } + ldlen = (ld && *ld) ? strlen (ld) : 0; + + retdir = (char *)malloc (n + ldlen + 3); + if (retdir == 0) + return 0; + if (ldlen) + sprintf (retdir, "%s/%s", cwd, ld); + else + strcpy (retdir, cwd); + free (ldirname); + + *dirnamep = retdir; + + DPRINT1("rl_directory_rewrite_hook returns %s\n", retdir); + return 1; + } + + /* Translate *DIRNAMEP to be relative to the inferior's CWD. Leave a trailing + slash on the result. */ + static int + rlfe_directory_completion_hook (dirnamep) + char **dirnamep; + { + char *ldirname, *retdir; + int n, ldlen; + + ldirname = *dirnamep; + + if (*ldirname == '/') + return 0; + + n = rlfe_directory_rewrite_hook (dirnamep); + if (n == 0) + return 0; + + ldirname = *dirnamep; + ldlen = (ldirname && *ldirname) ? strlen (ldirname) : 0; + + if (ldlen == 0 || ldirname[ldlen - 1] != '/') + { + retdir = (char *)malloc (ldlen + 3); + if (retdir == 0) + return 0; + if (ldlen) + strcpy (retdir, ldirname); + else + retdir[ldlen++] = '.'; + retdir[ldlen] = '/'; + retdir[ldlen+1] = '\0'; + free (ldirname); + + *dirnamep = retdir; + } + + DPRINT1("rl_directory_completion_hook returns %s\n", retdir); + return 1; + } + + static char * + rlfe_filename_completion_function (text, state) + const char *text; + int state; + { + static DIR *directory; + static char *filename = (char *)NULL; + static char *dirname = (char *)NULL, *ud = (char *)NULL; + static int flen, udlen; + char *temp; + struct dirent *dentry; + + if (state == 0) + { + if (directory) + { + closedir (directory); + directory = 0; + } + FREE (dirname); + FREE (filename); + FREE (ud); + + if (text && *text) + STRDUP (filename, text); + else + { + filename = malloc(1); + if (filename == 0) + return ((char *)NULL); + filename[0] = '\0'; + } + dirname = (text && *text) ? strdup (text) : strdup ("."); + if (dirname == 0) + return ((char *)NULL); + + temp = strrchr (dirname, '/'); + if (temp) + { + strcpy (filename, ++temp); + *temp = '\0'; + } + else + { + dirname[0] = '.'; + dirname[1] = '\0'; + } + + STRDUP (ud, dirname); + udlen = strlen (ud); + + rlfe_directory_completion_hook (&dirname); + + directory = opendir (dirname); + flen = strlen (filename); + + rl_filename_completion_desired = 1; + } + + dentry = 0; + while (directory && (dentry = readdir (directory))) + { + if (flen == 0) + { + if (DOT_OR_DOTDOT(dentry->d_name) == 0) + break; + } + else + { + if ((dentry->d_name[0] == filename[0]) && + (strlen (dentry->d_name) >= flen) && + (strncmp (filename, dentry->d_name, flen) == 0)) + break; + } + } + + if (dentry == 0) + { + if (directory) + { + closedir (directory); + directory = 0; + } + FREE (dirname); + FREE (filename); + FREE (ud); + dirname = filename = ud = 0; + return ((char *)NULL); + } + + if (ud == 0 || (ud[0] == '.' && ud[1] == '\0')) + temp = strdup (dentry->d_name); + else + { + temp = malloc (1 + udlen + strlen (dentry->d_name)); + strcpy (temp, ud); + strcpy (temp + udlen, dentry->d_name); + } + return (temp); } diff -Nrc2 readline-4.1/funmap.c readline-4.2/funmap.c *** readline-4.1/funmap.c Mon Jan 24 10:58:31 2000 --- readline-4.2/funmap.c Wed Nov 8 12:38:13 2000 *************** *** 47,51 **** #endif ! extern int _rl_qsort_string_compare (); FUNMAP **funmap; --- 47,51 ---- #endif ! extern int _rl_qsort_string_compare __P((char **, char **)); FUNMAP **funmap; *************** *** 109,113 **** { "non-incremental-forward-search-history-again", rl_noninc_forward_search_again }, { "non-incremental-reverse-search-history-again", rl_noninc_reverse_search_again }, ! #ifdef __CYGWIN32__ { "paste-from-clipboard", rl_paste_from_clipboard }, #endif --- 109,113 ---- { "non-incremental-forward-search-history-again", rl_noninc_forward_search_again }, { "non-incremental-reverse-search-history-again", rl_noninc_reverse_search_again }, ! #ifdef __CYGWIN__ { "paste-from-clipboard", rl_paste_from_clipboard }, #endif *************** *** 143,147 **** { "vi-back-to-indent", rl_vi_back_to_indent }, { "vi-bWord", rl_vi_bWord }, - { "vi-bracktype", rl_vi_bracktype }, { "vi-bword", rl_vi_bword }, { "vi-change-case", rl_vi_change_case }, --- 143,146 ---- *************** *** 183,193 **** #endif /* VI_MODE */ ! {(char *)NULL, (Function *)NULL } }; int rl_add_funmap_entry (name, function) ! char *name; ! Function *function; { if (funmap_entry + 2 >= funmap_size) --- 182,192 ---- #endif /* VI_MODE */ ! {(char *)NULL, (rl_command_func_t *)NULL } }; int rl_add_funmap_entry (name, function) ! const char *name; ! rl_command_func_t *function; { if (funmap_entry + 2 >= funmap_size) *************** *** 226,233 **** is sorted. The array itself is allocated, but not the strings inside. You should free () the array when you done, but not the pointrs. */ ! char ** rl_funmap_names () { ! char **result; int result_size, result_index; --- 225,232 ---- is sorted. The array itself is allocated, but not the strings inside. You should free () the array when you done, but not the pointrs. */ ! const char ** rl_funmap_names () { ! const char **result; int result_size, result_index; *************** *** 235,244 **** rl_initialize_funmap (); ! for (result_index = result_size = 0, result = (char **)NULL; funmap[result_index]; result_index++) { if (result_index + 2 > result_size) { result_size += 20; ! result = (char **)xrealloc (result, result_size * sizeof (char *)); } --- 234,243 ---- rl_initialize_funmap (); ! for (result_index = result_size = 0, result = (const char **)NULL; funmap[result_index]; result_index++) { if (result_index + 2 > result_size) { result_size += 20; ! result = (const char **)xrealloc (result, result_size * sizeof (char *)); } *************** *** 250,260 **** return (result); } - - /* Things that mean `Control'. */ - char *possible_control_prefixes[] = { - "Control-", "C-", "CTRL-", (char *)NULL - }; - - char *possible_meta_prefixes[] = { - "Meta", "M-", (char *)NULL - }; --- 249,250 ---- diff -Nrc2 readline-4.1/histexpand.c readline-4.2/histexpand.c *** readline-4.1/histexpand.c Thu Aug 5 08:03:35 1999 --- readline-4.2/histexpand.c Tue Mar 6 14:09:25 2001 *************** *** 57,60 **** --- 57,62 ---- #define HISTORY_QUOTE_CHARACTERS "\"'`" + typedef int _hist_search_func_t __P((const char *, int)); + static char error_pointer; *************** *** 92,98 **** int history_quotes_inhibit_expansion = 0; /* If set, this points to a function that is called to verify that a particular history expansion should be performed. */ ! Function *history_inhibit_expansion_function; /* **************************************************************** */ --- 94,103 ---- int history_quotes_inhibit_expansion = 0; + /* Used to split words by history_tokenize_internal. */ + char *history_word_delimiters = HISTORY_WORD_DELIMITERS; + /* If set, this points to a function that is called to verify that a particular history expansion should be performed. */ ! rl_linebuf_func_t *history_inhibit_expansion_function; /* **************************************************************** */ *************** *** 123,127 **** char * get_history_event (string, caller_index, delimiting_quote) ! char *string; int *caller_index; int delimiting_quote; --- 128,132 ---- char * get_history_event (string, caller_index, delimiting_quote) ! const char *string; int *caller_index; int delimiting_quote; *************** *** 131,135 **** HIST_ENTRY *entry; int which, sign, local_index, substring_okay; ! Function *search_func; char *temp; --- 136,140 ---- HIST_ENTRY *entry; int which, sign, local_index, substring_okay; ! _hist_search_func_t *search_func; char *temp; *************** *** 341,345 **** int start, current, errtype; { ! char *temp, *emsg; int ll, elen; --- 346,351 ---- int start, current, errtype; { ! char *temp; ! const char *emsg; int ll, elen; *************** *** 623,627 **** case 's': { ! char *new_event, *t; int delimiter, failed, si, l_temp; --- 629,633 ---- case 's': { ! char *new_event; int delimiter, failed, si, l_temp; *************** *** 742,746 **** if (want_quotes == 'q') ! x = single_quote (temp); else if (want_quotes == 'x') x = quote_breaks (temp); --- 748,752 ---- if (want_quotes == 'q') ! x = sh_single_quote (temp); else if (want_quotes == 'x') x = quote_breaks (temp); *************** *** 817,820 **** --- 823,829 ---- char *temp; + if (output == 0) + return 0; + /* Setting the history expansion character to 0 inhibits all history expansion. */ *************** *** 866,870 **** Skip the rest of the line and break out of the loop. */ if (history_comment_char && string[i] == history_comment_char && ! (i == 0 || member (string[i - 1], HISTORY_WORD_DELIMITERS))) { while (string[i]) --- 875,879 ---- Skip the rest of the line and break out of the loop. */ if (history_comment_char && string[i] == history_comment_char && ! (i == 0 || member (string[i - 1], history_word_delimiters))) { while (string[i]) *************** *** 964,968 **** case -2: /* history_comment_char */ ! if (i == 0 || member (string[i - 1], HISTORY_WORD_DELIMITERS)) { temp = xmalloc (l - i + 1); --- 973,977 ---- case -2: /* history_comment_char */ ! if (i == 0 || member (string[i - 1], history_word_delimiters)) { temp = xmalloc (l - i + 1); *************** *** 1152,1156 **** history_arg_extract (first, last, string) int first, last; ! char *string; { register int i, len; --- 1161,1165 ---- history_arg_extract (first, last, string) int first, last; ! const char *string; { register int i, len; *************** *** 1218,1222 **** static char ** history_tokenize_internal (string, wind, indp) ! char *string; int wind, *indp; { --- 1227,1231 ---- static char ** history_tokenize_internal (string, wind, indp) ! const char *string; int wind, *indp; { *************** *** 1225,1228 **** --- 1234,1242 ---- int len, delimiter; + /* If we're searching for a string that's not part of a word (e.g., " "), + make sure we set *INDP to a reasonable value. */ + if (indp && wind != -1) + *indp = -1; + /* Get a token, and stuff it into RESULT. The tokens are split exactly where the shell would split them. */ *************** *** 1299,1303 **** } ! if (!delimiter && (member (string[i], HISTORY_WORD_DELIMITERS))) break; --- 1313,1317 ---- } ! if (!delimiter && (member (string[i], history_word_delimiters))) break; *************** *** 1329,1333 **** char ** history_tokenize (string) ! char *string; { return (history_tokenize_internal (string, -1, (int *)NULL)); --- 1343,1347 ---- char ** history_tokenize (string) ! const char *string; { return (history_tokenize_internal (string, -1, (int *)NULL)); *************** *** 1346,1350 **** words = history_tokenize_internal (line, ind, &wind); ! if (wind == -1) return ((char *)NULL); s = words[wind]; --- 1360,1364 ---- words = history_tokenize_internal (line, ind, &wind); ! if (wind == -1 || words == 0) return ((char *)NULL); s = words[wind]; diff -Nrc2 readline-4.1/histfile.c readline-4.2/histfile.c *** readline-4.1/histfile.c Thu Aug 5 08:04:04 1999 --- readline-4.2/histfile.c Tue Mar 6 13:14:27 2001 *************** *** 85,91 **** static char * history_filename (filename) ! char *filename; { ! char *return_val, *home; int home_len; --- 85,92 ---- static char * history_filename (filename) ! const char *filename; { ! char *return_val; ! const char *home; int home_len; *************** *** 95,99 **** return (return_val); ! home = get_env_value ("HOME"); if (home == 0) --- 96,100 ---- return (return_val); ! home = sh_get_env_value ("HOME"); if (home == 0) *************** *** 122,126 **** int read_history (filename) ! char *filename; { return (read_history_range (filename, 0, -1)); --- 123,127 ---- int read_history (filename) ! const char *filename; { return (read_history_range (filename, 0, -1)); *************** *** 134,138 **** int read_history_range (filename, from, to) ! char *filename; int from, to; { --- 135,139 ---- int read_history_range (filename, from, to) ! const char *filename; int from, to; { *************** *** 222,233 **** /* Truncate the history file FNAME, leaving only LINES trailing lines. ! If FNAME is NULL, then use ~/.history. */ int history_truncate_file (fname, lines) ! char *fname; int lines; { register int i; ! int file, chars_read; char *buffer, *filename; struct stat finfo; --- 223,235 ---- /* Truncate the history file FNAME, leaving only LINES trailing lines. ! If FNAME is NULL, then use ~/.history. Returns 0 on success, errno ! on failure. */ int history_truncate_file (fname, lines) ! const char *fname; int lines; { register int i; ! int file, chars_read, rv; char *buffer, *filename; struct stat finfo; *************** *** 237,247 **** filename = history_filename (fname); file = open (filename, O_RDONLY|O_BINARY, 0666); if (file == -1 || fstat (file, &finfo) == -1) ! goto truncate_exit; ! /* Don't try to truncate non-regular files. */ ! if (S_ISREG(finfo.st_mode) == 0) ! goto truncate_exit; file_size = (size_t)finfo.st_size; --- 239,263 ---- filename = history_filename (fname); file = open (filename, O_RDONLY|O_BINARY, 0666); + rv = 0; + /* Don't try to truncate non-regular files. */ if (file == -1 || fstat (file, &finfo) == -1) ! { ! rv = errno; ! if (file != -1) ! close (file); ! goto truncate_exit; ! } ! if (S_ISREG (finfo.st_mode) == 0) ! { ! close (file); ! #ifdef EFTYPE ! rv = EFTYPE; ! #else ! rv = EINVAL; ! #endif ! goto truncate_exit; ! } file_size = (size_t)finfo.st_size; *************** *** 252,256 **** close (file); #if defined (EFBIG) ! errno = EFBIG; #endif goto truncate_exit; --- 268,276 ---- close (file); #if defined (EFBIG) ! rv = errno = EFBIG; ! #elif defined (EOVERFLOW) ! rv = errno = EOVERFLOW; ! #else ! rv = errno = EINVAL; #endif goto truncate_exit; *************** *** 262,266 **** if (chars_read <= 0) ! goto truncate_exit; /* Count backwards from the end of buffer until we have passed --- 282,289 ---- if (chars_read <= 0) ! { ! rv = (chars_read < 0) ? errno : 0; ! goto truncate_exit; ! } /* Count backwards from the end of buffer until we have passed *************** *** 303,307 **** free (filename); ! return 0; } --- 326,330 ---- free (filename); ! return rv; } *************** *** 311,323 **** static int history_do_write (filename, nelements, overwrite) ! char *filename; int nelements, overwrite; { register int i; char *output; ! int file, mode; mode = overwrite ? O_WRONLY|O_CREAT|O_TRUNC|O_BINARY : O_WRONLY|O_APPEND|O_BINARY; output = history_filename (filename); if ((file = open (output, mode, 0600)) == -1) --- 334,347 ---- static int history_do_write (filename, nelements, overwrite) ! const char *filename; int nelements, overwrite; { register int i; char *output; ! int file, mode, rv; mode = overwrite ? O_WRONLY|O_CREAT|O_TRUNC|O_BINARY : O_WRONLY|O_APPEND|O_BINARY; output = history_filename (filename); + rv = 0; if ((file = open (output, mode, 0600)) == -1) *************** *** 353,357 **** } ! write (file, buffer, buffer_size); free (buffer); } --- 377,382 ---- } ! if (write (file, buffer, buffer_size) < 0) ! rv = errno; free (buffer); } *************** *** 361,365 **** FREE (output); ! return (0); } --- 386,390 ---- FREE (output); ! return (rv); } *************** *** 369,373 **** append_history (nelements, filename) int nelements; ! char *filename; { return (history_do_write (filename, nelements, HISTORY_APPEND)); --- 394,398 ---- append_history (nelements, filename) int nelements; ! const char *filename; { return (history_do_write (filename, nelements, HISTORY_APPEND)); *************** *** 379,383 **** int write_history (filename) ! char *filename; { return (history_do_write (filename, history_length, HISTORY_OVERWRITE)); --- 404,408 ---- int write_history (filename) ! const char *filename; { return (history_do_write (filename, history_length, HISTORY_OVERWRITE)); diff -Nrc2 readline-4.1/histlib.h readline-4.2/histlib.h *** readline-4.1/histlib.h Thu Aug 5 08:04:18 1999 --- readline-4.2/histlib.h Mon Oct 30 14:18:45 2000 *************** *** 23,35 **** #define _HISTLIB_H_ - /* Function pointers can be declared as (Function *)foo. */ - #if !defined (_FUNCTION_DEF) - # define _FUNCTION_DEF - typedef int Function (); - typedef void VFunction (); - typedef char *CPFunction (); - typedef char **CPPFunction (); - #endif /* _FUNCTION_DEF */ - #if !defined (STREQ) #define STREQ(a, b) (((a)[0] == (b)[0]) && (strcmp ((a), (b)) == 0)) --- 23,26 ---- diff -Nrc2 readline-4.1/history.c readline-4.2/history.c *** readline-4.1/history.c Thu Aug 5 08:04:31 1999 --- readline-4.2/history.c Tue Mar 6 13:34:44 2001 *************** *** 74,78 **** /* If HISTORY_STIFLED is non-zero, then this is the maximum number of entries to remember. */ ! int max_input_history; /* The current location of the interactive history pointer. Just makes --- 74,79 ---- /* If HISTORY_STIFLED is non-zero, then this is the maximum number of entries to remember. */ ! int history_max_entries; ! int max_input_history; /* backwards compatibility */ /* The current location of the interactive history pointer. Just makes *************** *** 135,141 **** register int i, result; ! result = 0; ! ! for (i = 0; the_history && the_history[i]; i++) result += strlen (the_history[i]->line); --- 136,140 ---- register int i, result; ! for (i = result = 0; the_history && the_history[i]; i++) result += strlen (the_history[i]->line); *************** *** 218,231 **** void add_history (string) ! char *string; { HIST_ENTRY *temp; ! if (history_stifled && (history_length == max_input_history)) { register int i; /* If the history is stifled, and history_length is zero, ! and it equals max_input_history, we don't save items. */ if (history_length == 0) return; --- 217,230 ---- void add_history (string) ! const char *string; { HIST_ENTRY *temp; ! if (history_stifled && (history_length == history_max_entries)) { register int i; /* If the history is stifled, and history_length is zero, ! and it equals history_max_entries, we don't save items. */ if (history_length == 0) return; *************** *** 278,290 **** replace_history_entry (which, line, data) int which; ! char *line; histdata_t data; { ! HIST_ENTRY *temp = (HIST_ENTRY *)xmalloc (sizeof (HIST_ENTRY)); ! HIST_ENTRY *old_value; if (which >= history_length) return ((HIST_ENTRY *)NULL); old_value = the_history[which]; --- 277,289 ---- replace_history_entry (which, line, data) int which; ! const char *line; histdata_t data; { ! HIST_ENTRY *temp, *old_value; if (which >= history_length) return ((HIST_ENTRY *)NULL); + temp = (HIST_ENTRY *)xmalloc (sizeof (HIST_ENTRY)); old_value = the_history[which]; *************** *** 304,307 **** --- 303,307 ---- { HIST_ENTRY *return_value; + register int i; if (which >= history_length || !history_length) *************** *** 309,313 **** else { - register int i; return_value = the_history[which]; --- 309,312 ---- *************** *** 326,329 **** --- 325,330 ---- int max; { + register int i, j; + if (max < 0) max = 0; *************** *** 331,336 **** if (history_length > max) { - register int i, j; - /* This loses because we cannot free the data. */ for (i = 0, j = history_length - max; i < j; i++) --- 332,335 ---- *************** *** 348,352 **** history_stifled = 1; ! max_input_history = max; } --- 347,351 ---- history_stifled = 1; ! max_input_history = history_max_entries = max; } *************** *** 360,367 **** { history_stifled = 0; ! return (-max_input_history); } ! return (max_input_history); } --- 359,366 ---- { history_stifled = 0; ! return (-history_max_entries); } ! return (history_max_entries); } diff -Nrc2 readline-4.1/history.h readline-4.2/history.h *** readline-4.1/history.h Thu Aug 5 08:04:45 1999 --- readline-4.2/history.h Tue Mar 6 13:54:26 2001 *************** *** 29,42 **** #if defined READLINE_LIBRARY # include "rlstdc.h" #else # include ! #endif ! ! #if !defined (_FUNCTION_DEF) ! # define _FUNCTION_DEF ! typedef int Function (); ! typedef void VFunction (); ! typedef char *CPFunction (); ! typedef char **CPPFunction (); #endif --- 29,36 ---- #if defined READLINE_LIBRARY # include "rlstdc.h" + # include "rltypedefs.h" #else # include ! # include #endif *************** *** 81,85 **** /* Place STRING at the end of the history list. The associated data field (if any) is set to NULL. */ ! extern void add_history __P((char *)); /* A reasonably useless function, only here for completeness. WHICH --- 75,79 ---- /* Place STRING at the end of the history list. The associated data field (if any) is set to NULL. */ ! extern void add_history __P((const char *)); /* A reasonably useless function, only here for completeness. WHICH *************** *** 91,95 **** the old entry so you can dispose of the data. In the case of an invalid WHICH, a NULL pointer is returned. */ ! extern HIST_ENTRY *replace_history_entry __P((int, char *, histdata_t)); /* Clear the history list and start over. */ --- 85,89 ---- the old entry so you can dispose of the data. In the case of an invalid WHICH, a NULL pointer is returned. */ ! extern HIST_ENTRY *replace_history_entry __P((int, const char *, histdata_t)); /* Clear the history list and start over. */ *************** *** 153,162 **** is the offset in the line of that history entry that the string was found in. Otherwise, nothing is changed, and a -1 is returned. */ ! extern int history_search __P((char *, int)); /* Search the history for STRING, starting at history_offset. The search is anchored: matching lines must begin with string. DIRECTION is as in history_search(). */ ! extern int history_search_prefix __P((char *, int)); /* Search for STRING in the history list, starting at POS, an --- 147,156 ---- is the offset in the line of that history entry that the string was found in. Otherwise, nothing is changed, and a -1 is returned. */ ! extern int history_search __P((const char *, int)); /* Search the history for STRING, starting at history_offset. The search is anchored: matching lines must begin with string. DIRECTION is as in history_search(). */ ! extern int history_search_prefix __P((const char *, int)); /* Search for STRING in the history list, starting at POS, an *************** *** 165,169 **** Returns the absolute index of the history element where STRING was found, or -1 otherwise. */ ! extern int history_search_pos __P((char *, int, int)); /* Managing the history file. */ --- 159,163 ---- Returns the absolute index of the history element where STRING was found, or -1 otherwise. */ ! extern int history_search_pos __P((const char *, int, int)); /* Managing the history file. */ *************** *** 172,176 **** If FILENAME is NULL, then read from ~/.history. Returns 0 if successful, or errno if not. */ ! extern int read_history __P((char *)); /* Read a range of lines from FILENAME, adding them to the history list. --- 166,170 ---- If FILENAME is NULL, then read from ~/.history. Returns 0 if successful, or errno if not. */ ! extern int read_history __P((const char *)); /* Read a range of lines from FILENAME, adding them to the history list. *************** *** 179,195 **** until the end of the file. If FILENAME is NULL, then read from ~/.history. Returns 0 if successful, or errno if not. */ ! extern int read_history_range __P((char *, int, int)); /* Write the current history to FILENAME. If FILENAME is NULL, then write the history list to ~/.history. Values returned are as in read_history (). */ ! extern int write_history __P((char *)); /* Append NELEMENT entries to FILENAME. The entries appended are from the end of the list minus NELEMENTs up to the end of the list. */ ! extern int append_history __P((int, char *)); /* Truncate the history file, leaving only the last NLINES lines. */ ! extern int history_truncate_file __P((char *, int)); /* History expansion. */ --- 173,189 ---- until the end of the file. If FILENAME is NULL, then read from ~/.history. Returns 0 if successful, or errno if not. */ ! extern int read_history_range __P((const char *, int, int)); /* Write the current history to FILENAME. If FILENAME is NULL, then write the history list to ~/.history. Values returned are as in read_history (). */ ! extern int write_history __P((const char *)); /* Append NELEMENT entries to FILENAME. The entries appended are from the end of the list minus NELEMENTs up to the end of the list. */ ! extern int append_history __P((int, const char *)); /* Truncate the history file, leaving only the last NLINES lines. */ ! extern int history_truncate_file __P((const char *, int)); /* History expansion. */ *************** *** 212,216 **** arguments present in STRING. Arguments are broken up as in the shell. */ ! extern char *history_arg_extract __P((int, int, char *)); /* Return the text of the history event beginning at the current --- 206,210 ---- arguments present in STRING. Arguments are broken up as in the shell. */ ! extern char *history_arg_extract __P((int, int, const char *)); /* Return the text of the history event beginning at the current *************** *** 220,235 **** specification for what to search for in addition to the normal characters `:', ` ', `\t', `\n', and sometimes `?'. */ ! extern char *get_history_event __P((char *, int *, int)); /* Return an array of tokens, much as the shell might. The tokens are parsed out of STRING. */ ! extern char **history_tokenize __P((char *)); /* Exported history variables. */ extern int history_base; extern int history_length; ! extern int max_input_history; extern char history_expansion_char; extern char history_subst_char; extern char history_comment_char; extern char *history_no_expand_chars; --- 214,230 ---- specification for what to search for in addition to the normal characters `:', ` ', `\t', `\n', and sometimes `?'. */ ! extern char *get_history_event __P((const char *, int *, int)); /* Return an array of tokens, much as the shell might. The tokens are parsed out of STRING. */ ! extern char **history_tokenize __P((const char *)); /* Exported history variables. */ extern int history_base; extern int history_length; ! extern int history_max_entries; extern char history_expansion_char; extern char history_subst_char; + extern char *history_word_delimiters; extern char history_comment_char; extern char *history_no_expand_chars; *************** *** 237,244 **** extern int history_quotes_inhibit_expansion; /* If set, this function is called to decide whether or not a particular history expansion should be treated as a special case for the calling application and not expanded. */ ! extern Function *history_inhibit_expansion_function; #ifdef __cplusplus --- 232,242 ---- extern int history_quotes_inhibit_expansion; + /* Backwards compatibility */ + extern int max_input_history; + /* If set, this function is called to decide whether or not a particular history expansion should be treated as a special case for the calling application and not expanded. */ ! extern rl_linebuf_func_t *history_inhibit_expansion_function; #ifdef __cplusplus diff -Nrc2 readline-4.1/histsearch.c readline-4.2/histsearch.c *** readline-4.1/histsearch.c Thu Aug 5 08:05:01 1999 --- readline-4.2/histsearch.c Thu Sep 28 14:15:52 2000 *************** *** 64,68 **** static int history_search_internal (string, direction, anchored) ! char *string; int direction, anchored; { --- 64,68 ---- static int history_search_internal (string, direction, anchored) ! const char *string; int direction, anchored; { *************** *** 160,164 **** int history_search (string, direction) ! char *string; int direction; { --- 160,164 ---- int history_search (string, direction) ! const char *string; int direction; { *************** *** 169,173 **** int history_search_prefix (string, direction) ! char *string; int direction; { --- 169,173 ---- int history_search_prefix (string, direction) ! const char *string; int direction; { *************** *** 180,184 **** int history_search_pos (string, dir, pos) ! char *string; int dir, pos; { --- 180,184 ---- int history_search_pos (string, dir, pos) ! const char *string; int dir, pos; { diff -Nrc2 readline-4.1/input.c readline-4.2/input.c *** readline-4.1/input.c Thu Aug 5 08:05:12 1999 --- readline-4.2/input.c Tue Mar 27 10:15:04 2001 *************** *** 79,85 **** /* Non-null means it is a pointer to a function to run while waiting for character input. */ ! Function *rl_event_hook = (Function *)NULL; ! Function *rl_getc_function = rl_getc; /* **************************************************************** */ --- 79,87 ---- /* Non-null means it is a pointer to a function to run while waiting for character input. */ ! rl_hook_func_t *rl_event_hook = (rl_hook_func_t *)NULL; ! rl_getc_func_t *rl_getc_function = rl_getc; ! ! static int _keyboard_input_timeout = 100000; /* 0.1 seconds; it's in usec */ /* **************************************************************** */ *************** *** 170,174 **** FD_SET (tty, &exceptfds); timeout.tv_sec = 0; ! timeout.tv_usec = 100000; /* 0.1 seconds */ if (select (tty + 1, &readfds, (fd_set *)NULL, &exceptfds, &timeout) <= 0) return; /* Nothing to read. */ --- 172,176 ---- FD_SET (tty, &exceptfds); timeout.tv_sec = 0; ! timeout.tv_usec = _keyboard_input_timeout; if (select (tty + 1, &readfds, (fd_set *)NULL, &exceptfds, &timeout) <= 0) return; /* Nothing to read. */ *************** *** 223,226 **** --- 225,240 ---- } + int + rl_set_keyboard_input_timeout (u) + int u; + { + int o; + + o = _keyboard_input_timeout; + if (u > 0) + _keyboard_input_timeout = u; + return (o); + } + /* Is there input available to be read on the readline input file descriptor? Only works if the system has select(2) or FIONREAD. */ *************** *** 245,249 **** FD_SET (tty, &exceptfds); timeout.tv_sec = 0; ! timeout.tv_usec = 100000; /* 0.1 seconds */ return (select (tty + 1, &readfds, (fd_set *)NULL, &exceptfds, &timeout) > 0); #endif --- 259,263 ---- FD_SET (tty, &exceptfds); timeout.tv_sec = 0; ! timeout.tv_usec = _keyboard_input_timeout; return (select (tty + 1, &readfds, (fd_set *)NULL, &exceptfds, &timeout) > 0); #endif *************** *** 294,297 **** --- 308,312 ---- key = NEWLINE; rl_pending_input = EOF; + RL_SETSTATE (RL_STATE_INPUTPENDING); } ibuffer[push_index++] = key; *************** *** 308,311 **** --- 323,336 ---- { rl_pending_input = c; + RL_SETSTATE (RL_STATE_INPUTPENDING); + return 0; + } + + /* Clear any pending input pushed with rl_execute_next() */ + int + rl_clear_pending_input () + { + rl_pending_input = 0; + RL_UNSETSTATE (RL_STATE_INPUTPENDING); return 0; } *************** *** 328,332 **** { c = rl_pending_input; ! rl_pending_input = 0; } else --- 353,357 ---- { c = rl_pending_input; ! rl_clear_pending_input (); } else *************** *** 342,345 **** --- 367,372 ---- { (*rl_event_hook) (); + if (rl_done) /* XXX - experimental */ + return ('\n'); rl_gather_tyi (); } *************** *** 393,397 **** if (errno == X_EWOULDBLOCK || errno == X_EAGAIN) { ! if (unset_nodelay_mode (fileno (stream)) < 0) return (EOF); continue; --- 420,424 ---- if (errno == X_EWOULDBLOCK || errno == X_EAGAIN) { ! if (sh_unset_nodelay_mode (fileno (stream)) < 0) return (EOF); continue; diff -Nrc2 readline-4.1/isearch.c readline-4.2/isearch.c *** readline-4.1/isearch.c Thu Aug 5 08:05:29 1999 --- readline-4.2/isearch.c Wed Feb 14 07:37:01 2001 *************** *** 56,60 **** /* Variables imported from other files in the readline library. */ ! extern HIST_ENTRY *saved_line_for_history; /* Forward declarations */ --- 56,60 ---- /* Variables imported from other files in the readline library. */ ! extern HIST_ENTRY *_rl_saved_line_for_history; /* Forward declarations */ *************** *** 65,68 **** --- 65,70 ---- static char *prev_line_found; + static unsigned char *default_isearch_terminators = "\033\012"; + /* Search backwards through the history looking for a string which is typed interactively. Start with the current line. */ *************** *** 177,180 **** --- 179,183 ---- unsigned char *isearch_terminators; + RL_SETSTATE(RL_STATE_ISEARCH); orig_point = rl_point; last_found_line = orig_line = where_history (); *************** *** 184,191 **** isearch_terminators = _rl_isearch_terminators ? _rl_isearch_terminators ! : (unsigned char *)"\033\012"; /* Create an arrary of pointers to the lines that we want to search. */ ! maybe_replace_line (); i = 0; if (hlist) --- 187,194 ---- isearch_terminators = _rl_isearch_terminators ? _rl_isearch_terminators ! : default_isearch_terminators; /* Create an arrary of pointers to the lines that we want to search. */ ! rl_maybe_replace_line (); i = 0; if (hlist) *************** *** 198,203 **** lines[i] = hlist[i]->line; ! if (saved_line_for_history) ! lines[i] = saved_line_for_history->line; else { --- 201,206 ---- lines[i] = hlist[i]->line; ! if (_rl_saved_line_for_history) ! lines[i] = _rl_saved_line_for_history->line; else { *************** *** 233,240 **** for (;;) { ! Function *f = (Function *)NULL; /* Read a key and decide how to proceed. */ c = rl_read_key (); if (_rl_keymap[c].type == ISFUNC) --- 236,245 ---- for (;;) { ! rl_command_func_t *f = (rl_command_func_t *)NULL; /* Read a key and decide how to proceed. */ + RL_SETSTATE(RL_STATE_MOREINPUT); c = rl_read_key (); + RL_UNSETSTATE(RL_STATE_MOREINPUT); if (_rl_keymap[c].type == ISFUNC) *************** *** 274,277 **** --- 279,284 ---- if (c >= 0 && (CTRL_CHAR (c) || META_CHAR (c) || c == RUBOUT) && c != CTRL ('G')) { + /* This sets rl_pending_input to c; it will be picked up the next + time rl_read_key is called. */ rl_execute_next (c); break; *************** *** 288,292 **** ++line_index; else ! ding (); break; --- 295,299 ---- ++line_index; else ! rl_ding (); break; *************** *** 306,309 **** --- 313,317 ---- free (allocated_line); free (lines); + RL_UNSETSTATE(RL_STATE_ISEARCH); return 0; *************** *** 312,316 **** case -3: if (search_string_index == 0) ! ding (); else { --- 320,324 ---- case -3: if (search_string_index == 0) ! rl_ding (); else { *************** *** 385,389 **** { /* We cannot find the search string. Ding the bell. */ ! ding (); i = last_found_line; continue; /* XXX - was break */ --- 393,397 ---- { /* We cannot find the search string. Ding the bell. */ ! rl_ding (); i = last_found_line; continue; /* XXX - was break */ *************** *** 438,441 **** --- 446,451 ---- free (allocated_line); free (lines); + + RL_UNSETSTATE(RL_STATE_ISEARCH); return 0; diff -Nrc2 readline-4.1/keymaps.c readline-4.2/keymaps.c *** readline-4.1/keymaps.c Thu Aug 5 08:05:44 1999 --- readline-4.2/keymaps.c Mon Oct 30 12:05:43 2000 *************** *** 62,66 **** { keymap[i].type = ISFUNC; ! keymap[i].function = (Function *)NULL; } --- 62,66 ---- { keymap[i].type = ISFUNC; ! keymap[i].function = (rl_command_func_t *)NULL; } diff -Nrc2 readline-4.1/keymaps.h readline-4.2/keymaps.h *** readline-4.1/keymaps.h Thu Dec 2 15:44:46 1999 --- readline-4.2/keymaps.h Mon Oct 30 13:23:23 2000 *************** *** 31,45 **** # include "rlstdc.h" # include "chardefs.h" #else # include # include ! #endif ! ! #if !defined (_FUNCTION_DEF) ! # define _FUNCTION_DEF ! typedef int Function (); ! typedef void VFunction (); ! typedef char *CPFunction (); ! typedef char **CPPFunction (); #endif --- 31,39 ---- # include "rlstdc.h" # include "chardefs.h" + # include "rltypedefs.h" #else # include # include ! # include #endif *************** *** 51,55 **** typedef struct _keymap_entry { char type; ! Function *function; } KEYMAP_ENTRY; --- 45,49 ---- typedef struct _keymap_entry { char type; ! rl_command_func_t *function; } KEYMAP_ENTRY; *************** *** 60,64 **** /* I wanted to make the above structure contain a union of: ! union { Function *function; struct _keymap_entry *keymap; } value; but this made it impossible for me to create a static array. Maybe I need C lessons. */ --- 54,58 ---- /* I wanted to make the above structure contain a union of: ! union { rl_command_func_t *function; struct _keymap_entry *keymap; } value; but this made it impossible for me to create a static array. Maybe I need C lessons. */ *************** *** 94,98 **** /* Return the keymap corresponding to a given name. Names look like `emacs' or `emacs-meta' or `vi-insert'. */ ! extern Keymap rl_get_keymap_by_name __P((char *)); /* Return the current keymap. */ --- 88,92 ---- /* Return the keymap corresponding to a given name. Names look like `emacs' or `emacs-meta' or `vi-insert'. */ ! extern Keymap rl_get_keymap_by_name __P((const char *)); /* Return the current keymap. */ diff -Nrc2 readline-4.1/kill.c readline-4.2/kill.c *** readline-4.1/kill.c Thu Aug 5 08:06:11 1999 --- readline-4.2/kill.c Thu Nov 2 12:36:25 2000 *************** *** 265,269 **** { if (!rl_point) ! ding (); else { --- 265,269 ---- { if (!rl_point) ! rl_ding (); else { *************** *** 300,304 **** if (rl_point == 0) ! ding (); else { --- 300,304 ---- if (rl_point == 0) ! rl_ding (); else { *************** *** 332,336 **** { if (rl_point == 0) ! ding (); else { --- 332,336 ---- { if (rl_point == 0) ! rl_ding (); else { *************** *** 513,517 **** if (entry == 0) { ! ding (); return -1; } --- 513,517 ---- if (entry == 0) { ! rl_ding (); return -1; } *************** *** 520,524 **** if (!arg || !*arg) { ! ding (); return -1; } --- 520,524 ---- if (!arg || !*arg) { ! rl_ding (); return -1; } *************** *** 593,597 **** /* A special paste command for users of Cygnus's cygwin32. */ ! #if defined (__CYGWIN32__) #include --- 593,597 ---- /* A special paste command for users of Cygnus's cygwin32. */ ! #if defined (__CYGWIN__) #include *************** *** 626,628 **** return (0); } ! #endif /* __CYGWIN32__ */ --- 626,628 ---- return (0); } ! #endif /* __CYGWIN__ */ diff -Nrc2 readline-4.1/macro.c readline-4.2/macro.c *** readline-4.1/macro.c Thu Aug 5 08:06:25 1999 --- readline-4.2/macro.c Thu Nov 2 12:36:37 2000 *************** *** 58,67 **** /* **************************************************************** */ - /* Non-zero means to save keys that we dispatch on in a kbd macro. */ - int _rl_defining_kbd_macro = 0; - /* The currently executing macro string. If this is non-zero, then it is a malloc ()'ed string where input is coming from. */ ! char *_rl_executing_macro = (char *)NULL; /* The offset in the above string to the next character to be read. */ --- 58,67 ---- /* **************************************************************** */ /* The currently executing macro string. If this is non-zero, then it is a malloc ()'ed string where input is coming from. */ ! char *rl_executing_macro = (char *)NULL; ! ! /* Non-zero means to save keys that we dispatch on in a kbd macro. */ ! int _rl_defining_kbd_macro = 0; /* The offset in the above string to the next character to be read. */ *************** *** 96,101 **** { _rl_push_executing_macro (); ! _rl_executing_macro = string; executing_macro_index = 0; } --- 96,102 ---- { _rl_push_executing_macro (); ! rl_executing_macro = string; executing_macro_index = 0; + RL_SETSTATE(RL_STATE_MACROINPUT); } *************** *** 105,112 **** _rl_next_macro_key () { ! if (_rl_executing_macro == 0) return (0); ! if (_rl_executing_macro[executing_macro_index] == 0) { _rl_pop_executing_macro (); --- 106,113 ---- _rl_next_macro_key () { ! if (rl_executing_macro == 0) return (0); ! if (rl_executing_macro[executing_macro_index] == 0) { _rl_pop_executing_macro (); *************** *** 114,118 **** } ! return (_rl_executing_macro[executing_macro_index++]); } --- 115,119 ---- } ! return (rl_executing_macro[executing_macro_index++]); } *************** *** 126,130 **** saver->next = macro_list; saver->sindex = executing_macro_index; ! saver->string = _rl_executing_macro; macro_list = saver; --- 127,131 ---- saver->next = macro_list; saver->sindex = executing_macro_index; ! saver->string = rl_executing_macro; macro_list = saver; *************** *** 138,145 **** struct saved_macro *macro; ! if (_rl_executing_macro) ! free (_rl_executing_macro); ! ! _rl_executing_macro = (char *)NULL; executing_macro_index = 0; --- 139,144 ---- struct saved_macro *macro; ! FREE (rl_executing_macro); ! rl_executing_macro = (char *)NULL; executing_macro_index = 0; *************** *** 147,155 **** { macro = macro_list; ! _rl_executing_macro = macro_list->string; executing_macro_index = macro_list->sindex; macro_list = macro_list->next; free (macro); } } --- 146,157 ---- { macro = macro_list; ! rl_executing_macro = macro_list->string; executing_macro_index = macro_list->sindex; macro_list = macro_list->next; free (macro); } + + if (rl_executing_macro == 0) + RL_UNSETSTATE(RL_STATE_MACROINPUT); } *************** *** 181,192 **** current_macro_size = current_macro_index = 0; ! if (_rl_executing_macro) ! { ! free (_rl_executing_macro); ! _rl_executing_macro = (char *) NULL; ! } executing_macro_index = 0; _rl_defining_kbd_macro = 0; } --- 183,192 ---- current_macro_size = current_macro_index = 0; ! FREE (rl_executing_macro); ! rl_executing_macro = (char *) NULL; executing_macro_index = 0; _rl_defining_kbd_macro = 0; + RL_UNSETSTATE(RL_STATE_MACRODEF); } *************** *** 216,219 **** --- 216,220 ---- _rl_defining_kbd_macro = 1; + RL_SETSTATE(RL_STATE_MACRODEF); return 0; } *************** *** 236,239 **** --- 237,241 ---- _rl_defining_kbd_macro = 0; + RL_UNSETSTATE(RL_STATE_MACRODEF); return (rl_call_last_kbd_macro (--count, 0)); *************** *** 251,255 **** if (_rl_defining_kbd_macro) { ! ding (); /* no recursive macros */ current_macro[--current_macro_index] = '\0'; /* erase this char */ return 0; --- 253,257 ---- if (_rl_defining_kbd_macro) { ! rl_ding (); /* no recursive macros */ current_macro[--current_macro_index] = '\0'; /* erase this char */ return 0; diff -Nrc2 readline-4.1/nls.c readline-4.2/nls.c *** readline-4.1/nls.c Thu Aug 5 08:09:55 1999 --- readline-4.2/nls.c Fri Nov 3 11:44:27 2000 *************** *** 106,112 **** appropriate variables and set eight-bit mode if they have the right values. */ ! lspec = get_env_value ("LC_ALL"); ! if (lspec == 0) lspec = get_env_value ("LC_CTYPE"); ! if (lspec == 0) lspec = get_env_value ("LANG"); if (lspec == 0 || (t = normalize_codeset (lspec)) == 0) return (0); --- 106,112 ---- appropriate variables and set eight-bit mode if they have the right values. */ ! lspec = sh_get_env_value ("LC_ALL"); ! if (lspec == 0) lspec = sh_get_env_value ("LC_CTYPE"); ! if (lspec == 0) lspec = sh_get_env_value ("LANG"); if (lspec == 0 || (t = normalize_codeset (lspec)) == 0) return (0); diff -Nrc2 readline-4.1/parens.c readline-4.2/parens.c *** readline-4.1/parens.c Thu Aug 5 08:10:08 1999 --- readline-4.2/parens.c Wed Aug 30 15:10:45 2000 *************** *** 65,68 **** --- 65,70 ---- #endif /* !HAVE_SELECT */ + static int _paren_blink_usec = 500000; + /* Change emacs_standard_keymap to have bindings for paren matching when ON_OR_OFF is 1, change them back to self_insert when ON_OR_OFF == 0. */ *************** *** 86,89 **** --- 88,103 ---- int + rl_set_paren_blink_timeout (u) + int u; + { + int o; + + o = _paren_blink_usec; + if (u > 0) + _paren_blink_usec = u; + return (o); + } + + int rl_insert_close (count, invoking_key) int count, invoking_key; *************** *** 110,114 **** FD_SET (fileno (rl_instream), &readfds); timer.tv_sec = 0; ! timer.tv_usec = 500000; orig_point = rl_point; --- 124,128 ---- FD_SET (fileno (rl_instream), &readfds); timer.tv_sec = 0; ! timer.tv_usec = _paren_blink_usec; orig_point = rl_point; diff -Nrc2 readline-4.1/readline.c readline-4.2/readline.c *** readline-4.1/readline.c Thu Aug 5 08:10:46 1999 --- readline-4.2/readline.c Mon Apr 2 15:56:20 2001 *************** *** 68,72 **** #ifndef RL_LIBRARY_VERSION ! # define RL_LIBRARY_VERSION "4.1" #endif --- 68,72 ---- #ifndef RL_LIBRARY_VERSION ! # define RL_LIBRARY_VERSION "4.2" #endif *************** *** 91,96 **** /* **************************************************************** */ ! char *rl_library_version = RL_LIBRARY_VERSION; int rl_gnu_readline_p = 1; --- 91,97 ---- /* **************************************************************** */ ! const char *rl_library_version = RL_LIBRARY_VERSION; + /* True if this is `real' readline as opposed to some stub substitute. */ int rl_gnu_readline_p = 1; *************** *** 122,127 **** --- 123,133 ---- static int rl_initialized; + #if 0 /* If non-zero, this program is running in an EMACS buffer. */ static int running_in_emacs; + #endif + + /* Flags word encapsulating the current readline state. */ + int rl_readline_state = RL_STATE_NONE; /* The current offset in the current input line. */ *************** *** 138,142 **** /* The last function executed by readline. */ ! Function *rl_last_func = (Function *)NULL; /* Top level environment for readline_internal (). */ --- 144,148 ---- /* The last function executed by readline. */ ! rl_command_func_t *rl_last_func = (rl_command_func_t *)NULL; /* Top level environment for readline_internal (). */ *************** *** 154,158 **** /* Current prompt. */ ! char *rl_prompt; int rl_visible_prompt_length = 0; --- 160,164 ---- /* Current prompt. */ ! char *rl_prompt = (char *)NULL; int rl_visible_prompt_length = 0; *************** *** 166,175 **** /* If non-zero, then this is the address of a function to call just before readline_internal_setup () prints the first prompt. */ ! Function *rl_startup_hook = (Function *)NULL; /* If non-zero, this is the address of a function to call just before readline_internal_setup () returns and readline_internal starts reading input characters. */ ! Function *rl_pre_input_hook = (Function *)NULL; /* What we use internally. You should always refer to RL_LINE_BUFFER. */ --- 172,181 ---- /* If non-zero, then this is the address of a function to call just before readline_internal_setup () prints the first prompt. */ ! rl_hook_func_t *rl_startup_hook = (rl_hook_func_t *)NULL; /* If non-zero, this is the address of a function to call just before readline_internal_setup () returns and readline_internal starts reading input characters. */ ! rl_hook_func_t *rl_pre_input_hook = (rl_hook_func_t *)NULL; /* What we use internally. You should always refer to RL_LINE_BUFFER. */ *************** *** 184,188 **** /* Pointer to a useful terminal name. */ ! char *rl_terminal_name = (char *)NULL; /* Non-zero means to always use horizontal scrolling in line display. */ --- 190,194 ---- /* Pointer to a useful terminal name. */ ! const char *rl_terminal_name = (const char *)NULL; /* Non-zero means to always use horizontal scrolling in line display. */ *************** *** 244,265 **** int _rl_meta_flag = 0; /* Forward declaration */ /* Read a line of input. Prompt with PROMPT. An empty PROMPT means none. A return value of NULL means that EOF was encountered. */ char * readline (prompt) ! char *prompt; { char *value; - rl_prompt = prompt; - /* If we are at EOF return a NULL string. */ if (rl_pending_input == EOF) { ! rl_pending_input = 0; return ((char *)NULL); } ! rl_visible_prompt_length = rl_expand_prompt (rl_prompt); rl_initialize (); --- 250,284 ---- int _rl_meta_flag = 0; /* Forward declaration */ + /* Set up the prompt and expand it. Called from readline() and + rl_callback_handler_install (). */ + int + rl_set_prompt (prompt) + const char *prompt; + { + FREE (rl_prompt); + rl_prompt = prompt ? savestring (prompt) : (char *)NULL; + + rl_visible_prompt_length = (rl_prompt && *rl_prompt) + ? rl_expand_prompt (rl_prompt) + : 0; + return 0; + } + /* Read a line of input. Prompt with PROMPT. An empty PROMPT means none. A return value of NULL means that EOF was encountered. */ char * readline (prompt) ! const char *prompt; { char *value; /* If we are at EOF return a NULL string. */ if (rl_pending_input == EOF) { ! rl_clear_pending_input (); return ((char *)NULL); } ! rl_set_prompt (prompt); rl_initialize (); *************** *** 349,353 **** rid of it now. */ if (rl_undo_list) ! free_undo_list (); return (eof ? (char *)NULL : savestring (the_line)); --- 368,372 ---- rid of it now. */ if (rl_undo_list) ! rl_free_undo_list (); return (eof ? (char *)NULL : savestring (the_line)); *************** *** 385,389 **** --- 404,410 ---- } + RL_SETSTATE(RL_STATE_READCMD); c = rl_read_key (); + RL_UNSETSTATE(RL_STATE_READCMD); /* EOF typed to a non-blank line is a . */ *************** *** 396,399 **** --- 417,421 ---- { #if defined (READLINE_CALLBACKS) + RL_SETSTATE(RL_STATE_DONE); return (rl_done = 1); #else *************** *** 492,496 **** int r, newkey; char *macro; ! Function *func; if (META_CHAR (key) && _rl_convert_meta_chars_to_ascii) --- 514,518 ---- int r, newkey; char *macro; ! rl_command_func_t *func; if (META_CHAR (key) && _rl_convert_meta_chars_to_ascii) *************** *** 506,510 **** } else ! ding (); return 0; } --- 528,532 ---- } else ! rl_ding (); return 0; } *************** *** 518,522 **** case ISFUNC: func = map[key].function; ! if (func != (Function *)NULL) { /* Special case rl_do_lowercase_version (). */ --- 540,544 ---- case ISFUNC: func = map[key].function; ! if (func) { /* Special case rl_do_lowercase_version (). */ *************** *** 531,535 **** --- 553,559 ---- rl_dispatching = 1; + RL_SETSTATE(RL_STATE_DISPATCHING); r = (*map[key].function)(rl_numeric_arg * rl_arg_sign, key); + RL_UNSETSTATE(RL_STATE_DISPATCHING); rl_dispatching = 0; *************** *** 537,541 **** command. Don't change the state of rl_last_func. Otherwise, remember the last command executed in this variable. */ ! if (!rl_pending_input && map[key].function != rl_digit_argument) rl_last_func = map[key].function; } --- 561,565 ---- command. Don't change the state of rl_last_func. Otherwise, remember the last command executed in this variable. */ ! if (rl_pending_input == 0 && map[key].function != rl_digit_argument) rl_last_func = map[key].function; } *************** *** 548,555 **** case ISKMAP: ! if (map[key].function != (Function *)NULL) { rl_key_sequence_length++; newkey = rl_read_key (); r = _rl_dispatch (newkey, FUNCTION_TO_KEYMAP (map, key)); } --- 572,587 ---- case ISKMAP: ! if (map[key].function != 0) { rl_key_sequence_length++; + + if (key == ESC) + RL_SETSTATE(RL_STATE_METANEXT); + RL_SETSTATE(RL_STATE_MOREINPUT); newkey = rl_read_key (); + RL_UNSETSTATE(RL_STATE_MOREINPUT); + if (key == ESC) + RL_UNSETSTATE(RL_STATE_METANEXT); + r = _rl_dispatch (newkey, FUNCTION_TO_KEYMAP (map, key)); } *************** *** 562,566 **** case ISMACR: ! if (map[key].function != (Function *)NULL) { macro = savestring ((char *)map[key].function); --- 594,598 ---- case ISMACR: ! if (map[key].function != 0) { macro = savestring ((char *)map[key].function); *************** *** 592,597 **** --- 624,632 ---- if (!rl_initialized) { + RL_SETSTATE(RL_STATE_INITIALIZING); readline_initialize_everything (); + RL_UNSETSTATE(RL_STATE_INITIALIZING); rl_initialized++; + RL_SETSTATE(RL_STATE_INITIALIZED); } *************** *** 601,604 **** --- 636,640 ---- /* We aren't done yet. We haven't even gotten started yet! */ rl_done = 0; + RL_UNSETSTATE(RL_STATE_DONE); /* Tell the history routines what is going on. */ *************** *** 609,613 **** /* No such function typed yet. */ ! rl_last_func = (Function *)NULL; /* Parsing of key-bindings begins in an enabled state. */ --- 645,649 ---- /* No such function typed yet. */ ! rl_last_func = (rl_command_func_t *)NULL; /* Parsing of key-bindings begins in an enabled state. */ *************** *** 659,664 **** #endif ! /* Find out if we are running in Emacs. */ ! running_in_emacs = get_env_value ("EMACS") != (char *)0; /* Set up input and output if they are not already set up. */ --- 695,702 ---- #endif ! #if 0 ! /* Find out if we are running in Emacs -- UNUSED. */ ! running_in_emacs = sh_get_env_value ("EMACS") != (char *)0; ! #endif /* Set up input and output if they are not already set up. */ *************** *** 680,684 **** /* Initialize the terminal interface. */ ! _rl_init_terminal_io ((char *)NULL); /* Bind tty characters to readline functions. */ --- 718,724 ---- /* Initialize the terminal interface. */ ! if (rl_terminal_name == 0) ! rl_terminal_name = sh_get_env_value ("TERM"); ! _rl_init_terminal_io (rl_terminal_name); /* Bind tty characters to readline functions. */ *************** *** 697,702 **** if (_rl_horizontal_scroll_mode && _rl_term_autowrap) { ! screenwidth--; ! screenchars -= screenheight; } --- 737,742 ---- if (_rl_horizontal_scroll_mode && _rl_term_autowrap) { ! _rl_screenwidth--; ! _rl_screenchars -= _rl_screenheight; } *************** *** 724,728 **** readline_default_bindings () { ! rltty_set_default_bindings (_rl_keymap); } --- 764,768 ---- readline_default_bindings () { ! rl_tty_set_default_bindings (_rl_keymap); } *************** *** 730,734 **** bind_arrow_keys_internal () { ! Function *f; #if defined (__MSDOS__) --- 770,774 ---- bind_arrow_keys_internal () { ! rl_command_func_t *f; #if defined (__MSDOS__) *************** *** 798,801 **** --- 838,842 ---- rl_save_prompt (); + RL_SETSTATE(RL_STATE_NUMERICARG); sawminus = sawdigits = 0; while (1) *************** *** 804,814 **** { sawdigits = rl_explicit_arg = rl_numeric_arg = 0; ! ding (); rl_restore_prompt (); rl_clear_message (); return 1; } rl_message ("(arg: %d) ", rl_arg_sign * rl_numeric_arg); key = c = rl_read_key (); /* If we see a key bound to `universal-argument' after seeing digits, --- 845,858 ---- { sawdigits = rl_explicit_arg = rl_numeric_arg = 0; ! rl_ding (); rl_restore_prompt (); rl_clear_message (); + RL_UNSETSTATE(RL_STATE_NUMERICARG); return 1; } rl_message ("(arg: %d) ", rl_arg_sign * rl_numeric_arg); + RL_SETSTATE(RL_STATE_MOREINPUT); key = c = rl_read_key (); + RL_UNSETSTATE(RL_STATE_MOREINPUT); /* If we see a key bound to `universal-argument' after seeing digits, *************** *** 824,830 **** --- 868,877 ---- else { + RL_SETSTATE(RL_STATE_MOREINPUT); key = rl_read_key (); + RL_UNSETSTATE(RL_STATE_MOREINPUT); rl_restore_prompt (); rl_clear_message (); + RL_UNSETSTATE(RL_STATE_NUMERICARG); return (_rl_dispatch (key, _rl_keymap)); } *************** *** 850,857 **** --- 897,906 ---- rl_restore_prompt (); rl_clear_message (); + RL_UNSETSTATE(RL_STATE_NUMERICARG); return (_rl_dispatch (key, _rl_keymap)); } } + RL_UNSETSTATE(RL_STATE_NUMERICARG); return 0; } *************** *** 862,866 **** int ignore, key; { ! rl_pending_input = key; return (rl_digit_loop ()); } --- 911,915 ---- int ignore, key; { ! rl_execute_next (key); return (rl_digit_loop ()); } *************** *** 870,874 **** rl_discard_argument () { ! ding (); rl_clear_message (); _rl_init_argument (); --- 919,923 ---- rl_discard_argument () { ! rl_ding (); rl_clear_message (); _rl_init_argument (); *************** *** 907,911 **** int rl_insert_text (string) ! char *string; { register int i, l = strlen (string); --- 956,960 ---- int rl_insert_text (string) ! const char *string; { register int i, l = strlen (string); *************** *** 1000,1004 **** void _rl_replace_text (text, start, end) ! char *text; int start, end; { --- 1049,1053 ---- void _rl_replace_text (text, start, end) ! const char *text; int start, end; { *************** *** 1054,1058 **** int end = rl_point + count; #if defined (VI_MODE) ! int lend = rl_end - (rl_editing_mode == vi_mode); #else int lend = rl_end; --- 1103,1107 ---- int end = rl_point + count; #if defined (VI_MODE) ! int lend = rl_end > 0 ? rl_end - (rl_editing_mode == vi_mode) : rl_end; #else int lend = rl_end; *************** *** 1062,1066 **** { rl_point = lend; ! ding (); } else --- 1111,1115 ---- { rl_point = lend; ! rl_ding (); } else *************** *** 1086,1090 **** { rl_point = 0; ! ding (); } else --- 1135,1139 ---- { rl_point = 0; ! rl_ding (); } else *************** *** 1133,1142 **** Then, move forward until we hit a non-alphabetic character. */ c = the_line[rl_point]; ! if (alphabetic (c) == 0) { while (++rl_point < rl_end) { c = the_line[rl_point]; ! if (alphabetic (c)) break; } --- 1182,1191 ---- Then, move forward until we hit a non-alphabetic character. */ c = the_line[rl_point]; ! if (rl_alphabetic (c) == 0) { while (++rl_point < rl_end) { c = the_line[rl_point]; ! if (rl_alphabetic (c)) break; } *************** *** 1147,1151 **** { c = the_line[rl_point]; ! if (alphabetic (c) == 0) break; } --- 1196,1200 ---- { c = the_line[rl_point]; ! if (rl_alphabetic (c) == 0) break; } *************** *** 1177,1186 **** c = the_line[rl_point - 1]; ! if (alphabetic (c) == 0) { while (--rl_point) { c = the_line[rl_point - 1]; ! if (alphabetic (c)) break; } --- 1226,1235 ---- c = the_line[rl_point - 1]; ! if (rl_alphabetic (c) == 0) { while (--rl_point) { c = the_line[rl_point - 1]; ! if (rl_alphabetic (c)) break; } *************** *** 1190,1194 **** { c = the_line[rl_point - 1]; ! if (alphabetic (c) == 0) break; else --- 1239,1243 ---- { c = the_line[rl_point - 1]; ! if (rl_alphabetic (c) == 0) break; else *************** *** 1246,1250 **** --- 1295,1301 ---- int ch; + RL_SETSTATE(RL_STATE_MOREINPUT); ch = rl_read_key (); + RL_UNSETSTATE(RL_STATE_MOREINPUT); switch (_rl_to_upper (ch)) *************** *** 1267,1271 **** default: ! ding (); } return 0; --- 1318,1322 ---- default: ! rl_ding (); } return 0; *************** *** 1353,1357 **** --- 1404,1412 ---- _rl_disable_tty_signals (); #endif + + RL_SETSTATE(RL_STATE_MOREINPUT); c = rl_read_key (); + RL_UNSETSTATE(RL_STATE_MOREINPUT); + #if defined (HANDLE_SIGNALS) _rl_restore_tty_signals (); *************** *** 1377,1380 **** --- 1432,1436 ---- { rl_done = 1; + RL_SETSTATE(RL_STATE_DONE); #if defined (VI_MODE) *************** *** 1387,1391 **** /* If we've been asked to erase empty lines, suppress the final update, ! since _rl_update_final calls crlf(). */ if (rl_erase_empty_line && rl_point == 0 && rl_end == 0) return 0; --- 1443,1447 ---- /* If we've been asked to erase empty lines, suppress the final update, ! since _rl_update_final calls rl_crlf(). */ if (rl_erase_empty_line && rl_point == 0 && rl_end == 0) return 0; *************** *** 1420,1424 **** if (!rl_point) { ! ding (); return -1; } --- 1476,1480 ---- if (!rl_point) { ! rl_ding (); return -1; } *************** *** 1456,1460 **** if (rl_point == rl_end) { ! ding (); return -1; } --- 1512,1516 ---- if (rl_point == rl_end) { ! rl_ding (); return -1; } *************** *** 1612,1620 **** case CapCase: the_line[start] = (inword == 0) ? _rl_to_upper (c) : _rl_to_lower (c); ! inword = alphabetic (the_line[start]); break; default: ! ding (); return -1; } --- 1668,1676 ---- case CapCase: the_line[start] = (inword == 0) ? _rl_to_upper (c) : _rl_to_lower (c); ! inword = rl_alphabetic (the_line[start]); break; default: ! rl_ding (); return -1; } *************** *** 1655,1659 **** if ((w1_beg == w2_beg) || (w2_beg < w1_end)) { ! ding (); rl_point = orig_point; return -1; --- 1711,1715 ---- if ((w1_beg == w2_beg) || (w2_beg < w1_end)) { ! rl_ding (); rl_point = orig_point; return -1; *************** *** 1703,1707 **** if (!rl_point || rl_end < 2) { ! ding (); return -1; } --- 1759,1763 ---- if (!rl_point || rl_end < 2) { ! rl_ding (); return -1; } *************** *** 1747,1751 **** if ((dir < 0 && pos <= 0) || (dir > 0 && pos >= rl_end)) { ! ding (); return -1; } --- 1803,1807 ---- if ((dir < 0 && pos <= 0) || (dir > 0 && pos >= rl_end)) { ! rl_ding (); return -1; } *************** *** 1778,1782 **** --- 1834,1841 ---- int c; + RL_SETSTATE(RL_STATE_MOREINPUT); c = rl_read_key (); + RL_UNSETSTATE(RL_STATE_MOREINPUT); + if (count < 0) return (_rl_char_search_internal (-count, bdir, c)); *************** *** 1811,1815 **** /* While we are editing the history, this is the saved version of the original line. */ ! HIST_ENTRY *saved_line_for_history = (HIST_ENTRY *)NULL; /* Set the history pointer back to the last entry in the history. */ --- 1870,1874 ---- /* While we are editing the history, this is the saved version of the original line. */ ! HIST_ENTRY *_rl_saved_line_for_history = (HIST_ENTRY *)NULL; /* Set the history pointer back to the last entry in the history. */ *************** *** 1818,1825 **** { using_history (); ! if (saved_line_for_history) ! _rl_free_history_entry (saved_line_for_history); ! saved_line_for_history = (HIST_ENTRY *)NULL; } --- 1877,1884 ---- { using_history (); ! if (_rl_saved_line_for_history) ! _rl_free_history_entry (_rl_saved_line_for_history); ! _rl_saved_line_for_history = (HIST_ENTRY *)NULL; } *************** *** 1838,1842 **** /* Perhaps put back the current line if it has changed. */ int ! maybe_replace_line () { HIST_ENTRY *temp; --- 1897,1901 ---- /* Perhaps put back the current line if it has changed. */ int ! rl_maybe_replace_line () { HIST_ENTRY *temp; *************** *** 1853,1893 **** } ! /* Put back the saved_line_for_history if there is one. */ int ! maybe_unsave_line () { int line_len; ! if (saved_line_for_history) { ! line_len = strlen (saved_line_for_history->line); if (line_len >= rl_line_buffer_len) rl_extend_line_buffer (line_len); ! strcpy (the_line, saved_line_for_history->line); ! rl_undo_list = (UNDO_LIST *)saved_line_for_history->data; ! _rl_free_history_entry (saved_line_for_history); ! saved_line_for_history = (HIST_ENTRY *)NULL; rl_end = rl_point = strlen (the_line); } else ! ding (); return 0; } ! /* Save the current line in saved_line_for_history. */ int ! maybe_save_line () { ! if (saved_line_for_history == 0) { ! saved_line_for_history = (HIST_ENTRY *)xmalloc (sizeof (HIST_ENTRY)); ! saved_line_for_history->line = savestring (the_line); ! saved_line_for_history->data = (char *)rl_undo_list; } return 0; } /* **************************************************************** */ /* */ --- 1912,1963 ---- } ! /* Restore the _rl_saved_line_for_history if there is one. */ int ! rl_maybe_unsave_line () { int line_len; ! if (_rl_saved_line_for_history) { ! line_len = strlen (_rl_saved_line_for_history->line); if (line_len >= rl_line_buffer_len) rl_extend_line_buffer (line_len); ! strcpy (the_line, _rl_saved_line_for_history->line); ! rl_undo_list = (UNDO_LIST *)_rl_saved_line_for_history->data; ! _rl_free_history_entry (_rl_saved_line_for_history); ! _rl_saved_line_for_history = (HIST_ENTRY *)NULL; rl_end = rl_point = strlen (the_line); } else ! rl_ding (); return 0; } ! /* Save the current line in _rl_saved_line_for_history. */ int ! rl_maybe_save_line () { ! if (_rl_saved_line_for_history == 0) { ! _rl_saved_line_for_history = (HIST_ENTRY *)xmalloc (sizeof (HIST_ENTRY)); ! _rl_saved_line_for_history->line = savestring (the_line); ! _rl_saved_line_for_history->data = (char *)rl_undo_list; } return 0; } + int + _rl_free_saved_history_line () + { + if (_rl_saved_line_for_history) + { + _rl_free_history_entry (_rl_saved_line_for_history); + _rl_saved_line_for_history = (HIST_ENTRY *)NULL; + } + return 0; + } + /* **************************************************************** */ /* */ *************** *** 1909,1915 **** int count, key; { ! maybe_replace_line (); using_history (); ! maybe_unsave_line (); return 0; } --- 1979,1985 ---- int count, key; { ! rl_maybe_replace_line (); using_history (); ! rl_maybe_unsave_line (); return 0; } *************** *** 1929,1933 **** return 0; ! maybe_replace_line (); temp = (HIST_ENTRY *)NULL; --- 1999,2003 ---- return 0; ! rl_maybe_replace_line (); temp = (HIST_ENTRY *)NULL; *************** *** 1941,1945 **** if (temp == 0) ! maybe_unsave_line (); else { --- 2011,2015 ---- if (temp == 0) ! rl_maybe_unsave_line (); else { *************** *** 1976,1983 **** /* If we don't have a line saved, then save this one. */ ! maybe_save_line (); /* If the current line has changed, save the changes. */ ! maybe_replace_line (); temp = old_temp = (HIST_ENTRY *)NULL; --- 2046,2053 ---- /* If we don't have a line saved, then save this one. */ ! rl_maybe_save_line (); /* If the current line has changed, save the changes. */ ! rl_maybe_replace_line (); temp = old_temp = (HIST_ENTRY *)NULL; *************** *** 1998,2002 **** if (temp == 0) ! ding (); else { --- 2068,2072 ---- if (temp == 0) ! rl_ding (); else { *************** *** 2054,2058 **** if (rl_mark == -1) { ! ding (); return -1; } --- 2124,2128 ---- if (rl_mark == -1) { ! rl_ding (); return -1; } diff -Nrc2 readline-4.1/readline.h readline-4.2/readline.h *** readline-4.1/readline.h Thu Aug 5 08:10:59 1999 --- readline-4.2/readline.h Wed Feb 14 16:27:54 2001 *************** *** 61,66 **** /* The data structure for mapping textual names to code addresses. */ typedef struct _funmap { ! char *name; ! Function *function; } FUNMAP; --- 61,66 ---- /* The data structure for mapping textual names to code addresses. */ typedef struct _funmap { ! const char *name; ! rl_command_func_t *function; } FUNMAP; *************** *** 156,161 **** extern int rl_yank_nth_arg __P((int, int)); extern int rl_yank_last_arg __P((int, int)); ! /* Not available unless __CYGWIN32__ is defined. */ ! #ifdef __CYGWIN32__ extern int rl_paste_from_clipboard __P((int, int)); #endif --- 156,161 ---- extern int rl_yank_nth_arg __P((int, int)); extern int rl_yank_last_arg __P((int, int)); ! /* Not available unless __CYGWIN__ is defined. */ ! #ifdef __CYGWIN__ extern int rl_paste_from_clipboard __P((int, int)); #endif *************** *** 197,201 **** /* Not available unless READLINE_CALLBACKS is defined. */ ! extern void rl_callback_handler_install __P((char *, VFunction *)); extern void rl_callback_read_char __P((void)); extern void rl_callback_handler_remove __P((void)); --- 197,201 ---- /* Not available unless READLINE_CALLBACKS is defined. */ ! extern void rl_callback_handler_install __P((const char *, rl_vcpfunc_t *)); extern void rl_callback_read_char __P((void)); extern void rl_callback_handler_remove __P((void)); *************** *** 261,295 **** /* Readline functions. */ /* Read a line of input. Prompt with PROMPT. A NULL PROMPT means none. */ ! extern char *readline __P((char *)); extern int rl_initialize __P((void)); extern int rl_discard_argument __P((void)); /* Utility functions to bind keys to readline commands. */ ! extern int rl_add_defun __P((char *, Function *, int)); ! extern int rl_bind_key __P((int, Function *)); ! extern int rl_bind_key_in_map __P((int, Function *, Keymap)); extern int rl_unbind_key __P((int)); extern int rl_unbind_key_in_map __P((int, Keymap)); ! extern int rl_unbind_function_in_map __P((Function *, Keymap)); ! extern int rl_unbind_command_in_map __P((char *, Keymap)); ! extern int rl_set_key __P((char *, Function *, Keymap)); ! extern int rl_generic_bind __P((int, char *, char *, Keymap)); ! extern int rl_variable_bind __P((char *, char *)); /* Backwards compatibility, use rl_generic_bind instead. */ ! extern int rl_macro_bind __P((char *, char *, Keymap)); /* Undocumented in the texinfo manual; not really useful to programs. */ ! extern int rl_translate_keyseq __P((char *, char *, int *)); extern char *rl_untranslate_keyseq __P((int)); ! extern Function *rl_named_function __P((char *)); ! extern Function *rl_function_of_keyseq __P((char *, Keymap, int *)); extern void rl_list_funmap_names __P((void)); ! extern char **rl_invoking_keyseqs_in_map __P((Function *, Keymap)); ! extern char **rl_invoking_keyseqs __P((Function *)); extern void rl_function_dumper __P((int)); --- 261,299 ---- /* Readline functions. */ /* Read a line of input. Prompt with PROMPT. A NULL PROMPT means none. */ ! extern char *readline __P((const char *)); ! ! extern int rl_set_prompt __P((const char *)); ! extern int rl_expand_prompt __P((char *)); extern int rl_initialize __P((void)); + /* Undocumented; unused by readline */ extern int rl_discard_argument __P((void)); /* Utility functions to bind keys to readline commands. */ ! extern int rl_add_defun __P((const char *, rl_command_func_t *, int)); ! extern int rl_bind_key __P((int, rl_command_func_t *)); ! extern int rl_bind_key_in_map __P((int, rl_command_func_t *, Keymap)); extern int rl_unbind_key __P((int)); extern int rl_unbind_key_in_map __P((int, Keymap)); ! extern int rl_unbind_function_in_map __P((rl_command_func_t *, Keymap)); ! extern int rl_unbind_command_in_map __P((const char *, Keymap)); ! extern int rl_set_key __P((const char *, rl_command_func_t *, Keymap)); ! extern int rl_generic_bind __P((int, const char *, char *, Keymap)); ! extern int rl_variable_bind __P((const char *, const char *)); /* Backwards compatibility, use rl_generic_bind instead. */ ! extern int rl_macro_bind __P((const char *, const char *, Keymap)); /* Undocumented in the texinfo manual; not really useful to programs. */ ! extern int rl_translate_keyseq __P((const char *, char *, int *)); extern char *rl_untranslate_keyseq __P((int)); ! extern rl_command_func_t *rl_named_function __P((const char *)); ! extern rl_command_func_t *rl_function_of_keyseq __P((const char *, Keymap, int *)); extern void rl_list_funmap_names __P((void)); ! extern char **rl_invoking_keyseqs_in_map __P((rl_command_func_t *, Keymap)); ! extern char **rl_invoking_keyseqs __P((rl_command_func_t *)); extern void rl_function_dumper __P((int)); *************** *** 297,301 **** extern void rl_variable_dumper __P((int)); ! extern int rl_read_init_file __P((char *)); extern int rl_parse_and_bind __P((char *)); --- 301,305 ---- extern void rl_variable_dumper __P((int)); ! extern int rl_read_init_file __P((const char *)); extern int rl_parse_and_bind __P((char *)); *************** *** 306,320 **** extern void rl_discard_keymap __P((Keymap)); ! extern Keymap rl_get_keymap_by_name __P((char *)); extern char *rl_get_keymap_name __P((Keymap)); extern void rl_set_keymap __P((Keymap)); extern Keymap rl_get_keymap __P((void)); extern void rl_set_keymap_from_edit_mode __P((void)); extern char *rl_get_keymap_name_from_edit_mode __P((void)); /* Functions for manipulating the funmap, which maps command names to functions. */ ! extern int rl_add_funmap_entry __P((char *, Function *)); extern void rl_initialize_funmap __P((void)); - extern char **rl_funmap_names __P((void)); /* Utility functions for managing keyboard macros. */ --- 310,327 ---- extern void rl_discard_keymap __P((Keymap)); ! extern Keymap rl_get_keymap_by_name __P((const char *)); extern char *rl_get_keymap_name __P((Keymap)); extern void rl_set_keymap __P((Keymap)); extern Keymap rl_get_keymap __P((void)); + /* Undocumented; used internally only. */ extern void rl_set_keymap_from_edit_mode __P((void)); extern char *rl_get_keymap_name_from_edit_mode __P((void)); /* Functions for manipulating the funmap, which maps command names to functions. */ ! extern int rl_add_funmap_entry __P((const char *, rl_command_func_t *)); ! extern const char **rl_funmap_names __P((void)); ! /* Undocumented, only used internally -- there is only one funmap, and this ! function may be called only once. */ extern void rl_initialize_funmap __P((void)); /* Utility functions for managing keyboard macros. */ *************** *** 323,327 **** /* Functions for undoing, from undo.c */ extern void rl_add_undo __P((enum undo_code, int, int, char *)); ! extern void free_undo_list __P((void)); extern int rl_do_undo __P((void)); extern int rl_begin_undo_group __P((void)); --- 330,334 ---- /* Functions for undoing, from undo.c */ extern void rl_add_undo __P((enum undo_code, int, int, char *)); ! extern void rl_free_undo_list __P((void)); extern int rl_do_undo __P((void)); extern int rl_begin_undo_group __P((void)); *************** *** 336,339 **** --- 343,347 ---- extern int rl_clear_message __P((void)); extern int rl_reset_line_state __P((void)); + extern int rl_crlf __P((void)); #if (defined (__STDC__) || defined (__cplusplus)) && defined (USE_VARARGS) && defined (PREFER_STDARG) *************** *** 343,350 **** #endif - /* Undocumented in texinfo manual. */ extern int rl_show_char __P((int)); extern int rl_character_len __P((int, int)); - extern int crlf __P((void)); /* Save and restore internal prompt redisplay information. */ --- 351,358 ---- #endif extern int rl_show_char __P((int)); + + /* Undocumented in texinfo manual. */ extern int rl_character_len __P((int, int)); /* Save and restore internal prompt redisplay information. */ *************** *** 353,357 **** /* Modifying text. */ ! extern int rl_insert_text __P((char *)); extern int rl_delete_text __P((int, int)); extern int rl_kill_text __P((int, int)); --- 361,365 ---- /* Modifying text. */ ! extern int rl_insert_text __P((const char *)); extern int rl_delete_text __P((int, int)); extern int rl_kill_text __P((int, int)); *************** *** 361,378 **** extern void rl_prep_terminal __P((int)); extern void rl_deprep_terminal __P((void)); ! extern void rltty_set_default_bindings __P((Keymap)); ! extern int rl_reset_terminal __P((char *)); extern void rl_resize_terminal __P((void)); ! ! /* `Public' utility functions . */ ! extern void rl_extend_line_buffer __P((int)); ! extern int ding __P((void)); /* Functions for character input. */ extern int rl_stuff_char __P((int)); extern int rl_execute_next __P((int)); extern int rl_read_key __P((void)); extern int rl_getc __P((FILE *)); /* Readline signal handling, from signals.c */ --- 369,391 ---- extern void rl_prep_terminal __P((int)); extern void rl_deprep_terminal __P((void)); ! extern void rl_tty_set_default_bindings __P((Keymap)); ! extern int rl_reset_terminal __P((const char *)); extern void rl_resize_terminal __P((void)); ! extern void rl_set_screen_size __P((int, int)); ! extern void rl_get_screen_size __P((int *, int *)); /* Functions for character input. */ extern int rl_stuff_char __P((int)); extern int rl_execute_next __P((int)); + extern int rl_clear_pending_input __P((void)); extern int rl_read_key __P((void)); extern int rl_getc __P((FILE *)); + extern int rl_set_keyboard_input_timeout __P((int)); + + /* `Public' utility functions . */ + extern void rl_extend_line_buffer __P((int)); + extern int rl_ding __P((void)); + extern int rl_alphabetic __P((int)); /* Readline signal handling, from signals.c */ *************** *** 384,392 **** /* Undocumented. */ ! extern int rl_expand_prompt __P((char *)); ! extern int maybe_save_line __P((void)); ! extern int maybe_unsave_line __P((void)); ! extern int maybe_replace_line __P((void)); /* Completion functions. */ --- 397,406 ---- /* Undocumented. */ ! extern int rl_set_paren_blink_timeout __P((int)); ! /* Undocumented. */ ! extern int rl_maybe_save_line __P((void)); ! extern int rl_maybe_unsave_line __P((void)); ! extern int rl_maybe_replace_line __P((void)); /* Completion functions. */ *************** *** 394,400 **** extern void rl_display_match_list __P((char **, int, int)); ! extern char **completion_matches __P((char *, CPFunction *)); ! extern char *username_completion_function __P((char *, int)); ! extern char *filename_completion_function __P((char *, int)); /* **************************************************************** */ --- 408,430 ---- extern void rl_display_match_list __P((char **, int, int)); ! extern char **rl_completion_matches __P((const char *, rl_compentry_func_t *)); ! extern char *rl_username_completion_function __P((const char *, int)); ! extern char *rl_filename_completion_function __P((const char *, int)); ! ! #if 0 ! /* Backwards compatibility (compat.c). These will go away sometime. */ ! extern void free_undo_list __P((void)); ! extern int maybe_save_line __P((void)); ! extern int maybe_unsave_line __P((void)); ! extern int maybe_replace_line __P((void)); ! ! extern int ding __P((void)); ! extern int alphabetic __P((int)); ! extern int crlf __P((void)); ! ! extern char **completion_matches __P((char *, rl_compentry_func_t *)); ! extern char *username_completion_function __P((const char *, int)); ! extern char *filename_completion_function __P((const char *, int)); ! #endif /* **************************************************************** */ *************** *** 405,416 **** /* The version of this incarnation of the readline library. */ ! extern char *rl_library_version; /* True if this is real GNU readline. */ extern int rl_gnu_readline_p; /* The name of the calling program. You should initialize this to whatever was in argv[0]. It is used when parsing conditionals. */ ! extern char *rl_readline_name; /* The prompt readline uses. This is set from the argument to --- 435,453 ---- /* The version of this incarnation of the readline library. */ ! extern const char *rl_library_version; /* True if this is real GNU readline. */ extern int rl_gnu_readline_p; + /* Flags word encapsulating the current readline state. */ + extern int rl_readline_state; + + /* Says which editing mode readline is currently using. 1 means emacs mode; + 0 means vi mode. */ + extern int rl_editing_mode; + /* The name of the calling program. You should initialize this to whatever was in argv[0]. It is used when parsing conditionals. */ ! extern const char *rl_readline_name; /* The prompt readline uses. This is set from the argument to *************** *** 422,426 **** /* The location of point, and end. */ ! extern int rl_point, rl_end; /* The mark, or saved cursor position. */ --- 459,464 ---- /* The location of point, and end. */ ! extern int rl_point; ! extern int rl_end; /* The mark, or saved cursor position. */ *************** *** 439,465 **** extern int rl_dispatching; /* The name of the terminal to use. */ ! extern char *rl_terminal_name; /* The input and output streams. */ ! extern FILE *rl_instream, *rl_outstream; /* If non-zero, then this is the address of a function to call just before readline_internal () prints the first prompt. */ ! extern Function *rl_startup_hook; /* If non-zero, this is the address of a function to call just before readline_internal_setup () returns and readline_internal starts reading input characters. */ ! extern Function *rl_pre_input_hook; /* The address of a function to call periodically while Readline is awaiting character input, or NULL, for no event handling. */ ! extern Function *rl_event_hook; ! extern Function *rl_getc_function; ! extern VFunction *rl_redisplay_function; ! extern VFunction *rl_prep_term_function; ! extern VFunction *rl_deprep_term_function; /* Dispatch variables. */ --- 477,518 ---- extern int rl_dispatching; + /* Non-zero if the user typed a numeric argument before executing the + current function. */ + extern int rl_explicit_arg; + + /* The current value of the numeric argument specified by the user. */ + extern int rl_numeric_arg; + + /* The address of the last command function Readline executed. */ + extern rl_command_func_t *rl_last_func; + /* The name of the terminal to use. */ ! extern const char *rl_terminal_name; /* The input and output streams. */ ! extern FILE *rl_instream; ! extern FILE *rl_outstream; /* If non-zero, then this is the address of a function to call just before readline_internal () prints the first prompt. */ ! extern rl_hook_func_t *rl_startup_hook; /* If non-zero, this is the address of a function to call just before readline_internal_setup () returns and readline_internal starts reading input characters. */ ! extern rl_hook_func_t *rl_pre_input_hook; /* The address of a function to call periodically while Readline is awaiting character input, or NULL, for no event handling. */ ! extern rl_hook_func_t *rl_event_hook; ! ! /* The address of the function to call to fetch a character from the current ! Readline input stream */ ! extern rl_getc_func_t *rl_getc_function; ! extern rl_voidfunc_t *rl_redisplay_function; ! ! extern rl_vintfunc_t *rl_prep_term_function; ! extern rl_voidfunc_t *rl_deprep_term_function; /* Dispatch variables. */ *************** *** 482,485 **** --- 535,541 ---- extern int rl_num_chars_to_read; + /* The text of a currently-executing keyboard macro. */ + extern char *rl_executing_macro; + /* Variables to control readline signal handling. */ /* If non-zero, readline will install its own signal handlers for *************** *** 498,502 **** NULL means to use filename_entry_function (), the default filename completer. */ ! extern Function *rl_completion_entry_function; /* If rl_ignore_some_completions_function is non-NULL it is the address --- 554,558 ---- NULL means to use filename_entry_function (), the default filename completer. */ ! extern rl_compentry_func_t *rl_completion_entry_function; /* If rl_ignore_some_completions_function is non-NULL it is the address *************** *** 506,510 **** of (char *). If your function removes any of the elements, they must be free()'ed. */ ! extern Function *rl_ignore_some_completions_function; /* Pointer to alternative function to create matches. --- 562,566 ---- of (char *). If your function removes any of the elements, they must be free()'ed. */ ! extern rl_compignore_func_t *rl_ignore_some_completions_function; /* Pointer to alternative function to create matches. *************** *** 515,529 **** rl_completion_entry_function to try to match, otherwise use the array of strings returned. */ ! extern CPPFunction *rl_attempted_completion_function; /* The basic list of characters that signal a break between words for the completer routine. The initial contents of this variable is what breaks words in the shell, i.e. "n\"\\'`@$>". */ ! extern char *rl_basic_word_break_characters; /* The list of characters that signal a break between words for rl_complete_internal. The default list is the contents of rl_basic_word_break_characters. */ ! extern char *rl_completer_word_break_characters; /* List of characters which can be used to quote a substring of the line. --- 571,585 ---- rl_completion_entry_function to try to match, otherwise use the array of strings returned. */ ! extern rl_completion_func_t *rl_attempted_completion_function; /* The basic list of characters that signal a break between words for the completer routine. The initial contents of this variable is what breaks words in the shell, i.e. "n\"\\'`@$>". */ ! extern const char *rl_basic_word_break_characters; /* The list of characters that signal a break between words for rl_complete_internal. The default list is the contents of rl_basic_word_break_characters. */ ! extern const char *rl_completer_word_break_characters; /* List of characters which can be used to quote a substring of the line. *************** *** 531,551 **** rl_completer_word_break_characters are treated as any other character, unless they also appear within this list. */ ! extern char *rl_completer_quote_characters; /* List of quote characters which cause a word break. */ ! extern char *rl_basic_quote_characters; /* List of characters that need to be quoted in filenames by the completer. */ ! extern char *rl_filename_quote_characters; /* List of characters that are word break characters, but should be left in TEXT when it is passed to the completion function. The shell uses this to help determine what kind of completing to do. */ ! extern char *rl_special_prefixes; /* If non-zero, then this is the address of a function to call when completing on a directory name. The function is called with ! the address of a string (the current directory name) as an arg. */ ! extern Function *rl_directory_completion_hook; /* Backwards compatibility with previous versions of readline. */ --- 587,618 ---- rl_completer_word_break_characters are treated as any other character, unless they also appear within this list. */ ! extern const char *rl_completer_quote_characters; /* List of quote characters which cause a word break. */ ! extern const char *rl_basic_quote_characters; /* List of characters that need to be quoted in filenames by the completer. */ ! extern const char *rl_filename_quote_characters; /* List of characters that are word break characters, but should be left in TEXT when it is passed to the completion function. The shell uses this to help determine what kind of completing to do. */ ! extern const char *rl_special_prefixes; /* If non-zero, then this is the address of a function to call when completing on a directory name. The function is called with ! the address of a string (the current directory name) as an arg. It ! changes what is displayed when the possible completions are printed ! or inserted. */ ! extern rl_icppfunc_t *rl_directory_completion_hook; ! ! /* If non-zero, this is the address of a function to call when completing ! a directory name. This function takes the address of the directory name ! to be modified as an argument. Unlike rl_directory_completion_hook, it ! only modifies the directory name used in opendir(2), not what is displayed ! when the possible completions are printed or inserted. It is called ! before rl_directory_completion_hook. I'm not happy with how this works ! yet, so it's undocumented. */ ! extern rl_icppfunc_t *rl_directory_rewrite_hook; /* Backwards compatibility with previous versions of readline. */ *************** *** 559,563 **** number of strings in that array, and MAX_LENGTH is the length of the longest string in that array. */ ! extern VFunction *rl_completion_display_matches_hook; /* Non-zero means that the results of the matches are to be treated --- 626,630 ---- number of strings in that array, and MAX_LENGTH is the length of the longest string in that array. */ ! extern rl_compdisp_func_t *rl_completion_display_matches_hook; /* Non-zero means that the results of the matches are to be treated *************** *** 577,591 **** and a pointer to the quoting character to be used, which the function can reset if desired. */ ! extern CPFunction *rl_filename_quoting_function; /* Function to call to remove quoting characters from a filename. Called before completion is attempted, so the embedded quotes do not interfere with matching names in the file system. */ ! extern CPFunction *rl_filename_dequoting_function; /* Function to call to decide whether or not a word break character is quoted. If a character is quoted, it does not break words for the completer. */ ! extern Function *rl_char_is_quoted_p; /* Non-zero means to suppress normal filename completion after the --- 644,658 ---- and a pointer to the quoting character to be used, which the function can reset if desired. */ ! extern rl_quote_func_t *rl_filename_quoting_function; /* Function to call to remove quoting characters from a filename. Called before completion is attempted, so the embedded quotes do not interfere with matching names in the file system. */ ! extern rl_dequote_func_t *rl_filename_dequoting_function; /* Function to call to decide whether or not a word break character is quoted. If a character is quoted, it does not break words for the completer. */ ! extern rl_linebuf_func_t *rl_char_is_quoted_p; /* Non-zero means to suppress normal filename completion after the *************** *** 624,630 **** #define MULT_MATCH 2 ! #if !defined (savestring) ! extern char *savestring __P((char *)); /* XXX backwards compatibility */ ! #endif #ifdef __cplusplus --- 691,721 ---- #define MULT_MATCH 2 ! /* Possible state values for rl_readline_state */ ! #define RL_STATE_NONE 0x00000 /* no state; before first call */ ! ! #define RL_STATE_INITIALIZING 0x00001 /* initializing */ ! #define RL_STATE_INITIALIZED 0x00002 /* initialization done */ ! #define RL_STATE_TERMPREPPED 0x00004 /* terminal is prepped */ ! #define RL_STATE_READCMD 0x00008 /* reading a command key */ ! #define RL_STATE_METANEXT 0x00010 /* reading input after ESC */ ! #define RL_STATE_DISPATCHING 0x00020 /* dispatching to a command */ ! #define RL_STATE_MOREINPUT 0x00040 /* reading more input in a command function */ ! #define RL_STATE_ISEARCH 0x00080 /* doing incremental search */ ! #define RL_STATE_NSEARCH 0x00100 /* doing non-inc search */ ! #define RL_STATE_SEARCH 0x00200 /* doing a history search */ ! #define RL_STATE_NUMERICARG 0x00400 /* reading numeric argument */ ! #define RL_STATE_MACROINPUT 0x00800 /* getting input from a macro */ ! #define RL_STATE_MACRODEF 0x01000 /* defining keyboard macro */ ! #define RL_STATE_OVERWRITE 0x02000 /* overwrite mode */ ! #define RL_STATE_COMPLETING 0x04000 /* doing completion */ ! #define RL_STATE_SIGHANDLER 0x08000 /* in readline sighandler */ ! #define RL_STATE_UNDOING 0x10000 /* doing an undo */ ! #define RL_STATE_INPUTPENDING 0x20000 /* rl_execute_next called */ ! ! #define RL_STATE_DONE 0x80000 /* done; accepted line */ ! ! #define RL_SETSTATE(x) (rl_readline_state |= (x)) ! #define RL_UNSETSTATE(x) (rl_readline_state &= ~(x)) ! #define RL_ISSTATE(x) (rl_readline_state & (x)) #ifdef __cplusplus diff -Nrc2 readline-4.1/rldefs.h readline-4.2/rldefs.h *** readline-4.1/rldefs.h Thu Aug 5 08:11:28 1999 --- readline-4.2/rldefs.h Wed Nov 8 10:50:32 2000 *************** *** 31,34 **** --- 31,36 ---- #endif + #include "rlstdc.h" + #if defined (_POSIX_VERSION) && !defined (TERMIOS_MISSING) # define TERMIOS_TTY_DRIVER *************** *** 72,76 **** #define _rl_strnicmp strncasecmp #else ! extern int _rl_stricmp (), _rl_strnicmp (); #endif --- 74,79 ---- #define _rl_strnicmp strncasecmp #else ! extern int _rl_stricmp __P((char *, char *); ! extern int _rl_strnicmp __P((char *, char *)); #endif *************** *** 88,99 **** #if defined (CRAY) # define FUNCTION_TO_KEYMAP(map, key) (Keymap)((int)map[key].function) ! # define KEYMAP_TO_FUNCTION(data) (Function *)((int)(data)) #else # define FUNCTION_TO_KEYMAP(map, key) (Keymap)(map[key].function) ! # define KEYMAP_TO_FUNCTION(data) (Function *)(data) #endif #ifndef savestring ! extern char *xmalloc (); #define savestring(x) strcpy (xmalloc (1 + strlen (x)), (x)) #endif --- 91,102 ---- #if defined (CRAY) # define FUNCTION_TO_KEYMAP(map, key) (Keymap)((int)map[key].function) ! # define KEYMAP_TO_FUNCTION(data) (rl_command_func_t *)((int)(data)) #else # define FUNCTION_TO_KEYMAP(map, key) (Keymap)(map[key].function) ! # define KEYMAP_TO_FUNCTION(data) (rl_command_func_t *)(data) #endif #ifndef savestring ! extern char *xmalloc __P((int)); #define savestring(x) strcpy (xmalloc (1 + strlen (x)), (x)) #endif diff -Nrc2 readline-4.1/rlprivate.h readline-4.2/rlprivate.h *** readline-4.1/rlprivate.h Mon Jan 24 10:40:34 2000 --- readline-4.2/rlprivate.h Wed Feb 14 07:43:14 2001 *************** *** 36,40 **** /* terminal.c */ ! extern char *rl_get_termcap __P((char *)); /************************************************************************* --- 36,40 ---- /* terminal.c */ ! extern char *rl_get_termcap __P((const char *)); /************************************************************************* *************** *** 52,61 **** /* readline.c */ extern int rl_line_buffer_len; - extern int rl_numeric_arg; extern int rl_arg_sign; - extern int rl_explicit_arg; - extern int rl_editing_mode; extern int rl_visible_prompt_length; - extern Function *rl_last_func; extern int readline_echoing_p; extern int rl_key_sequence_length; --- 52,57 ---- *************** *** 92,96 **** /* util.c */ ! extern char *_rl_savestring __P((char *)); /************************************************************************* --- 88,92 ---- /* util.c */ ! extern char *_rl_savestring __P((const char *)); /************************************************************************* *************** *** 119,127 **** /* bind.c */ ! extern void _rl_bind_if_unbound __P((char *, Function *)); /* display.c */ extern char *_rl_strip_prompt __P((char *)); ! extern void _rl_move_cursor_relative __P((int, char *)); extern void _rl_move_vert __P((int)); extern void _rl_save_prompt __P((void)); --- 115,123 ---- /* bind.c */ ! extern void _rl_bind_if_unbound __P((const char *, rl_command_func_t *)); /* display.c */ extern char *_rl_strip_prompt __P((char *)); ! extern void _rl_move_cursor_relative __P((int, const char *)); extern void _rl_move_vert __P((int)); extern void _rl_save_prompt __P((void)); *************** *** 135,139 **** extern void _rl_clean_up_for_exit __P((void)); extern void _rl_erase_entire_line __P((void)); ! extern int _rl_currentb_display_line __P((void)); /* input.c */ --- 131,135 ---- extern void _rl_clean_up_for_exit __P((void)); extern void _rl_erase_entire_line __P((void)); ! extern int _rl_current_display_line __P((void)); /* input.c */ *************** *** 162,168 **** extern int _rl_init_argument __P((void)); extern void _rl_fix_point __P((int)); ! extern void _rl_replace_text __P((char *, int, int)); extern int _rl_char_search_internal __P((int, int, int)); extern int _rl_set_mark_at_pos __P((int)); /* rltty.c */ --- 158,165 ---- extern int _rl_init_argument __P((void)); extern void _rl_fix_point __P((int)); ! extern void _rl_replace_text __P((const char *, int, int)); extern int _rl_char_search_internal __P((int, int, int)); extern int _rl_set_mark_at_pos __P((int)); + extern int _rl_free_saved_history_line __P((void)); /* rltty.c */ *************** *** 172,176 **** /* terminal.c */ extern void _rl_get_screen_size __P((int, int)); ! extern int _rl_init_terminal_io __P((char *)); #ifdef _MINIX extern void _rl_output_character_function __P((int)); --- 169,173 ---- /* terminal.c */ extern void _rl_get_screen_size __P((int, int)); ! extern int _rl_init_terminal_io __P((const char *)); #ifdef _MINIX extern void _rl_output_character_function __P((int)); *************** *** 178,182 **** extern int _rl_output_character_function __P((int)); #endif ! extern void _rl_output_some_chars __P((char *, int)); extern int _rl_backspace __P((int)); extern void _rl_enable_meta_key __P((void)); --- 175,179 ---- extern int _rl_output_character_function __P((int)); #endif ! extern void _rl_output_some_chars __P((const char *, int)); extern int _rl_backspace __P((int)); extern void _rl_enable_meta_key __P((void)); *************** *** 184,190 **** /* util.c */ ! extern int alphabetic __P((int)); extern int _rl_abort_internal __P((void)); ! extern char *_rl_strindex __P((char *, char *)); extern int _rl_qsort_string_compare __P((char **, char **)); extern int (_rl_uppercase_p) __P((int)); --- 181,188 ---- /* util.c */ ! extern int rl_alphabetic __P((int)); extern int _rl_abort_internal __P((void)); ! extern char *_rl_strindex __P((const char *, const char *)); ! extern char *_rl_strpbrk __P((const char *, const char *)); extern int _rl_qsort_string_compare __P((char **, char **)); extern int (_rl_uppercase_p) __P((int)); *************** *** 207,210 **** --- 205,212 ---- *************************************************************************/ + /* bind.c */ + extern const char *_rl_possible_control_prefixes[]; + extern const char *_rl_possible_meta_prefixes[]; + /* complete.c */ extern int _rl_complete_show_all; *************** *** 219,226 **** extern char *rl_display_prompt; - /* funmap.c */ - extern char *possible_control_prefixes[]; - extern char *possible_meta_prefixes[]; - /* isearch.c */ extern unsigned char *_rl_isearch_terminators; --- 221,224 ---- *************** *** 249,266 **** extern int _rl_enable_keypad; extern int _rl_enable_meta; ! extern char *term_clreol; ! extern char *term_clrpag; ! extern char *term_im; ! extern char *term_ic; ! extern char *term_ei; ! extern char *term_DC; ! extern char *term_up; ! extern char *term_dc; ! extern char *term_cr; ! extern char *term_IC; ! extern int screenheight; ! extern int screenwidth; ! extern int screenchars; ! extern int terminal_can_insert; extern int _rl_term_autowrap; --- 247,264 ---- extern int _rl_enable_keypad; extern int _rl_enable_meta; ! extern char *_rl_term_clreol; ! extern char *_rl_term_clrpag; ! extern char *_rl_term_im; ! extern char *_rl_term_ic; ! extern char *_rl_term_ei; ! extern char *_rl_term_DC; ! extern char *_rl_term_up; ! extern char *_rl_term_dc; ! extern char *_rl_term_cr; ! extern char *_rl_term_IC; ! extern int _rl_screenheight; ! extern int _rl_screenwidth; ! extern int _rl_screenchars; ! extern int _rl_terminal_can_insert; extern int _rl_term_autowrap; diff -Nrc2 readline-4.1/rlshell.h readline-4.2/rlshell.h *** readline-4.1/rlshell.h Mon Jan 24 10:36:14 2000 --- readline-4.2/rlshell.h Wed Nov 8 10:51:03 2000 *************** *** 26,34 **** #include "rlstdc.h" ! extern char *single_quote __P((char *)); ! extern void set_lines_and_columns __P((int, int)); ! extern char *get_env_value __P((char *)); ! extern char *get_home_dir __P((void)); ! extern int unset_nodelay_mode __P((int)); #endif /* _RL_SHELL_H_ */ --- 26,34 ---- #include "rlstdc.h" ! extern char *sh_single_quote __P((char *)); ! extern void sh_set_lines_and_columns __P((int, int)); ! extern char *sh_get_env_value __P((const char *)); ! extern char *sh_get_home_dir __P((void)); ! extern int sh_unset_nodelay_mode __P((int)); #endif /* _RL_SHELL_H_ */ diff -Nrc2 readline-4.1/rlstdc.h readline-4.2/rlstdc.h *** readline-4.1/rlstdc.h Thu Aug 5 08:12:17 1999 --- readline-4.2/rlstdc.h Wed Sep 13 14:10:14 2000 *************** *** 37,39 **** --- 37,51 ---- #endif + #if !defined (__STDC__) && !defined (__cplusplus) + # if defined (__GNUC__) /* gcc with -traditional */ + # if !defined (const) + # define const __const + # endif /* !const */ + # else /* !__GNUC__ */ + # if !defined (const) + # define const + # endif /* !const */ + # endif /* !__GNUC__ */ + #endif /* !__STDC__ && !__cplusplus */ + #endif /* !_RL_STDC_H_ */ diff -Nrc2 readline-4.1/rltty.c readline-4.2/rltty.c *** readline-4.1/rltty.c Thu Aug 5 08:12:32 1999 --- readline-4.2/rltty.c Fri Feb 2 13:13:01 2001 *************** *** 50,55 **** #endif /* !errno */ ! VFunction *rl_prep_term_function = rl_prep_terminal; ! VFunction *rl_deprep_term_function = rl_deprep_terminal; /* **************************************************************** */ --- 50,55 ---- #endif /* !errno */ ! rl_vintfunc_t *rl_prep_term_function = rl_prep_terminal; ! rl_voidfunc_t *rl_deprep_term_function = rl_deprep_terminal; /* **************************************************************** */ *************** *** 191,195 **** _rl_tty_chars.t_quit = tiop->tchars.t_quitc; _rl_tty_chars.t_start = tiop->tchars.t_startc; ! _rl_tty_chars.t_stop = tiop->tchars.t_stopc _rl_tty_chars.t_eof = tiop->tchars.t_eofc; _rl_tty_chars.t_eol = '\n'; --- 191,195 ---- _rl_tty_chars.t_quit = tiop->tchars.t_quitc; _rl_tty_chars.t_start = tiop->tchars.t_startc; ! _rl_tty_chars.t_stop = tiop->tchars.t_stopc; _rl_tty_chars.t_eof = tiop->tchars.t_eofc; _rl_tty_chars.t_eol = '\n'; *************** *** 219,238 **** tiop->flags = tiop->lflag = 0; ! ioctl (tty, TIOCGETP, &(tiop->sgttyb)); tiop->flags |= SGTTY_SET; #if defined (TIOCLGET) ! ioctl (tty, TIOCLGET, &(tiop->lflag)); ! tiop->flags |= LFLAG_SET; #endif #if defined (TIOCGETC) ! ioctl (tty, TIOCGETC, &(tiop->tchars)); ! tiop->flags |= TCHARS_SET; #endif #if defined (TIOCGLTC) ! ioctl (tty, TIOCGLTC, &(tiop->ltchars)); ! tiop->flags |= LTCHARS_SET; #endif --- 219,239 ---- tiop->flags = tiop->lflag = 0; ! if (ioctl (tty, TIOCGETP, &(tiop->sgttyb)) < 0) ! return -1; tiop->flags |= SGTTY_SET; #if defined (TIOCLGET) ! if (ioctl (tty, TIOCLGET, &(tiop->lflag)) == 0) ! tiop->flags |= LFLAG_SET; #endif #if defined (TIOCGETC) ! if (ioctl (tty, TIOCGETC, &(tiop->tchars)) == 0) ! tiop->flags |= TCHARS_SET; #endif #if defined (TIOCGLTC) ! if (ioctl (tty, TIOCGLTC, &(tiop->ltchars)) == 0) ! tiop->flags |= LTCHARS_SET; #endif *************** *** 280,300 **** static void ! prepare_terminal_settings (meta_flag, otio, tiop) int meta_flag; ! TIOTYPE otio, *tiop; { ! readline_echoing_p = (otio.sgttyb.sg_flags & ECHO); /* Copy the original settings to the structure we're going to use for our settings. */ ! tiop->sgttyb = otio.sgttyb; ! tiop->lflag = otio.lflag; #if defined (TIOCGETC) ! tiop->tchars = otio.tchars; #endif #if defined (TIOCGLTC) ! tiop->ltchars = otio.ltchars; #endif ! tiop->flags = otio.flags; /* First, the basic settings to put us into character-at-a-time, no-echo --- 281,301 ---- static void ! prepare_terminal_settings (meta_flag, oldtio, tiop) int meta_flag; ! TIOTYPE oldtio, *tiop; { ! readline_echoing_p = (oldtio.sgttyb.sg_flags & ECHO); /* Copy the original settings to the structure we're going to use for our settings. */ ! tiop->sgttyb = oldtio.sgttyb; ! tiop->lflag = oldtio.lflag; #if defined (TIOCGETC) ! tiop->tchars = oldtio.tchars; #endif #if defined (TIOCGLTC) ! tiop->ltchars = oldtio.ltchars; #endif ! tiop->flags = oldtio.flags; /* First, the basic settings to put us into character-at-a-time, no-echo *************** *** 309,314 **** # define ANYP (EVENP | ODDP) #endif ! if (((otio.sgttyb.sg_flags & ANYP) == ANYP) || ! ((otio.sgttyb.sg_flags & ANYP) == 0)) { tiop->sgttyb.sg_flags |= ANYP; --- 310,315 ---- # define ANYP (EVENP | ODDP) #endif ! if (((oldtio.sgttyb.sg_flags & ANYP) == ANYP) || ! ((oldtio.sgttyb.sg_flags & ANYP) == 0)) { tiop->sgttyb.sg_flags |= ANYP; *************** *** 329,339 **** /* If there is an XON character, bind it to restart the output. */ ! if (otio.tchars.t_startc != -1) ! rl_bind_key (otio.tchars.t_startc, rl_restart_output); # endif /* USE_XON_XOFF */ /* If there is an EOF char, bind _rl_eof_char to it. */ ! if (otio.tchars.t_eofc != -1) ! _rl_eof_char = otio.tchars.t_eofc; # if defined (NO_KILL_INTR) --- 330,340 ---- /* If there is an XON character, bind it to restart the output. */ ! if (oldtio.tchars.t_startc != -1) ! rl_bind_key (oldtio.tchars.t_startc, rl_restart_output); # endif /* USE_XON_XOFF */ /* If there is an EOF char, bind _rl_eof_char to it. */ ! if (oldtio.tchars.t_eofc != -1) ! _rl_eof_char = oldtio.tchars.t_eofc; # if defined (NO_KILL_INTR) *************** *** 374,378 **** # define DRAIN_OUTPUT(fd) # define GETATTR(tty, tiop) (ioctl (tty, TCGETA, tiop)) ! # define SETATTR(tty, tiop) (ioctl (tty, TCSETA, tiop)) #endif /* !TERMIOS_TTY_DRIVER */ --- 375,379 ---- # define DRAIN_OUTPUT(fd) # define GETATTR(tty, tiop) (ioctl (tty, TCGETA, tiop)) ! # define SETATTR(tty, tiop) (ioctl (tty, TCSETAW, tiop)) #endif /* !TERMIOS_TTY_DRIVER */ *************** *** 546,559 **** static void ! prepare_terminal_settings (meta_flag, otio, tiop) int meta_flag; ! TIOTYPE otio, *tiop; { ! readline_echoing_p = (otio.c_lflag & ECHO); tiop->c_lflag &= ~(ICANON | ECHO); ! if ((unsigned char) otio.c_cc[VEOF] != (unsigned char) _POSIX_VDISABLE) ! _rl_eof_char = otio.c_cc[VEOF]; #if defined (USE_XON_XOFF) --- 547,560 ---- static void ! prepare_terminal_settings (meta_flag, oldtio, tiop) int meta_flag; ! TIOTYPE oldtio, *tiop; { ! readline_echoing_p = (oldtio.c_lflag & ECHO); tiop->c_lflag &= ~(ICANON | ECHO); ! if ((unsigned char) oldtio.c_cc[VEOF] != (unsigned char) _POSIX_VDISABLE) ! _rl_eof_char = oldtio.c_cc[VEOF]; #if defined (USE_XON_XOFF) *************** *** 586,590 **** { tiop->c_lflag &= ~FLUSHO; ! otio.c_lflag &= ~FLUSHO; } #endif --- 587,591 ---- { tiop->c_lflag &= ~FLUSHO; ! oldtio.c_lflag &= ~FLUSHO; } #endif *************** *** 646,649 **** --- 647,651 ---- fflush (rl_outstream); terminal_prepped = 1; + RL_SETSTATE(RL_STATE_TERMPREPPED); release_sigint (); *************** *** 676,679 **** --- 678,682 ---- terminal_prepped = 0; + RL_UNSETSTATE(RL_STATE_TERMPREPPED); release_sigint (); *************** *** 752,755 **** --- 755,761 ---- /* */ /* **************************************************************** */ + + /* Set the system's default editing characters to their readline equivalents + in KMAP. Should be static, now that we have rl_tty_set_default_bindings. */ void rltty_set_default_bindings (kmap) *************** *** 814,817 **** --- 820,832 ---- } #endif /* !NEW_TTY_DRIVER */ + } + + /* New public way to set the system default editing chars to their readline + equivalents. */ + void + rl_tty_set_default_bindings (kmap) + Keymap kmap; + { + rltty_set_default_bindings (kmap); } diff -Nrc2 readline-4.1/rltypedefs.h readline-4.2/rltypedefs.h *** readline-4.1/rltypedefs.h Wed Dec 31 19:00:00 1969 --- readline-4.2/rltypedefs.h Mon Nov 27 11:52:04 2000 *************** *** 0 **** --- 1,88 ---- + /* rltypedefs.h -- Type declarations for readline functions. */ + + /* Copyright (C) 2000 Free Software Foundation, Inc. + + This file is part of the GNU Readline Library, a library for + reading lines of text with interactive input and history editing. + + The GNU Readline Library 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. + + The GNU Readline Library 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. + + The GNU General Public License is often shipped with GNU software, and + is generally kept in a file called COPYING or LICENSE. If you do not + have a copy of the license, write to the Free Software Foundation, + 59 Temple Place, Suite 330, Boston, MA 02111 USA. */ + + #ifndef _RL_TYPEDEFS_H_ + #define _RL_TYPEDEFS_H_ + + #ifdef __cplusplus + extern "C" { + #endif + + /* Old-style */ + + #if !defined (_FUNCTION_DEF) + # define _FUNCTION_DEF + + typedef int Function (); + typedef void VFunction (); + typedef char *CPFunction (); + typedef char **CPPFunction (); + + #endif /* _FUNCTION_DEF */ + + /* New style. */ + + #if !defined (_RL_FUNCTION_TYPEDEF) + # define _RL_FUNCTION_TYPEDEF + + /* Bindable functions */ + typedef int rl_command_func_t __P((int, int)); + + /* Typedefs for the completion system */ + typedef char *rl_compentry_func_t __P((const char *, int)); + typedef char **rl_completion_func_t __P((const char *, int, int)); + + typedef char *rl_quote_func_t __P((char *, int, char *)); + typedef char *rl_dequote_func_t __P((char *, int)); + + typedef int rl_compignore_func_t __P((char **)); + + typedef void rl_compdisp_func_t __P((char **, int, int)); + + /* Type for input and pre-read hook functions like rl_event_hook */ + typedef int rl_hook_func_t __P((void)); + + /* Input function type */ + typedef int rl_getc_func_t __P((FILE *)); + + /* Generic function that takes a character buffer (which could be the readline + line buffer) and an index into it (which could be rl_point) and returns + an int. */ + typedef int rl_linebuf_func_t __P((char *, int)); + + /* `Generic' function pointer typedefs */ + typedef int rl_intfunc_t __P((int)); + #define rl_ivoidfunc_t rl_hook_func_t + typedef int rl_icpfunc_t __P((char *)); + typedef int rl_icppfunc_t __P((char **)); + + typedef void rl_voidfunc_t __P((void)); + typedef void rl_vintfunc_t __P((int)); + typedef void rl_vcpfunc_t __P((char *)); + typedef void rl_vcppfunc_t __P((char **)); + #endif /* _RL_FUNCTION_TYPEDEF */ + + #ifdef __cplusplus + } + #endif + + #endif /* _RL_TYPEDEFS_H_ */ diff -Nrc2 readline-4.1/savestring.c readline-4.2/savestring.c *** readline-4.1/savestring.c Thu Aug 5 08:13:15 1999 --- readline-4.2/savestring.c Thu Sep 14 14:58:41 2000 *************** *** 28,32 **** char * savestring (s) ! char *s; { return ((char *)strcpy (xmalloc (1 + (int)strlen (s)), (s))); --- 28,32 ---- char * savestring (s) ! const char *s; { return ((char *)strcpy (xmalloc (1 + (int)strlen (s)), (s))); diff -Nrc2 readline-4.1/search.c readline-4.2/search.c *** readline-4.1/search.c Thu Aug 5 08:13:32 1999 --- readline-4.2/search.c Thu Nov 2 13:13:25 2000 *************** *** 52,56 **** #define abs(x) (((x) >= 0) ? (x) : -(x)) ! extern HIST_ENTRY *saved_line_for_history; /* Functions imported from the rest of the library. */ --- 52,56 ---- #define abs(x) (((x) >= 0) ? (x) : -(x)) ! extern HIST_ENTRY *_rl_saved_line_for_history; /* Functions imported from the rest of the library. */ *************** *** 84,90 **** rl_end = line_len; ! if (saved_line_for_history) ! _rl_free_history_entry (saved_line_for_history); ! saved_line_for_history = (HIST_ENTRY *)NULL; } --- 84,90 ---- rl_end = line_len; ! if (_rl_saved_line_for_history) ! _rl_free_history_entry (_rl_saved_line_for_history); ! _rl_saved_line_for_history = (HIST_ENTRY *)NULL; } *************** *** 101,111 **** int ret, old; old = where_history (); ! history_set_pos (pos); if (*string == '^') ret = history_search_prefix (string + 1, dir); else ret = history_search (string, dir); if (ret != -1) --- 101,117 ---- int ret, old; + if (pos < 0) + return -1; + old = where_history (); ! if (history_set_pos (pos) == 0) ! return -1; + RL_SETSTATE(RL_STATE_SEARCH); if (*string == '^') ret = history_search_prefix (string + 1, dir); else ret = history_search (string, dir); + RL_UNSETSTATE(RL_STATE_SEARCH); if (ret != -1) *************** *** 129,133 **** if (string == 0 || *string == '\0' || noninc_history_pos < 0) { ! ding (); return; } --- 135,139 ---- if (string == 0 || *string == '\0' || noninc_history_pos < 0) { ! rl_ding (); return; } *************** *** 137,144 **** { /* Search failed, current history position unchanged. */ ! maybe_unsave_line (); rl_clear_message (); rl_point = 0; ! ding (); return; } --- 143,150 ---- { /* Search failed, current history position unchanged. */ ! rl_maybe_unsave_line (); rl_clear_message (); rl_point = 0; ! rl_ding (); return; } *************** *** 173,177 **** char *p; ! maybe_save_line (); saved_point = rl_point; --- 179,183 ---- char *p; ! rl_maybe_save_line (); saved_point = rl_point; *************** *** 184,192 **** free (p); ! #define SEARCH_RETURN rl_restore_prompt (); return /* Read the search string. */ ! while (c = rl_read_key ()) { switch (c) { --- 190,206 ---- free (p); ! #define SEARCH_RETURN rl_restore_prompt (); RL_UNSETSTATE(RL_STATE_NSEARCH); return + RL_SETSTATE(RL_STATE_NSEARCH); /* Read the search string. */ ! while (1) { + RL_SETSTATE(RL_STATE_MOREINPUT); + c = rl_read_key (); + RL_UNSETSTATE(RL_STATE_MOREINPUT); + + if (c == 0) + break; + switch (c) { *************** *** 195,199 **** if (rl_point == 0) { ! maybe_unsave_line (); rl_clear_message (); rl_point = saved_point; --- 209,213 ---- if (rl_point == 0) { ! rl_maybe_unsave_line (); rl_clear_message (); rl_point = saved_point; *************** *** 219,226 **** case CTRL('C'): case CTRL('G'): ! maybe_unsave_line (); rl_clear_message (); rl_point = saved_point; ! ding (); SEARCH_RETURN; --- 233,240 ---- case CTRL('C'): case CTRL('G'): ! rl_maybe_unsave_line (); rl_clear_message (); rl_point = saved_point; ! rl_ding (); SEARCH_RETURN; *************** *** 240,244 **** if (!noninc_search_string) { ! ding (); SEARCH_RETURN; } --- 254,258 ---- if (!noninc_search_string) { ! rl_ding (); SEARCH_RETURN; } *************** *** 254,257 **** --- 268,272 ---- rl_restore_prompt (); noninc_dosearch (noninc_search_string, dir); + RL_UNSETSTATE(RL_STATE_NSEARCH); } *************** *** 284,288 **** if (!noninc_search_string) { ! ding (); return (-1); } --- 299,303 ---- if (!noninc_search_string) { ! rl_ding (); return (-1); } *************** *** 299,303 **** if (!noninc_search_string) { ! ding (); return (-1); } --- 314,318 ---- if (!noninc_search_string) { ! rl_ding (); return (-1); } *************** *** 313,317 **** int ret, oldpos; ! maybe_save_line (); temp = (HIST_ENTRY *)NULL; --- 328,332 ---- int ret, oldpos; ! rl_maybe_save_line (); temp = (HIST_ENTRY *)NULL; *************** *** 342,347 **** if (temp == 0) { ! maybe_unsave_line (); ! ding (); /* If you don't want the saved history line (last match) to show up in the line buffer after the search fails, change the #if 0 to --- 357,362 ---- if (temp == 0) { ! rl_maybe_unsave_line (); ! rl_ding (); /* If you don't want the saved history line (last match) to show up in the line buffer after the search fails, change the #if 0 to *************** *** 354,358 **** } #else ! rl_point = rl_history_search_len; /* maybe_unsave_line changes it */ #endif return 1; --- 369,373 ---- } #else ! rl_point = rl_history_search_len; /* rl_maybe_unsave_line changes it */ #endif return 1; *************** *** 383,386 **** --- 398,402 ---- history_search_string[rl_point + 1] = '\0'; } + _rl_free_saved_history_line (); } diff -Nrc2 readline-4.1/shell.c readline-4.2/shell.c *** readline-4.1/shell.c Mon Nov 29 11:04:14 1999 --- readline-4.2/shell.c Wed Nov 8 12:12:45 2000 *************** *** 50,58 **** #include #include "rlshell.h" #include "xmalloc.h" #if !defined (HAVE_GETPW_DECLS) ! extern struct passwd *getpwuid (); #endif /* !HAVE_GETPW_DECLS */ --- 50,59 ---- #include + #include "rlstdc.h" #include "rlshell.h" #include "xmalloc.h" #if !defined (HAVE_GETPW_DECLS) ! extern struct passwd *getpwuid __P((uid_t)); #endif /* !HAVE_GETPW_DECLS */ *************** *** 66,70 **** /* Does shell-like quoting using single quotes. */ char * ! single_quote (string) char *string; { --- 67,71 ---- /* Does shell-like quoting using single quotes. */ char * ! sh_single_quote (string) char *string; { *************** *** 97,101 **** respectively. */ void ! set_lines_and_columns (lines, cols) int lines, cols; { --- 98,102 ---- respectively. */ void ! sh_set_lines_and_columns (lines, cols) int lines, cols; { *************** *** 122,127 **** char * ! get_env_value (varname) ! char *varname; { return ((char *)getenv (varname)); --- 123,128 ---- char * ! sh_get_env_value (varname) ! const char *varname; { return ((char *)getenv (varname)); *************** *** 129,133 **** char * ! get_home_dir () { char *home_dir; --- 130,134 ---- char * ! sh_get_home_dir () { char *home_dir; *************** *** 148,152 **** int ! unset_nodelay_mode (fd) int fd; { --- 149,153 ---- int ! sh_unset_nodelay_mode (fd) int fd; { diff -Nrc2 readline-4.1/shlib/Makefile.in readline-4.2/shlib/Makefile.in *** readline-4.1/shlib/Makefile.in Thu Aug 5 10:56:46 1999 --- readline-4.2/shlib/Makefile.in Mon Nov 27 12:03:27 2000 *************** *** 37,40 **** --- 37,41 ---- CP = cp MV = mv + LN = ln SHELL = @MAKE_SHELL@ *************** *** 44,47 **** --- 45,49 ---- prefix = @prefix@ exec_prefix = @exec_prefix@ + includedir = @includedir@ libdir = @libdir@ *************** *** 109,113 **** $(topdir)/history.c $(topdir)/histsearch.c $(topdir)/histexpand.c \ $(topdir)/histfile.c $(topdir)/nls.c $(topdir)/search.c \ ! $(topdir)/shell.c $(topdir)/savestring.c $(topdir)/tilde.c # The header files for this library. --- 111,116 ---- $(topdir)/history.c $(topdir)/histsearch.c $(topdir)/histexpand.c \ $(topdir)/histfile.c $(topdir)/nls.c $(topdir)/search.c \ ! $(topdir)/shell.c $(topdir)/savestring.c $(topdir)/compat.c \ ! $(topdir)/tilde.c # The header files for this library. *************** *** 121,125 **** rltty.so complete.so bind.so isearch.so display.so signals.so \ util.so kill.so undo.so macro.so input.so callback.so terminal.so \ ! nls.so xmalloc.so $(SHARED_HISTOBJ) $(SHARED_TILDEOBJ) ########################################################################## --- 124,128 ---- rltty.so complete.so bind.so isearch.so display.so signals.so \ util.so kill.so undo.so macro.so input.so callback.so terminal.so \ ! nls.so xmalloc.so $(SHARED_HISTOBJ) $(SHARED_TILDEOBJ) compat.so ########################################################################## *************** *** 174,185 **** --- 177,192 ---- bind.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h bind.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h + bind.so: $(topdir)/rltypedefs.h bind.so: $(topdir)/tilde.h $(topdir)/history.h + compat.so: $(topdir)/rlstdc.h callback.so: $(topdir)/rlconf.h callback.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h callback.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h + callback.so: $(topdir)/rltypedefs.h callback.so: $(topdir)/tilde.h complete.so: $(topdir)/ansi_stdlib.h posixdir.h $(topdir)/posixstat.h complete.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h complete.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h + complete.so: $(topdir)/rltypedefs.h complete.so: $(topdir)/tilde.h display.so: $(topdir)/ansi_stdlib.h $(topdir)/posixstat.h *************** *** 187,234 **** display.so: $(topdir)/tcap.h display.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h display.so: $(topdir)/tilde.h $(topdir)/history.h funmap.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h funmap.so: $(topdir)/rlconf.h $(topdir)/ansi_stdlib.h funmap.so: ${BUILD_DIR}/config.h $(topdir)/tilde.h histexpand.so: $(topdir)/ansi_stdlib.h ! histexpand.so: $(topdir)/history.h histlib.h histexpand.so: ${BUILD_DIR}/config.h histfile.so: $(topdir)/ansi_stdlib.h ! histfile.so: $(topdir)/history.h histlib.h histfile.so: ${BUILD_DIR}/config.h history.so: $(topdir)/ansi_stdlib.h ! history.so: $(topdir)/history.h histlib.h history.so: ${BUILD_DIR}/config.h histsearch.so: $(topdir)/ansi_stdlib.h ! histsearch.so: $(topdir)/history.h histlib.h histsearch.so: ${BUILD_DIR}/config.h input.so: $(topdir)/ansi_stdlib.h input.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h input.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h input.so: $(topdir)/tilde.h isearch.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h isearch.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h isearch.so: $(topdir)/ansi_stdlib.h $(topdir)/history.h $(topdir)/tilde.h keymaps.so: emacs_keymap.c vi_keymap.c keymaps.so: $(topdir)/keymaps.h $(topdir)/chardefs.h $(topdir)/rlconf.h keymaps.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h keymaps.so: ${BUILD_DIR}/config.h $(topdir)/ansi_stdlib.h $(topdir)/tilde.h kill.so: $(topdir)/ansi_stdlib.h kill.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h kill.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h ! kill.so: $(topdir)/tilde.h $(topdir)/history.h macro.so: $(topdir)/ansi_stdlib.h macro.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h macro.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h ! macro.so: $(topdir)/tilde.h $(topdir)/history.h nls.so: $(topdir)/ansi_stdlib.h nls.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h nls.o: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h nls.o: $(topdir)/tilde.h $(topdir)/history.h $(topdir)/rlstdc.h parens.so: $(topdir)/rlconf.h ${BUILD_DIR}/config.h parens.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h parens.so: $(topdir)/tilde.h readline.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h readline.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h readline.so: $(topdir)/history.h $(topdir)/tilde.h readline.so: $(topdir)/posixstat.h $(topdir)/ansi_stdlib.h $(topdir)/posixjmp.h --- 194,249 ---- display.so: $(topdir)/tcap.h display.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h + display.so: $(topdir)/rltypedefs.h display.so: $(topdir)/tilde.h $(topdir)/history.h funmap.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h + funmap.so: $(topdir)/rltypedefs.h funmap.so: $(topdir)/rlconf.h $(topdir)/ansi_stdlib.h funmap.so: ${BUILD_DIR}/config.h $(topdir)/tilde.h histexpand.so: $(topdir)/ansi_stdlib.h ! histexpand.so: $(topdir)/history.h $(topdir)/histlib.h $(topdir)/rltypedefs.h histexpand.so: ${BUILD_DIR}/config.h histfile.so: $(topdir)/ansi_stdlib.h ! histfile.so: $(topdir)/history.h $(topdir)/histlib.h $(topdir)/rltypedefs.h histfile.so: ${BUILD_DIR}/config.h history.so: $(topdir)/ansi_stdlib.h ! history.so: $(topdir)/history.h $(topdir)/histlib.h $(topdir)/rltypedefs.h history.so: ${BUILD_DIR}/config.h histsearch.so: $(topdir)/ansi_stdlib.h ! histsearch.so: $(topdir)/history.h $(topdir)/histlib.h $(topdir)/rltypedefs.h histsearch.so: ${BUILD_DIR}/config.h input.so: $(topdir)/ansi_stdlib.h input.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h input.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h + input.so: $(topdir)/rltypedefs.h input.so: $(topdir)/tilde.h isearch.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h isearch.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h + isearch.so: $(topdir)/rltypedefs.h isearch.so: $(topdir)/ansi_stdlib.h $(topdir)/history.h $(topdir)/tilde.h keymaps.so: emacs_keymap.c vi_keymap.c keymaps.so: $(topdir)/keymaps.h $(topdir)/chardefs.h $(topdir)/rlconf.h keymaps.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h + keymaps.so: $(topdir)/rltypedefs.h keymaps.so: ${BUILD_DIR}/config.h $(topdir)/ansi_stdlib.h $(topdir)/tilde.h kill.so: $(topdir)/ansi_stdlib.h kill.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h kill.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h ! kill.so: $(topdir)/tilde.h $(topdir)/history.h $(topdir)/rltypedefs.h macro.so: $(topdir)/ansi_stdlib.h macro.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h macro.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h ! macro.so: $(topdir)/tilde.h $(topdir)/history.h $(topdir)/rltypedefs.h nls.so: $(topdir)/ansi_stdlib.h nls.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h nls.o: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h + nls.o: $(topdir)/rltypedefs.h nls.o: $(topdir)/tilde.h $(topdir)/history.h $(topdir)/rlstdc.h parens.so: $(topdir)/rlconf.h ${BUILD_DIR}/config.h parens.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h + parens.so: $(topdir)/rltypedefs.h parens.so: $(topdir)/tilde.h readline.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h readline.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h + readline.so: $(topdir)/rltypedefs.h readline.so: $(topdir)/history.h $(topdir)/tilde.h readline.so: $(topdir)/posixstat.h $(topdir)/ansi_stdlib.h $(topdir)/posixjmp.h *************** *** 236,261 **** rltty.so: $(topdir)/rltty.h $(topdir)/tilde.h rltty.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h search.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h search.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h search.so: $(topdir)/ansi_stdlib.h $(topdir)/history.h $(topdir)/tilde.h signals.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h signals.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h signals.so: $(topdir)/history.h $(topdir)/tilde.h terminal.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h terminal.so: $(topdir)/tcap.h terminal.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h terminal.so: $(topdir)/tilde.h $(topdir)/history.h tilde.so: $(topdir)/ansi_stdlib.h ${BUILD_DIR}/config.h $(topdir)/tilde.h undo.so: $(topdir)/ansi_stdlib.h undo.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h undo.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h undo.so: $(topdir)/tilde.h $(topdir)/history.h util.so: $(topdir)/posixjmp.h $(topdir)/ansi_stdlib.h util.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h util.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h ! util.so: $(topdir)/tilde.h vi_mode.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h vi_mode.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h vi_mode.so: $(topdir)/history.h $(topdir)/ansi_stdlib.h $(topdir)/tilde.h xmalloc.so: ${BUILD_DIR}/config.h xmalloc.so: $(topdir)/ansi_stdlib.h --- 251,282 ---- rltty.so: $(topdir)/rltty.h $(topdir)/tilde.h rltty.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h + rltty.so: $(topdir)/rltypedefs.h search.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h search.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h search.so: $(topdir)/ansi_stdlib.h $(topdir)/history.h $(topdir)/tilde.h + search.so: $(topdir)/rltypedefs.h signals.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h signals.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h signals.so: $(topdir)/history.h $(topdir)/tilde.h + signals.so: $(topdir)/rltypedefs.h terminal.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h terminal.so: $(topdir)/tcap.h terminal.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h terminal.so: $(topdir)/tilde.h $(topdir)/history.h + terminal.so: $(topdir)/rltypedefs.h tilde.so: $(topdir)/ansi_stdlib.h ${BUILD_DIR}/config.h $(topdir)/tilde.h undo.so: $(topdir)/ansi_stdlib.h undo.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h undo.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h + undo.so: $(topdir)/rltypedefs.h undo.so: $(topdir)/tilde.h $(topdir)/history.h util.so: $(topdir)/posixjmp.h $(topdir)/ansi_stdlib.h util.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h util.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h ! util.so: $(topdir)/rltypedefs.h $(topdir)/tilde.h vi_mode.so: $(topdir)/rldefs.h ${BUILD_DIR}/config.h $(topdir)/rlconf.h vi_mode.so: $(topdir)/readline.h $(topdir)/keymaps.h $(topdir)/chardefs.h vi_mode.so: $(topdir)/history.h $(topdir)/ansi_stdlib.h $(topdir)/tilde.h + vi_mode.so: $(topdir)/rltypedefs.h xmalloc.so: ${BUILD_DIR}/config.h xmalloc.so: $(topdir)/ansi_stdlib.h *************** *** 316,319 **** --- 337,341 ---- search.so: $(topdir)/search.c rltty.so: $(topdir)/rltty.c + compat.so: $(topdir)/compat.c complete.so: $(topdir)/complete.c bind.so: $(topdir)/bind.c *************** *** 345,348 **** --- 367,371 ---- search.so: search.c rltty.so: rltty.c + comapt.so: compat.c complete.so: complete.c bind.so: bind.c diff -Nrc2 readline-4.1/signals.c readline-4.2/signals.c *** readline-4.1/signals.c Mon Feb 21 11:22:57 2000 --- readline-4.2/signals.c Tue Dec 12 15:01:45 2000 *************** *** 62,66 **** #endif ! /* This typedef is equivalant to the one for Function; it allows us to say SigHandler *foo = signal (SIGKILL, SIG_IGN); */ typedef RETSIGTYPE SigHandler (); --- 62,66 ---- #endif ! /* This typedef is equivalent to the one for Function; it allows us to say SigHandler *foo = signal (SIGKILL, SIG_IGN); */ typedef RETSIGTYPE SigHandler (); *************** *** 120,123 **** --- 120,125 ---- #endif /* !HAVE_POSIX_SIGNALS */ + RL_SETSTATE(RL_STATE_SIGHANDLER); + #if !defined (HAVE_BSD_SIGNALS) && !defined (HAVE_POSIX_SIGNALS) /* Since the signal will not be blocked while we are in the signal *************** *** 170,173 **** --- 172,176 ---- } + RL_UNSETSTATE(RL_STATE_SIGHANDLER); SIGHANDLER_RETURN; } *************** *** 190,193 **** --- 193,197 ---- #endif + RL_SETSTATE(RL_STATE_SIGHANDLER); rl_resize_terminal (); *************** *** 197,200 **** --- 201,205 ---- (*oh) (sig); + RL_UNSETSTATE(RL_STATE_SIGHANDLER); SIGHANDLER_RETURN; } *************** *** 359,363 **** (*rl_deprep_term_function) (); rl_clear_signals (); ! rl_pending_input = 0; } --- 364,368 ---- (*rl_deprep_term_function) (); rl_clear_signals (); ! rl_clear_pending_input (); } *************** *** 379,383 **** register HIST_ENTRY *entry; ! free_undo_list (); entry = current_history (); --- 384,388 ---- register HIST_ENTRY *entry; ! rl_free_undo_list (); entry = current_history (); diff -Nrc2 readline-4.1/support/config.guess readline-4.2/support/config.guess *** readline-4.1/support/config.guess Tue Nov 30 16:10:14 1999 --- readline-4.2/support/config.guess Mon Dec 18 10:43:18 2000 *************** *** 169,176 **** echo intel-pc-opennt exit 0 ;; # end cases added for Bash alpha:OSF1:*:*) ! if test $UNAME_RELEASE = "V4.0"; then UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $3}'` fi # A Vn.n version is a released version. --- 169,183 ---- echo intel-pc-opennt exit 0 ;; + *:NonStop-UX:*:*) + echo mips-compaq-nonstopux + exit 0 ;; # end cases added for Bash alpha:OSF1:*:*) ! # TEST CHANGED FOR BASH to handle `letter version' releases ! UNAME_MAJOR=`echo "$UNAME_RELEASE" | sed -e 's/^.\([0-9]\).*/\1/'` ! if test X"$UNAME_MAJOR" != X"" && test $UNAME_MAJOR = 4 ; then UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $3}'` + elif test X"$UNAME_MAJOR" != X"" && test $UNAME_MAJOR -gt 4 ; then + UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $4}'` fi # A Vn.n version is a released version. *************** *** 704,708 **** exit 0 ;; i*:CYGWIN*:*) ! echo ${UNAME_MACHINE}-pc-cygwin32 exit 0 ;; i*:MINGW*:*) --- 711,715 ---- exit 0 ;; i*:CYGWIN*:*) ! echo ${UNAME_MACHINE}-pc-cygwin exit 0 ;; i*:MINGW*:*) *************** *** 1058,1061 **** --- 1065,1074 ---- *:Rhapsody:*:*) echo ${UNAME_MACHINE}-apple-rhapsody${UNAME_RELEASE} + exit 0 ;; + Power*:Darwin:*:*) + echo powerpc-apple-darwin${UNAME_RELEASE} + exit 0 ;; + *:Darwin:*:*) + echo ${UNAME_MACHINE}-apple-darwin${UNAME_RELEASE} exit 0 ;; esac diff -Nrc2 readline-4.1/support/config.sub readline-4.2/support/config.sub *** readline-4.1/support/config.sub Tue Nov 30 16:53:37 1999 --- readline-4.2/support/config.sub Mon Feb 12 12:50:05 2001 *************** *** 174,178 **** | mips64vr5000 | miprs64vr5000el | mcore \ | sparc | sparclet | sparclite | sparc64 | sparcv9 | v850 | c4x \ ! | thumb | d10v) basic_machine=$basic_machine-unknown ;; --- 174,178 ---- | mips64vr5000 | miprs64vr5000el | mcore \ | sparc | sparclet | sparclite | sparc64 | sparcv9 | v850 | c4x \ ! | thumb | d10v | s390) basic_machine=$basic_machine-unknown ;; *************** *** 677,680 **** --- 677,684 ---- basic_machine=romp-ibm ;; + s390-*) + basic_machine=s390-ibm + os=-linux + ;; sa29200) basic_machine=a29k-amd *************** *** 947,951 **** | -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \ | -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \ ! | -cygwin32* | -pe* | -psos* | -moss* | -proelf* | -rtems* \ | -mingw32* | -linux-gnu* | -uxpv* | -beos* | -mpeix* | -udk* \ | -interix* | -uwin* | -rhapsody* | -openstep* | -oskit*) --- 951,955 ---- | -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \ | -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \ ! | -cygwin* | -pe* | -psos* | -moss* | -proelf* | -rtems* \ | -mingw32* | -linux-gnu* | -uxpv* | -beos* | -mpeix* | -udk* \ | -interix* | -uwin* | -rhapsody* | -openstep* | -oskit*) *************** *** 953,957 **** ;; # BEGIN CASES ADDED FOR Bash ! -qnx* | -powerux* | -superux* ) ;; # END CASES ADDED FOR Bash --- 957,961 ---- ;; # BEGIN CASES ADDED FOR Bash ! -qnx* | -powerux* | -superux* | -darwin* | -nonstopux*) ;; # END CASES ADDED FOR Bash diff -Nrc2 readline-4.1/support/shlib-install readline-4.2/support/shlib-install *** readline-4.1/support/shlib-install Tue Sep 21 13:29:16 1999 --- readline-4.2/support/shlib-install Tue Sep 12 10:26:14 2000 *************** *** 67,71 **** case "$host_os" in hpux*) if [ -z "$uninstall" ]; then ! chmod 755 ${INSTALLDIR}/${LIBNAME} fi ;; *) ;; --- 67,71 ---- case "$host_os" in hpux*) if [ -z "$uninstall" ]; then ! chmod 555 ${INSTALLDIR}/${LIBNAME} fi ;; *) ;; *************** *** 85,88 **** --- 85,91 ---- esac + INSTALL_LINK1='cd $INSTALLDIR ; ln -s $LIBNAME $LINK1' + INSTALL_LINK2='cd $INSTALLDIR ; ln -s $LIBNAME $LINK2' + # # Create symlinks to the installed library. This section is incomplete. *************** *** 93,97 **** ${echo} ${RM} ${INSTALLDIR}/$LINK2 if [ -z "$uninstall" ]; then ! ${echo} ln -s $INSTALLDIR/$LIBNAME ${INSTALLDIR}/$LINK2 fi --- 96,100 ---- ${echo} ${RM} ${INSTALLDIR}/$LINK2 if [ -z "$uninstall" ]; then ! ${echo} ln -s $LIBNAME ${INSTALLDIR}/$LINK2 fi *************** *** 99,103 **** ${echo} ${RM} ${INSTALLDIR}/$LINK1 if [ -z "$uninstall" ]; then ! ${echo} ln -s $INSTALLDIR/$LIBNAME ${INSTALLDIR}/$LINK1 fi ;; --- 102,106 ---- ${echo} ${RM} ${INSTALLDIR}/$LINK1 if [ -z "$uninstall" ]; then ! ${echo} ln -s $LIBNAME ${INSTALLDIR}/$LINK1 fi ;; *************** *** 107,111 **** ${echo} ${RM} ${INSTALLDIR}/$LINK1 if [ -z "$uninstall" ]; then ! ${echo} ln -s $INSTALLDIR/$LIBNAME ${INSTALLDIR}/$LINK1 fi ;; --- 110,114 ---- ${echo} ${RM} ${INSTALLDIR}/$LINK1 if [ -z "$uninstall" ]; then ! ${echo} ln -s $LIBNAME ${INSTALLDIR}/$LINK1 fi ;; *************** *** 118,122 **** ${echo} ${RM} ${INSTALLDIR}/$LINK1 if [ -z "$uninstall" ]; then ! ${echo} ln -s $INSTALLDIR/$LIBNAME ${INSTALLDIR}/$LINK1 fi else --- 121,125 ---- ${echo} ${RM} ${INSTALLDIR}/$LINK1 if [ -z "$uninstall" ]; then ! ${echo} ln -s $LIBNAME ${INSTALLDIR}/$LINK1 fi else *************** *** 124,128 **** ${echo} ${RM} ${INSTALLDIR}/$LINK2 if [ -z "$uninstall" ]; then ! ${echo} ln -s $INSTALLDIR/$LIBNAME ${INSTALLDIR}/$LINK2 fi --- 127,131 ---- ${echo} ${RM} ${INSTALLDIR}/$LINK2 if [ -z "$uninstall" ]; then ! ${echo} ln -s $LIBNAME ${INSTALLDIR}/$LINK2 fi *************** *** 130,134 **** ${echo} ${RM} ${INSTALLDIR}/$LINK1 if [ -z "$uninstall" ]; then ! ${echo} ln -s $INSTALLDIR/$LIBNAME ${INSTALLDIR}/$LINK1 fi fi --- 133,137 ---- ${echo} ${RM} ${INSTALLDIR}/$LINK1 if [ -z "$uninstall" ]; then ! ${echo} ln -s $LIBNAME ${INSTALLDIR}/$LINK1 fi fi *************** *** 139,143 **** ${echo} ${RM} ${INSTALLDIR}/$LINK1.sl if [ -z "$uninstall" ]; then ! ${echo} ln -s $INSTALLDIR/$LIBNAME ${INSTALLDIR}/${LINK1}.sl fi ;; --- 142,147 ---- ${echo} ${RM} ${INSTALLDIR}/$LINK1.sl if [ -z "$uninstall" ]; then ! # ${echo} ln -s $LIBNAME ${INSTALLDIR}/${LINK1}.sl ! ${echo} ln -s $LIBNAME ${INSTALLDIR}/${LINK1} fi ;; diff -Nrc2 readline-4.1/support/shobj-conf readline-4.2/support/shobj-conf *** readline-4.1/support/shobj-conf Tue Sep 21 13:03:43 1999 --- readline-4.2/support/shobj-conf Tue Jan 2 11:15:44 2001 *************** *** 44,48 **** case "${host_os}-${SHOBJ_CC}" in ! sunos4*-gcc*) SHOBJ_CFLAGS=-fpic SHOBJ_LD=/usr/bin/ld --- 44,48 ---- case "${host_os}-${SHOBJ_CC}" in ! sunos4*-*gcc*) SHOBJ_CFLAGS=-fpic SHOBJ_LD=/usr/bin/ld *************** *** 60,64 **** ;; ! sunos5*-gcc*|solaris2*-gcc*) SHOBJ_CFLAGS=-fpic SHOBJ_LD='${CC}' --- 60,64 ---- ;; ! sunos5*-*gcc*|solaris2*-*gcc*) SHOBJ_CFLAGS=-fpic SHOBJ_LD='${CC}' *************** *** 98,102 **** # FreeBSD-3.x ELF ! freebsd3*) SHOBJ_CFLAGS=-fpic SHOBJ_LD='${CC}' --- 98,102 ---- # FreeBSD-3.x ELF ! freebsd[3-9]*|freebsdelf[3-9]*|freebsdaout[3-9]*) SHOBJ_CFLAGS=-fpic SHOBJ_LD='${CC}' *************** *** 114,124 **** fi ;; ! ! linux*) SHOBJ_CFLAGS=-fPIC SHOBJ_LD='${CC}' SHOBJ_LDFLAGS='-shared -Wl,-soname,$@' ! SHLIB_XLDFLAGS='-Wl,-rpath,$(libdir)' SHLIB_LIBVERSION='$(SHLIB_LIBSUFF).$(SHLIB_MAJOR)$(SHLIB_MINOR)' ;; --- 114,124 ---- fi ;; ! # All versions of Linux or the semi-mythical GNU Hurd. ! linux*|gnu*) SHOBJ_CFLAGS=-fPIC SHOBJ_LD='${CC}' SHOBJ_LDFLAGS='-shared -Wl,-soname,$@' ! SHLIB_XLDFLAGS='-Wl,-rpath,$(libdir) -Wl,-soname,`basename $@ $(SHLIB_MINOR)`' SHLIB_LIBVERSION='$(SHLIB_LIBSUFF).$(SHLIB_MAJOR)$(SHLIB_MINOR)' ;; *************** *** 159,166 **** SHOBJ_LDFLAGS='-shared -Wl,-soname,$@' SHLIB_LIBVERSION='$(SHLIB_LIBSUFF).$(SHLIB_MAJOR)$(SHLIB_MINOR)' ;; ! osf*-gcc*) # Fix to use gcc linker driver from bfischer@TechFak.Uni-Bielefeld.DE SHOBJ_LD='${CC}' --- 159,167 ---- SHOBJ_LDFLAGS='-shared -Wl,-soname,$@' + SHLIB_XLDFLAGS='-Wl,-soname,`basename $@ $(SHLIB_MINOR)`' SHLIB_LIBVERSION='$(SHLIB_LIBSUFF).$(SHLIB_MAJOR)$(SHLIB_MINOR)' ;; ! osf*-*gcc*) # Fix to use gcc linker driver from bfischer@TechFak.Uni-Bielefeld.DE SHOBJ_LD='${CC}' *************** *** 179,183 **** ;; ! aix4.[2-9]*-gcc*) # lightly tested by jik@cisco.com SHOBJ_CFLAGS=-fpic SHOBJ_LD='ld' --- 180,184 ---- ;; ! aix4.[2-9]*-*gcc*) # lightly tested by jik@cisco.com SHOBJ_CFLAGS=-fpic SHOBJ_LD='ld' *************** *** 204,208 **** # THE FOLLOWING ARE UNTESTED -- and some may not support the dlopen interface # ! irix[56]*-gcc*) SHOBJ_CFLAGS='-fpic' SHOBJ_LD='${CC}' --- 205,209 ---- # THE FOLLOWING ARE UNTESTED -- and some may not support the dlopen interface # ! irix[56]*-*gcc*) SHOBJ_CFLAGS='-fpic' SHOBJ_LD='${CC}' *************** *** 217,221 **** SHOBJ_LD=ld # SHOBJ_LDFLAGS='-call_shared -hidden_symbol -no_unresolved -soname $@' ! # Change from David Kaelbling SHOBJ_LDFLAGS='-shared -no_unresolved -soname $@' --- 218,223 ---- SHOBJ_LD=ld # SHOBJ_LDFLAGS='-call_shared -hidden_symbol -no_unresolved -soname $@' ! # Change from David Kaelbling . If you have problems, ! # remove the `-no_unresolved' SHOBJ_LDFLAGS='-shared -no_unresolved -soname $@' *************** *** 224,228 **** ;; ! hpux9*-gcc*) # must use gcc; the bundled cc cannot compile PIC code SHOBJ_CFLAGS='-fpic' --- 226,230 ---- ;; ! hpux9*-*gcc*) # must use gcc; the bundled cc cannot compile PIC code SHOBJ_CFLAGS='-fpic' *************** *** 240,244 **** ;; ! hpux10*-gcc*) # must use gcc; the bundled cc cannot compile PIC code SHOBJ_CFLAGS='-fpic' --- 242,246 ---- ;; ! hpux10*-*gcc*) # must use gcc; the bundled cc cannot compile PIC code SHOBJ_CFLAGS='-fpic' *************** *** 254,265 **** SHOBJ_STATUS=unsupported SHLIB_STATUS=unsupported ;; ! hpux11*-gcc*) # must use gcc; the bundled cc cannot compile PIC code SHOBJ_CFLAGS='-fpic' SHOBJ_LD='${CC}' # SHOBJ_LDFLAGS='-shared -Wl,-b -Wl,-B,symbolic -Wl,+s -Wl,+std -Wl,+h,$@' ! SHOBJ_LDFLAGS='-shared -Wl,-b -Wl,+s -Wl,+h,$@' SHLIB_XLDFLAGS='-Wl,+b,$(libdir)' --- 256,280 ---- SHOBJ_STATUS=unsupported SHLIB_STATUS=unsupported + + # If you are using the HP ANSI C compiler, you can uncomment and use + # this code + # SHOBJ_STATUS=unsupported + # SHLIB_STATUS=unsupported + # + # SHOBJ_CFLAGS='+z' + # SHOBJ_LD='ld' + # SHOBJ_LDFLAGS='-b' + # + # SHLIB_XLDFLAGS='' + # SHLIB_LIBSUFF='sl' + # SHLIB_LIBVERSION='$(SHLIB_LIBSUFF).$(SHLIB_MAJOR)' ;; ! hpux11*-*gcc*) # must use gcc; the bundled cc cannot compile PIC code SHOBJ_CFLAGS='-fpic' SHOBJ_LD='${CC}' # SHOBJ_LDFLAGS='-shared -Wl,-b -Wl,-B,symbolic -Wl,+s -Wl,+std -Wl,+h,$@' ! SHOBJ_LDFLAGS='-shared -fpic -Wl,-b -Wl,+s -Wl,+h,$@' SHLIB_XLDFLAGS='-Wl,+b,$(libdir)' *************** *** 271,277 **** SHOBJ_STATUS=unsupported SHLIB_STATUS=unsupported ;; ! sysv4*-gcc*) SHOBJ_CFLAGS=-shared SHOBJ_LDFLAGS='-shared -h $@' --- 286,306 ---- SHOBJ_STATUS=unsupported SHLIB_STATUS=unsupported + + # If you are using the HP ANSI C compiler, you can uncomment and use + # this code + # SHOBJ_STATUS=unsupported + # SHLIB_STATUS=unsupported + # + # SHOBJ_CFLAGS='+z' + # SHOBJ_LD='ld' + # SHOBJ_LDFLAGS='-b' + # + # SHLIB_XLDFLAGS='' + # SHLIB_LIBSUFF='sl' + # SHLIB_LIBVERSION='$(SHLIB_LIBSUFF).$(SHLIB_MAJOR)' + ;; ! sysv4*-*gcc*) SHOBJ_CFLAGS=-shared SHOBJ_LDFLAGS='-shared -h $@' *************** *** 289,293 **** ;; ! sco3.2v5*-gcc*) SHOBJ_CFLAGS='-fpic' # DEFAULTS TO ELF SHOBJ_LD='${CC}' --- 318,322 ---- ;; ! sco3.2v5*-*gcc*) SHOBJ_CFLAGS='-fpic' # DEFAULTS TO ELF SHOBJ_LD='${CC}' *************** *** 305,309 **** ;; ! sysv5uw7*-gcc*) SHOBJ_CFLAGS='-fpic' SHOBJ_LD='${CC}' --- 334,338 ---- ;; ! sysv5uw7*-*gcc*) SHOBJ_CFLAGS='-fpic' SHOBJ_LD='${CC}' *************** *** 321,325 **** ;; ! dgux*-gcc*) SHOBJ_CFLAGS=-fpic SHOBJ_LD='${CC}' --- 350,354 ---- ;; ! dgux*-*gcc*) SHOBJ_CFLAGS=-fpic SHOBJ_LD='${CC}' *************** *** 345,349 **** # Rely on correct gcc configuration for everything else # ! *-gcc*) SHOBJ_CFLAGS=-fpic SHOBJ_LD='${CC}' --- 374,378 ---- # Rely on correct gcc configuration for everything else # ! *-*gcc*) SHOBJ_CFLAGS=-fpic SHOBJ_LD='${CC}' diff -Nrc2 readline-4.1/terminal.c readline-4.2/terminal.c *** readline-4.1/terminal.c Mon Jan 24 10:44:28 2000 --- readline-4.2/terminal.c Tue Feb 6 15:39:22 2001 *************** *** 77,83 **** static int tcap_initialized; - /* Non-zero means this terminal can't really do anything. */ - static int dumb_term; - #if !defined (__linux__) # if defined (__EMX__) || defined (NEED_EXTERN_PC) --- 77,80 ---- *************** *** 88,112 **** /* Some strings to control terminal actions. These are output by tputs (). */ ! char *term_goto, *term_clreol, *term_cr, *term_clrpag, *term_backspace; ! char *term_pc; /* Non-zero if we determine that the terminal can do character insertion. */ ! int terminal_can_insert = 0; /* How to insert characters. */ ! char *term_im, *term_ei, *term_ic, *term_ip, *term_IC; /* How to delete characters. */ ! char *term_dc, *term_DC; #if defined (HACK_TERMCAP_MOTION) ! char *term_forward_char; #endif /* HACK_TERMCAP_MOTION */ /* How to go up a line. */ ! char *term_up; ! /* A visible bell, if the terminal can be made to flash the screen. */ ! static char *visible_bell; /* Non-zero means the terminal can auto-wrap lines. */ --- 85,118 ---- /* Some strings to control terminal actions. These are output by tputs (). */ ! char *_rl_term_clreol; ! char *_rl_term_clrpag; ! char *_rl_term_cr; ! char *_rl_term_backspace; ! char *_rl_term_goto; ! char *_rl_term_pc; /* Non-zero if we determine that the terminal can do character insertion. */ ! int _rl_terminal_can_insert = 0; /* How to insert characters. */ ! char *_rl_term_im; ! char *_rl_term_ei; ! char *_rl_term_ic; ! char *_rl_term_ip; ! char *_rl_term_IC; /* How to delete characters. */ ! char *_rl_term_dc; ! char *_rl_term_DC; #if defined (HACK_TERMCAP_MOTION) ! char *_rl_term_forward_char; #endif /* HACK_TERMCAP_MOTION */ /* How to go up a line. */ ! char *_rl_term_up; ! /* A visible bell; char if the terminal can be made to flash the screen. */ ! static char *_rl_visible_bell; /* Non-zero means the terminal can auto-wrap lines. */ *************** *** 117,134 **** /* The sequences to write to turn on and off the meta key, if this ! terminal has one. */ ! static char *term_mm, *term_mo; /* The key sequences output by the arrow keys, if this terminal has any. */ ! static char *term_ku, *term_kd, *term_kr, *term_kl; /* How to initialize and reset the arrow keys, if this terminal has any. */ ! static char *term_ks, *term_ke; /* The key sequences sent by the Home and End keys, if any. */ ! static char *term_kh, *term_kH; /* Variables that hold the screen dimensions, used by the display code. */ ! int screenwidth, screenheight, screenchars; /* Non-zero means the user wants to enable the keypad. */ --- 123,146 ---- /* The sequences to write to turn on and off the meta key, if this ! terminal has one. */ ! static char *_rl_term_mm; ! static char *_rl_term_mo; /* The key sequences output by the arrow keys, if this terminal has any. */ ! static char *_rl_term_ku; ! static char *_rl_term_kd; ! static char *_rl_term_kr; ! static char *_rl_term_kl; /* How to initialize and reset the arrow keys, if this terminal has any. */ ! static char *_rl_term_ks; ! static char *_rl_term_ke; /* The key sequences sent by the Home and End keys, if any. */ ! static char *_rl_term_kh; ! static char *_rl_term_kH; /* Variables that hold the screen dimensions, used by the display code. */ ! int _rl_screenwidth, _rl_screenheight, _rl_screenchars; /* Non-zero means the user wants to enable the keypad. */ *************** *** 170,192 **** if (ioctl (tty, TIOCGWINSZ, &window_size) == 0) { ! screenwidth = (int) window_size.ws_col; ! screenheight = (int) window_size.ws_row; } #endif /* TIOCGWINSZ */ #if defined (__EMX__) ! _emx_get_screensize (&screenwidth, &screenheight); #endif /* Environment variable COLUMNS overrides setting of "co" if IGNORE_ENV is unset. */ ! if (screenwidth <= 0) { ! if (ignore_env == 0 && (ss = get_env_value ("COLUMNS"))) ! screenwidth = atoi (ss); #if !defined (__DJGPP__) ! if (screenwidth <= 0 && term_string_buffer) ! screenwidth = tgetnum ("co"); #endif } --- 182,204 ---- if (ioctl (tty, TIOCGWINSZ, &window_size) == 0) { ! _rl_screenwidth = (int) window_size.ws_col; ! _rl_screenheight = (int) window_size.ws_row; } #endif /* TIOCGWINSZ */ #if defined (__EMX__) ! _emx_get_screensize (&_rl_screenwidth, &_rl_screenheight); #endif /* Environment variable COLUMNS overrides setting of "co" if IGNORE_ENV is unset. */ ! if (_rl_screenwidth <= 0) { ! if (ignore_env == 0 && (ss = sh_get_env_value ("COLUMNS"))) ! _rl_screenwidth = atoi (ss); #if !defined (__DJGPP__) ! if (_rl_screenwidth <= 0 && term_string_buffer) ! _rl_screenwidth = tgetnum ("co"); #endif } *************** *** 194,224 **** /* Environment variable LINES overrides setting of "li" if IGNORE_ENV is unset. */ ! if (screenheight <= 0) { ! if (ignore_env == 0 && (ss = get_env_value ("LINES"))) ! screenheight = atoi (ss); #if !defined (__DJGPP__) ! if (screenheight <= 0 && term_string_buffer) ! screenheight = tgetnum ("li"); #endif } /* If all else fails, default to 80x24 terminal. */ ! if (screenwidth <= 1) ! screenwidth = 80; ! if (screenheight <= 0) ! screenheight = 24; /* If we're being compiled as part of bash, set the environment variables $LINES and $COLUMNS to new values. Otherwise, just do a pair of putenv () or setenv () calls. */ ! set_lines_and_columns (screenheight, screenwidth); if (_rl_term_autowrap == 0) ! screenwidth--; ! screenchars = screenwidth * screenheight; } --- 206,236 ---- /* Environment variable LINES overrides setting of "li" if IGNORE_ENV is unset. */ ! if (_rl_screenheight <= 0) { ! if (ignore_env == 0 && (ss = sh_get_env_value ("LINES"))) ! _rl_screenheight = atoi (ss); #if !defined (__DJGPP__) ! if (_rl_screenheight <= 0 && term_string_buffer) ! _rl_screenheight = tgetnum ("li"); #endif } /* If all else fails, default to 80x24 terminal. */ ! if (_rl_screenwidth <= 1) ! _rl_screenwidth = 80; ! if (_rl_screenheight <= 0) ! _rl_screenheight = 24; /* If we're being compiled as part of bash, set the environment variables $LINES and $COLUMNS to new values. Otherwise, just do a pair of putenv () or setenv () calls. */ ! sh_set_lines_and_columns (_rl_screenheight, _rl_screenwidth); if (_rl_term_autowrap == 0) ! _rl_screenwidth--; ! _rl_screenchars = _rl_screenwidth * _rl_screenheight; } *************** *** 227,240 **** int rows, cols; { ! screenheight = rows; ! screenwidth = cols; if (_rl_term_autowrap == 0) ! screenwidth--; ! screenchars = screenwidth * screenheight; } void rl_resize_terminal () { --- 239,272 ---- int rows, cols; { ! if (rows == 0 || cols == 0) ! return; ! ! _rl_screenheight = rows; ! _rl_screenwidth = cols; if (_rl_term_autowrap == 0) ! _rl_screenwidth--; ! _rl_screenchars = _rl_screenwidth * _rl_screenheight; ! } ! ! void ! rl_set_screen_size (rows, cols) ! int rows, cols; ! { ! _rl_set_screen_size (rows, cols); } void + rl_get_screen_size (rows, cols) + int *rows, *cols; + { + if (rows) + *rows = _rl_screenheight; + if (cols) + *cols = _rl_screenwidth; + } + + void rl_resize_terminal () { *************** *** 247,251 **** struct _tc_string { ! char *tc_var; char **tc_value; }; --- 279,283 ---- struct _tc_string { ! const char *tc_var; char **tc_value; }; *************** *** 255,284 **** static struct _tc_string tc_strings[] = { ! { "DC", &term_DC }, ! { "IC", &term_IC }, ! { "ce", &term_clreol }, ! { "cl", &term_clrpag }, ! { "cr", &term_cr }, ! { "dc", &term_dc }, ! { "ei", &term_ei }, ! { "ic", &term_ic }, ! { "im", &term_im }, ! { "kd", &term_kd }, ! { "kh", &term_kh }, /* home */ ! { "kH", &term_kH }, /* end */ ! { "kl", &term_kl }, ! { "kr", &term_kr }, ! { "ku", &term_ku }, ! { "ks", &term_ks }, ! { "ke", &term_ke }, ! { "le", &term_backspace }, ! { "mm", &term_mm }, ! { "mo", &term_mo }, #if defined (HACK_TERMCAP_MOTION) ! { "nd", &term_forward_char }, #endif ! { "pc", &term_pc }, ! { "up", &term_up }, ! { "vb", &visible_bell }, }; --- 287,316 ---- static struct _tc_string tc_strings[] = { ! { "DC", &_rl_term_DC }, ! { "IC", &_rl_term_IC }, ! { "ce", &_rl_term_clreol }, ! { "cl", &_rl_term_clrpag }, ! { "cr", &_rl_term_cr }, ! { "dc", &_rl_term_dc }, ! { "ei", &_rl_term_ei }, ! { "ic", &_rl_term_ic }, ! { "im", &_rl_term_im }, ! { "kd", &_rl_term_kd }, ! { "kh", &_rl_term_kh }, /* home */ ! { "kH", &_rl_term_kH }, /* end */ ! { "kl", &_rl_term_kl }, ! { "kr", &_rl_term_kr }, ! { "ku", &_rl_term_ku }, ! { "ks", &_rl_term_ks }, ! { "ke", &_rl_term_ke }, ! { "le", &_rl_term_backspace }, ! { "mm", &_rl_term_mm }, ! { "mo", &_rl_term_mo }, #if defined (HACK_TERMCAP_MOTION) ! { "nd", &_rl_term_forward_char }, #endif ! { "pc", &_rl_term_pc }, ! { "up", &_rl_term_up }, ! { "vb", &_rl_visible_bell }, }; *************** *** 305,318 **** int _rl_init_terminal_io (terminal_name) ! char *terminal_name; { ! char *term, *buffer; int tty, tgetent_ret; Keymap xkeymap; ! term = terminal_name ? terminal_name : get_env_value ("TERM"); ! term_clrpag = term_cr = term_clreol = (char *)NULL; tty = rl_instream ? fileno (rl_instream) : 0; ! screenwidth = screenheight = 0; if (term == 0) --- 337,351 ---- int _rl_init_terminal_io (terminal_name) ! const char *terminal_name; { ! const char *term; ! char *buffer; int tty, tgetent_ret; Keymap xkeymap; ! term = terminal_name ? terminal_name : sh_get_env_value ("TERM"); ! _rl_term_clrpag = _rl_term_cr = _rl_term_clreol = (char *)NULL; tty = rl_instream ? fileno (rl_instream) : 0; ! _rl_screenwidth = _rl_screenheight = 0; if (term == 0) *************** *** 345,354 **** buffer = term_buffer = term_string_buffer = (char *)NULL; - dumb_term = 1; _rl_term_autowrap = 0; /* used by _rl_get_screen_size */ #if defined (__EMX__) ! _emx_get_screensize (&screenwidth, &screenheight); ! screenwidth--; #else /* !__EMX__ */ _rl_get_screen_size (tty, 0); --- 378,386 ---- buffer = term_buffer = term_string_buffer = (char *)NULL; _rl_term_autowrap = 0; /* used by _rl_get_screen_size */ #if defined (__EMX__) ! _emx_get_screensize (&_rl_screenwidth, &_rl_screenheight); ! _rl_screenwidth--; #else /* !__EMX__ */ _rl_get_screen_size (tty, 0); *************** *** 356,383 **** /* Defaults. */ ! if (screenwidth <= 0 || screenheight <= 0) { ! screenwidth = 79; ! screenheight = 24; } /* Everything below here is used by the redisplay code (tputs). */ ! screenchars = screenwidth * screenheight; ! term_cr = "\r"; ! term_im = term_ei = term_ic = term_IC = (char *)NULL; ! term_up = term_dc = term_DC = visible_bell = (char *)NULL; ! term_ku = term_kd = term_kl = term_kr = (char *)NULL; ! term_mm = term_mo = (char *)NULL; #if defined (HACK_TERMCAP_MOTION) term_forward_char = (char *)NULL; #endif ! terminal_can_insert = term_has_meta = 0; /* Reasonable defaults for tgoto(). Readline currently only uses ! tgoto if term_IC or term_DC is defined, but just in case we change that later... */ PC = '\0'; ! BC = term_backspace = "\b"; ! UP = term_up; return 0; --- 388,415 ---- /* Defaults. */ ! if (_rl_screenwidth <= 0 || _rl_screenheight <= 0) { ! _rl_screenwidth = 79; ! _rl_screenheight = 24; } /* Everything below here is used by the redisplay code (tputs). */ ! _rl_screenchars = _rl_screenwidth * _rl_screenheight; ! _rl_term_cr = "\r"; ! _rl_term_im = _rl_term_ei = _rl_term_ic = _rl_term_IC = (char *)NULL; ! _rl_term_up = _rl_term_dc = _rl_term_DC = _rl_visible_bell = (char *)NULL; ! _rl_term_ku = _rl_term_kd = _rl_term_kl = _rl_term_kr = (char *)NULL; ! _rl_term_mm = _rl_term_mo = (char *)NULL; #if defined (HACK_TERMCAP_MOTION) term_forward_char = (char *)NULL; #endif ! _rl_terminal_can_insert = term_has_meta = 0; /* Reasonable defaults for tgoto(). Readline currently only uses ! tgoto if _rl_term_IC or _rl_term_DC is defined, but just in case we change that later... */ PC = '\0'; ! BC = _rl_term_backspace = "\b"; ! UP = _rl_term_up; return 0; *************** *** 388,397 **** /* Set up the variables that the termcap library expects the application to provide. */ ! PC = term_pc ? *term_pc : 0; ! BC = term_backspace; ! UP = term_up; ! if (!term_cr) ! term_cr = "\r"; _rl_term_autowrap = tgetflag ("am") && tgetflag ("xn"); --- 420,429 ---- /* Set up the variables that the termcap library expects the application to provide. */ ! PC = _rl_term_pc ? *_rl_term_pc : 0; ! BC = _rl_term_backspace; ! UP = _rl_term_up; ! if (!_rl_term_cr) ! _rl_term_cr = "\r"; _rl_term_autowrap = tgetflag ("am") && tgetflag ("xn"); *************** *** 403,407 **** `im', `ic' or `ip' is provided." But we can't do anything if only `ip' is provided, so... */ ! terminal_can_insert = (term_IC || term_im || term_ic); /* Check to see if this terminal has a meta key and clear the capability --- 435,439 ---- `im', `ic' or `ip' is provided." But we can't do anything if only `ip' is provided, so... */ ! _rl_terminal_can_insert = (_rl_term_IC || _rl_term_im || _rl_term_ic); /* Check to see if this terminal has a meta key and clear the capability *************** *** 409,413 **** term_has_meta = (tgetflag ("km") || tgetflag ("MT")); if (!term_has_meta) ! term_mm = term_mo = (char *)NULL; /* Attempt to find and bind the arrow keys. Do not override already --- 441,445 ---- term_has_meta = (tgetflag ("km") || tgetflag ("MT")); if (!term_has_meta) ! _rl_term_mm = _rl_term_mo = (char *)NULL; /* Attempt to find and bind the arrow keys. Do not override already *************** *** 416,436 **** _rl_keymap = emacs_standard_keymap; ! _rl_bind_if_unbound (term_ku, rl_get_previous_history); ! _rl_bind_if_unbound (term_kd, rl_get_next_history); ! _rl_bind_if_unbound (term_kr, rl_forward); ! _rl_bind_if_unbound (term_kl, rl_backward); ! _rl_bind_if_unbound (term_kh, rl_beg_of_line); /* Home */ ! _rl_bind_if_unbound (term_kH, rl_end_of_line); /* End */ #if defined (VI_MODE) _rl_keymap = vi_movement_keymap; ! _rl_bind_if_unbound (term_ku, rl_get_previous_history); ! _rl_bind_if_unbound (term_kd, rl_get_next_history); ! _rl_bind_if_unbound (term_kr, rl_forward); ! _rl_bind_if_unbound (term_kl, rl_backward); ! _rl_bind_if_unbound (term_kh, rl_beg_of_line); /* Home */ ! _rl_bind_if_unbound (term_kH, rl_end_of_line); /* End */ #endif /* VI_MODE */ --- 448,468 ---- _rl_keymap = emacs_standard_keymap; ! _rl_bind_if_unbound (_rl_term_ku, rl_get_previous_history); ! _rl_bind_if_unbound (_rl_term_kd, rl_get_next_history); ! _rl_bind_if_unbound (_rl_term_kr, rl_forward); ! _rl_bind_if_unbound (_rl_term_kl, rl_backward); ! _rl_bind_if_unbound (_rl_term_kh, rl_beg_of_line); /* Home */ ! _rl_bind_if_unbound (_rl_term_kH, rl_end_of_line); /* End */ #if defined (VI_MODE) _rl_keymap = vi_movement_keymap; ! _rl_bind_if_unbound (_rl_term_ku, rl_get_previous_history); ! _rl_bind_if_unbound (_rl_term_kd, rl_get_next_history); ! _rl_bind_if_unbound (_rl_term_kr, rl_forward); ! _rl_bind_if_unbound (_rl_term_kl, rl_backward); ! _rl_bind_if_unbound (_rl_term_kh, rl_beg_of_line); /* Home */ ! _rl_bind_if_unbound (_rl_term_kH, rl_end_of_line); /* End */ #endif /* VI_MODE */ *************** *** 442,446 **** char * rl_get_termcap (cap) ! char *cap; { register int i; --- 474,478 ---- char * rl_get_termcap (cap) ! const char *cap; { register int i; *************** *** 460,464 **** int rl_reset_terminal (terminal_name) ! char *terminal_name; { _rl_init_terminal_io (terminal_name); --- 492,496 ---- int rl_reset_terminal (terminal_name) ! const char *terminal_name; { _rl_init_terminal_io (terminal_name); *************** *** 486,490 **** void _rl_output_some_chars (string, count) ! char *string; int count; { --- 518,522 ---- void _rl_output_some_chars (string, count) ! const char *string; int count; { *************** *** 499,505 **** register int i; ! if (term_backspace) for (i = 0; i < count; i++) ! tputs (term_backspace, 1, _rl_output_character_function); else for (i = 0; i < count; i++) --- 531,537 ---- register int i; ! if (_rl_term_backspace) for (i = 0; i < count; i++) ! tputs (_rl_term_backspace, 1, _rl_output_character_function); else for (i = 0; i < count; i++) *************** *** 510,518 **** /* Move to the start of the next line. */ int ! crlf () { #if defined (NEW_TTY_DRIVER) ! if (term_cr) ! tputs (term_cr, 1, _rl_output_character_function); #endif /* NEW_TTY_DRIVER */ putc ('\n', _rl_out_stream); --- 542,550 ---- /* Move to the start of the next line. */ int ! rl_crlf () { #if defined (NEW_TTY_DRIVER) ! if (_rl_term_cr) ! tputs (_rl_term_cr, 1, _rl_output_character_function); #endif /* NEW_TTY_DRIVER */ putc ('\n', _rl_out_stream); *************** *** 522,526 **** /* Ring the terminal bell. */ int ! ding () { if (readline_echoing_p) --- 554,558 ---- /* Ring the terminal bell. */ int ! rl_ding () { if (readline_echoing_p) *************** *** 532,538 **** break; case VISIBLE_BELL: ! if (visible_bell) { ! tputs (visible_bell, 1, _rl_output_character_function); break; } --- 564,570 ---- break; case VISIBLE_BELL: ! if (_rl_visible_bell) { ! tputs (_rl_visible_bell, 1, _rl_output_character_function); break; } *************** *** 558,563 **** { #if !defined (__DJGPP__) ! if (term_has_meta && term_mm) ! tputs (term_mm, 1, _rl_output_character_function); #endif } --- 590,595 ---- { #if !defined (__DJGPP__) ! if (term_has_meta && _rl_term_mm) ! tputs (_rl_term_mm, 1, _rl_output_character_function); #endif } *************** *** 568,575 **** { #if !defined (__DJGPP__) ! if (on && term_ks) ! tputs (term_ks, 1, _rl_output_character_function); ! else if (!on && term_ke) ! tputs (term_ke, 1, _rl_output_character_function); #endif } --- 600,607 ---- { #if !defined (__DJGPP__) ! if (on && _rl_term_ks) ! tputs (_rl_term_ks, 1, _rl_output_character_function); ! else if (!on && _rl_term_ke) ! tputs (_rl_term_ke, 1, _rl_output_character_function); #endif } diff -Nrc2 readline-4.1/tilde.c readline-4.2/tilde.c *** readline-4.1/tilde.c Thu Dec 16 16:10:44 1999 --- readline-4.2/tilde.c Wed Feb 14 17:04:21 2001 *************** *** 51,64 **** static char *xmalloc (), *xrealloc (); #else ! # if defined __STDC__ ! extern char *xmalloc (int); ! extern char *xrealloc (void *, int); ! # else ! extern char *xmalloc (), *xrealloc (); ! # endif /* !__STDC__ */ #endif /* TEST || STATIC_MALLOC */ #if !defined (HAVE_GETPW_DECLS) ! extern struct passwd *getpwuid (), *getpwnam (); #endif /* !HAVE_GETPW_DECLS */ --- 51,61 ---- static char *xmalloc (), *xrealloc (); #else ! extern char *xmalloc __P((int)); ! extern char *xrealloc __P((void *, int)); #endif /* TEST || STATIC_MALLOC */ #if !defined (HAVE_GETPW_DECLS) ! extern struct passwd *getpwuid __P((uid_t)); ! extern struct passwd *getpwnam __P((const char *)); #endif /* !HAVE_GETPW_DECLS */ *************** *** 81,98 **** variables.o. If being compiled as part of readline, they will be satisfied from shell.o. */ ! extern char *get_home_dir __P((void)); ! extern char *get_env_value __P((char *)); /* The default value of tilde_additional_prefixes. This is set to whitespace preceding a tilde so that simple programs which do not perform any word separation get desired behaviour. */ ! static char *default_prefixes[] = ! { " ~", "\t~", (char *)NULL }; /* The default value of tilde_additional_suffixes. This is set to whitespace or newline so that simple programs which do not perform any word separation get desired behaviour. */ ! static char *default_suffixes[] = ! { " ", "\n", (char *)NULL }; /* If non-null, this contains the address of a function that the application --- 78,95 ---- variables.o. If being compiled as part of readline, they will be satisfied from shell.o. */ ! extern char *sh_get_home_dir __P((void)); ! extern char *sh_get_env_value __P((const char *)); /* The default value of tilde_additional_prefixes. This is set to whitespace preceding a tilde so that simple programs which do not perform any word separation get desired behaviour. */ ! static const char *default_prefixes[] = ! { " ~", "\t~", (const char *)NULL }; /* The default value of tilde_additional_suffixes. This is set to whitespace or newline so that simple programs which do not perform any word separation get desired behaviour. */ ! static const char *default_suffixes[] = ! { " ", "\n", (const char *)NULL }; /* If non-null, this contains the address of a function that the application *************** *** 100,104 **** is called with the text sans tilde, and returns a malloc()'ed string which is the expansion, or a NULL pointer if the expansion fails. */ ! CPFunction *tilde_expansion_preexpansion_hook = (CPFunction *)NULL; /* If non-null, this contains the address of a function to call if the --- 97,101 ---- is called with the text sans tilde, and returns a malloc()'ed string which is the expansion, or a NULL pointer if the expansion fails. */ ! tilde_hook_func_t *tilde_expansion_preexpansion_hook = (tilde_hook_func_t *)NULL; /* If non-null, this contains the address of a function to call if the *************** *** 106,120 **** with the text (sans tilde, as in "foo"), and returns a malloc()'ed string which is the expansion, or a NULL pointer if there is no expansion. */ ! CPFunction *tilde_expansion_failure_hook = (CPFunction *)NULL; /* When non-null, this is a NULL terminated array of strings which are duplicates for a tilde prefix. Bash uses this to expand `=~' and `:~'. */ ! char **tilde_additional_prefixes = default_prefixes; /* When non-null, this is a NULL terminated array of strings which match the end of a username, instead of just "/". Bash sets this to `:' and `=~'. */ ! char **tilde_additional_suffixes = default_suffixes; /* Find the start of a tilde expansion in STRING, and return the index of --- 103,117 ---- with the text (sans tilde, as in "foo"), and returns a malloc()'ed string which is the expansion, or a NULL pointer if there is no expansion. */ ! tilde_hook_func_t *tilde_expansion_failure_hook = (tilde_hook_func_t *)NULL; /* When non-null, this is a NULL terminated array of strings which are duplicates for a tilde prefix. Bash uses this to expand `=~' and `:~'. */ ! char **tilde_additional_prefixes = (char **)default_prefixes; /* When non-null, this is a NULL terminated array of strings which match the end of a username, instead of just "/". Bash sets this to `:' and `=~'. */ ! char **tilde_additional_suffixes = (char **)default_suffixes; /* Find the start of a tilde expansion in STRING, and return the index of *************** *** 187,191 **** char * tilde_expand (string) ! char *string; { char *result; --- 184,188 ---- char * tilde_expand (string) ! const char *string; { char *result; *************** *** 236,242 **** len = strlen (expansion); ! #ifdef __CYGWIN32__ /* Fix for Cygwin to prevent ~user/xxx from expanding to //xxx when ! $HOME for `user' is /. On cygwin, // denotes a network drive. */ if (len > 1 || *expansion != '/' || *string != '/') #endif --- 233,239 ---- len = strlen (expansion); ! #ifdef __CYGWIN__ /* Fix for Cygwin to prevent ~user/xxx from expanding to //xxx when ! $HOME for `user' is /. On cygwin, // denotes a network drive. */ if (len > 1 || *expansion != '/' || *string != '/') #endif *************** *** 304,308 **** char * tilde_expand_word (filename) ! char *filename; { char *dirname, *expansion, *username; --- 301,305 ---- char * tilde_expand_word (filename) ! const char *filename; { char *dirname, *expansion, *username; *************** *** 322,331 **** { /* Prefix $HOME to the rest of the string. */ ! expansion = get_env_value ("HOME"); /* If there is no HOME variable, look up the directory in the password database. */ if (expansion == 0) ! expansion = get_home_dir (); return (glue_prefix_and_suffix (expansion, filename, 1)); --- 319,328 ---- { /* Prefix $HOME to the rest of the string. */ ! expansion = sh_get_env_value ("HOME"); /* If there is no HOME variable, look up the directory in the password database. */ if (expansion == 0) ! expansion = sh_get_home_dir (); return (glue_prefix_and_suffix (expansion, filename, 1)); diff -Nrc2 readline-4.1/tilde.h readline-4.2/tilde.h *** readline-4.1/tilde.h Thu Dec 2 15:47:02 1999 --- readline-4.2/tilde.h Mon Oct 30 14:31:04 2000 *************** *** 41,52 **** #endif ! /* Function pointers can be declared as (Function *)foo. */ ! #if !defined (_FUNCTION_DEF) ! # define _FUNCTION_DEF ! typedef int Function (); ! typedef void VFunction (); ! typedef char *CPFunction (); ! typedef char **CPPFunction (); ! #endif /* _FUNCTION_DEF */ /* If non-null, this contains the address of a function that the application --- 41,57 ---- #endif ! #if !defined (__STDC__) && !defined (__cplusplus) ! # if defined (__GNUC__) /* gcc with -traditional */ ! # if !defined (const) ! # define const __const ! # endif /* !const */ ! # else /* !__GNUC__ */ ! # if !defined (const) ! # define const ! # endif /* !const */ ! # endif /* !__GNUC__ */ ! #endif /* !__STDC__ && !__cplusplus */ ! ! typedef char *tilde_hook_func_t __P((char *)); /* If non-null, this contains the address of a function that the application *************** *** 54,58 **** is called with the text sans tilde, and returns a malloc()'ed string which is the expansion, or a NULL pointer if the expansion fails. */ ! extern CPFunction *tilde_expansion_preexpansion_hook; /* If non-null, this contains the address of a function to call if the --- 59,63 ---- is called with the text sans tilde, and returns a malloc()'ed string which is the expansion, or a NULL pointer if the expansion fails. */ ! extern tilde_hook_func_t *tilde_expansion_preexpansion_hook; /* If non-null, this contains the address of a function to call if the *************** *** 60,64 **** with the text (sans tilde, as in "foo"), and returns a malloc()'ed string which is the expansion, or a NULL pointer if there is no expansion. */ ! extern CPFunction *tilde_expansion_failure_hook; /* When non-null, this is a NULL terminated array of strings which --- 65,69 ---- with the text (sans tilde, as in "foo"), and returns a malloc()'ed string which is the expansion, or a NULL pointer if there is no expansion. */ ! extern tilde_hook_func_t *tilde_expansion_failure_hook; /* When non-null, this is a NULL terminated array of strings which *************** *** 73,81 **** /* Return a new string which is the result of tilde expanding STRING. */ ! extern char *tilde_expand __P((char *)); /* Do the work of tilde expansion on FILENAME. FILENAME starts with a tilde. If there is no expansion, call tilde_expansion_failure_hook. */ ! extern char *tilde_expand_word __P((char *)); #ifdef __cplusplus --- 78,86 ---- /* Return a new string which is the result of tilde expanding STRING. */ ! extern char *tilde_expand __P((const char *)); /* Do the work of tilde expansion on FILENAME. FILENAME starts with a tilde. If there is no expansion, call tilde_expansion_failure_hook. */ ! extern char *tilde_expand_word __P((const char *)); #ifdef __cplusplus diff -Nrc2 readline-4.1/undo.c readline-4.2/undo.c *** readline-4.1/undo.c Thu Aug 5 08:15:52 1999 --- readline-4.2/undo.c Tue Feb 6 14:14:45 2001 *************** *** 87,91 **** /* Free the existing undo list. */ void ! free_undo_list () { while (rl_undo_list) --- 87,91 ---- /* Free the existing undo list. */ void ! rl_free_undo_list () { while (rl_undo_list) *************** *** 108,116 **** { UNDO_LIST *release; ! int waiting_for_begin = 0; ! int start, end; #define TRANS(i) ((i) == -1 ? rl_point : ((i) == -2 ? rl_end : (i))) do { --- 108,116 ---- { UNDO_LIST *release; ! int waiting_for_begin, start, end; #define TRANS(i) ((i) == -1 ? rl_point : ((i) == -2 ? rl_end : (i))) + start = end = waiting_for_begin = 0; do { *************** *** 119,122 **** --- 119,123 ---- _rl_doing_an_undo = 1; + RL_SETSTATE(RL_STATE_UNDOING); /* To better support vi-mode, a start or end value of -1 means *************** *** 153,161 **** waiting_for_begin--; else ! ding (); break; } _rl_doing_an_undo = 0; release = rl_undo_list; --- 154,163 ---- waiting_for_begin--; else ! rl_ding (); break; } _rl_doing_an_undo = 0; + RL_UNSETSTATE(RL_STATE_UNDOING); release = rl_undo_list; *************** *** 232,236 **** { if (!rl_undo_list) ! ding (); else { --- 234,238 ---- { if (!rl_undo_list) ! rl_ding (); else { *************** *** 255,259 **** else { ! ding (); break; } --- 257,261 ---- else { ! rl_ding (); break; } diff -Nrc2 readline-4.1/util.c readline-4.2/util.c *** readline-4.1/util.c Thu Aug 5 08:16:05 1999 --- readline-4.2/util.c Wed Feb 14 07:43:19 2001 *************** *** 68,75 **** int _rl_allow_pathname_alphabetic_chars = 0; ! static char *pathname_alphabetic_chars = "/-_=~.#$"; int ! alphabetic (c) int c; { --- 68,75 ---- int _rl_allow_pathname_alphabetic_chars = 0; ! static const char *pathname_alphabetic_chars = "/-_=~.#$"; int ! rl_alphabetic (c) int c; { *************** *** 85,98 **** _rl_abort_internal () { ! ding (); rl_clear_message (); _rl_init_argument (); ! rl_pending_input = 0; _rl_defining_kbd_macro = 0; ! while (_rl_executing_macro) _rl_pop_executing_macro (); ! rl_last_func = (Function *)NULL; longjmp (readline_top_level, 1); return (0); --- 85,98 ---- _rl_abort_internal () { ! rl_ding (); rl_clear_message (); _rl_init_argument (); ! rl_clear_pending_input (); _rl_defining_kbd_macro = 0; ! while (rl_executing_macro) _rl_pop_executing_macro (); ! rl_last_func = (rl_command_func_t *)NULL; longjmp (readline_top_level, 1); return (0); *************** *** 114,118 **** rl_refresh_line (count, key); #else ! ding (); #endif return 0; --- 114,118 ---- rl_refresh_line (count, key); #else ! rl_ding (); #endif return 0; *************** *** 216,220 **** char * _rl_strindex (s1, s2) ! register char *s1, *s2; { register int i, l, len; --- 216,220 ---- char * _rl_strindex (s1, s2) ! register const char *s1, *s2; { register int i, l, len; *************** *** 222,226 **** for (i = 0, l = strlen (s2), len = strlen (s1); (len - i) >= l; i++) if (_rl_strnicmp (s1 + i, s2, l) == 0) ! return (s1 + i); return ((char *)NULL); } --- 222,245 ---- for (i = 0, l = strlen (s2), len = strlen (s1); (len - i) >= l; i++) if (_rl_strnicmp (s1 + i, s2, l) == 0) ! return ((char *) (s1 + i)); ! return ((char *)NULL); ! } ! ! /* Find the first occurrence in STRING1 of any character from STRING2. ! Return a pointer to the character in STRING1. */ ! char * ! _rl_strpbrk (string1, string2) ! const char *string1, *string2; ! { ! register const char *scan; ! ! for (; *string1; string1++) ! { ! for (scan = string2; *scan; scan++) ! { ! if (*string1 == *scan) ! return ((char *)string1); ! } ! } return ((char *)NULL); } *************** *** 346,351 **** char * _rl_savestring (s) ! char *s; { ! return ((char *)strcpy (xmalloc (1 + (int)strlen (s)), (s))); } --- 365,370 ---- char * _rl_savestring (s) ! const char *s; { ! return (strcpy (xmalloc (1 + (int)strlen (s)), (s))); } diff -Nrc2 readline-4.1/vi_keymap.c readline-4.2/vi_keymap.c *** readline-4.1/vi_keymap.c Thu Aug 5 08:16:20 1999 --- readline-4.2/vi_keymap.c Mon Oct 30 11:55:52 2000 *************** *** 34,311 **** KEYMAP_ENTRY_ARRAY vi_movement_keymap = { /* The regular control keys come first. */ ! { ISFUNC, (Function *)0x0 }, /* Control-@ */ ! { ISFUNC, (Function *)0x0 }, /* Control-a */ ! { ISFUNC, (Function *)0x0 }, /* Control-b */ ! { ISFUNC, (Function *)0x0 }, /* Control-c */ ! { ISFUNC, rl_vi_eof_maybe }, /* Control-d */ ! { ISFUNC, rl_emacs_editing_mode }, /* Control-e */ ! { ISFUNC, (Function *)0x0 }, /* Control-f */ ! { ISFUNC, rl_abort }, /* Control-g */ ! { ISFUNC, rl_backward }, /* Control-h */ ! { ISFUNC, (Function *)0x0 }, /* Control-i */ ! { ISFUNC, rl_newline }, /* Control-j */ ! { ISFUNC, rl_kill_line }, /* Control-k */ ! { ISFUNC, rl_clear_screen }, /* Control-l */ ! { ISFUNC, rl_newline }, /* Control-m */ ! { ISFUNC, rl_get_next_history }, /* Control-n */ ! { ISFUNC, (Function *)0x0 }, /* Control-o */ ! { ISFUNC, rl_get_previous_history }, /* Control-p */ ! { ISFUNC, rl_quoted_insert }, /* Control-q */ ! { ISFUNC, rl_reverse_search_history }, /* Control-r */ ! { ISFUNC, rl_forward_search_history }, /* Control-s */ ! { ISFUNC, rl_transpose_chars }, /* Control-t */ ! { ISFUNC, rl_unix_line_discard }, /* Control-u */ ! { ISFUNC, rl_quoted_insert }, /* Control-v */ ! { ISFUNC, rl_unix_word_rubout }, /* Control-w */ ! { ISFUNC, (Function *)0x0 }, /* Control-x */ ! { ISFUNC, rl_yank }, /* Control-y */ ! { ISFUNC, (Function *)0x0 }, /* Control-z */ ! ! { ISFUNC, (Function *)0x0 }, /* Control-[ */ /* vi_escape_keymap */ ! { ISFUNC, (Function *)0x0 }, /* Control-\ */ ! { ISFUNC, (Function *)0x0 }, /* Control-] */ ! { ISFUNC, (Function *)0x0 }, /* Control-^ */ ! { ISFUNC, rl_vi_undo }, /* Control-_ */ /* The start of printing characters. */ ! { ISFUNC, rl_forward }, /* SPACE */ ! { ISFUNC, (Function *)0x0 }, /* ! */ ! { ISFUNC, (Function *)0x0 }, /* " */ ! { ISFUNC, rl_insert_comment }, /* # */ ! { ISFUNC, rl_end_of_line }, /* $ */ ! { ISFUNC, rl_vi_match }, /* % */ ! { ISFUNC, rl_vi_tilde_expand }, /* & */ ! { ISFUNC, (Function *)0x0 }, /* ' */ ! { ISFUNC, (Function *)0x0 }, /* ( */ ! { ISFUNC, (Function *)0x0 }, /* ) */ ! { ISFUNC, rl_vi_complete }, /* * */ ! { ISFUNC, rl_get_next_history}, /* + */ ! { ISFUNC, rl_vi_char_search }, /* , */ ! { ISFUNC, rl_get_previous_history }, /* - */ ! { ISFUNC, rl_vi_redo }, /* . */ ! { ISFUNC, rl_vi_search }, /* / */ /* Regular digits. */ ! { ISFUNC, rl_beg_of_line }, /* 0 */ ! { ISFUNC, rl_vi_arg_digit }, /* 1 */ ! { ISFUNC, rl_vi_arg_digit }, /* 2 */ ! { ISFUNC, rl_vi_arg_digit }, /* 3 */ ! { ISFUNC, rl_vi_arg_digit }, /* 4 */ ! { ISFUNC, rl_vi_arg_digit }, /* 5 */ ! { ISFUNC, rl_vi_arg_digit }, /* 6 */ ! { ISFUNC, rl_vi_arg_digit }, /* 7 */ ! { ISFUNC, rl_vi_arg_digit }, /* 8 */ ! { ISFUNC, rl_vi_arg_digit }, /* 9 */ /* A little more punctuation. */ ! { ISFUNC, (Function *)0x0 }, /* : */ ! { ISFUNC, rl_vi_char_search }, /* ; */ ! { ISFUNC, (Function *)0x0 }, /* < */ ! { ISFUNC, rl_vi_complete }, /* = */ ! { ISFUNC, (Function *)0x0 }, /* > */ ! { ISFUNC, rl_vi_search }, /* ? */ ! { ISFUNC, (Function *)0x0 }, /* @ */ /* Uppercase alphabet. */ ! { ISFUNC, rl_vi_append_eol }, /* A */ ! { ISFUNC, rl_vi_prev_word}, /* B */ ! { ISFUNC, rl_vi_change_to }, /* C */ ! { ISFUNC, rl_vi_delete_to }, /* D */ ! { ISFUNC, rl_vi_end_word }, /* E */ ! { ISFUNC, rl_vi_char_search }, /* F */ ! { ISFUNC, rl_vi_fetch_history }, /* G */ ! { ISFUNC, (Function *)0x0 }, /* H */ ! { ISFUNC, rl_vi_insert_beg }, /* I */ ! { ISFUNC, (Function *)0x0 }, /* J */ ! { ISFUNC, (Function *)0x0 }, /* K */ ! { ISFUNC, (Function *)0x0 }, /* L */ ! { ISFUNC, (Function *)0x0 }, /* M */ ! { ISFUNC, rl_vi_search_again }, /* N */ ! { ISFUNC, (Function *)0x0 }, /* O */ ! { ISFUNC, rl_vi_put }, /* P */ ! { ISFUNC, (Function *)0x0 }, /* Q */ ! { ISFUNC, rl_vi_replace }, /* R */ ! { ISFUNC, rl_vi_subst }, /* S */ ! { ISFUNC, rl_vi_char_search }, /* T */ ! { ISFUNC, rl_revert_line }, /* U */ ! { ISFUNC, (Function *)0x0 }, /* V */ ! { ISFUNC, rl_vi_next_word }, /* W */ ! { ISFUNC, rl_rubout }, /* X */ ! { ISFUNC, rl_vi_yank_to }, /* Y */ ! { ISFUNC, (Function *)0x0 }, /* Z */ /* Some more punctuation. */ ! { ISFUNC, (Function *)0x0 }, /* [ */ ! { ISFUNC, rl_vi_complete }, /* \ */ ! { ISFUNC, (Function *)0x0 }, /* ] */ ! { ISFUNC, rl_vi_first_print }, /* ^ */ ! { ISFUNC, rl_vi_yank_arg }, /* _ */ ! { ISFUNC, rl_vi_goto_mark }, /* ` */ /* Lowercase alphabet. */ ! { ISFUNC, rl_vi_append_mode }, /* a */ ! { ISFUNC, rl_vi_prev_word }, /* b */ ! { ISFUNC, rl_vi_change_to }, /* c */ ! { ISFUNC, rl_vi_delete_to }, /* d */ ! { ISFUNC, rl_vi_end_word }, /* e */ ! { ISFUNC, rl_vi_char_search }, /* f */ ! { ISFUNC, (Function *)0x0 }, /* g */ ! { ISFUNC, rl_backward }, /* h */ ! { ISFUNC, rl_vi_insertion_mode }, /* i */ ! { ISFUNC, rl_get_next_history }, /* j */ ! { ISFUNC, rl_get_previous_history }, /* k */ ! { ISFUNC, rl_forward }, /* l */ ! { ISFUNC, rl_vi_set_mark }, /* m */ ! { ISFUNC, rl_vi_search_again }, /* n */ ! { ISFUNC, (Function *)0x0 }, /* o */ ! { ISFUNC, rl_vi_put }, /* p */ ! { ISFUNC, (Function *)0x0 }, /* q */ ! { ISFUNC, rl_vi_change_char }, /* r */ ! { ISFUNC, rl_vi_subst }, /* s */ ! { ISFUNC, rl_vi_char_search }, /* t */ ! { ISFUNC, rl_vi_undo }, /* u */ ! { ISFUNC, (Function *)0x0 }, /* v */ ! { ISFUNC, rl_vi_next_word }, /* w */ ! { ISFUNC, rl_vi_delete }, /* x */ ! { ISFUNC, rl_vi_yank_to }, /* y */ ! { ISFUNC, (Function *)0x0 }, /* z */ /* Final punctuation. */ ! { ISFUNC, (Function *)0x0 }, /* { */ ! { ISFUNC, rl_vi_column }, /* | */ ! { ISFUNC, (Function *)0x0 }, /* } */ ! { ISFUNC, rl_vi_change_case }, /* ~ */ ! { ISFUNC, (Function *)0x0 }, /* RUBOUT */ #if KEYMAP_SIZE > 128 /* Undefined keys. */ ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 } #endif /* KEYMAP_SIZE > 128 */ }; --- 34,311 ---- KEYMAP_ENTRY_ARRAY vi_movement_keymap = { /* The regular control keys come first. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-@ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-a */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-b */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-c */ ! { ISFUNC, rl_vi_eof_maybe }, /* Control-d */ ! { ISFUNC, rl_emacs_editing_mode }, /* Control-e */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-f */ ! { ISFUNC, rl_abort }, /* Control-g */ ! { ISFUNC, rl_backward }, /* Control-h */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-i */ ! { ISFUNC, rl_newline }, /* Control-j */ ! { ISFUNC, rl_kill_line }, /* Control-k */ ! { ISFUNC, rl_clear_screen }, /* Control-l */ ! { ISFUNC, rl_newline }, /* Control-m */ ! { ISFUNC, rl_get_next_history }, /* Control-n */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-o */ ! { ISFUNC, rl_get_previous_history }, /* Control-p */ ! { ISFUNC, rl_quoted_insert }, /* Control-q */ ! { ISFUNC, rl_reverse_search_history }, /* Control-r */ ! { ISFUNC, rl_forward_search_history }, /* Control-s */ ! { ISFUNC, rl_transpose_chars }, /* Control-t */ ! { ISFUNC, rl_unix_line_discard }, /* Control-u */ ! { ISFUNC, rl_quoted_insert }, /* Control-v */ ! { ISFUNC, rl_unix_word_rubout }, /* Control-w */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-x */ ! { ISFUNC, rl_yank }, /* Control-y */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-z */ ! ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-[ */ /* vi_escape_keymap */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-\ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-] */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-^ */ ! { ISFUNC, rl_vi_undo }, /* Control-_ */ /* The start of printing characters. */ ! { ISFUNC, rl_forward }, /* SPACE */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ! */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* " */ ! { ISFUNC, rl_insert_comment }, /* # */ ! { ISFUNC, rl_end_of_line }, /* $ */ ! { ISFUNC, rl_vi_match }, /* % */ ! { ISFUNC, rl_vi_tilde_expand }, /* & */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ' */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ( */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ) */ ! { ISFUNC, rl_vi_complete }, /* * */ ! { ISFUNC, rl_get_next_history}, /* + */ ! { ISFUNC, rl_vi_char_search }, /* , */ ! { ISFUNC, rl_get_previous_history }, /* - */ ! { ISFUNC, rl_vi_redo }, /* . */ ! { ISFUNC, rl_vi_search }, /* / */ /* Regular digits. */ ! { ISFUNC, rl_beg_of_line }, /* 0 */ ! { ISFUNC, rl_vi_arg_digit }, /* 1 */ ! { ISFUNC, rl_vi_arg_digit }, /* 2 */ ! { ISFUNC, rl_vi_arg_digit }, /* 3 */ ! { ISFUNC, rl_vi_arg_digit }, /* 4 */ ! { ISFUNC, rl_vi_arg_digit }, /* 5 */ ! { ISFUNC, rl_vi_arg_digit }, /* 6 */ ! { ISFUNC, rl_vi_arg_digit }, /* 7 */ ! { ISFUNC, rl_vi_arg_digit }, /* 8 */ ! { ISFUNC, rl_vi_arg_digit }, /* 9 */ /* A little more punctuation. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* : */ ! { ISFUNC, rl_vi_char_search }, /* ; */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* < */ ! { ISFUNC, rl_vi_complete }, /* = */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* > */ ! { ISFUNC, rl_vi_search }, /* ? */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* @ */ /* Uppercase alphabet. */ ! { ISFUNC, rl_vi_append_eol }, /* A */ ! { ISFUNC, rl_vi_prev_word}, /* B */ ! { ISFUNC, rl_vi_change_to }, /* C */ ! { ISFUNC, rl_vi_delete_to }, /* D */ ! { ISFUNC, rl_vi_end_word }, /* E */ ! { ISFUNC, rl_vi_char_search }, /* F */ ! { ISFUNC, rl_vi_fetch_history }, /* G */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* H */ ! { ISFUNC, rl_vi_insert_beg }, /* I */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* J */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* K */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* L */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* M */ ! { ISFUNC, rl_vi_search_again }, /* N */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* O */ ! { ISFUNC, rl_vi_put }, /* P */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Q */ ! { ISFUNC, rl_vi_replace }, /* R */ ! { ISFUNC, rl_vi_subst }, /* S */ ! { ISFUNC, rl_vi_char_search }, /* T */ ! { ISFUNC, rl_revert_line }, /* U */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* V */ ! { ISFUNC, rl_vi_next_word }, /* W */ ! { ISFUNC, rl_rubout }, /* X */ ! { ISFUNC, rl_vi_yank_to }, /* Y */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Z */ /* Some more punctuation. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* [ */ ! { ISFUNC, rl_vi_complete }, /* \ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ] */ ! { ISFUNC, rl_vi_first_print }, /* ^ */ ! { ISFUNC, rl_vi_yank_arg }, /* _ */ ! { ISFUNC, rl_vi_goto_mark }, /* ` */ /* Lowercase alphabet. */ ! { ISFUNC, rl_vi_append_mode }, /* a */ ! { ISFUNC, rl_vi_prev_word }, /* b */ ! { ISFUNC, rl_vi_change_to }, /* c */ ! { ISFUNC, rl_vi_delete_to }, /* d */ ! { ISFUNC, rl_vi_end_word }, /* e */ ! { ISFUNC, rl_vi_char_search }, /* f */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* g */ ! { ISFUNC, rl_backward }, /* h */ ! { ISFUNC, rl_vi_insertion_mode }, /* i */ ! { ISFUNC, rl_get_next_history }, /* j */ ! { ISFUNC, rl_get_previous_history }, /* k */ ! { ISFUNC, rl_forward }, /* l */ ! { ISFUNC, rl_vi_set_mark }, /* m */ ! { ISFUNC, rl_vi_search_again }, /* n */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* o */ ! { ISFUNC, rl_vi_put }, /* p */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* q */ ! { ISFUNC, rl_vi_change_char }, /* r */ ! { ISFUNC, rl_vi_subst }, /* s */ ! { ISFUNC, rl_vi_char_search }, /* t */ ! { ISFUNC, rl_vi_undo }, /* u */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* v */ ! { ISFUNC, rl_vi_next_word }, /* w */ ! { ISFUNC, rl_vi_delete }, /* x */ ! { ISFUNC, rl_vi_yank_to }, /* y */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* z */ /* Final punctuation. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* { */ ! { ISFUNC, rl_vi_column }, /* | */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* } */ ! { ISFUNC, rl_vi_change_case }, /* ~ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* RUBOUT */ #if KEYMAP_SIZE > 128 /* Undefined keys. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 } #endif /* KEYMAP_SIZE > 128 */ }; *************** *** 314,460 **** KEYMAP_ENTRY_ARRAY vi_insertion_keymap = { /* The regular control keys come first. */ ! { ISFUNC, (Function *)0x0 }, /* Control-@ */ ! { ISFUNC, rl_insert }, /* Control-a */ ! { ISFUNC, rl_insert }, /* Control-b */ ! { ISFUNC, rl_insert }, /* Control-c */ ! { ISFUNC, rl_vi_eof_maybe }, /* Control-d */ ! { ISFUNC, rl_insert }, /* Control-e */ ! { ISFUNC, rl_insert }, /* Control-f */ ! { ISFUNC, rl_insert }, /* Control-g */ ! { ISFUNC, rl_rubout }, /* Control-h */ ! { ISFUNC, rl_complete }, /* Control-i */ ! { ISFUNC, rl_newline }, /* Control-j */ ! { ISFUNC, rl_insert }, /* Control-k */ ! { ISFUNC, rl_insert }, /* Control-l */ ! { ISFUNC, rl_newline }, /* Control-m */ ! { ISFUNC, rl_insert }, /* Control-n */ ! { ISFUNC, rl_insert }, /* Control-o */ ! { ISFUNC, rl_insert }, /* Control-p */ ! { ISFUNC, rl_insert }, /* Control-q */ ! { ISFUNC, rl_reverse_search_history }, /* Control-r */ ! { ISFUNC, rl_forward_search_history }, /* Control-s */ ! { ISFUNC, rl_transpose_chars }, /* Control-t */ ! { ISFUNC, rl_unix_line_discard }, /* Control-u */ ! { ISFUNC, rl_quoted_insert }, /* Control-v */ ! { ISFUNC, rl_unix_word_rubout }, /* Control-w */ ! { ISFUNC, rl_insert }, /* Control-x */ ! { ISFUNC, rl_yank }, /* Control-y */ ! { ISFUNC, rl_insert }, /* Control-z */ ! ! { ISFUNC, rl_vi_movement_mode }, /* Control-[ */ ! { ISFUNC, rl_insert }, /* Control-\ */ ! { ISFUNC, rl_insert }, /* Control-] */ ! { ISFUNC, rl_insert }, /* Control-^ */ ! { ISFUNC, rl_vi_undo }, /* Control-_ */ /* The start of printing characters. */ ! { ISFUNC, rl_insert }, /* SPACE */ ! { ISFUNC, rl_insert }, /* ! */ ! { ISFUNC, rl_insert }, /* " */ ! { ISFUNC, rl_insert }, /* # */ ! { ISFUNC, rl_insert }, /* $ */ ! { ISFUNC, rl_insert }, /* % */ ! { ISFUNC, rl_insert }, /* & */ ! { ISFUNC, rl_insert }, /* ' */ ! { ISFUNC, rl_insert }, /* ( */ ! { ISFUNC, rl_insert }, /* ) */ ! { ISFUNC, rl_insert }, /* * */ ! { ISFUNC, rl_insert }, /* + */ ! { ISFUNC, rl_insert }, /* , */ ! { ISFUNC, rl_insert }, /* - */ ! { ISFUNC, rl_insert }, /* . */ ! { ISFUNC, rl_insert }, /* / */ /* Regular digits. */ ! { ISFUNC, rl_insert }, /* 0 */ ! { ISFUNC, rl_insert }, /* 1 */ ! { ISFUNC, rl_insert }, /* 2 */ ! { ISFUNC, rl_insert }, /* 3 */ ! { ISFUNC, rl_insert }, /* 4 */ ! { ISFUNC, rl_insert }, /* 5 */ ! { ISFUNC, rl_insert }, /* 6 */ ! { ISFUNC, rl_insert }, /* 7 */ ! { ISFUNC, rl_insert }, /* 8 */ ! { ISFUNC, rl_insert }, /* 9 */ /* A little more punctuation. */ ! { ISFUNC, rl_insert }, /* : */ ! { ISFUNC, rl_insert }, /* ; */ ! { ISFUNC, rl_insert }, /* < */ ! { ISFUNC, rl_insert }, /* = */ ! { ISFUNC, rl_insert }, /* > */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* @ */ /* Uppercase alphabet. */ ! { ISFUNC, rl_insert }, /* A */ ! { ISFUNC, rl_insert }, /* B */ ! { ISFUNC, rl_insert }, /* C */ ! { ISFUNC, rl_insert }, /* D */ ! { ISFUNC, rl_insert }, /* E */ ! { ISFUNC, rl_insert }, /* F */ ! { ISFUNC, rl_insert }, /* G */ ! { ISFUNC, rl_insert }, /* H */ ! { ISFUNC, rl_insert }, /* I */ ! { ISFUNC, rl_insert }, /* J */ ! { ISFUNC, rl_insert }, /* K */ ! { ISFUNC, rl_insert }, /* L */ ! { ISFUNC, rl_insert }, /* M */ ! { ISFUNC, rl_insert }, /* N */ ! { ISFUNC, rl_insert }, /* O */ ! { ISFUNC, rl_insert }, /* P */ ! { ISFUNC, rl_insert }, /* Q */ ! { ISFUNC, rl_insert }, /* R */ ! { ISFUNC, rl_insert }, /* S */ ! { ISFUNC, rl_insert }, /* T */ ! { ISFUNC, rl_insert }, /* U */ ! { ISFUNC, rl_insert }, /* V */ ! { ISFUNC, rl_insert }, /* W */ ! { ISFUNC, rl_insert }, /* X */ ! { ISFUNC, rl_insert }, /* Y */ ! { ISFUNC, rl_insert }, /* Z */ /* Some more punctuation. */ ! { ISFUNC, rl_insert }, /* [ */ ! { ISFUNC, rl_insert }, /* \ */ ! { ISFUNC, rl_insert }, /* ] */ ! { ISFUNC, rl_insert }, /* ^ */ ! { ISFUNC, rl_insert }, /* _ */ ! { ISFUNC, rl_insert }, /* ` */ /* Lowercase alphabet. */ ! { ISFUNC, rl_insert }, /* a */ ! { ISFUNC, rl_insert }, /* b */ ! { ISFUNC, rl_insert }, /* c */ ! { ISFUNC, rl_insert }, /* d */ ! { ISFUNC, rl_insert }, /* e */ ! { ISFUNC, rl_insert }, /* f */ ! { ISFUNC, rl_insert }, /* g */ ! { ISFUNC, rl_insert }, /* h */ ! { ISFUNC, rl_insert }, /* i */ ! { ISFUNC, rl_insert }, /* j */ ! { ISFUNC, rl_insert }, /* k */ ! { ISFUNC, rl_insert }, /* l */ ! { ISFUNC, rl_insert }, /* m */ ! { ISFUNC, rl_insert }, /* n */ ! { ISFUNC, rl_insert }, /* o */ ! { ISFUNC, rl_insert }, /* p */ ! { ISFUNC, rl_insert }, /* q */ ! { ISFUNC, rl_insert }, /* r */ ! { ISFUNC, rl_insert }, /* s */ ! { ISFUNC, rl_insert }, /* t */ ! { ISFUNC, rl_insert }, /* u */ ! { ISFUNC, rl_insert }, /* v */ ! { ISFUNC, rl_insert }, /* w */ ! { ISFUNC, rl_insert }, /* x */ ! { ISFUNC, rl_insert }, /* y */ ! { ISFUNC, rl_insert }, /* z */ /* Final punctuation. */ ! { ISFUNC, rl_insert }, /* { */ ! { ISFUNC, rl_insert }, /* | */ ! { ISFUNC, rl_insert }, /* } */ ! { ISFUNC, rl_insert }, /* ~ */ ! { ISFUNC, rl_rubout }, /* RUBOUT */ #if KEYMAP_SIZE > 128 --- 314,460 ---- KEYMAP_ENTRY_ARRAY vi_insertion_keymap = { /* The regular control keys come first. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-@ */ ! { ISFUNC, rl_insert }, /* Control-a */ ! { ISFUNC, rl_insert }, /* Control-b */ ! { ISFUNC, rl_insert }, /* Control-c */ ! { ISFUNC, rl_vi_eof_maybe }, /* Control-d */ ! { ISFUNC, rl_insert }, /* Control-e */ ! { ISFUNC, rl_insert }, /* Control-f */ ! { ISFUNC, rl_insert }, /* Control-g */ ! { ISFUNC, rl_rubout }, /* Control-h */ ! { ISFUNC, rl_complete }, /* Control-i */ ! { ISFUNC, rl_newline }, /* Control-j */ ! { ISFUNC, rl_insert }, /* Control-k */ ! { ISFUNC, rl_insert }, /* Control-l */ ! { ISFUNC, rl_newline }, /* Control-m */ ! { ISFUNC, rl_insert }, /* Control-n */ ! { ISFUNC, rl_insert }, /* Control-o */ ! { ISFUNC, rl_insert }, /* Control-p */ ! { ISFUNC, rl_insert }, /* Control-q */ ! { ISFUNC, rl_reverse_search_history }, /* Control-r */ ! { ISFUNC, rl_forward_search_history }, /* Control-s */ ! { ISFUNC, rl_transpose_chars }, /* Control-t */ ! { ISFUNC, rl_unix_line_discard }, /* Control-u */ ! { ISFUNC, rl_quoted_insert }, /* Control-v */ ! { ISFUNC, rl_unix_word_rubout }, /* Control-w */ ! { ISFUNC, rl_insert }, /* Control-x */ ! { ISFUNC, rl_yank }, /* Control-y */ ! { ISFUNC, rl_insert }, /* Control-z */ ! ! { ISFUNC, rl_vi_movement_mode }, /* Control-[ */ ! { ISFUNC, rl_insert }, /* Control-\ */ ! { ISFUNC, rl_insert }, /* Control-] */ ! { ISFUNC, rl_insert }, /* Control-^ */ ! { ISFUNC, rl_vi_undo }, /* Control-_ */ /* The start of printing characters. */ ! { ISFUNC, rl_insert }, /* SPACE */ ! { ISFUNC, rl_insert }, /* ! */ ! { ISFUNC, rl_insert }, /* " */ ! { ISFUNC, rl_insert }, /* # */ ! { ISFUNC, rl_insert }, /* $ */ ! { ISFUNC, rl_insert }, /* % */ ! { ISFUNC, rl_insert }, /* & */ ! { ISFUNC, rl_insert }, /* ' */ ! { ISFUNC, rl_insert }, /* ( */ ! { ISFUNC, rl_insert }, /* ) */ ! { ISFUNC, rl_insert }, /* * */ ! { ISFUNC, rl_insert }, /* + */ ! { ISFUNC, rl_insert }, /* , */ ! { ISFUNC, rl_insert }, /* - */ ! { ISFUNC, rl_insert }, /* . */ ! { ISFUNC, rl_insert }, /* / */ /* Regular digits. */ ! { ISFUNC, rl_insert }, /* 0 */ ! { ISFUNC, rl_insert }, /* 1 */ ! { ISFUNC, rl_insert }, /* 2 */ ! { ISFUNC, rl_insert }, /* 3 */ ! { ISFUNC, rl_insert }, /* 4 */ ! { ISFUNC, rl_insert }, /* 5 */ ! { ISFUNC, rl_insert }, /* 6 */ ! { ISFUNC, rl_insert }, /* 7 */ ! { ISFUNC, rl_insert }, /* 8 */ ! { ISFUNC, rl_insert }, /* 9 */ /* A little more punctuation. */ ! { ISFUNC, rl_insert }, /* : */ ! { ISFUNC, rl_insert }, /* ; */ ! { ISFUNC, rl_insert }, /* < */ ! { ISFUNC, rl_insert }, /* = */ ! { ISFUNC, rl_insert }, /* > */ ! { ISFUNC, rl_insert }, /* ? */ ! { ISFUNC, rl_insert }, /* @ */ /* Uppercase alphabet. */ ! { ISFUNC, rl_insert }, /* A */ ! { ISFUNC, rl_insert }, /* B */ ! { ISFUNC, rl_insert }, /* C */ ! { ISFUNC, rl_insert }, /* D */ ! { ISFUNC, rl_insert }, /* E */ ! { ISFUNC, rl_insert }, /* F */ ! { ISFUNC, rl_insert }, /* G */ ! { ISFUNC, rl_insert }, /* H */ ! { ISFUNC, rl_insert }, /* I */ ! { ISFUNC, rl_insert }, /* J */ ! { ISFUNC, rl_insert }, /* K */ ! { ISFUNC, rl_insert }, /* L */ ! { ISFUNC, rl_insert }, /* M */ ! { ISFUNC, rl_insert }, /* N */ ! { ISFUNC, rl_insert }, /* O */ ! { ISFUNC, rl_insert }, /* P */ ! { ISFUNC, rl_insert }, /* Q */ ! { ISFUNC, rl_insert }, /* R */ ! { ISFUNC, rl_insert }, /* S */ ! { ISFUNC, rl_insert }, /* T */ ! { ISFUNC, rl_insert }, /* U */ ! { ISFUNC, rl_insert }, /* V */ ! { ISFUNC, rl_insert }, /* W */ ! { ISFUNC, rl_insert }, /* X */ ! { ISFUNC, rl_insert }, /* Y */ ! { ISFUNC, rl_insert }, /* Z */ /* Some more punctuation. */ ! { ISFUNC, rl_insert }, /* [ */ ! { ISFUNC, rl_insert }, /* \ */ ! { ISFUNC, rl_insert }, /* ] */ ! { ISFUNC, rl_insert }, /* ^ */ ! { ISFUNC, rl_insert }, /* _ */ ! { ISFUNC, rl_insert }, /* ` */ /* Lowercase alphabet. */ ! { ISFUNC, rl_insert }, /* a */ ! { ISFUNC, rl_insert }, /* b */ ! { ISFUNC, rl_insert }, /* c */ ! { ISFUNC, rl_insert }, /* d */ ! { ISFUNC, rl_insert }, /* e */ ! { ISFUNC, rl_insert }, /* f */ ! { ISFUNC, rl_insert }, /* g */ ! { ISFUNC, rl_insert }, /* h */ ! { ISFUNC, rl_insert }, /* i */ ! { ISFUNC, rl_insert }, /* j */ ! { ISFUNC, rl_insert }, /* k */ ! { ISFUNC, rl_insert }, /* l */ ! { ISFUNC, rl_insert }, /* m */ ! { ISFUNC, rl_insert }, /* n */ ! { ISFUNC, rl_insert }, /* o */ ! { ISFUNC, rl_insert }, /* p */ ! { ISFUNC, rl_insert }, /* q */ ! { ISFUNC, rl_insert }, /* r */ ! { ISFUNC, rl_insert }, /* s */ ! { ISFUNC, rl_insert }, /* t */ ! { ISFUNC, rl_insert }, /* u */ ! { ISFUNC, rl_insert }, /* v */ ! { ISFUNC, rl_insert }, /* w */ ! { ISFUNC, rl_insert }, /* x */ ! { ISFUNC, rl_insert }, /* y */ ! { ISFUNC, rl_insert }, /* z */ /* Final punctuation. */ ! { ISFUNC, rl_insert }, /* { */ ! { ISFUNC, rl_insert }, /* | */ ! { ISFUNC, rl_insert }, /* } */ ! { ISFUNC, rl_insert }, /* ~ */ ! { ISFUNC, rl_rubout }, /* RUBOUT */ #if KEYMAP_SIZE > 128 *************** *** 599,876 **** KEYMAP_ENTRY_ARRAY vi_escape_keymap = { /* The regular control keys come first. */ ! { ISFUNC, (Function *)0x0 }, /* Control-@ */ ! { ISFUNC, (Function *)0x0 }, /* Control-a */ ! { ISFUNC, (Function *)0x0 }, /* Control-b */ ! { ISFUNC, (Function *)0x0 }, /* Control-c */ ! { ISFUNC, (Function *)0x0 }, /* Control-d */ ! { ISFUNC, (Function *)0x0 }, /* Control-e */ ! { ISFUNC, (Function *)0x0 }, /* Control-f */ ! { ISFUNC, (Function *)0x0 }, /* Control-g */ ! { ISFUNC, (Function *)0x0 }, /* Control-h */ ! { ISFUNC, rl_tab_insert}, /* Control-i */ ! { ISFUNC, rl_emacs_editing_mode}, /* Control-j */ ! { ISFUNC, rl_kill_line }, /* Control-k */ ! { ISFUNC, (Function *)0x0 }, /* Control-l */ ! { ISFUNC, rl_emacs_editing_mode}, /* Control-m */ ! { ISFUNC, (Function *)0x0 }, /* Control-n */ ! { ISFUNC, (Function *)0x0 }, /* Control-o */ ! { ISFUNC, (Function *)0x0 }, /* Control-p */ ! { ISFUNC, (Function *)0x0 }, /* Control-q */ ! { ISFUNC, (Function *)0x0 }, /* Control-r */ ! { ISFUNC, (Function *)0x0 }, /* Control-s */ ! { ISFUNC, (Function *)0x0 }, /* Control-t */ ! { ISFUNC, (Function *)0x0 }, /* Control-u */ ! { ISFUNC, (Function *)0x0 }, /* Control-v */ ! { ISFUNC, (Function *)0x0 }, /* Control-w */ ! { ISFUNC, (Function *)0x0 }, /* Control-x */ ! { ISFUNC, (Function *)0x0 }, /* Control-y */ ! { ISFUNC, (Function *)0x0 }, /* Control-z */ ! ! { ISFUNC, rl_vi_movement_mode }, /* Control-[ */ ! { ISFUNC, (Function *)0x0 }, /* Control-\ */ ! { ISFUNC, (Function *)0x0 }, /* Control-] */ ! { ISFUNC, (Function *)0x0 }, /* Control-^ */ ! { ISFUNC, rl_vi_undo }, /* Control-_ */ /* The start of printing characters. */ ! { ISFUNC, (Function *)0x0 }, /* SPACE */ ! { ISFUNC, (Function *)0x0 }, /* ! */ ! { ISFUNC, (Function *)0x0 }, /* " */ ! { ISFUNC, (Function *)0x0 }, /* # */ ! { ISFUNC, (Function *)0x0 }, /* $ */ ! { ISFUNC, (Function *)0x0 }, /* % */ ! { ISFUNC, (Function *)0x0 }, /* & */ ! { ISFUNC, (Function *)0x0 }, /* ' */ ! { ISFUNC, (Function *)0x0 }, /* ( */ ! { ISFUNC, (Function *)0x0 }, /* ) */ ! { ISFUNC, (Function *)0x0 }, /* * */ ! { ISFUNC, (Function *)0x0 }, /* + */ ! { ISFUNC, (Function *)0x0 }, /* , */ ! { ISFUNC, (Function *)0x0 }, /* - */ ! { ISFUNC, (Function *)0x0 }, /* . */ ! { ISFUNC, (Function *)0x0 }, /* / */ /* Regular digits. */ ! { ISFUNC, rl_vi_arg_digit }, /* 0 */ ! { ISFUNC, rl_vi_arg_digit }, /* 1 */ ! { ISFUNC, rl_vi_arg_digit }, /* 2 */ ! { ISFUNC, rl_vi_arg_digit }, /* 3 */ ! { ISFUNC, rl_vi_arg_digit }, /* 4 */ ! { ISFUNC, rl_vi_arg_digit }, /* 5 */ ! { ISFUNC, rl_vi_arg_digit }, /* 6 */ ! { ISFUNC, rl_vi_arg_digit }, /* 7 */ ! { ISFUNC, rl_vi_arg_digit }, /* 8 */ ! { ISFUNC, rl_vi_arg_digit }, /* 9 */ /* A little more punctuation. */ ! { ISFUNC, (Function *)0x0 }, /* : */ ! { ISFUNC, (Function *)0x0 }, /* ; */ ! { ISFUNC, (Function *)0x0 }, /* < */ ! { ISFUNC, (Function *)0x0 }, /* = */ ! { ISFUNC, (Function *)0x0 }, /* > */ ! { ISFUNC, (Function *)0x0 }, /* ? */ ! { ISFUNC, (Function *)0x0 }, /* @ */ /* Uppercase alphabet. */ ! { ISFUNC, rl_do_lowercase_version }, /* A */ ! { ISFUNC, rl_do_lowercase_version }, /* B */ ! { ISFUNC, rl_do_lowercase_version }, /* C */ ! { ISFUNC, rl_do_lowercase_version }, /* D */ ! { ISFUNC, rl_do_lowercase_version }, /* E */ ! { ISFUNC, rl_do_lowercase_version }, /* F */ ! { ISFUNC, rl_do_lowercase_version }, /* G */ ! { ISFUNC, rl_do_lowercase_version }, /* H */ ! { ISFUNC, rl_do_lowercase_version }, /* I */ ! { ISFUNC, rl_do_lowercase_version }, /* J */ ! { ISFUNC, rl_do_lowercase_version }, /* K */ ! { ISFUNC, rl_do_lowercase_version }, /* L */ ! { ISFUNC, rl_do_lowercase_version }, /* M */ ! { ISFUNC, rl_do_lowercase_version }, /* N */ ! { ISFUNC, rl_do_lowercase_version }, /* O */ ! { ISFUNC, rl_do_lowercase_version }, /* P */ ! { ISFUNC, rl_do_lowercase_version }, /* Q */ ! { ISFUNC, rl_do_lowercase_version }, /* R */ ! { ISFUNC, rl_do_lowercase_version }, /* S */ ! { ISFUNC, rl_do_lowercase_version }, /* T */ ! { ISFUNC, rl_do_lowercase_version }, /* U */ ! { ISFUNC, rl_do_lowercase_version }, /* V */ ! { ISFUNC, rl_do_lowercase_version }, /* W */ ! { ISFUNC, rl_do_lowercase_version }, /* X */ ! { ISFUNC, rl_do_lowercase_version }, /* Y */ ! { ISFUNC, rl_do_lowercase_version }, /* Z */ /* Some more punctuation. */ ! { ISFUNC, rl_arrow_keys }, /* [ */ ! { ISFUNC, (Function *)0x0 }, /* \ */ ! { ISFUNC, (Function *)0x0 }, /* ] */ ! { ISFUNC, (Function *)0x0 }, /* ^ */ ! { ISFUNC, (Function *)0x0 }, /* _ */ ! { ISFUNC, (Function *)0x0 }, /* ` */ /* Lowercase alphabet. */ ! { ISFUNC, (Function *)0x0 }, /* a */ ! { ISFUNC, (Function *)0x0 }, /* b */ ! { ISFUNC, (Function *)0x0 }, /* c */ ! { ISFUNC, (Function *)0x0 }, /* d */ ! { ISFUNC, (Function *)0x0 }, /* e */ ! { ISFUNC, (Function *)0x0 }, /* f */ ! { ISFUNC, (Function *)0x0 }, /* g */ ! { ISFUNC, (Function *)0x0 }, /* h */ ! { ISFUNC, (Function *)0x0 }, /* i */ ! { ISFUNC, (Function *)0x0 }, /* j */ ! { ISFUNC, (Function *)0x0 }, /* k */ ! { ISFUNC, (Function *)0x0 }, /* l */ ! { ISFUNC, (Function *)0x0 }, /* m */ ! { ISFUNC, (Function *)0x0 }, /* n */ ! { ISFUNC, rl_arrow_keys }, /* o */ ! { ISFUNC, (Function *)0x0 }, /* p */ ! { ISFUNC, (Function *)0x0 }, /* q */ ! { ISFUNC, (Function *)0x0 }, /* r */ ! { ISFUNC, (Function *)0x0 }, /* s */ ! { ISFUNC, (Function *)0x0 }, /* t */ ! { ISFUNC, (Function *)0x0 }, /* u */ ! { ISFUNC, (Function *)0x0 }, /* v */ ! { ISFUNC, (Function *)0x0 }, /* w */ ! { ISFUNC, (Function *)0x0 }, /* x */ ! { ISFUNC, (Function *)0x0 }, /* y */ ! { ISFUNC, (Function *)0x0 }, /* z */ /* Final punctuation. */ ! { ISFUNC, (Function *)0x0 }, /* { */ ! { ISFUNC, (Function *)0x0 }, /* | */ ! { ISFUNC, (Function *)0x0 }, /* } */ ! { ISFUNC, (Function *)0x0 }, /* ~ */ ! { ISFUNC, rl_backward_kill_word }, /* RUBOUT */ #if KEYMAP_SIZE > 128 /* Undefined keys. */ ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 }, ! { ISFUNC, (Function *)0x0 } #endif /* KEYMAP_SIZE > 128 */ }; --- 599,876 ---- KEYMAP_ENTRY_ARRAY vi_escape_keymap = { /* The regular control keys come first. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-@ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-a */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-b */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-c */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-d */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-e */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-f */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-g */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-h */ ! { ISFUNC, rl_tab_insert}, /* Control-i */ ! { ISFUNC, rl_emacs_editing_mode}, /* Control-j */ ! { ISFUNC, rl_kill_line }, /* Control-k */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-l */ ! { ISFUNC, rl_emacs_editing_mode}, /* Control-m */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-n */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-o */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-p */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-q */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-r */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-s */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-t */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-u */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-v */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-w */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-x */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-y */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-z */ ! ! { ISFUNC, rl_vi_movement_mode }, /* Control-[ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-\ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-] */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* Control-^ */ ! { ISFUNC, rl_vi_undo }, /* Control-_ */ /* The start of printing characters. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* SPACE */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ! */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* " */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* # */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* $ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* % */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* & */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ' */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ( */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ) */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* * */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* + */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* , */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* - */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* . */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* / */ /* Regular digits. */ ! { ISFUNC, rl_vi_arg_digit }, /* 0 */ ! { ISFUNC, rl_vi_arg_digit }, /* 1 */ ! { ISFUNC, rl_vi_arg_digit }, /* 2 */ ! { ISFUNC, rl_vi_arg_digit }, /* 3 */ ! { ISFUNC, rl_vi_arg_digit }, /* 4 */ ! { ISFUNC, rl_vi_arg_digit }, /* 5 */ ! { ISFUNC, rl_vi_arg_digit }, /* 6 */ ! { ISFUNC, rl_vi_arg_digit }, /* 7 */ ! { ISFUNC, rl_vi_arg_digit }, /* 8 */ ! { ISFUNC, rl_vi_arg_digit }, /* 9 */ /* A little more punctuation. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* : */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ; */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* < */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* = */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* > */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ? */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* @ */ /* Uppercase alphabet. */ ! { ISFUNC, rl_do_lowercase_version }, /* A */ ! { ISFUNC, rl_do_lowercase_version }, /* B */ ! { ISFUNC, rl_do_lowercase_version }, /* C */ ! { ISFUNC, rl_do_lowercase_version }, /* D */ ! { ISFUNC, rl_do_lowercase_version }, /* E */ ! { ISFUNC, rl_do_lowercase_version }, /* F */ ! { ISFUNC, rl_do_lowercase_version }, /* G */ ! { ISFUNC, rl_do_lowercase_version }, /* H */ ! { ISFUNC, rl_do_lowercase_version }, /* I */ ! { ISFUNC, rl_do_lowercase_version }, /* J */ ! { ISFUNC, rl_do_lowercase_version }, /* K */ ! { ISFUNC, rl_do_lowercase_version }, /* L */ ! { ISFUNC, rl_do_lowercase_version }, /* M */ ! { ISFUNC, rl_do_lowercase_version }, /* N */ ! { ISFUNC, rl_do_lowercase_version }, /* O */ ! { ISFUNC, rl_do_lowercase_version }, /* P */ ! { ISFUNC, rl_do_lowercase_version }, /* Q */ ! { ISFUNC, rl_do_lowercase_version }, /* R */ ! { ISFUNC, rl_do_lowercase_version }, /* S */ ! { ISFUNC, rl_do_lowercase_version }, /* T */ ! { ISFUNC, rl_do_lowercase_version }, /* U */ ! { ISFUNC, rl_do_lowercase_version }, /* V */ ! { ISFUNC, rl_do_lowercase_version }, /* W */ ! { ISFUNC, rl_do_lowercase_version }, /* X */ ! { ISFUNC, rl_do_lowercase_version }, /* Y */ ! { ISFUNC, rl_do_lowercase_version }, /* Z */ /* Some more punctuation. */ ! { ISFUNC, rl_arrow_keys }, /* [ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* \ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ] */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ^ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* _ */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ` */ /* Lowercase alphabet. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* a */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* b */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* c */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* d */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* e */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* f */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* g */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* h */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* i */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* j */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* k */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* l */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* m */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* n */ ! { ISFUNC, rl_arrow_keys }, /* o */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* p */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* q */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* r */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* s */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* t */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* u */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* v */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* w */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* x */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* y */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* z */ /* Final punctuation. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* { */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* | */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* } */ ! { ISFUNC, (rl_command_func_t *)0x0 }, /* ~ */ ! { ISFUNC, rl_backward_kill_word }, /* RUBOUT */ #if KEYMAP_SIZE > 128 /* Undefined keys. */ ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 }, ! { ISFUNC, (rl_command_func_t *)0x0 } #endif /* KEYMAP_SIZE > 128 */ }; diff -Nrc2 readline-4.1/vi_mode.c readline-4.2/vi_mode.c *** readline-4.1/vi_mode.c Thu Aug 5 08:16:33 1999 --- readline-4.2/vi_mode.c Wed Nov 8 11:47:02 2000 *************** *** 82,86 **** /* Command keys which do movement for xxx_to commands. */ ! static char *vi_motion = " hl^$0ftFt;,%wbeWBE|"; /* Keymap used for vi replace characters. Created dynamically since --- 82,86 ---- /* Command keys which do movement for xxx_to commands. */ ! static const char *vi_motion = " hl^$0ftFt;,%wbeWBE|"; /* Keymap used for vi replace characters. Created dynamically since *************** *** 110,114 **** /* Text modification commands. These are the `redoable' commands. */ ! static char *vi_textmod = "_*\\AaIiCcDdPpYyRrSsXx~"; /* Arrays for the saved marks. */ --- 110,114 ---- /* Text modification commands. These are the `redoable' commands. */ ! static const char *vi_textmod = "_*\\AaIiCcDdPpYyRrSsXx~"; /* Arrays for the saved marks. */ *************** *** 275,279 **** default: ! ding (); break; } --- 275,279 ---- default: ! rl_ding (); break; } *************** *** 331,335 **** if (rl_point == 0) { ! ding (); return (0); } --- 331,335 ---- if (rl_point == 0) { ! rl_ding (); return (0); } *************** *** 353,357 **** if (rl_point >= (rl_end - 1)) { ! ding (); return (0); } --- 353,357 ---- if (rl_point >= (rl_end - 1)) { ! rl_ding (); return (0); } *************** *** 371,375 **** if (count < 0) { ! ding (); return -1; } --- 371,375 ---- if (count < 0) { ! rl_ding (); return -1; } *************** *** 745,749 **** --- 745,751 ---- rl_mark = rl_point; + RL_SETSTATE(RL_STATE_MOREINPUT); c = rl_read_key (); + RL_UNSETSTATE(RL_STATE_MOREINPUT); *nextkey = c; *************** *** 756,760 **** --- 758,764 ---- rl_digit_loop1 (); rl_numeric_arg *= save; + RL_SETSTATE(RL_STATE_MOREINPUT); c = rl_read_key (); /* real command */ + RL_UNSETSTATE(RL_STATE_MOREINPUT); *nextkey = c; } *************** *** 826,830 **** /* A simplified loop for vi. Don't dispatch key at end. ! Don't recognize minus sign? */ static int rl_digit_loop1 () --- 830,835 ---- /* A simplified loop for vi. Don't dispatch key at end. ! Don't recognize minus sign? ! Should this do rl_save_prompt/rl_restore_prompt? */ static int rl_digit_loop1 () *************** *** 832,839 **** --- 837,855 ---- int key, c; + RL_SETSTATE(RL_STATE_NUMERICARG); while (1) { + if (rl_numeric_arg > 1000000) + { + rl_explicit_arg = rl_numeric_arg = 0; + rl_ding (); + rl_clear_message (); + RL_UNSETSTATE(RL_STATE_NUMERICARG); + return 1; + } rl_message ("(arg: %d) ", rl_arg_sign * rl_numeric_arg, 0); + RL_SETSTATE(RL_STATE_MOREINPUT); key = c = rl_read_key (); + RL_UNSETSTATE(RL_STATE_MOREINPUT); if (_rl_keymap[c].type == ISFUNC && *************** *** 860,863 **** --- 876,881 ---- } } + + RL_UNSETSTATE(RL_STATE_NUMERICARG); return (0); } *************** *** 876,880 **** if (rl_vi_domove (key, &c)) { ! ding (); return -1; } --- 894,898 ---- if (rl_vi_domove (key, &c)) { ! rl_ding (); return -1; } *************** *** 904,908 **** if (rl_vi_domove (key, &c)) { ! ding (); return -1; } --- 922,926 ---- if (rl_vi_domove (key, &c)) { ! rl_ding (); return -1; } *************** *** 954,958 **** if (rl_vi_domove (key, &c)) { ! ding (); return -1; } --- 972,976 ---- if (rl_vi_domove (key, &c)) { ! rl_ding (); return -1; } *************** *** 980,984 **** if (rl_end == 0) { ! ding (); return -1; } --- 998,1002 ---- if (rl_end == 0) { ! rl_ding (); return -1; } *************** *** 1027,1031 **** target = _rl_vi_last_search_char; else ! _rl_vi_last_search_char = target = (*rl_getc_function) (rl_instream); switch (key) --- 1045,1053 ---- target = _rl_vi_last_search_char; else ! { ! RL_SETSTATE(RL_STATE_MOREINPUT); ! _rl_vi_last_search_char = target = rl_read_key (); ! RL_UNSETSTATE(RL_STATE_MOREINPUT); ! } switch (key) *************** *** 1069,1073 **** { rl_point = pos; ! ding (); return -1; } --- 1091,1095 ---- { rl_point = pos; ! rl_ding (); return -1; } *************** *** 1090,1094 **** else { ! ding (); return -1; } --- 1112,1116 ---- else { ! rl_ding (); return -1; } *************** *** 1109,1113 **** else { ! ding (); return -1; } --- 1131,1135 ---- else { ! rl_ding (); return -1; } *************** *** 1143,1147 **** c = _rl_vi_last_replacement; else ! _rl_vi_last_replacement = c = (*rl_getc_function) (rl_instream); if (c == '\033' || c == CTRL ('C')) --- 1165,1173 ---- c = _rl_vi_last_replacement; else ! { ! RL_SETSTATE(RL_STATE_MOREINPUT); ! _rl_vi_last_replacement = c = rl_read_key (); ! RL_UNSETSTATE(RL_STATE_MOREINPUT); ! } if (c == '\033' || c == CTRL ('C')) *************** *** 1239,1243 **** if (vi_replace_count == 0) { ! ding (); break; } --- 1265,1269 ---- if (vi_replace_count == 0) { ! rl_ding (); break; } *************** *** 1309,1313 **** else if (rl_line_buffer[rl_point - 1] == ';') { ! ding (); return (0); } --- 1335,1339 ---- else if (rl_line_buffer[rl_point - 1] == ';') { ! rl_ding (); return (0); } *************** *** 1327,1334 **** int ch; ch = rl_read_key (); if (_rl_lowercase_p (ch) == 0) { ! ding (); return -1; } --- 1353,1363 ---- int ch; + RL_SETSTATE(RL_STATE_MOREINPUT); ch = rl_read_key (); + RL_UNSETSTATE(RL_STATE_MOREINPUT); + if (_rl_lowercase_p (ch) == 0) { ! rl_ding (); return -1; } *************** *** 1344,1348 **** --- 1373,1380 ---- int ch; + RL_SETSTATE(RL_STATE_MOREINPUT); ch = rl_read_key (); + RL_UNSETSTATE(RL_STATE_MOREINPUT); + if (ch == '`') { *************** *** 1352,1356 **** else if (_rl_lowercase_p (ch) == 0) { ! ding (); return -1; } --- 1384,1388 ---- else if (_rl_lowercase_p (ch) == 0) { ! rl_ding (); return -1; } *************** *** 1359,1363 **** if (vi_mark_chars[ch] == -1) { ! ding (); return -1; } --- 1391,1395 ---- if (vi_mark_chars[ch] == -1) { ! rl_ding (); return -1; }