diff options
Diffstat (limited to 'doc/gawk.info')
-rw-r--r-- | doc/gawk.info | 1866 |
1 files changed, 1124 insertions, 742 deletions
diff --git a/doc/gawk.info b/doc/gawk.info index b927b445..24a4a638 100644 --- a/doc/gawk.info +++ b/doc/gawk.info @@ -217,6 +217,7 @@ entitled "GNU Free Documentation License". `getline'. * Getline Summary:: Summary of `getline' Variants. * Read Timeout:: Reading input with a timeout. +* Retrying Input:: Retrying input after certain errors. * Command-line directories:: What happens if you put a directory on the command line. * Input Summary:: Input summary. @@ -246,6 +247,7 @@ entitled "GNU Free Documentation License". * Special Caveats:: Things to watch out for. * Close Files And Pipes:: Closing Input and Output Files and Pipes. +* Nonfatal:: Enabling Nonfatal Output. * Output Summary:: Output summary. * Output Exercises:: Exercises. * Values:: Constants, Variables, and Regular @@ -557,6 +559,7 @@ entitled "GNU Free Documentation License". * Array Functions:: Functions for working with arrays. * Flattening Arrays:: How to flatten arrays. * Creating Arrays:: How to create and populate arrays. +* Redirection API:: How to access and manipulate redirections. * Extension API Variables:: Variables provided by the API. * Extension Versioning:: API Version information. * Extension API Informational Variables:: Variables providing information about @@ -615,6 +618,7 @@ entitled "GNU Free Documentation License". * Unix Installation:: Installing `gawk' under various versions of Unix. * Quick Installation:: Compiling `gawk' under Unix. +* Shell Startup Files:: Shell convenience functions. * Additional Configuration Options:: Other compile-time options. * Configuration Philosophy:: How it's all supposed to work. * Non-Unix Installation:: Installation on Other Operating @@ -2640,10 +2644,8 @@ The following list describes options mandated by the POSIX standard: different file name for the output. No space is allowed between the `-o' and FILE, if FILE is supplied. - NOTE: Due to the way `gawk' has evolved, with this option - your program still executes. This will change in the next - major release, such that `gawk' will only pretty-print the - program and not run it. + NOTE: In the past, this option would also execute your + program. This is no longer the case. `-O' `--optimize' @@ -2943,6 +2945,9 @@ Since `.' is included at the beginning, `gawk' searches first in the current directory and then in `/usr/local/share/awk'. In practice, this means that you will rarely need to change the value of `AWKPATH'. + *Note Shell Startup Files::, for information on functions that help +to manipulate the `AWKPATH' variable. + `gawk' places the value of the search path that it used into `ENVIRON["AWKPATH"]'. This provides access to the actual search path value from within an `awk' program. @@ -2982,6 +2987,9 @@ empty value, `gawk' uses a default path; this is typically `/usr/local/lib/gawk', although it can vary depending upon how `gawk' was built. + *Note Shell Startup Files::, for information on functions that help +to manipulate the `AWKLIBPATH' variable. + `gawk' places the value of the search path that it used into `ENVIRON["AWKLIBPATH"]'. This provides access to the actual search path value from within an `awk' program. @@ -3008,7 +3016,8 @@ used by regular users: `GAWK_SOCK_RETRIES' Controls the number of times `gawk' attempts to retry a two-way TCP/IP (socket) connection before giving up. *Note TCP/IP - Networking::. + Networking::. Note that when nonfatal I/O is enabled (*note + Nonfatal::), `gawk' only tries to open a TCP/IP socket once. `POSIXLY_CORRECT' Causes `gawk' to switch to POSIX-compatibility mode, disabling all @@ -3053,13 +3062,6 @@ change. The variables are: supposed to be differences, but occasionally theory and practice don't coordinate with each other.) -`GAWK_NO_PP_RUN' - When `gawk' is invoked with the `--pretty-print' option, it will - not run the program if this environment variable exists. - - CAUTION: This variable will not survive into the next major - release. - `GAWK_STACKSIZE' This specifies the amount by which `gawk' should grow its internal evaluation stack, when needed. @@ -3451,15 +3453,18 @@ sequences apply to both string constants and regexp constants: `\xHH...' The hexadecimal value HH, where HH stands for a sequence of - hexadecimal digits (`0'-`9', and either `A'-`F' or `a'-`f'). Like - the same construct in ISO C, the escape sequence continues until - the first nonhexadecimal digit is seen. (c.e.) However, using - more than two hexadecimal digits produces undefined results. (The - `\x' escape sequence is not allowed in POSIX `awk'.) - - CAUTION: The next major release of `gawk' will change, such - that a maximum of two hexadecimal digits following the `\x' - will be used. + hexadecimal digits (`0'-`9', and either `A'-`F' or `a'-`f'). A + maximum of two digts are allowed after the `\x'. Any further + hexadecimal digits are treated as simple letters or numbers. + (c.e.) (The `\x' escape sequence is not allowed in POSIX awk.) + + CAUTION: In ISO C, the escape sequence continues until the + first nonhexadecimal digit is seen. For many years, `gawk' + would continue incorporating hexadecimal digits into the + value until a non-hexadecimal digit or the end of the string + was encountered. However, using more than two hexadecimal + digits produced undefined results. As of version 4.2, only + two digits are processed. `\/' A literal slash (necessary for regexp constants only). This @@ -4175,6 +4180,7 @@ have to be named on the `awk' command line (*note Getline::). * Getline:: Reading files under explicit program control using the `getline' function. * Read Timeout:: Reading input with a timeout. +* Retrying Input:: Retrying input after certain errors. * Command-line directories:: What happens if you put a directory on the command line. * Input Summary:: Input summary. @@ -5447,6 +5453,11 @@ record, such as a file that cannot be opened, then `getline' returns -1. In this case, `gawk' sets the variable `ERRNO' to a string describing the error that occurred. + If `ERRNO' indicates that the I/O operation may be retried, and +`PROCINFO["INPUT", "RETRY"]' is set, then `getline' returns -2 instead +of -1, and further calls to `getline' may be attemped. *Note Retrying +Input::, for further information about this feature. + In the following examples, COMMAND stands for a string value that represents a shell command. @@ -5883,7 +5894,7 @@ VAR Table 4.1: `getline' variants and what they set -File: gawk.info, Node: Read Timeout, Next: Command-line directories, Prev: Getline, Up: Reading Files +File: gawk.info, Node: Read Timeout, Next: Retrying Input, Prev: Getline, Up: Reading Files 4.10 Reading Input with a Timeout ================================= @@ -5962,7 +5973,8 @@ a per-command or per-connection basis. `gawk' considers a timeout event to be an error even though the attempt to read from the underlying device may succeed in a later attempt. This is a limitation, and it also means that you cannot use -this to multiplex input from two or more sources. +this to multiplex input from two or more sources. *Note Retrying +Input::, for a way to enable later I/O attempts to succeed. Assigning a timeout value prevents read operations from blocking indefinitely. But bear in mind that there are other ways `gawk' can @@ -5977,9 +5989,36 @@ writing. (1) This assumes that standard input is the keyboard. -File: gawk.info, Node: Command-line directories, Next: Input Summary, Prev: Read Timeout, Up: Reading Files +File: gawk.info, Node: Retrying Input, Next: Command-line directories, Prev: Read Timeout, Up: Reading Files + +4.11 Retrying Reads After Certain Input Errors +============================================== + +This minor node describes a feature that is specific to `gawk'. + + When `gawk' encounters an error while reading input, by default +`getline' returns -1, and subsequent attempts to read from that file +result in an end-of-file indication. However, you may optionally +instruct `gawk' to allow I/O to be retried when certain errors are +encountered by setting a special element in the `PROCINFO' array (*note +Auto-set::): + + PROCINFO["INPUT_NAME", "RETRY"] = 1 + + When this element exists, `gawk' checks the value of the system (C +language) `errno' variable when an I/O error occurs. If `errno' +indicates a subsequent I/O attempt may succeed, `getline' instead +returns -2 and further calls to `getline' may succeed. This applies to +the `errno' values `EAGAIN', `EWOULDBLOCK', `EINTR', or `ETIMEDOUT'. + + This feature is useful in conjunction with `PROCINFO["INPUT_NAME", +"READ_TIMEOUT"]' or situations where a file descriptor has been +configured to behave in a non-blocking fashion. + + +File: gawk.info, Node: Command-line directories, Next: Input Summary, Prev: Retrying Input, Up: Reading Files -4.11 Directories on the Command Line +4.12 Directories on the Command Line ==================================== According to the POSIX standard, files named on the `awk' command line @@ -6002,7 +6041,7 @@ usable data from an `awk' program. File: gawk.info, Node: Input Summary, Next: Input Exercises, Prev: Command-line directories, Up: Reading Files -4.12 Summary +4.13 Summary ============ * Input is split into records based on the value of `RS'. The @@ -6076,7 +6115,7 @@ File: gawk.info, Node: Input Summary, Next: Input Exercises, Prev: Command-li File: gawk.info, Node: Input Exercises, Prev: Input Summary, Up: Reading Files -4.13 Exercises +4.14 Exercises ============== 1. Using the `FIELDWIDTHS' variable (*note Constant Size::), write a @@ -6127,6 +6166,7 @@ function. `gawk' allows access to inherited file descriptors. * Close Files And Pipes:: Closing Input and Output Files and Pipes. +* Nonfatal:: Enabling Nonfatal Output. * Output Summary:: Output summary. * Output Exercises:: Exercises. @@ -7040,7 +7080,7 @@ that `gawk' provides: behavior. -File: gawk.info, Node: Close Files And Pipes, Next: Output Summary, Prev: Special Files, Up: Printing +File: gawk.info, Node: Close Files And Pipes, Next: Nonfatal, Prev: Special Files, Up: Printing 5.9 Closing Input and Output Redirections ========================================= @@ -7209,9 +7249,68 @@ call. See the system manual pages for information on how to decode this value. -File: gawk.info, Node: Output Summary, Next: Output Exercises, Prev: Close Files And Pipes, Up: Printing +File: gawk.info, Node: Nonfatal, Next: Output Summary, Prev: Close Files And Pipes, Up: Printing + +5.10 Enabling Nonfatal Output +============================= + +This minor node describes a `gawk'-specific feature. + + In standard `awk', output with `print' or `printf' to a nonexistent +file, or some other I/O error (such as filling up the disk) is a fatal +error. + + $ gawk 'BEGIN { print "hi" > "/no/such/file" }' + error--> gawk: cmd. line:1: fatal: can't redirect to `/no/such/file' (No such file or directory) + + `gawk' makes it possible to detect that an error has occurred, +allowing you to possibly recover from the error, or at least print an +error message of your choosing before exiting. You can do this in one +of two ways: + + * For all output files, by assigning any value to + `PROCINFO["NONFATAL"]'. + + * On a per-file basis, by assigning any value to `PROCINFO[FILENAME, + "NONFATAL"]'. Here, FILENAME is the name of the file to which you + wish output to be nonfatal. + + Once you have enabled nonfatal output, you must check `ERRNO' after +every relevant `print' or `printf' statement to see if something went +wrong. It is also a good idea to initialize `ERRNO' to zero before +attempting the output. For example: + + $ gawk ' + > BEGIN { + > PROCINFO["NONFATAL"] = 1 + > ERRNO = 0 + > print "hi" > "/no/such/file" + > if (ERRNO) { + > print("Output failed:", ERRNO) > "/dev/stderr" + > exit 1 + > } + > }' + error--> Output failed: No such file or directory + + Here, `gawk' did not produce a fatal error; instead it let the `awk' +program code detect the problem and handle it. + + This mechanism works also for standard output and standard error. +For standard output, you may use `PROCINFO["-", "NONFATAL"]' or +`PROCINFO["/dev/stdout", "NONFATAL"]'. For standard error, use +`PROCINFO["/dev/stderr", "NONFATAL"]'. + + When attempting to open a TCP/IP socket (*note TCP/IP Networking::), +`gawk' tries multiple times. The `GAWK_SOCK_RETRIES' environment +variable (*note Other Environment Variables::) allows you to override +`gawk''s builtin default number of attempts. However, once nonfatal +I/O is enabled for a given socket, `gawk' only retries once, relying on +`awk'-level code to notice that there was a problem. + + +File: gawk.info, Node: Output Summary, Next: Output Exercises, Prev: Nonfatal, Up: Printing -5.10 Summary +5.11 Summary ============ * The `print' statement prints comma-separated expressions. Each @@ -7233,11 +7332,16 @@ File: gawk.info, Node: Output Summary, Next: Output Exercises, Prev: Close Fi For coprocesses, it is possible to close only one direction of the communications. + * Normally errors with `print' or `printf' are fatal. `gawk' lets + you make output errors be nonfatal either for all files or on a + per-file basis. You must then check for errors after every + relevant output statement. + File: gawk.info, Node: Output Exercises, Prev: Output Summary, Up: Printing -5.11 Exercises +5.12 Exercises ============== 1. Rewrite the program: @@ -10332,10 +10436,24 @@ Options::), they are not special: An associative array containing the values of the environment. The array indices are the environment variable names; the elements are the values of the particular environment variables. For - example, `ENVIRON["HOME"]' might be `"/home/arnold"'. Changing - this array does not affect the environment passed on to any - programs that `awk' may spawn via redirection or the `system()' - function. (In a future version of `gawk', it may do so.) + example, `ENVIRON["HOME"]' might be `/home/arnold'. + + For POSIX `awk', changing this array does not affect the + environment passed on to any programs that `awk' may spawn via + redirection or the `system()' function. + + However, beginning with version 4.2, if not in POSIX compatibility + mode, `gawk' does update its own environment when `ENVIRON' is + changed, thus changing the environment seen by programs that it + creates. You should therefore be especially careful if you modify + `ENVIRON["PATH"]"', which is the search path for finding + executable programs. + + This can also affect the running `gawk' program, since some of the + built-in functions may pay attention to certain environment + variables. The most notable instance of this is `mktime()' (*note + Time Functions::), which pays attention the value of the `TZ' + environment variable on many systems. Some operating systems may not have environment variables. On such systems, the `ENVIRON' array is empty (except for @@ -10358,6 +10476,11 @@ Options::), they are not special: `getline' returning -1. You are, of course, free to clear it yourself before doing an I/O operation. + If the value of `ERRNO' corresponds to a system error in the C + `errno' variable, then `PROCINFO["errno"]' will be set to the value + of `errno'. For non-system errors, `PROCINFO["errno"]' will be + zero. + `FILENAME' The name of the current input file. When no data files are listed on the command line, `awk' reads from the standard input and @@ -10406,6 +10529,10 @@ Options::), they are not special: `PROCINFO["egid"]' The value of the `getegid()' system call. + `PROCINFO["errno"]' + The value of the C `errno' variable when `ERRNO' is set to + the associated error message. + `PROCINFO["euid"]' The value of the `geteuid()' system call. @@ -10516,6 +10643,10 @@ Options::), they are not special: open input file, pipe, or coprocess. *Note Read Timeout::, for more information. + * It may be used to indicate that input may be retried when it + fails due to certain errors. *Note Retrying Input::, for + more information. + * It may be used to cause coprocesses to communicate over pseudo-ttys instead of through two-way pipes; this is discussed further in *note Two-way I/O::. @@ -11900,6 +12031,21 @@ brackets ([ ]): `cos(X)' Return the cosine of X, with X in radians. +`div(NUMERATOR, DENOMINATOR, RESULT)' + Perform integer division, similar to the standard C function of the + same name. First, truncate `numerator' and `denominator' towards + zero, creating integer values. Clear the `result' array, and then + set `result["quotient"]' to the result of `numerator / + denominator', truncated towards zero to an integer, and set + `result["remainder"]' to the result of `numerator % denominator', + truncated towards zero to an integer. This function is primarily + intended for use with arbitrary length integers; it avoids + creating MPFR arbitrary precision floating-point values (*note + Arbitrary Precision Integers::). + + This function is a `gawk' extension. It is not available in + compatibility mode (*note Options::). + `exp(X)' Return the exponential of X (`e ^ X') or report an error if X is out of range. The range of values X can have depends on your @@ -19912,8 +20058,7 @@ output. They are as follows: you typed when you wrote it. This is because `gawk' creates the profiled version by "pretty-printing" its internal representation of the program. The advantage to this is that `gawk' can produce a -standard representation. The disadvantage is that all source code -comments are lost. Also, things such as: +standard representation. Also, things such as: /foo/ @@ -19972,8 +20117,24 @@ the `Ctrl-\' key. called this way, `gawk' "pretty-prints" the program into `awkprof.out', without any execution counts. - NOTE: The `--pretty-print' option still runs your program. This - will change in the next major release. + NOTE: Once upon a time, the `--pretty-print' option would also run + your program. This is is no longer the case. + + There is a significant difference between the output created when +profiling, and that created when pretty-printing. Pretty-printed output +preserves the original comments that were in the program, although their +placement may not correspond exactly to their original locations in the +source code. + + However, as a deliberate design decision, profiling output _omits_ +the original program's comments. This allows you to focus on the +execution count data and helps you avoid the temptation to use the +profiler for pretty-printing. + + Additionally, pretty-printed output does not have the leading +indentation that the profiling output does. This makes it easy to +pretty-print your code once development is completed, and then use the +result as the final version of your program. File: gawk.info, Node: Advanced Features Summary, Prev: Profiling, Up: Advanced Features @@ -22453,6 +22614,62 @@ the following: gawk -M 'BEGIN { n = 13; print n % 2 }' + When dividing two arbitrary precision integers with either `/' or +`%', the result is typically an arbitrary precision floating point +value (unless the denominator evenly divides into the numerator). In +order to do integer division or remainder with arbitrary precision +integers, use the built-in `div()' function (*note Numeric Functions::). + + You can simulate the `div()' function in standard `awk' using this +user-defined function: + + # div --- do integer division + + function div(numerator, denominator, result) + { + split("", result) + + numerator = int(numerator) + denominator = int(denominator) + result["quotient"] = int(numerator / denominator) + result["remainder"] = int(numerator % denominator) + + return 0.0 + } + + The following example program, contributed by Katie Wasserman, uses +`div()' to compute the digits of pi to as many places as you choose to +set: + + # pi.awk --- compute the digits of pi + + BEGIN { + digits = 100000 + two = 2 * 10 ^ digits + pi = two + for (m = digits * 4; m > 0; --m) { + d = m * 2 + 1 + x = pi * m + div(x, d, result) + pi = result["quotient"] + pi = pi + two + } + print pi + } + + When asked about the algorithm used, Katie replied: + + It's not that well known but it's not that obscure either. It's + Euler's modification to Newton's method for calculating pi. Take + a look at lines (23) - (25) here: + `http://mathworld.wolfram.com/PiFormulas.html'. + + The algorithm I wrote simply expands the multiply by 2 and works + from the innermost expression outwards. I used this to program HP + calculators because it's quite easy to modify for tiny memory + devices with smallish word sizes. See + `http://www.hpmuseum.org/cgi-sys/cgiwrap/hpmuseum/articles.cgi?read=899'. + ---------- Footnotes ---------- (1) Weisstein, Eric W. `Sylvester's Sequence'. From MathWorld--A @@ -22813,6 +23030,7 @@ describes the API in detail. * Symbol Table Access:: Functions for accessing global variables. * Array Manipulation:: Functions for working with arrays. +* Redirection API:: How to access and manipulate redirections. * Extension API Variables:: Variables provided by the API. * Extension API Boilerplate:: Boilerplate code for using the API. @@ -22873,6 +23091,9 @@ operations: - Flattening an array for easy C-style looping over all its indices and elements + * Accessing and manipulating redirections. + + Some points about using the API: * The following types, macros, and/or functions are referenced in @@ -24084,7 +24305,7 @@ using `release_value()'. `double' to store. -File: gawk.info, Node: Array Manipulation, Next: Extension API Variables, Prev: Symbol Table Access, Up: Extension API Description +File: gawk.info, Node: Array Manipulation, Next: Redirection API, Prev: Symbol Table Access, Up: Extension API Description 16.4.11 Array Manipulation -------------------------- @@ -24569,9 +24790,78 @@ array: environment variable.) -File: gawk.info, Node: Extension API Variables, Next: Extension API Boilerplate, Prev: Array Manipulation, Up: Extension API Description +File: gawk.info, Node: Redirection API, Next: Extension API Variables, Prev: Array Manipulation, Up: Extension API Description + +16.4.12 Accessing and Manipulating Redirections +----------------------------------------------- + +The following function allows extensions to access and manipulate +redirections. + +`awk_bool_t get_file(const char *name,' +` size_t name_len,' +` const char *filetype,' +` int fd,' +` const awk_input_buf_t **ibufp,' +` const awk_output_buf_t **obufp);' + Look up a file in `gawk''s internal redirection table. If `name' + is `NULL' or `name_len' is zero, return data for the currently + open input file corresponding to `FILENAME'. (This does not + access the `filetype' argument, so that may be undefined). If the + file is not already open, attempt to open it. The `filetype' + argument must be zero-terminated and should be one of: + + `">"' + A file opened for output. + + `">>"' + A file opened for append. + + `"<"' + A file opened for input. + + `"|>"' + A pipe opened for output. + + `"|<"' + A pipe opened for input. + + `"|&"' + A two-way coprocess. + + On error, return a `false' value. Otherwise, return `true', and + return additional information about the redirection in the `ibufp' + and `obufp' pointers. For input redirections, the `*ibufp' value + should be non-`NULL', and `*obufp' should be `NULL'. For output + redirections, the `*obufp' value should be non-`NULL', and `*ibufp' + should be `NULL'. For two-way coprocesses, both values should be + non-`NULL'. + + In the usual case, the extension is interested in `(*ibufp)->fd' + and/or `fileno((*obufp)->fp)'. If the file is not already open, + and the `fd' argument is non-negative, `gawk' will use that file + descriptor instead of opening the file in the usual way. If `fd' + is non-negative, but the file exists already, `gawk' ignores `fd' + and returns the existing file. It is the caller's responsibility + to notice that neither the `fd' in the returned `awk_input_buf_t' + nor the `fd' in the returned `awk_output_buf_t' matches the + requested value. + + Note that supplying a file descriptor is currently _not_ supported + for pipes. However, supplying a file descriptor should work for + input, output, append, and two-way (coprocess) sockets. If + `filetype' is two-way, `gawk' assumes that it is a socket! Note + that in the two-way case, the input and output file descriptors + may differ. To check for success, you must check whether either + matches. + + It is anticipated that this API function will be used to implement +I/O multiplexing and a socket library. + + +File: gawk.info, Node: Extension API Variables, Next: Extension API Boilerplate, Prev: Redirection API, Up: Extension API Description -16.4.12 API Variables +16.4.13 API Variables --------------------- The API provides two sets of variables. The first provides information @@ -24588,7 +24878,7 @@ information about how `gawk' was invoked. File: gawk.info, Node: Extension Versioning, Next: Extension API Informational Variables, Up: Extension API Variables -16.4.12.1 API Version Constants and Variables +16.4.13.1 API Version Constants and Variables ............................................. The API provides both a "major" and a "minor" version number. The API @@ -24637,7 +24927,7 @@ Boilerplate::). File: gawk.info, Node: Extension API Informational Variables, Prev: Extension Versioning, Up: Extension API Variables -16.4.12.2 Informational Variables +16.4.13.2 Informational Variables ................................. The API provides access to several variables that describe whether the @@ -24672,7 +24962,7 @@ not change during execution. File: gawk.info, Node: Extension API Boilerplate, Prev: Extension API Variables, Up: Extension API Description -16.4.13 Boilerplate Code +16.4.14 Boilerplate Code ------------------------ As mentioned earlier (*note Extension Mechanism Outline::), the function @@ -25977,15 +26267,17 @@ project. * GD graphics library extension + * MPFR library extension (this provides access to a number of MPFR + functions that `gawk''s native MPFR support does not) + * PDF extension * PostgreSQL extension - * MPFR library extension (this provides access to a number of MPFR - functions that `gawk''s native MPFR support does not) - * Redis extension + * Select extension + * XML parser extension, using the Expat (http://expat.sourceforge.net) XML parsing library @@ -26408,6 +26700,9 @@ the current version of `gawk'. - Directories on the command line produce a warning and are skipped (*note Command-line directories::) + - Output with `print' and `printf' need not be fatal (*note + Nonfatal::) + * New keywords: - The `BEGINFILE' and `ENDFILE' special patterns (*note @@ -26457,6 +26752,9 @@ the current version of `gawk'. - The `bindtextdomain()', `dcgettext()', and `dcngettext()' functions for internationalization (*note Programmer i18n::) + - The `div()' function for doing integer division and remainder + (*note Numeric Functions::) + * Changes and/or additions in the command-line options: - The `AWKPATH' environment variable for specifying a path @@ -26511,6 +26809,11 @@ the current version of `gawk'. - Ultrix + * Support for the following systems was removed from the code for + `gawk' version 4.2: + + - MirBSD + File: gawk.info, Node: Feature History, Next: Common Extensions, Prev: POSIX/GNU, Up: Language History @@ -26896,6 +27199,28 @@ in POSIX `awk', in the order they were added to `gawk'. * The dynamic extension interface was completely redone (*note Dynamic Extensions::). + * Support for Ultrix was removed. + + + Version 4.2 introduced the following changes: + + * Changes to `ENVIRON' are reflected into `gawk''s environment and + that of programs that it runs. *Note Auto-set::. + + * The `--pretty-print' option no longer runs the `awk' program too. + *Note Options::. + + * The `igawk' program and its manual page are no longer installed + when `gawk' is built. *Note Igawk Program::. + + * The `div()' function. *Note Numeric Functions::. + + * The maximum number of hexdecimal digits in `\x' escapes is now two. + *Note Escape Sequences::. + + * Nonfatal output with `print' and `printf'. *Note Nonfatal::. + + * Support for MirBSD was removed. File: gawk.info, Node: Common Extensions, Next: Ranges and Locales, Prev: Feature History, Up: Language History @@ -27413,7 +27738,9 @@ Various `.c', `.y', and `.h' files `doc/igawk.1' The `troff' source for a manual page describing the `igawk' - program presented in *note Igawk Program::. + program presented in *note Igawk Program::. (Since `gawk' can do + its own `@include' processing, neither `igawk' nor `igawk.1' are + installed.) `doc/Makefile.in' The input file used during the configuration process to generate @@ -27455,17 +27782,23 @@ Various `.c', `.y', and `.h' files contains a `Makefile.in' file, which `configure' uses to generate a `Makefile'. `Makefile.am' is used by GNU Automake to create `Makefile.in'. The library functions from *note Library - Functions::, and the `igawk' program from *note Igawk Program::, - are included as ready-to-use files in the `gawk' distribution. - They are installed as part of the installation process. The rest - of the programs in this Info file are available in appropriate - subdirectories of `awklib/eg'. + Functions::, are included as ready-to-use files in the `gawk' + distribution. They are installed as part of the installation + process. The rest of the programs in this Info file are available + in appropriate subdirectories of `awklib/eg'. `extension/*' The source code, manual pages, and infrastructure files for the sample extensions included with `gawk'. *Note Dynamic Extensions::, for more information. +`extras/*' + Additional non-essential files. Currently, this directory + contains some shell startup files to be installed in + `/etc/profile.d' to aid in manipulating the `AWKPATH' and + `AWKLIBPATH' environment variables. *Note Shell Startup Files::, + for more information. + `posix/*' Files needed for building `gawk' on POSIX-compliant systems. @@ -27496,11 +27829,12 @@ configure `gawk' for your system yourself. * Menu: * Quick Installation:: Compiling `gawk' under Unix. +* Shell Startup Files:: Shell convenience functions. * Additional Configuration Options:: Other compile-time options. * Configuration Philosophy:: How it's all supposed to work. -File: gawk.info, Node: Quick Installation, Next: Additional Configuration Options, Up: Unix Installation +File: gawk.info, Node: Quick Installation, Next: Shell Startup Files, Up: Unix Installation B.2.1 Compiling `gawk' for Unix-Like Systems -------------------------------------------- @@ -27556,9 +27890,43 @@ will be asked for your password, and you will have to have been set up previously as a user who is allowed to run the `sudo' command. -File: gawk.info, Node: Additional Configuration Options, Next: Configuration Philosophy, Prev: Quick Installation, Up: Unix Installation +File: gawk.info, Node: Shell Startup Files, Next: Additional Configuration Options, Prev: Quick Installation, Up: Unix Installation + +B.2.2 Shell Startup Files +------------------------- + +The distribution contains shell startup files `gawk.sh' and `gawk.csh' +containing functions to aid in manipulating the `AWKPATH' and +`AWKLIBPATH' environment variables. On a Fedora system, these files +should be installed in `/etc/profile.d'; on other platforms, the +appropriate location may be different. + +`gawkpath_default' + Reset the `AWKPATH' environment variable to its default value. + +`gawkpath_prepend' + Add the argument to the front of the `AWKPATH' environment + variable. + +`gawkpath_append' + Add the argument to the end of the `AWKPATH' environment variable. + +`gawklibpath_default' + Reset the `AWKLIBPATH' environment variable to its default value. + +`gawklibpath_prepend' + Add the argument to the front of the `AWKLIBPATH' environment + variable. + +`gawklibpath_append' + Add the argument to the end of the `AWKLIBPATH' environment + variable. + + + +File: gawk.info, Node: Additional Configuration Options, Next: Configuration Philosophy, Prev: Shell Startup Files, Up: Unix Installation -B.2.2 Additional Configuration Options +B.2.3 Additional Configuration Options -------------------------------------- There are several additional options you may use on the `configure' @@ -27602,7 +27970,7 @@ supplied by `configure'. File: gawk.info, Node: Configuration Philosophy, Prev: Additional Configuration Options, Up: Unix Installation -B.2.3 The Configuration Process +B.2.4 The Configuration Process ------------------------------- This minor node is of interest only if you know something about using @@ -31554,20 +31922,20 @@ Index * --include option: Options. (line 159) * --lint option <1>: Options. (line 185) * --lint option: Command Line. (line 20) -* --lint-old option: Options. (line 297) +* --lint-old option: Options. (line 295) * --load option: Options. (line 173) * --non-decimal-data option <1>: Nondecimal Data. (line 6) * --non-decimal-data option: Options. (line 211) * --non-decimal-data option, strtonum() function and: Nondecimal Data. (line 35) -* --optimize option: Options. (line 238) -* --posix option: Options. (line 256) -* --posix option, --traditional option and: Options. (line 275) +* --optimize option: Options. (line 236) +* --posix option: Options. (line 254) +* --posix option, --traditional option and: Options. (line 273) * --pretty-print option: Options. (line 225) * --profile option <1>: Profiling. (line 12) -* --profile option: Options. (line 244) -* --re-interval option: Options. (line 281) -* --sandbox option: Options. (line 288) +* --profile option: Options. (line 242) +* --re-interval option: Options. (line 279) +* --sandbox option: Options. (line 286) * --sandbox option, disabling system() function: I/O Functions. (line 129) * --sandbox option, input redirection with getline: Getline. (line 19) @@ -31575,9 +31943,9 @@ Index (line 6) * --source option: Options. (line 117) * --traditional option: Options. (line 81) -* --traditional option, --posix option and: Options. (line 275) +* --traditional option, --posix option and: Options. (line 273) * --use-lc-numeric option: Options. (line 220) -* --version option: Options. (line 302) +* --version option: Options. (line 300) * --with-whiny-user-strftime configuration option: Additional Configuration Options. (line 37) * -b option: Options. (line 68) @@ -31585,32 +31953,32 @@ Index * -c option: Options. (line 81) * -D option: Options. (line 108) * -d option: Options. (line 93) -* -e option: Options. (line 338) +* -e option: Options. (line 336) * -E option: Options. (line 125) * -e option: Options. (line 117) * -f option: Options. (line 25) * -F option: Options. (line 21) * -f option: Long. (line 12) -* -F option, -Ft sets FS to TAB: Options. (line 310) +* -F option, -Ft sets FS to TAB: Options. (line 308) * -F option, command-line: Command Line Field Separator. (line 6) -* -f option, multiple uses: Options. (line 315) +* -f option, multiple uses: Options. (line 313) * -g option: Options. (line 147) * -h option: Options. (line 154) * -i option: Options. (line 159) -* -L option: Options. (line 297) +* -L option: Options. (line 295) * -l option: Options. (line 173) * -M option: Options. (line 205) * -N option: Options. (line 220) * -n option: Options. (line 211) -* -O option: Options. (line 238) +* -O option: Options. (line 236) * -o option: Options. (line 225) -* -P option: Options. (line 256) -* -p option: Options. (line 244) -* -r option: Options. (line 281) -* -S option: Options. (line 288) +* -P option: Options. (line 254) +* -p option: Options. (line 242) +* -r option: Options. (line 279) +* -S option: Options. (line 286) * -v option: Assignment Options. (line 12) -* -V option: Options. (line 302) +* -V option: Options. (line 300) * -v option: Options. (line 32) * -W option: Options. (line 46) * . (period), regexp operator: Regexp Operators. (line 44) @@ -31672,10 +32040,10 @@ Index (line 8) * [] (square brackets), regexp operator: Regexp Operators. (line 56) * \ (backslash): Comments. (line 50) -* \ (backslash), \" escape sequence: Escape Sequences. (line 82) +* \ (backslash), \" escape sequence: Escape Sequences. (line 85) * \ (backslash), \' operator (gawk): GNU Regexp Operators. (line 56) -* \ (backslash), \/ escape sequence: Escape Sequences. (line 73) +* \ (backslash), \/ escape sequence: Escape Sequences. (line 76) * \ (backslash), \< operator (gawk): GNU Regexp Operators. (line 30) * \ (backslash), \> operator (gawk): GNU Regexp Operators. @@ -31715,7 +32083,7 @@ Index * \ (backslash), in bracket expressions: Bracket Expressions. (line 17) * \ (backslash), in escape sequences: Escape Sequences. (line 6) * \ (backslash), in escape sequences, POSIX and: Escape Sequences. - (line 105) + (line 108) * \ (backslash), in regexp constants: Computed Regexps. (line 30) * \ (backslash), in shell commands: Quoting. (line 48) * \ (backslash), regexp operator: Regexp Operators. (line 18) @@ -31883,7 +32251,7 @@ Index * awf (amazingly workable formatter) program: Glossary. (line 24) * awk debugging, enabling: Options. (line 108) * awk language, POSIX version: Assignment Ops. (line 137) -* awk profiling, enabling: Options. (line 244) +* awk profiling, enabling: Options. (line 242) * awk programs <1>: Two Rules. (line 6) * awk programs <2>: Executable Scripts. (line 6) * awk programs: Getting Started. (line 12) @@ -31941,10 +32309,10 @@ Index * awkvars.out file: Options. (line 93) * b debugger command (alias for break): Breakpoint Control. (line 11) * backslash (\): Comments. (line 50) -* backslash (\), \" escape sequence: Escape Sequences. (line 82) +* backslash (\), \" escape sequence: Escape Sequences. (line 85) * backslash (\), \' operator (gawk): GNU Regexp Operators. (line 56) -* backslash (\), \/ escape sequence: Escape Sequences. (line 73) +* backslash (\), \/ escape sequence: Escape Sequences. (line 76) * backslash (\), \< operator (gawk): GNU Regexp Operators. (line 30) * backslash (\), \> operator (gawk): GNU Regexp Operators. @@ -31984,7 +32352,7 @@ Index * backslash (\), in bracket expressions: Bracket Expressions. (line 17) * backslash (\), in escape sequences: Escape Sequences. (line 6) * backslash (\), in escape sequences, POSIX and: Escape Sequences. - (line 105) + (line 108) * backslash (\), in regexp constants: Computed Regexps. (line 30) * backslash (\), in shell commands: Quoting. (line 48) * backslash (\), regexp operator: Regexp Operators. (line 18) @@ -32090,7 +32458,7 @@ Index (line 67) * Brian Kernighan's awk <12>: GNU Regexp Operators. (line 82) -* Brian Kernighan's awk <13>: Escape Sequences. (line 109) +* Brian Kernighan's awk <13>: Escape Sequences. (line 112) * Brian Kernighan's awk: When. (line 21) * Brian Kernighan's awk, extensions: BTL. (line 6) * Brian Kernighan's awk, source code: Other Versions. (line 13) @@ -32284,7 +32652,7 @@ Index * cosine: Numeric Functions. (line 15) * counting: Wc Program. (line 6) * csh utility: Statements/Lines. (line 44) -* csh utility, POSIXLY_CORRECT environment variable: Options. (line 356) +* csh utility, POSIXLY_CORRECT environment variable: Options. (line 354) * csh utility, |& operator, comparison with: Two-way I/O. (line 25) * ctime() user-defined function: Function Example. (line 74) * currency symbols, localization: Explaining gettext. (line 104) @@ -32315,12 +32683,12 @@ Index * dark corner, CONVFMT variable: Strings And Numbers. (line 40) * dark corner, escape sequences: Other Arguments. (line 38) * dark corner, escape sequences, for metacharacters: Escape Sequences. - (line 140) + (line 143) * dark corner, exit statement: Exit Statement. (line 30) * dark corner, field separators: Full Line Fields. (line 22) -* dark corner, FILENAME variable <1>: Auto-set. (line 90) +* dark corner, FILENAME variable <1>: Auto-set. (line 109) * dark corner, FILENAME variable: Getline Notes. (line 19) -* dark corner, FNR/NR variables: Auto-set. (line 314) +* dark corner, FNR/NR variables: Auto-set. (line 341) * dark corner, format-control characters: Control Letters. (line 18) * dark corner, FS as null string: Single Character Fields. (line 20) @@ -32470,7 +32838,7 @@ Index * debugger, read commands from a file: Debugger Info. (line 97) * debugging awk programs: Debugger. (line 6) * debugging gawk, bug reports: Bugs. (line 9) -* decimal point character, locale specific: Options. (line 272) +* decimal point character, locale specific: Options. (line 270) * decrement operators: Increment Ops. (line 35) * default keyword: Switch Statement. (line 6) * Deifik, Scott <1>: Bugs. (line 71) @@ -32509,12 +32877,12 @@ Index (line 81) * differences in awk and gawk, command-line directories: Command-line directories. (line 6) -* differences in awk and gawk, ERRNO variable: Auto-set. (line 74) +* differences in awk and gawk, ERRNO variable: Auto-set. (line 88) * differences in awk and gawk, error messages: Special FD. (line 19) * differences in awk and gawk, FIELDWIDTHS variable: User-modified. (line 37) * differences in awk and gawk, FPAT variable: User-modified. (line 43) -* differences in awk and gawk, FUNCTAB variable: Auto-set. (line 116) +* differences in awk and gawk, FUNCTAB variable: Auto-set. (line 135) * differences in awk and gawk, function arguments (gawk): Calling Built-in. (line 16) * differences in awk and gawk, getline command: Getline. (line 19) @@ -32537,7 +32905,7 @@ Index (line 263) * differences in awk and gawk, print/printf statements: Format Modifiers. (line 13) -* differences in awk and gawk, PROCINFO array: Auto-set. (line 130) +* differences in awk and gawk, PROCINFO array: Auto-set. (line 149) * differences in awk and gawk, read timeouts: Read Timeout. (line 6) * differences in awk and gawk, record separators: awk split records. (line 125) @@ -32545,9 +32913,11 @@ Index (line 43) * differences in awk and gawk, regular expressions: Case-sensitivity. (line 26) +* differences in awk and gawk, retrying input: Retrying Input. + (line 6) * differences in awk and gawk, RS/RT variables: gawk split records. (line 58) -* differences in awk and gawk, RT variable: Auto-set. (line 265) +* differences in awk and gawk, RT variable: Auto-set. (line 292) * differences in awk and gawk, single-character fields: Single Character Fields. (line 6) * differences in awk and gawk, split() function: String Functions. @@ -32555,7 +32925,7 @@ Index * differences in awk and gawk, strings: Scalar Constants. (line 20) * differences in awk and gawk, strings, storing: gawk split records. (line 77) -* differences in awk and gawk, SYMTAB variable: Auto-set. (line 269) +* differences in awk and gawk, SYMTAB variable: Auto-set. (line 296) * differences in awk and gawk, TEXTDOMAIN variable: User-modified. (line 151) * differences in awk and gawk, trunc-mod operation: Arithmetic Ops. @@ -32571,6 +32941,7 @@ Index * display debugger command: Viewing And Changing Data. (line 8) * display debugger options: Debugger Info. (line 57) +* div: Numeric Functions. (line 18) * division: Arithmetic Ops. (line 44) * do-while statement: Do Statement. (line 6) * do-while statement, use of regexps in: Regexp Usage. (line 19) @@ -32591,12 +32962,12 @@ Index * dump debugger command: Miscellaneous Debugger Commands. (line 9) * dupword.awk program: Dupword Program. (line 31) -* dynamic profiling: Profiling. (line 179) +* dynamic profiling: Profiling. (line 178) * dynamically loaded extensions: Dynamic Extensions. (line 6) * e debugger command (alias for enable): Breakpoint Control. (line 73) * EBCDIC: Ordinal Functions. (line 45) -* effective group ID of gawk user: Auto-set. (line 135) -* effective user ID of gawk user: Auto-set. (line 139) +* effective group ID of gawk user: Auto-set. (line 154) +* effective user ID of gawk user: Auto-set. (line 162) * egrep utility <1>: Egrep Program. (line 6) * egrep utility: Bracket Expressions. (line 26) * egrep.awk program: Egrep Program. (line 54) @@ -32651,13 +33022,13 @@ Index (line 11) * EREs (Extended Regular Expressions): Bracket Expressions. (line 26) * ERRNO variable <1>: TCP/IP Networking. (line 54) -* ERRNO variable: Auto-set. (line 74) +* ERRNO variable: Auto-set. (line 88) * ERRNO variable, with BEGINFILE pattern: BEGINFILE/ENDFILE. (line 26) * ERRNO variable, with close() function: Close Files And Pipes. (line 141) * ERRNO variable, with getline command: Getline. (line 19) * error handling: Special FD. (line 19) -* error handling, ERRNO variable and: Auto-set. (line 74) +* error handling, ERRNO variable and: Auto-set. (line 88) * error output: Special FD. (line 6) * escape processing, gsub()/gensub()/sub() functions: Gory Details. (line 6) @@ -32690,10 +33061,10 @@ Index * exit status, of VMS: VMS Running. (line 28) * exit the debugger: Miscellaneous Debugger Commands. (line 99) -* exp: Numeric Functions. (line 18) +* exp: Numeric Functions. (line 33) * expand utility: Very Simple. (line 73) -* Expat XML parser library: gawkextlib. (line 35) -* exponent: Numeric Functions. (line 18) +* Expat XML parser library: gawkextlib. (line 37) +* exponent: Numeric Functions. (line 33) * expressions: Expressions. (line 6) * expressions, as patterns: Expression Patterns. (line 6) * expressions, assignment: Assignment Ops. (line 6) @@ -32711,7 +33082,7 @@ Index (line 6) * extension API version: Extension Versioning. (line 6) -* extension API, version number: Auto-set. (line 232) +* extension API, version number: Auto-set. (line 255) * extension example: Extension Example. (line 6) * extension registration: Registration Functions. (line 6) @@ -32792,7 +33163,7 @@ Index * file names, distinguishing: Auto-set. (line 56) * file names, in compatibility mode: Special Caveats. (line 9) * file names, standard streams in gawk: Special FD. (line 48) -* FILENAME variable <1>: Auto-set. (line 90) +* FILENAME variable <1>: Auto-set. (line 109) * FILENAME variable: Reading Files. (line 6) * FILENAME variable, getline, setting with: Getline Notes. (line 19) * filenames, assignments as: Ignoring Assigns. (line 6) @@ -32860,9 +33231,9 @@ Index * flush buffered output: I/O Functions. (line 28) * fnmatch() extension function: Extension Sample Fnmatch. (line 12) -* FNR variable <1>: Auto-set. (line 100) +* FNR variable <1>: Auto-set. (line 119) * FNR variable: Records. (line 6) -* FNR variable, changing: Auto-set. (line 314) +* FNR variable, changing: Auto-set. (line 341) * for statement: For Statement. (line 6) * for statement, looping over arrays: Scanning an Array. (line 20) * fork() extension function: Extension Sample Fork. @@ -32899,7 +33270,7 @@ Index * FS variable, --field-separator option and: Options. (line 21) * FS variable, as null string: Single Character Fields. (line 20) -* FS variable, as TAB character: Options. (line 268) +* FS variable, as TAB character: Options. (line 266) * FS variable, changing value of: Field Separators. (line 35) * FS variable, running awk programs and: Cut Program. (line 63) * FS variable, setting from command line: Command Line Field Separator. @@ -32912,7 +33283,7 @@ Index * FSF (Free Software Foundation): Manual History. (line 6) * fts() extension function: Extension Sample File Functions. (line 61) -* FUNCTAB array: Auto-set. (line 116) +* FUNCTAB array: Auto-set. (line 135) * function calls: Function Calls. (line 6) * function calls, indirect: Indirect Calls. (line 6) * function calls, indirect, @-notation for: Indirect Calls. (line 47) @@ -32961,8 +33332,8 @@ Index (line 44) * G-d: Acknowledgments. (line 94) * Garfinkle, Scott: Contributors. (line 34) -* gawk program, dynamic profiling: Profiling. (line 179) -* gawk version: Auto-set. (line 207) +* gawk program, dynamic profiling: Profiling. (line 178) +* gawk version: Auto-set. (line 230) * gawk, ARGIND variable in: Other Arguments. (line 15) * gawk, awk and <1>: This Manual. (line 14) * gawk, awk and: Preface. (line 21) @@ -32980,13 +33351,13 @@ Index * gawk, distribution: Distribution contents. (line 6) * gawk, ERRNO variable in <1>: TCP/IP Networking. (line 54) -* gawk, ERRNO variable in <2>: Auto-set. (line 74) +* gawk, ERRNO variable in <2>: Auto-set. (line 88) * gawk, ERRNO variable in <3>: BEGINFILE/ENDFILE. (line 26) * gawk, ERRNO variable in <4>: Close Files And Pipes. (line 141) * gawk, ERRNO variable in: Getline. (line 19) -* gawk, escape sequences: Escape Sequences. (line 117) -* gawk, extensions, disabling: Options. (line 256) +* gawk, escape sequences: Escape Sequences. (line 120) +* gawk, extensions, disabling: Options. (line 254) * gawk, features, adding: Adding Code. (line 6) * gawk, features, advanced: Advanced Features. (line 6) * gawk, field separators and: User-modified. (line 71) @@ -32997,7 +33368,7 @@ Index * gawk, FPAT variable in <1>: User-modified. (line 43) * gawk, FPAT variable in: Splitting By Content. (line 25) -* gawk, FUNCTAB array in: Auto-set. (line 116) +* gawk, FUNCTAB array in: Auto-set. (line 135) * gawk, function arguments and: Calling Built-in. (line 16) * gawk, hexadecimal numbers and: Nondecimal-numbers. (line 42) * gawk, IGNORECASE variable in <1>: Array Sorting Functions. @@ -33029,7 +33400,7 @@ Index * gawk, predefined variables and: Built-in Variables. (line 14) * gawk, PROCINFO array in <1>: Two-way I/O. (line 99) * gawk, PROCINFO array in <2>: Time Functions. (line 47) -* gawk, PROCINFO array in: Auto-set. (line 130) +* gawk, PROCINFO array in: Auto-set. (line 149) * gawk, regexp constants and: Using Constant Regexps. (line 28) * gawk, regular expressions, case sensitivity: Case-sensitivity. @@ -33037,23 +33408,29 @@ Index * gawk, regular expressions, operators: GNU Regexp Operators. (line 6) * gawk, regular expressions, precedence: Regexp Operators. (line 161) -* gawk, RT variable in <1>: Auto-set. (line 265) +* gawk, RT variable in <1>: Auto-set. (line 292) * gawk, RT variable in <2>: Multiple Line. (line 129) * gawk, RT variable in: awk split records. (line 125) * gawk, See Also awk: Preface. (line 34) * gawk, source code, obtaining: Getting. (line 6) * gawk, splitting fields and: Constant Size. (line 87) * gawk, string-translation functions: I18N Functions. (line 6) -* gawk, SYMTAB array in: Auto-set. (line 269) +* gawk, SYMTAB array in: Auto-set. (line 296) * gawk, TEXTDOMAIN variable in: User-modified. (line 151) * gawk, timestamps: Time Functions. (line 6) * gawk, uses for: Preface. (line 34) -* gawk, versions of, information about, printing: Options. (line 302) +* gawk, versions of, information about, printing: Options. (line 300) * gawk, VMS version of: VMS Installation. (line 6) * gawk, word-boundary operator: GNU Regexp Operators. (line 63) * gawkextlib: gawkextlib. (line 6) * gawkextlib project: gawkextlib. (line 6) +* gawklibpath_append shell function: Shell Startup Files. (line 29) +* gawklibpath_default shell function: Shell Startup Files. (line 22) +* gawklibpath_prepend shell function: Shell Startup Files. (line 25) +* gawkpath_append shell function: Shell Startup Files. (line 19) +* gawkpath_default shell function: Shell Startup Files. (line 12) +* gawkpath_prepend shell function: Shell Startup Files. (line 15) * General Public License (GPL): Glossary. (line 399) * General Public License, See GPL: Manual History. (line 11) * generate time values: Time Functions. (line 25) @@ -33106,7 +33483,7 @@ Index * git utility <2>: Accessing The Source. (line 10) * git utility <3>: Other Versions. (line 29) -* git utility: gawkextlib. (line 29) +* git utility: gawkextlib. (line 31) * Git, use of for gawk source code: Derived Files. (line 6) * GNITS mailing list: Acknowledgments. (line 52) * GNU awk, See gawk: Preface. (line 51) @@ -33130,7 +33507,7 @@ Index * Grigera, Juan: Contributors. (line 57) * group database, reading: Group Functions. (line 6) * group file: Group Functions. (line 6) -* group ID of gawk user: Auto-set. (line 180) +* group ID of gawk user: Auto-set. (line 203) * groups, information about: Group Functions. (line 6) * gsub <1>: String Functions. (line 140) * gsub: Using Constant Regexps. @@ -33152,7 +33529,7 @@ Index * history expansion, in debugger: Readline Support. (line 6) * histsort.awk program: History Sorting. (line 25) * Hughes, Phil: Acknowledgments. (line 43) -* HUP signal, for dynamic profiling: Profiling. (line 211) +* HUP signal, for dynamic profiling: Profiling. (line 210) * hyphen (-), - operator: Precedence. (line 52) * hyphen (-), -- operator <1>: Precedence. (line 46) * hyphen (-), -- operator: Increment Ops. (line 48) @@ -33231,8 +33608,8 @@ Index * installation, VMS: VMS Installation. (line 6) * installing gawk: Installation. (line 6) * instruction tracing, in debugger: Debugger Info. (line 90) -* int: Numeric Functions. (line 23) -* INT signal (MS-Windows): Profiling. (line 214) +* int: Numeric Functions. (line 38) +* INT signal (MS-Windows): Profiling. (line 213) * integer array indices: Numeric Array Subscripts. (line 31) * integers, arbitrary precision: Arbitrary Precision Integers. @@ -33288,7 +33665,7 @@ Index * Kernighan, Brian <9>: Acknowledgments. (line 78) * Kernighan, Brian <10>: Conventions. (line 38) * Kernighan, Brian: History. (line 17) -* kill command, dynamic profiling: Profiling. (line 188) +* kill command, dynamic profiling: Profiling. (line 187) * Knights, jedi: Undocumented. (line 6) * Kwok, Conrad: Contributors. (line 34) * l debugger command (alias for list): Miscellaneous Debugger Commands. @@ -33360,7 +33737,7 @@ Index * lint checking, empty programs: Command Line. (line 16) * lint checking, issuing warnings: Options. (line 185) * lint checking, POSIXLY_CORRECT environment variable: Options. - (line 341) + (line 339) * lint checking, undefined functions: Pass By Value/Reference. (line 85) * LINT variable: User-modified. (line 87) @@ -33376,14 +33753,14 @@ Index * loading, extensions: Options. (line 173) * local variables, in a function: Variable Scope. (line 6) * locale categories: Explaining gettext. (line 81) -* locale decimal point character: Options. (line 272) +* locale decimal point character: Options. (line 270) * locale, definition of: Locales. (line 6) * localization: I18N and L10N. (line 6) * localization, See internationalization, localization: I18N and L10N. (line 6) -* log: Numeric Functions. (line 28) +* log: Numeric Functions. (line 43) * log files, timestamps in: Time Functions. (line 6) -* logarithm: Numeric Functions. (line 28) +* logarithm: Numeric Functions. (line 43) * logical false/true: Truth Values. (line 6) * logical operators, See Boolean expressions: Boolean Ops. (line 6) * login information: Passwd Functions. (line 16) @@ -33424,8 +33801,8 @@ Index * mawk utility <2>: Nextfile Statement. (line 47) * mawk utility <3>: Concatenation. (line 36) * mawk utility <4>: Getline/Pipe. (line 62) -* mawk utility: Escape Sequences. (line 117) -* maximum precision supported by MPFR library: Auto-set. (line 221) +* mawk utility: Escape Sequences. (line 120) +* maximum precision supported by MPFR library: Auto-set. (line 244) * McIlroy, Doug: Glossary. (line 258) * McPhee, Patrick: Contributors. (line 100) * message object files: Explaining gettext. (line 42) @@ -33437,8 +33814,8 @@ Index (line 54) * messages from extensions: Printing Messages. (line 6) * metacharacters in regular expressions: Regexp Operators. (line 6) -* metacharacters, escape sequences for: Escape Sequences. (line 136) -* minimum precision required by MPFR library: Auto-set. (line 224) +* metacharacters, escape sequences for: Escape Sequences. (line 139) +* minimum precision required by MPFR library: Auto-set. (line 247) * mktime: Time Functions. (line 25) * modifiers, in format specifiers: Format Modifiers. (line 6) * monetary information, localization: Explaining gettext. (line 104) @@ -33458,7 +33835,7 @@ Index * networks, programming: TCP/IP Networking. (line 6) * networks, support for: Special Network. (line 6) * newlines <1>: Boolean Ops. (line 69) -* newlines <2>: Options. (line 262) +* newlines <2>: Options. (line 260) * newlines: Statements/Lines. (line 6) * newlines, as field separators: Default Field Splitting. (line 6) @@ -33487,7 +33864,7 @@ Index (line 47) * nexti debugger command: Debugger Execution Control. (line 49) -* NF variable <1>: Auto-set. (line 105) +* NF variable <1>: Auto-set. (line 124) * NF variable: Fields. (line 33) * NF variable, decrementing: Changing Fields. (line 107) * ni debugger command (alias for nexti): Debugger Execution Control. @@ -33496,9 +33873,9 @@ Index * non-existent array elements: Reference to Elements. (line 23) * not Boolean-logic operator: Boolean Ops. (line 6) -* NR variable <1>: Auto-set. (line 125) +* NR variable <1>: Auto-set. (line 144) * NR variable: Records. (line 6) -* NR variable, changing: Auto-set. (line 314) +* NR variable, changing: Auto-set. (line 341) * null strings <1>: Basic Data Typing. (line 26) * null strings <2>: Truth Values. (line 6) * null strings <3>: Regexp Field Splitting. @@ -33612,7 +33989,7 @@ Index * p debugger command (alias for print): Viewing And Changing Data. (line 36) * Papadopoulos, Panos: Contributors. (line 128) -* parent process ID of gawk process: Auto-set. (line 189) +* parent process ID of gawk process: Auto-set. (line 212) * parentheses (), in a profile: Profiling. (line 146) * parentheses (), regexp operator: Regexp Operators. (line 81) * password file: Passwd Functions. (line 16) @@ -33654,14 +34031,14 @@ Index * plus sign (+), += operator: Assignment Ops. (line 82) * plus sign (+), regexp operator: Regexp Operators. (line 105) * pointers to functions: Indirect Calls. (line 6) -* portability: Escape Sequences. (line 100) +* portability: Escape Sequences. (line 103) * portability, #! (executable scripts): Executable Scripts. (line 33) * portability, ** operator and: Arithmetic Ops. (line 81) * portability, **= operator and: Assignment Ops. (line 143) * portability, ARGV variable: Executable Scripts. (line 59) * portability, backslash continuation and: Statements/Lines. (line 30) * portability, backslash in escape sequences: Escape Sequences. - (line 105) + (line 108) * portability, close() function and: Close Files And Pipes. (line 81) * portability, data files as single record: gawk split records. @@ -33679,7 +34056,7 @@ Index * portability, NF variable, decrementing: Changing Fields. (line 115) * portability, operators: Increment Ops. (line 60) * portability, operators, not in POSIX awk: Precedence. (line 98) -* portability, POSIXLY_CORRECT environment variable: Options. (line 361) +* portability, POSIXLY_CORRECT environment variable: Options. (line 359) * portability, substr() function: String Functions. (line 513) * portable object files <1>: Translator i18n. (line 6) * portable object files: Explaining gettext. (line 37) @@ -33700,7 +34077,7 @@ Index * POSIX awk, < operator and: Getline/File. (line 26) * POSIX awk, arithmetic operators and: Arithmetic Ops. (line 30) * POSIX awk, backslashes in string constants: Escape Sequences. - (line 105) + (line 108) * POSIX awk, BEGIN/END patterns: I/O And BEGIN/END. (line 16) * POSIX awk, bracket expressions and: Bracket Expressions. (line 26) * POSIX awk, bracket expressions and, character classes: Bracket Expressions. @@ -33727,11 +34104,11 @@ Index * POSIX awk, regular expressions and: Regexp Operators. (line 161) * POSIX awk, timestamps and: Time Functions. (line 6) * POSIX awk, | I/O operator and: Getline/Pipe. (line 55) -* POSIX mode: Options. (line 256) +* POSIX mode: Options. (line 254) * POSIX, awk and: Preface. (line 21) * POSIX, gawk extensions not included in: POSIX/GNU. (line 6) * POSIX, programs, implementing in awk: Clones. (line 6) -* POSIXLY_CORRECT environment variable: Options. (line 341) +* POSIXLY_CORRECT environment variable: Options. (line 339) * PREC variable: User-modified. (line 123) * precedence <1>: Precedence. (line 6) * precedence: Increment Ops. (line 60) @@ -33778,24 +34155,24 @@ Index * printing, unduplicated lines of text: Uniq Program. (line 6) * printing, user information: Id Program. (line 6) * private variables: Library Names. (line 11) -* process group ID of gawk process: Auto-set. (line 183) -* process ID of gawk process: Auto-set. (line 186) +* process group ID of gawk process: Auto-set. (line 206) +* process ID of gawk process: Auto-set. (line 209) * processes, two-way communications with: Two-way I/O. (line 6) * processing data: Basic High Level. (line 6) * PROCINFO array <1>: Passwd Functions. (line 6) * PROCINFO array <2>: Time Functions. (line 47) -* PROCINFO array: Auto-set. (line 130) +* PROCINFO array: Auto-set. (line 149) * PROCINFO array, and communications via ptys: Two-way I/O. (line 99) * PROCINFO array, and group membership: Group Functions. (line 6) * PROCINFO array, and user and group ID numbers: Id Program. (line 15) * PROCINFO array, testing the field splitting: Passwd Functions. (line 154) -* PROCINFO array, uses: Auto-set. (line 242) +* PROCINFO array, uses: Auto-set. (line 265) * PROCINFO, values of sorted_in: Controlling Scanning. (line 26) * profiling awk programs: Profiling. (line 6) -* profiling awk programs, dynamically: Profiling. (line 179) -* program identifiers: Auto-set. (line 148) +* profiling awk programs, dynamically: Profiling. (line 178) +* program identifiers: Auto-set. (line 171) * program, definition of: Getting Started. (line 21) * programming conventions, --non-decimal-data option: Nondecimal Data. (line 35) @@ -33830,7 +34207,7 @@ Index * QuikTrim Awk: Other Versions. (line 139) * quit debugger command: Miscellaneous Debugger Commands. (line 99) -* QUIT signal (MS-Windows): Profiling. (line 214) +* QUIT signal (MS-Windows): Profiling. (line 213) * quoting in gawk command lines: Long. (line 26) * quoting in gawk command lines, tricks for: Quoting. (line 91) * quoting, for small awk programs: Comments. (line 27) @@ -33839,12 +34216,12 @@ Index * Rakitzis, Byron: History Sorting. (line 25) * Ramey, Chet <1>: General Data Types. (line 6) * Ramey, Chet: Acknowledgments. (line 60) -* rand: Numeric Functions. (line 33) +* rand: Numeric Functions. (line 48) * random numbers, Cliff: Cliff Random Function. (line 6) * random numbers, rand()/srand() functions: Numeric Functions. - (line 33) -* random numbers, seed of: Numeric Functions. (line 63) + (line 48) +* random numbers, seed of: Numeric Functions. (line 78) * range expressions (regexps): Bracket Expressions. (line 6) * range patterns: Ranges. (line 6) * range patterns, line continuation and: Ranges. (line 65) @@ -33913,7 +34290,7 @@ Index (line 60) * regular expressions, gawk, command-line options: GNU Regexp Operators. (line 70) -* regular expressions, interval expressions and: Options. (line 281) +* regular expressions, interval expressions and: Options. (line 279) * regular expressions, leftmost longest match: Leftmost Longest. (line 6) * regular expressions, operators <1>: Regexp Operators. (line 6) @@ -33930,6 +34307,7 @@ Index * relational operators, See comparison operators: Typing and Comparison. (line 9) * replace in string: String Functions. (line 409) +* retrying input: Retrying Input. (line 6) * return debugger command: Debugger Execution Control. (line 54) * return statement, user-defined functions: Return Statement. (line 6) @@ -33953,7 +34331,7 @@ Index * right shift: Bitwise Functions. (line 53) * right shift, bitwise: Bitwise Functions. (line 32) * Ritchie, Dennis: Basic Data Typing. (line 54) -* RLENGTH variable: Auto-set. (line 252) +* RLENGTH variable: Auto-set. (line 279) * RLENGTH variable, match() function and: String Functions. (line 228) * Robbins, Arnold <1>: Future Extensions. (line 6) * Robbins, Arnold <2>: Bugs. (line 71) @@ -33971,7 +34349,7 @@ Index * Robbins, Miriam <2>: Getline/Pipe. (line 39) * Robbins, Miriam: Acknowledgments. (line 94) * Rommel, Kai Uwe: Contributors. (line 42) -* round to nearest integer: Numeric Functions. (line 23) +* round to nearest integer: Numeric Functions. (line 38) * round() user-defined function: Round Function. (line 16) * rounding numbers: Round Function. (line 6) * ROUNDMODE variable: User-modified. (line 127) @@ -33979,9 +34357,9 @@ Index * RS variable: awk split records. (line 12) * RS variable, multiline records and: Multiple Line. (line 17) * rshift: Bitwise Functions. (line 53) -* RSTART variable: Auto-set. (line 258) +* RSTART variable: Auto-set. (line 285) * RSTART variable, match() function and: String Functions. (line 228) -* RT variable <1>: Auto-set. (line 265) +* RT variable <1>: Auto-set. (line 292) * RT variable <2>: Multiple Line. (line 129) * RT variable: awk split records. (line 125) * Rubin, Paul <1>: Contributors. (line 15) @@ -33994,14 +34372,14 @@ Index (line 68) * sample debugging session: Sample Debugging Session. (line 6) -* sandbox mode: Options. (line 288) +* sandbox mode: Options. (line 286) * save debugger options: Debugger Info. (line 85) * scalar or array: Type Functions. (line 11) * scalar values: Basic Data Typing. (line 13) * scanning arrays: Scanning an Array. (line 6) * scanning multidimensional arrays: Multiscanning. (line 11) * Schorr, Andrew <1>: Contributors. (line 133) -* Schorr, Andrew <2>: Auto-set. (line 297) +* Schorr, Andrew <2>: Auto-set. (line 324) * Schorr, Andrew: Acknowledgments. (line 60) * Schreiber, Bert: Acknowledgments. (line 38) * Schreiber, Rita: Acknowledgments. (line 38) @@ -34020,7 +34398,7 @@ Index * sed utility <1>: Glossary. (line 16) * sed utility <2>: Simple Sed. (line 6) * sed utility: Full Line Fields. (line 22) -* seeding random number generator: Numeric Functions. (line 63) +* seeding random number generator: Numeric Functions. (line 78) * semicolon (;), AWKPATH variable and: PC Using. (line 10) * semicolon (;), separating statements in actions <1>: Statements. (line 10) @@ -34081,14 +34459,14 @@ Index * sidebar, A Constant's Base Does Not Affect Its Value: Nondecimal-numbers. (line 64) * sidebar, Backslash Before Regular Characters: Escape Sequences. - (line 103) + (line 106) * sidebar, Changing FS Does Not Affect the Fields: Full Line Fields. (line 14) -* sidebar, Changing NR and FNR: Auto-set. (line 312) +* sidebar, Changing NR and FNR: Auto-set. (line 339) * sidebar, Controlling Output Buffering with system(): I/O Functions. (line 139) * sidebar, Escape Sequences for Metacharacters: Escape Sequences. - (line 134) + (line 137) * sidebar, FS and IGNORECASE: Field Splitting Summary. (line 38) * sidebar, Interactive Versus Noninteractive Buffering: I/O Functions. @@ -34110,19 +34488,19 @@ Index (line 58) * sidebar, Using close()'s Return Value: Close Files And Pipes. (line 131) -* SIGHUP signal, for dynamic profiling: Profiling. (line 211) -* SIGINT signal (MS-Windows): Profiling. (line 214) -* signals, HUP/SIGHUP, for profiling: Profiling. (line 211) -* signals, INT/SIGINT (MS-Windows): Profiling. (line 214) -* signals, QUIT/SIGQUIT (MS-Windows): Profiling. (line 214) -* signals, USR1/SIGUSR1, for profiling: Profiling. (line 188) +* SIGHUP signal, for dynamic profiling: Profiling. (line 210) +* SIGINT signal (MS-Windows): Profiling. (line 213) +* signals, HUP/SIGHUP, for profiling: Profiling. (line 210) +* signals, INT/SIGINT (MS-Windows): Profiling. (line 213) +* signals, QUIT/SIGQUIT (MS-Windows): Profiling. (line 213) +* signals, USR1/SIGUSR1, for profiling: Profiling. (line 187) * signature program: Signature Program. (line 6) -* SIGQUIT signal (MS-Windows): Profiling. (line 214) -* SIGUSR1 signal, for dynamic profiling: Profiling. (line 188) +* SIGQUIT signal (MS-Windows): Profiling. (line 213) +* SIGUSR1 signal, for dynamic profiling: Profiling. (line 187) * silent debugger command: Debugger Execution Control. (line 10) -* sin: Numeric Functions. (line 74) -* sine: Numeric Functions. (line 74) +* sin: Numeric Functions. (line 89) +* sine: Numeric Functions. (line 89) * single quote ('): One-shot. (line 15) * single quote (') in gawk command lines: Long. (line 35) * single quote ('), in shell commands: Quoting. (line 48) @@ -34172,10 +34550,10 @@ Index * sprintf() function, OFMT variable and: User-modified. (line 113) * sprintf() function, print/printf statements and: Round Function. (line 6) -* sqrt: Numeric Functions. (line 77) +* sqrt: Numeric Functions. (line 92) * square brackets ([]), regexp operator: Regexp Operators. (line 56) -* square root: Numeric Functions. (line 77) -* srand: Numeric Functions. (line 81) +* square root: Numeric Functions. (line 92) +* srand: Numeric Functions. (line 96) * stack frame: Debugging Terms. (line 10) * Stallman, Richard <1>: Glossary. (line 375) * Stallman, Richard <2>: Contributors. (line 23) @@ -34246,9 +34624,9 @@ Index * substr: String Functions. (line 482) * substring: String Functions. (line 482) * Sumner, Andrew: Other Versions. (line 68) -* supplementary groups of gawk process: Auto-set. (line 237) +* supplementary groups of gawk process: Auto-set. (line 260) * switch statement: Switch Statement. (line 6) -* SYMTAB array: Auto-set. (line 269) +* SYMTAB array: Auto-set. (line 296) * syntactic ambiguity: /= operator vs. /=.../ regexp constant: Assignment Ops. (line 148) * system: I/O Functions. (line 107) @@ -34315,7 +34693,7 @@ Index (line 37) * troubleshooting, awk uses FS not IFS: Field Separators. (line 30) * troubleshooting, backslash before nonspecial character: Escape Sequences. - (line 105) + (line 108) * troubleshooting, division: Arithmetic Ops. (line 44) * troubleshooting, fatal errors, field widths, specifying: Constant Size. (line 22) @@ -34371,7 +34749,7 @@ Index * uniq.awk program: Uniq Program. (line 65) * Unix: Glossary. (line 753) * Unix awk, backslashes in escape sequences: Escape Sequences. - (line 117) + (line 120) * Unix awk, close() function and: Close Files And Pipes. (line 133) * Unix awk, password files, field separators and: Command Line Field Separator. @@ -34391,7 +34769,7 @@ Index * user-modifiable variables: User-modified. (line 6) * users, information about, printing: Id Program. (line 6) * users, information about, retrieving: Passwd Functions. (line 16) -* USR1 signal, for dynamic profiling: Profiling. (line 188) +* USR1 signal, for dynamic profiling: Profiling. (line 187) * values, numeric: Basic Data Typing. (line 13) * values, string: Basic Data Typing. (line 13) * variable assignments and input files: Other Arguments. (line 26) @@ -34425,10 +34803,10 @@ Index * variables, uninitialized, as array subscripts: Uninitialized Subscripts. (line 6) * variables, user-defined: Variables. (line 6) -* version of gawk: Auto-set. (line 207) -* version of gawk extension API: Auto-set. (line 232) -* version of GNU MP library: Auto-set. (line 218) -* version of GNU MPFR library: Auto-set. (line 214) +* version of gawk: Auto-set. (line 230) +* version of gawk extension API: Auto-set. (line 255) +* version of GNU MP library: Auto-set. (line 241) +* version of GNU MPFR library: Auto-set. (line 237) * vertical bar (|): Regexp Operators. (line 70) * vertical bar (|), | operator (I/O) <1>: Precedence. (line 65) * vertical bar (|), | operator (I/O): Getline/Pipe. (line 9) @@ -34465,7 +34843,7 @@ Index * whitespace, as field separators: Default Field Splitting. (line 6) * whitespace, functions, calling: Calling Built-in. (line 10) -* whitespace, newlines as: Options. (line 262) +* whitespace, newlines as: Options. (line 260) * Williams, Kent: Contributors. (line 34) * Woehlke, Matthew: Contributors. (line 79) * Woods, John: Contributors. (line 27) @@ -34518,559 +34896,563 @@ Index Tag Table: Node: Top1204 -Node: Foreword342156 -Node: Foreword446600 -Node: Preface48131 -Ref: Preface-Footnote-151002 -Ref: Preface-Footnote-251109 -Ref: Preface-Footnote-351342 -Node: History51484 -Node: Names53835 -Ref: Names-Footnote-154929 -Node: This Manual55075 -Ref: This Manual-Footnote-161575 -Node: Conventions61675 -Node: Manual History64012 -Ref: Manual History-Footnote-167005 -Ref: Manual History-Footnote-267046 -Node: How To Contribute67120 -Node: Acknowledgments68249 -Node: Getting Started73115 -Node: Running gawk75554 -Node: One-shot76744 -Node: Read Terminal78008 -Node: Long80039 -Node: Executable Scripts81552 -Ref: Executable Scripts-Footnote-184341 -Node: Comments84444 -Node: Quoting86926 -Node: DOS Quoting92444 -Node: Sample Data Files93119 -Node: Very Simple95714 -Node: Two Rules100613 -Node: More Complex102499 -Node: Statements/Lines105361 -Ref: Statements/Lines-Footnote-1109816 -Node: Other Features110081 -Node: When111017 -Ref: When-Footnote-1112771 -Node: Intro Summary112836 -Node: Invoking Gawk113720 -Node: Command Line115234 -Node: Options116032 -Ref: Options-Footnote-1131954 -Ref: Options-Footnote-2132183 -Node: Other Arguments132208 -Node: Naming Standard Input135156 -Node: Environment Variables136249 -Node: AWKPATH Variable136807 -Ref: AWKPATH Variable-Footnote-1140104 -Ref: AWKPATH Variable-Footnote-2140149 -Node: AWKLIBPATH Variable140409 -Node: Other Environment Variables141552 -Node: Exit Status145310 -Node: Include Files145986 -Node: Loading Shared Libraries149575 -Node: Obsolete151002 -Node: Undocumented151694 -Node: Invoking Summary151961 -Node: Regexp153624 -Node: Regexp Usage155078 -Node: Escape Sequences157115 -Node: Regexp Operators163125 -Ref: Regexp Operators-Footnote-1170535 -Ref: Regexp Operators-Footnote-2170682 -Node: Bracket Expressions170780 -Ref: table-char-classes172795 -Node: Leftmost Longest175737 -Node: Computed Regexps177039 -Node: GNU Regexp Operators180468 -Node: Case-sensitivity184140 -Ref: Case-sensitivity-Footnote-1187025 -Ref: Case-sensitivity-Footnote-2187260 -Node: Regexp Summary187368 -Node: Reading Files188835 -Node: Records190928 -Node: awk split records191661 -Node: gawk split records196590 -Ref: gawk split records-Footnote-1201129 -Node: Fields201166 -Ref: Fields-Footnote-1203944 -Node: Nonconstant Fields204030 -Ref: Nonconstant Fields-Footnote-1206268 -Node: Changing Fields206471 -Node: Field Separators212402 -Node: Default Field Splitting215106 -Node: Regexp Field Splitting216223 -Node: Single Character Fields219573 -Node: Command Line Field Separator220632 -Node: Full Line Fields223849 -Ref: Full Line Fields-Footnote-1225370 -Ref: Full Line Fields-Footnote-2225416 -Node: Field Splitting Summary225517 -Node: Constant Size227591 -Node: Splitting By Content232170 -Ref: Splitting By Content-Footnote-1236135 -Node: Multiple Line236298 -Ref: Multiple Line-Footnote-1242179 -Node: Getline242358 -Node: Plain Getline244565 -Node: Getline/Variable247205 -Node: Getline/File248354 -Node: Getline/Variable/File249739 -Ref: Getline/Variable/File-Footnote-1251342 -Node: Getline/Pipe251429 -Node: Getline/Variable/Pipe254107 -Node: Getline/Coprocess255238 -Node: Getline/Variable/Coprocess256502 -Node: Getline Notes257241 -Node: Getline Summary260035 -Ref: table-getline-variants260447 -Node: Read Timeout261276 -Ref: Read Timeout-Footnote-1265113 -Node: Command-line directories265171 -Node: Input Summary266076 -Node: Input Exercises269461 -Node: Printing270189 -Node: Print271966 -Node: Print Examples273423 -Node: Output Separators276202 -Node: OFMT278220 -Node: Printf279575 -Node: Basic Printf280360 -Node: Control Letters281932 -Node: Format Modifiers285917 -Node: Printf Examples291923 -Node: Redirection294409 -Node: Special FD301247 -Ref: Special FD-Footnote-1304413 -Node: Special Files304487 -Node: Other Inherited Files305104 -Node: Special Network306104 -Node: Special Caveats306966 -Node: Close Files And Pipes307915 -Ref: Close Files And Pipes-Footnote-1315106 -Ref: Close Files And Pipes-Footnote-2315254 -Node: Output Summary315404 -Node: Output Exercises316402 -Node: Expressions317082 -Node: Values318271 -Node: Constants318948 -Node: Scalar Constants319639 -Ref: Scalar Constants-Footnote-1320501 -Node: Nondecimal-numbers320751 -Node: Regexp Constants323761 -Node: Using Constant Regexps324287 -Node: Variables327450 -Node: Using Variables328107 -Node: Assignment Options330018 -Node: Conversion331893 -Node: Strings And Numbers332417 -Ref: Strings And Numbers-Footnote-1335482 -Node: Locale influences conversions335591 -Ref: table-locale-affects338337 -Node: All Operators338929 -Node: Arithmetic Ops339558 -Node: Concatenation342063 -Ref: Concatenation-Footnote-1344882 -Node: Assignment Ops344989 -Ref: table-assign-ops349968 -Node: Increment Ops351278 -Node: Truth Values and Conditions354709 -Node: Truth Values355792 -Node: Typing and Comparison356841 -Node: Variable Typing357657 -Node: Comparison Operators361324 -Ref: table-relational-ops361734 -Node: POSIX String Comparison365229 -Ref: POSIX String Comparison-Footnote-1366301 -Node: Boolean Ops366440 -Ref: Boolean Ops-Footnote-1370918 -Node: Conditional Exp371009 -Node: Function Calls372747 -Node: Precedence376627 -Node: Locales380287 -Node: Expressions Summary381919 -Node: Patterns and Actions384490 -Node: Pattern Overview385610 -Node: Regexp Patterns387289 -Node: Expression Patterns387832 -Node: Ranges391612 -Node: BEGIN/END394719 -Node: Using BEGIN/END395480 -Ref: Using BEGIN/END-Footnote-1398216 -Node: I/O And BEGIN/END398322 -Node: BEGINFILE/ENDFILE400637 -Node: Empty403534 -Node: Using Shell Variables403851 -Node: Action Overview406124 -Node: Statements408450 -Node: If Statement410298 -Node: While Statement411793 -Node: Do Statement413821 -Node: For Statement414969 -Node: Switch Statement418127 -Node: Break Statement420509 -Node: Continue Statement422602 -Node: Next Statement424429 -Node: Nextfile Statement426810 -Node: Exit Statement429438 -Node: Built-in Variables431849 -Node: User-modified432982 -Ref: User-modified-Footnote-1440616 -Node: Auto-set440678 -Ref: Auto-set-Footnote-1453730 -Ref: Auto-set-Footnote-2453935 -Node: ARGC and ARGV453991 -Node: Pattern Action Summary458209 -Node: Arrays460642 -Node: Array Basics461971 -Node: Array Intro462815 -Ref: figure-array-elements464752 -Ref: Array Intro-Footnote-1467375 -Node: Reference to Elements467503 -Node: Assigning Elements469965 -Node: Array Example470456 -Node: Scanning an Array472215 -Node: Controlling Scanning475238 -Ref: Controlling Scanning-Footnote-1480632 -Node: Numeric Array Subscripts480948 -Node: Uninitialized Subscripts483133 -Node: Delete484750 -Ref: Delete-Footnote-1487499 -Node: Multidimensional487556 -Node: Multiscanning490653 -Node: Arrays of Arrays492242 -Node: Arrays Summary496996 -Node: Functions499087 -Node: Built-in500126 -Node: Calling Built-in501204 -Node: Numeric Functions503199 -Ref: Numeric Functions-Footnote-1507227 -Ref: Numeric Functions-Footnote-2507584 -Ref: Numeric Functions-Footnote-3507632 -Node: String Functions507904 -Ref: String Functions-Footnote-1531405 -Ref: String Functions-Footnote-2531534 -Ref: String Functions-Footnote-3531782 -Node: Gory Details531869 -Ref: table-sub-escapes533650 -Ref: table-sub-proposed535165 -Ref: table-posix-sub536527 -Ref: table-gensub-escapes538064 -Ref: Gory Details-Footnote-1538897 -Node: I/O Functions539048 -Ref: I/O Functions-Footnote-1546284 -Node: Time Functions546431 -Ref: Time Functions-Footnote-1556940 -Ref: Time Functions-Footnote-2557008 -Ref: Time Functions-Footnote-3557166 -Ref: Time Functions-Footnote-4557277 -Ref: Time Functions-Footnote-5557389 -Ref: Time Functions-Footnote-6557616 -Node: Bitwise Functions557882 -Ref: table-bitwise-ops558444 -Ref: Bitwise Functions-Footnote-1562772 -Node: Type Functions562944 -Node: I18N Functions564096 -Node: User-defined565743 -Node: Definition Syntax566548 -Ref: Definition Syntax-Footnote-1572207 -Node: Function Example572278 -Ref: Function Example-Footnote-1575199 -Node: Function Caveats575221 -Node: Calling A Function575739 -Node: Variable Scope576697 -Node: Pass By Value/Reference579690 -Node: Return Statement583187 -Node: Dynamic Typing586166 -Node: Indirect Calls587095 -Ref: Indirect Calls-Footnote-1597338 -Node: Functions Summary597466 -Node: Library Functions600168 -Ref: Library Functions-Footnote-1603776 -Ref: Library Functions-Footnote-2603919 -Node: Library Names604090 -Ref: Library Names-Footnote-1607548 -Ref: Library Names-Footnote-2607771 -Node: General Functions607857 -Node: Strtonum Function608960 -Node: Assert Function611982 -Node: Round Function615306 -Node: Cliff Random Function616847 -Node: Ordinal Functions617863 -Ref: Ordinal Functions-Footnote-1620926 -Ref: Ordinal Functions-Footnote-2621178 -Node: Join Function621389 -Ref: Join Function-Footnote-1623159 -Node: Getlocaltime Function623359 -Node: Readfile Function627103 -Node: Shell Quoting629075 -Node: Data File Management630476 -Node: Filetrans Function631108 -Node: Rewind Function635204 -Node: File Checking636590 -Ref: File Checking-Footnote-1637923 -Node: Empty Files638124 -Node: Ignoring Assigns640103 -Node: Getopt Function641653 -Ref: Getopt Function-Footnote-1653117 -Node: Passwd Functions653317 -Ref: Passwd Functions-Footnote-1662157 -Node: Group Functions662245 -Ref: Group Functions-Footnote-1670142 -Node: Walking Arrays670347 -Node: Library Functions Summary673353 -Node: Library Exercises674755 -Node: Sample Programs676035 -Node: Running Examples676805 -Node: Clones677533 -Node: Cut Program678757 -Node: Egrep Program688477 -Ref: Egrep Program-Footnote-1695980 -Node: Id Program696090 -Node: Split Program699766 -Ref: Split Program-Footnote-1703220 -Node: Tee Program703348 -Node: Uniq Program706137 -Node: Wc Program713556 -Ref: Wc Program-Footnote-1717806 -Node: Miscellaneous Programs717900 -Node: Dupword Program719113 -Node: Alarm Program721144 -Node: Translate Program725949 -Ref: Translate Program-Footnote-1730512 -Node: Labels Program730782 -Ref: Labels Program-Footnote-1734133 -Node: Word Sorting734217 -Node: History Sorting738287 -Node: Extract Program740122 -Node: Simple Sed747646 -Node: Igawk Program750716 -Ref: Igawk Program-Footnote-1765042 -Ref: Igawk Program-Footnote-2765243 -Ref: Igawk Program-Footnote-3765365 -Node: Anagram Program765480 -Node: Signature Program768541 -Node: Programs Summary769788 -Node: Programs Exercises771009 -Ref: Programs Exercises-Footnote-1775140 -Node: Advanced Features775231 -Node: Nondecimal Data777213 -Node: Array Sorting778803 -Node: Controlling Array Traversal779503 -Ref: Controlling Array Traversal-Footnote-1787869 -Node: Array Sorting Functions787987 -Ref: Array Sorting Functions-Footnote-1791873 -Node: Two-way I/O792069 -Ref: Two-way I/O-Footnote-1797014 -Ref: Two-way I/O-Footnote-2797200 -Node: TCP/IP Networking797282 -Node: Profiling800154 -Node: Advanced Features Summary807695 -Node: Internationalization809628 -Node: I18N and L10N811108 -Node: Explaining gettext811794 -Ref: Explaining gettext-Footnote-1816819 -Ref: Explaining gettext-Footnote-2817003 -Node: Programmer i18n817168 -Ref: Programmer i18n-Footnote-1822044 -Node: Translator i18n822093 -Node: String Extraction822887 -Ref: String Extraction-Footnote-1824018 -Node: Printf Ordering824104 -Ref: Printf Ordering-Footnote-1826890 -Node: I18N Portability826954 -Ref: I18N Portability-Footnote-1829410 -Node: I18N Example829473 -Ref: I18N Example-Footnote-1832276 -Node: Gawk I18N832348 -Node: I18N Summary832992 -Node: Debugger834332 -Node: Debugging835354 -Node: Debugging Concepts835795 -Node: Debugging Terms837605 -Node: Awk Debugging840177 -Node: Sample Debugging Session841083 -Node: Debugger Invocation841617 -Node: Finding The Bug843002 -Node: List of Debugger Commands849481 -Node: Breakpoint Control850813 -Node: Debugger Execution Control854490 -Node: Viewing And Changing Data857849 -Node: Execution Stack861225 -Node: Debugger Info862860 -Node: Miscellaneous Debugger Commands866905 -Node: Readline Support871906 -Node: Limitations872800 -Node: Debugging Summary874915 -Node: Arbitrary Precision Arithmetic876089 -Node: Computer Arithmetic877505 -Ref: table-numeric-ranges881082 -Ref: Computer Arithmetic-Footnote-1881606 -Node: Math Definitions881663 -Ref: table-ieee-formats884958 -Ref: Math Definitions-Footnote-1885562 -Node: MPFR features885667 -Node: FP Math Caution887338 -Ref: FP Math Caution-Footnote-1888388 -Node: Inexactness of computations888757 -Node: Inexact representation889716 -Node: Comparing FP Values891074 -Node: Errors accumulate892156 -Node: Getting Accuracy893588 -Node: Try To Round896292 -Node: Setting precision897191 -Ref: table-predefined-precision-strings897875 -Node: Setting the rounding mode899704 -Ref: table-gawk-rounding-modes900068 -Ref: Setting the rounding mode-Footnote-1903520 -Node: Arbitrary Precision Integers903699 -Ref: Arbitrary Precision Integers-Footnote-1906683 -Node: POSIX Floating Point Problems906832 -Ref: POSIX Floating Point Problems-Footnote-1910711 -Node: Floating point summary910749 -Node: Dynamic Extensions912936 -Node: Extension Intro914488 -Node: Plugin License915753 -Node: Extension Mechanism Outline916550 -Ref: figure-load-extension916978 -Ref: figure-register-new-function918458 -Ref: figure-call-new-function919462 -Node: Extension API Description921449 -Node: Extension API Functions Introduction922899 -Node: General Data Types927720 -Ref: General Data Types-Footnote-1933620 -Node: Memory Allocation Functions933919 -Ref: Memory Allocation Functions-Footnote-1936758 -Node: Constructor Functions936857 -Node: Registration Functions938596 -Node: Extension Functions939281 -Node: Exit Callback Functions941578 -Node: Extension Version String942826 -Node: Input Parsers943489 -Node: Output Wrappers953364 -Node: Two-way processors957877 -Node: Printing Messages960140 -Ref: Printing Messages-Footnote-1961216 -Node: Updating `ERRNO'961368 -Node: Requesting Values962108 -Ref: table-value-types-returned962835 -Node: Accessing Parameters963792 -Node: Symbol Table Access965026 -Node: Symbol table by name965540 -Node: Symbol table by cookie967560 -Ref: Symbol table by cookie-Footnote-1971705 -Node: Cached values971768 -Ref: Cached values-Footnote-1975264 -Node: Array Manipulation975355 -Ref: Array Manipulation-Footnote-1976453 -Node: Array Data Types976490 -Ref: Array Data Types-Footnote-1979145 -Node: Array Functions979237 -Node: Flattening Arrays983096 -Node: Creating Arrays989998 -Node: Extension API Variables994769 -Node: Extension Versioning995405 -Node: Extension API Informational Variables997296 -Node: Extension API Boilerplate998361 -Node: Finding Extensions1002170 -Node: Extension Example1002730 -Node: Internal File Description1003502 -Node: Internal File Ops1007569 -Ref: Internal File Ops-Footnote-11019320 -Node: Using Internal File Ops1019460 -Ref: Using Internal File Ops-Footnote-11021843 -Node: Extension Samples1022116 -Node: Extension Sample File Functions1023644 -Node: Extension Sample Fnmatch1031325 -Node: Extension Sample Fork1032813 -Node: Extension Sample Inplace1034028 -Node: Extension Sample Ord1036114 -Node: Extension Sample Readdir1036950 -Ref: table-readdir-file-types1037827 -Node: Extension Sample Revout1038638 -Node: Extension Sample Rev2way1039227 -Node: Extension Sample Read write array1039967 -Node: Extension Sample Readfile1041907 -Node: Extension Sample Time1043002 -Node: Extension Sample API Tests1044350 -Node: gawkextlib1044841 -Node: Extension summary1047519 -Node: Extension Exercises1051208 -Node: Language History1052704 -Node: V7/SVR3.11054360 -Node: SVR41056513 -Node: POSIX1057947 -Node: BTL1059328 -Node: POSIX/GNU1060059 -Node: Feature History1065580 -Node: Common Extensions1078678 -Node: Ranges and Locales1080050 -Ref: Ranges and Locales-Footnote-11084669 -Ref: Ranges and Locales-Footnote-21084696 -Ref: Ranges and Locales-Footnote-31084931 -Node: Contributors1085152 -Node: History summary1090692 -Node: Installation1092071 -Node: Gawk Distribution1093017 -Node: Getting1093501 -Node: Extracting1094324 -Node: Distribution contents1095961 -Node: Unix Installation1101715 -Node: Quick Installation1102332 -Node: Additional Configuration Options1104756 -Node: Configuration Philosophy1106559 -Node: Non-Unix Installation1108928 -Node: PC Installation1109386 -Node: PC Binary Installation1110706 -Node: PC Compiling1112554 -Ref: PC Compiling-Footnote-11115575 -Node: PC Testing1115684 -Node: PC Using1116860 -Node: Cygwin1120975 -Node: MSYS1121745 -Node: VMS Installation1122246 -Node: VMS Compilation1123038 -Ref: VMS Compilation-Footnote-11124267 -Node: VMS Dynamic Extensions1124325 -Node: VMS Installation Details1126009 -Node: VMS Running1128260 -Node: VMS GNV1131100 -Node: VMS Old Gawk1131835 -Node: Bugs1132305 -Node: Other Versions1136194 -Node: Installation summary1142628 -Node: Notes1143687 -Node: Compatibility Mode1144552 -Node: Additions1145334 -Node: Accessing The Source1146259 -Node: Adding Code1147694 -Node: New Ports1153851 -Node: Derived Files1158333 -Ref: Derived Files-Footnote-11163808 -Ref: Derived Files-Footnote-21163842 -Ref: Derived Files-Footnote-31164438 -Node: Future Extensions1164552 -Node: Implementation Limitations1165158 -Node: Extension Design1166406 -Node: Old Extension Problems1167560 -Ref: Old Extension Problems-Footnote-11169077 -Node: Extension New Mechanism Goals1169134 -Ref: Extension New Mechanism Goals-Footnote-11172494 -Node: Extension Other Design Decisions1172683 -Node: Extension Future Growth1174791 -Node: Old Extension Mechanism1175627 -Node: Notes summary1177389 -Node: Basic Concepts1178575 -Node: Basic High Level1179256 -Ref: figure-general-flow1179528 -Ref: figure-process-flow1180127 -Ref: Basic High Level-Footnote-11183356 -Node: Basic Data Typing1183541 -Node: Glossary1186869 -Node: Copying1218798 -Node: GNU Free Documentation License1256354 -Node: Index1281490 +Node: Foreword342451 +Node: Foreword446895 +Node: Preface48426 +Ref: Preface-Footnote-151297 +Ref: Preface-Footnote-251404 +Ref: Preface-Footnote-351637 +Node: History51779 +Node: Names54130 +Ref: Names-Footnote-155224 +Node: This Manual55370 +Ref: This Manual-Footnote-161870 +Node: Conventions61970 +Node: Manual History64307 +Ref: Manual History-Footnote-167300 +Ref: Manual History-Footnote-267341 +Node: How To Contribute67415 +Node: Acknowledgments68544 +Node: Getting Started73410 +Node: Running gawk75849 +Node: One-shot77039 +Node: Read Terminal78303 +Node: Long80334 +Node: Executable Scripts81847 +Ref: Executable Scripts-Footnote-184636 +Node: Comments84739 +Node: Quoting87221 +Node: DOS Quoting92739 +Node: Sample Data Files93414 +Node: Very Simple96009 +Node: Two Rules100908 +Node: More Complex102794 +Node: Statements/Lines105656 +Ref: Statements/Lines-Footnote-1110111 +Node: Other Features110376 +Node: When111312 +Ref: When-Footnote-1113066 +Node: Intro Summary113131 +Node: Invoking Gawk114015 +Node: Command Line115529 +Node: Options116327 +Ref: Options-Footnote-1132122 +Ref: Options-Footnote-2132351 +Node: Other Arguments132376 +Node: Naming Standard Input135324 +Node: Environment Variables136417 +Node: AWKPATH Variable136975 +Ref: AWKPATH Variable-Footnote-1140382 +Ref: AWKPATH Variable-Footnote-2140427 +Node: AWKLIBPATH Variable140687 +Node: Other Environment Variables141943 +Node: Exit Status145574 +Node: Include Files146250 +Node: Loading Shared Libraries149839 +Node: Obsolete151266 +Node: Undocumented151958 +Node: Invoking Summary152225 +Node: Regexp153888 +Node: Regexp Usage155342 +Node: Escape Sequences157379 +Node: Regexp Operators163608 +Ref: Regexp Operators-Footnote-1171018 +Ref: Regexp Operators-Footnote-2171165 +Node: Bracket Expressions171263 +Ref: table-char-classes173278 +Node: Leftmost Longest176220 +Node: Computed Regexps177522 +Node: GNU Regexp Operators180951 +Node: Case-sensitivity184623 +Ref: Case-sensitivity-Footnote-1187508 +Ref: Case-sensitivity-Footnote-2187743 +Node: Regexp Summary187851 +Node: Reading Files189318 +Node: Records191480 +Node: awk split records192213 +Node: gawk split records197142 +Ref: gawk split records-Footnote-1201681 +Node: Fields201718 +Ref: Fields-Footnote-1204496 +Node: Nonconstant Fields204582 +Ref: Nonconstant Fields-Footnote-1206820 +Node: Changing Fields207023 +Node: Field Separators212954 +Node: Default Field Splitting215658 +Node: Regexp Field Splitting216775 +Node: Single Character Fields220125 +Node: Command Line Field Separator221184 +Node: Full Line Fields224401 +Ref: Full Line Fields-Footnote-1225922 +Ref: Full Line Fields-Footnote-2225968 +Node: Field Splitting Summary226069 +Node: Constant Size228143 +Node: Splitting By Content232722 +Ref: Splitting By Content-Footnote-1236687 +Node: Multiple Line236850 +Ref: Multiple Line-Footnote-1242731 +Node: Getline242910 +Node: Plain Getline245380 +Node: Getline/Variable248020 +Node: Getline/File249169 +Node: Getline/Variable/File250554 +Ref: Getline/Variable/File-Footnote-1252157 +Node: Getline/Pipe252244 +Node: Getline/Variable/Pipe254922 +Node: Getline/Coprocess256053 +Node: Getline/Variable/Coprocess257317 +Node: Getline Notes258056 +Node: Getline Summary260850 +Ref: table-getline-variants261262 +Node: Read Timeout262091 +Ref: Read Timeout-Footnote-1265994 +Node: Retrying Input266052 +Node: Command-line directories267251 +Node: Input Summary268158 +Node: Input Exercises271543 +Node: Printing272271 +Node: Print274106 +Node: Print Examples275563 +Node: Output Separators278342 +Node: OFMT280360 +Node: Printf281715 +Node: Basic Printf282500 +Node: Control Letters284072 +Node: Format Modifiers288057 +Node: Printf Examples294063 +Node: Redirection296549 +Node: Special FD303387 +Ref: Special FD-Footnote-1306553 +Node: Special Files306627 +Node: Other Inherited Files307244 +Node: Special Network308244 +Node: Special Caveats309106 +Node: Close Files And Pipes310055 +Ref: Close Files And Pipes-Footnote-1317240 +Ref: Close Files And Pipes-Footnote-2317388 +Node: Nonfatal317538 +Node: Output Summary319863 +Node: Output Exercises321084 +Node: Expressions321764 +Node: Values322953 +Node: Constants323630 +Node: Scalar Constants324321 +Ref: Scalar Constants-Footnote-1325183 +Node: Nondecimal-numbers325433 +Node: Regexp Constants328443 +Node: Using Constant Regexps328969 +Node: Variables332132 +Node: Using Variables332789 +Node: Assignment Options334700 +Node: Conversion336575 +Node: Strings And Numbers337099 +Ref: Strings And Numbers-Footnote-1340164 +Node: Locale influences conversions340273 +Ref: table-locale-affects343019 +Node: All Operators343611 +Node: Arithmetic Ops344240 +Node: Concatenation346745 +Ref: Concatenation-Footnote-1349564 +Node: Assignment Ops349671 +Ref: table-assign-ops354650 +Node: Increment Ops355960 +Node: Truth Values and Conditions359391 +Node: Truth Values360474 +Node: Typing and Comparison361523 +Node: Variable Typing362339 +Node: Comparison Operators366006 +Ref: table-relational-ops366416 +Node: POSIX String Comparison369911 +Ref: POSIX String Comparison-Footnote-1370983 +Node: Boolean Ops371122 +Ref: Boolean Ops-Footnote-1375600 +Node: Conditional Exp375691 +Node: Function Calls377429 +Node: Precedence381309 +Node: Locales384969 +Node: Expressions Summary386601 +Node: Patterns and Actions389172 +Node: Pattern Overview390292 +Node: Regexp Patterns391971 +Node: Expression Patterns392514 +Node: Ranges396294 +Node: BEGIN/END399401 +Node: Using BEGIN/END400162 +Ref: Using BEGIN/END-Footnote-1402898 +Node: I/O And BEGIN/END403004 +Node: BEGINFILE/ENDFILE405319 +Node: Empty408216 +Node: Using Shell Variables408533 +Node: Action Overview410806 +Node: Statements413132 +Node: If Statement414980 +Node: While Statement416475 +Node: Do Statement418503 +Node: For Statement419651 +Node: Switch Statement422809 +Node: Break Statement425191 +Node: Continue Statement427284 +Node: Next Statement429111 +Node: Nextfile Statement431492 +Node: Exit Statement434120 +Node: Built-in Variables436531 +Node: User-modified437664 +Ref: User-modified-Footnote-1445298 +Node: Auto-set445360 +Ref: Auto-set-Footnote-1459593 +Ref: Auto-set-Footnote-2459798 +Node: ARGC and ARGV459854 +Node: Pattern Action Summary464072 +Node: Arrays466505 +Node: Array Basics467834 +Node: Array Intro468678 +Ref: figure-array-elements470615 +Ref: Array Intro-Footnote-1473238 +Node: Reference to Elements473366 +Node: Assigning Elements475828 +Node: Array Example476319 +Node: Scanning an Array478078 +Node: Controlling Scanning481101 +Ref: Controlling Scanning-Footnote-1486495 +Node: Numeric Array Subscripts486811 +Node: Uninitialized Subscripts488996 +Node: Delete490613 +Ref: Delete-Footnote-1493362 +Node: Multidimensional493419 +Node: Multiscanning496516 +Node: Arrays of Arrays498105 +Node: Arrays Summary502859 +Node: Functions504950 +Node: Built-in505989 +Node: Calling Built-in507067 +Node: Numeric Functions509062 +Ref: Numeric Functions-Footnote-1513892 +Ref: Numeric Functions-Footnote-2514249 +Ref: Numeric Functions-Footnote-3514297 +Node: String Functions514569 +Ref: String Functions-Footnote-1538070 +Ref: String Functions-Footnote-2538199 +Ref: String Functions-Footnote-3538447 +Node: Gory Details538534 +Ref: table-sub-escapes540315 +Ref: table-sub-proposed541830 +Ref: table-posix-sub543192 +Ref: table-gensub-escapes544729 +Ref: Gory Details-Footnote-1545562 +Node: I/O Functions545713 +Ref: I/O Functions-Footnote-1552949 +Node: Time Functions553096 +Ref: Time Functions-Footnote-1563605 +Ref: Time Functions-Footnote-2563673 +Ref: Time Functions-Footnote-3563831 +Ref: Time Functions-Footnote-4563942 +Ref: Time Functions-Footnote-5564054 +Ref: Time Functions-Footnote-6564281 +Node: Bitwise Functions564547 +Ref: table-bitwise-ops565109 +Ref: Bitwise Functions-Footnote-1569437 +Node: Type Functions569609 +Node: I18N Functions570761 +Node: User-defined572408 +Node: Definition Syntax573213 +Ref: Definition Syntax-Footnote-1578872 +Node: Function Example578943 +Ref: Function Example-Footnote-1581864 +Node: Function Caveats581886 +Node: Calling A Function582404 +Node: Variable Scope583362 +Node: Pass By Value/Reference586355 +Node: Return Statement589852 +Node: Dynamic Typing592831 +Node: Indirect Calls593760 +Ref: Indirect Calls-Footnote-1604003 +Node: Functions Summary604131 +Node: Library Functions606833 +Ref: Library Functions-Footnote-1610441 +Ref: Library Functions-Footnote-2610584 +Node: Library Names610755 +Ref: Library Names-Footnote-1614213 +Ref: Library Names-Footnote-2614436 +Node: General Functions614522 +Node: Strtonum Function615625 +Node: Assert Function618647 +Node: Round Function621971 +Node: Cliff Random Function623512 +Node: Ordinal Functions624528 +Ref: Ordinal Functions-Footnote-1627591 +Ref: Ordinal Functions-Footnote-2627843 +Node: Join Function628054 +Ref: Join Function-Footnote-1629824 +Node: Getlocaltime Function630024 +Node: Readfile Function633768 +Node: Shell Quoting635740 +Node: Data File Management637141 +Node: Filetrans Function637773 +Node: Rewind Function641869 +Node: File Checking643255 +Ref: File Checking-Footnote-1644588 +Node: Empty Files644789 +Node: Ignoring Assigns646768 +Node: Getopt Function648318 +Ref: Getopt Function-Footnote-1659782 +Node: Passwd Functions659982 +Ref: Passwd Functions-Footnote-1668822 +Node: Group Functions668910 +Ref: Group Functions-Footnote-1676807 +Node: Walking Arrays677012 +Node: Library Functions Summary680018 +Node: Library Exercises681420 +Node: Sample Programs682700 +Node: Running Examples683470 +Node: Clones684198 +Node: Cut Program685422 +Node: Egrep Program695142 +Ref: Egrep Program-Footnote-1702645 +Node: Id Program702755 +Node: Split Program706431 +Ref: Split Program-Footnote-1709885 +Node: Tee Program710013 +Node: Uniq Program712802 +Node: Wc Program720221 +Ref: Wc Program-Footnote-1724471 +Node: Miscellaneous Programs724565 +Node: Dupword Program725778 +Node: Alarm Program727809 +Node: Translate Program732614 +Ref: Translate Program-Footnote-1737177 +Node: Labels Program737447 +Ref: Labels Program-Footnote-1740798 +Node: Word Sorting740882 +Node: History Sorting744952 +Node: Extract Program746787 +Node: Simple Sed754311 +Node: Igawk Program757381 +Ref: Igawk Program-Footnote-1771707 +Ref: Igawk Program-Footnote-2771908 +Ref: Igawk Program-Footnote-3772030 +Node: Anagram Program772145 +Node: Signature Program775206 +Node: Programs Summary776453 +Node: Programs Exercises777674 +Ref: Programs Exercises-Footnote-1781805 +Node: Advanced Features781896 +Node: Nondecimal Data783878 +Node: Array Sorting785468 +Node: Controlling Array Traversal786168 +Ref: Controlling Array Traversal-Footnote-1794534 +Node: Array Sorting Functions794652 +Ref: Array Sorting Functions-Footnote-1798538 +Node: Two-way I/O798734 +Ref: Two-way I/O-Footnote-1803679 +Ref: Two-way I/O-Footnote-2803865 +Node: TCP/IP Networking803947 +Node: Profiling806819 +Node: Advanced Features Summary815090 +Node: Internationalization817023 +Node: I18N and L10N818503 +Node: Explaining gettext819189 +Ref: Explaining gettext-Footnote-1824214 +Ref: Explaining gettext-Footnote-2824398 +Node: Programmer i18n824563 +Ref: Programmer i18n-Footnote-1829439 +Node: Translator i18n829488 +Node: String Extraction830282 +Ref: String Extraction-Footnote-1831413 +Node: Printf Ordering831499 +Ref: Printf Ordering-Footnote-1834285 +Node: I18N Portability834349 +Ref: I18N Portability-Footnote-1836805 +Node: I18N Example836868 +Ref: I18N Example-Footnote-1839671 +Node: Gawk I18N839743 +Node: I18N Summary840387 +Node: Debugger841727 +Node: Debugging842749 +Node: Debugging Concepts843190 +Node: Debugging Terms845000 +Node: Awk Debugging847572 +Node: Sample Debugging Session848478 +Node: Debugger Invocation849012 +Node: Finding The Bug850397 +Node: List of Debugger Commands856876 +Node: Breakpoint Control858208 +Node: Debugger Execution Control861885 +Node: Viewing And Changing Data865244 +Node: Execution Stack868620 +Node: Debugger Info870255 +Node: Miscellaneous Debugger Commands874300 +Node: Readline Support879301 +Node: Limitations880195 +Node: Debugging Summary882310 +Node: Arbitrary Precision Arithmetic883484 +Node: Computer Arithmetic884900 +Ref: table-numeric-ranges888477 +Ref: Computer Arithmetic-Footnote-1889001 +Node: Math Definitions889058 +Ref: table-ieee-formats892353 +Ref: Math Definitions-Footnote-1892957 +Node: MPFR features893062 +Node: FP Math Caution894733 +Ref: FP Math Caution-Footnote-1895783 +Node: Inexactness of computations896152 +Node: Inexact representation897111 +Node: Comparing FP Values898469 +Node: Errors accumulate899551 +Node: Getting Accuracy900983 +Node: Try To Round903687 +Node: Setting precision904586 +Ref: table-predefined-precision-strings905270 +Node: Setting the rounding mode907099 +Ref: table-gawk-rounding-modes907463 +Ref: Setting the rounding mode-Footnote-1910915 +Node: Arbitrary Precision Integers911094 +Ref: Arbitrary Precision Integers-Footnote-1915992 +Node: POSIX Floating Point Problems916141 +Ref: POSIX Floating Point Problems-Footnote-1920020 +Node: Floating point summary920058 +Node: Dynamic Extensions922245 +Node: Extension Intro923797 +Node: Plugin License925062 +Node: Extension Mechanism Outline925859 +Ref: figure-load-extension926287 +Ref: figure-register-new-function927767 +Ref: figure-call-new-function928771 +Node: Extension API Description930758 +Node: Extension API Functions Introduction932292 +Node: General Data Types937161 +Ref: General Data Types-Footnote-1943061 +Node: Memory Allocation Functions943360 +Ref: Memory Allocation Functions-Footnote-1946199 +Node: Constructor Functions946298 +Node: Registration Functions948037 +Node: Extension Functions948722 +Node: Exit Callback Functions951019 +Node: Extension Version String952267 +Node: Input Parsers952930 +Node: Output Wrappers962805 +Node: Two-way processors967318 +Node: Printing Messages969581 +Ref: Printing Messages-Footnote-1970657 +Node: Updating `ERRNO'970809 +Node: Requesting Values971549 +Ref: table-value-types-returned972276 +Node: Accessing Parameters973233 +Node: Symbol Table Access974467 +Node: Symbol table by name974981 +Node: Symbol table by cookie977001 +Ref: Symbol table by cookie-Footnote-1981146 +Node: Cached values981209 +Ref: Cached values-Footnote-1984705 +Node: Array Manipulation984796 +Ref: Array Manipulation-Footnote-1985886 +Node: Array Data Types985923 +Ref: Array Data Types-Footnote-1988578 +Node: Array Functions988670 +Node: Flattening Arrays992529 +Node: Creating Arrays999431 +Node: Redirection API1004202 +Node: Extension API Variables1007027 +Node: Extension Versioning1007660 +Node: Extension API Informational Variables1009551 +Node: Extension API Boilerplate1010616 +Node: Finding Extensions1014425 +Node: Extension Example1014985 +Node: Internal File Description1015757 +Node: Internal File Ops1019824 +Ref: Internal File Ops-Footnote-11031575 +Node: Using Internal File Ops1031715 +Ref: Using Internal File Ops-Footnote-11034098 +Node: Extension Samples1034371 +Node: Extension Sample File Functions1035899 +Node: Extension Sample Fnmatch1043580 +Node: Extension Sample Fork1045068 +Node: Extension Sample Inplace1046283 +Node: Extension Sample Ord1048369 +Node: Extension Sample Readdir1049205 +Ref: table-readdir-file-types1050082 +Node: Extension Sample Revout1050893 +Node: Extension Sample Rev2way1051482 +Node: Extension Sample Read write array1052222 +Node: Extension Sample Readfile1054162 +Node: Extension Sample Time1055257 +Node: Extension Sample API Tests1056605 +Node: gawkextlib1057096 +Node: Extension summary1059797 +Node: Extension Exercises1063486 +Node: Language History1064982 +Node: V7/SVR3.11066638 +Node: SVR41068791 +Node: POSIX1070225 +Node: BTL1071606 +Node: POSIX/GNU1072337 +Node: Feature History1078173 +Node: Common Extensions1091967 +Node: Ranges and Locales1093339 +Ref: Ranges and Locales-Footnote-11097958 +Ref: Ranges and Locales-Footnote-21097985 +Ref: Ranges and Locales-Footnote-31098220 +Node: Contributors1098441 +Node: History summary1103981 +Node: Installation1105360 +Node: Gawk Distribution1106306 +Node: Getting1106790 +Node: Extracting1107613 +Node: Distribution contents1109250 +Node: Unix Installation1115352 +Node: Quick Installation1116035 +Node: Shell Startup Files1118446 +Node: Additional Configuration Options1119525 +Node: Configuration Philosophy1121329 +Node: Non-Unix Installation1123698 +Node: PC Installation1124156 +Node: PC Binary Installation1125476 +Node: PC Compiling1127324 +Ref: PC Compiling-Footnote-11130345 +Node: PC Testing1130454 +Node: PC Using1131630 +Node: Cygwin1135745 +Node: MSYS1136515 +Node: VMS Installation1137016 +Node: VMS Compilation1137808 +Ref: VMS Compilation-Footnote-11139037 +Node: VMS Dynamic Extensions1139095 +Node: VMS Installation Details1140779 +Node: VMS Running1143030 +Node: VMS GNV1145870 +Node: VMS Old Gawk1146605 +Node: Bugs1147075 +Node: Other Versions1150964 +Node: Installation summary1157398 +Node: Notes1158457 +Node: Compatibility Mode1159322 +Node: Additions1160104 +Node: Accessing The Source1161029 +Node: Adding Code1162464 +Node: New Ports1168621 +Node: Derived Files1173103 +Ref: Derived Files-Footnote-11178578 +Ref: Derived Files-Footnote-21178612 +Ref: Derived Files-Footnote-31179208 +Node: Future Extensions1179322 +Node: Implementation Limitations1179928 +Node: Extension Design1181176 +Node: Old Extension Problems1182330 +Ref: Old Extension Problems-Footnote-11183847 +Node: Extension New Mechanism Goals1183904 +Ref: Extension New Mechanism Goals-Footnote-11187264 +Node: Extension Other Design Decisions1187453 +Node: Extension Future Growth1189561 +Node: Old Extension Mechanism1190397 +Node: Notes summary1192159 +Node: Basic Concepts1193345 +Node: Basic High Level1194026 +Ref: figure-general-flow1194298 +Ref: figure-process-flow1194897 +Ref: Basic High Level-Footnote-11198126 +Node: Basic Data Typing1198311 +Node: Glossary1201639 +Node: Copying1233568 +Node: GNU Free Documentation License1271124 +Node: Index1296260 End Tag Table |