diff options
Diffstat (limited to 'doc/gawk.info')
-rw-r--r-- | doc/gawk.info | 1340 |
1 files changed, 730 insertions, 610 deletions
diff --git a/doc/gawk.info b/doc/gawk.info index 0329a038..15f5d978 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. @@ -557,6 +558,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 @@ -4170,6 +4172,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. @@ -5440,7 +5443,11 @@ how `awk' works. encounters the end of the file. If there is some error in getting a 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. +describing the error that occurred. If the `errno' variable indicates +that the I/O operation may be retried, and `PROCINFO["input", "RETRY"]' +is set, then -2 will be returned 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. @@ -5878,7 +5885,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 ================================= @@ -5957,7 +5964,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 @@ -5972,9 +5980,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 Directories on the Command Line +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, it will by +default return -1 from getline, and subsequent attempts to read from +that file will 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 setting a special element in the +`PROCINFO' array (*note Auto-set::): + + PROCINFO["input_name", "RETRY"] + + When set, this causes `gawk' to check the value of the system +`errno' variable when an I/O error occurs. If `errno' indicates a +subsequent I/O attempt may succeed, `getline' will instead return -2 and +further calls to `getline' may succeed. This applies to `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.12 Directories on the Command Line ==================================== According to the POSIX standard, files named on the `awk' command line @@ -5997,7 +6032,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 @@ -6071,7 +6106,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 @@ -10367,6 +10402,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 @@ -10415,6 +10455,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. @@ -10525,6 +10569,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::. @@ -22899,6 +22947,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. @@ -22959,6 +23008,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 @@ -24165,7 +24217,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 -------------------------- @@ -24650,9 +24702,72 @@ array: environment variable.) -File: gawk.info, Node: Extension API Variables, Next: Extension API Boilerplate, Prev: Array Manipulation, Up: Extension API Description - -16.4.12 API Variables +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 0, it returns data for the currently open + input file corresponding to `FILENAME' (and it will not access the + `filetype' argument, so that may be undefined). If the file is + not already open, it tries to open it. The `filetype' argument + must be NUL-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, a `false' value is returned. Otherwise, the return + status is `true', and additional information about the redirection + is returned 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 the fd is + non-negative, but the file exists already, `gawk' ignores the 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. It should work for input, + output, append, and two-way (coprocess) sockets. If `filetype' is + two-way, we assume that it is a socket! Note that in the two-way + case, the input and output file descriptors may differ. To check + for success, one 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.13 API Variables --------------------- The API provides two sets of variables. The first provides information @@ -24669,7 +24784,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 @@ -24718,7 +24833,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 @@ -24753,7 +24868,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 @@ -32417,9 +32532,9 @@ Index (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 104) +* 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 328) +* 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) @@ -32613,7 +32728,7 @@ Index * 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 130) +* 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) @@ -32636,7 +32751,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 144) +* 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) @@ -32644,9 +32759,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 279) +* 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. @@ -32654,7 +32771,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 283) +* differences in awk and gawk, SYMTAB variable: Auto-set. (line 296) * differences in awk and gawk, TEXTDOMAIN variable: User-modified. (line 152) * differences in awk and gawk, trunc-mod operation: Arithmetic Ops. @@ -32695,8 +32812,8 @@ Index * 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 149) -* effective user ID of gawk user: Auto-set. (line 153) +* 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) @@ -32811,7 +32928,7 @@ Index (line 6) * extension API version: Extension Versioning. (line 6) -* extension API, version number: Auto-set. (line 246) +* extension API, version number: Auto-set. (line 255) * extension example: Extension Example. (line 6) * extension registration: Registration Functions. (line 6) @@ -32892,7 +33009,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 104) +* 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) @@ -32960,9 +33077,9 @@ Index * flush buffered output: I/O Functions. (line 28) * fnmatch() extension function: Extension Sample Fnmatch. (line 12) -* FNR variable <1>: Auto-set. (line 114) +* FNR variable <1>: Auto-set. (line 119) * FNR variable: Records. (line 6) -* FNR variable, changing: Auto-set. (line 328) +* 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. @@ -33012,7 +33129,7 @@ Index * FSF (Free Software Foundation): Manual History. (line 6) * fts() extension function: Extension Sample File Functions. (line 61) -* FUNCTAB array: Auto-set. (line 130) +* 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) @@ -33062,7 +33179,7 @@ Index * G-d: Acknowledgments. (line 94) * Garfinkle, Scott: Contributors. (line 34) * gawk program, dynamic profiling: Profiling. (line 178) -* gawk version: Auto-set. (line 221) +* 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) @@ -33097,7 +33214,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 130) +* 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. @@ -33129,7 +33246,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 144) +* gawk, PROCINFO array in: Auto-set. (line 149) * gawk, regexp constants and: Using Constant Regexps. (line 28) * gawk, regular expressions, case sensitivity: Case-sensitivity. @@ -33137,14 +33254,14 @@ 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 279) +* 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 283) +* gawk, SYMTAB array in: Auto-set. (line 296) * gawk, TEXTDOMAIN variable in: User-modified. (line 152) * gawk, timestamps: Time Functions. (line 6) * gawk, uses for: Preface. (line 34) @@ -33236,7 +33353,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 194) +* 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. @@ -33531,7 +33648,7 @@ Index * mawk utility <3>: Concatenation. (line 36) * mawk utility <4>: Getline/Pipe. (line 62) * mawk utility: Escape Sequences. (line 120) -* maximum precision supported by MPFR library: Auto-set. (line 235) +* 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) @@ -33544,7 +33661,7 @@ Index * messages from extensions: Printing Messages. (line 6) * metacharacters in regular expressions: Regexp Operators. (line 6) * metacharacters, escape sequences for: Escape Sequences. (line 139) -* minimum precision supported by MPFR library: Auto-set. (line 238) +* minimum precision supported 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) @@ -33593,7 +33710,7 @@ Index (line 47) * nexti debugger command: Debugger Execution Control. (line 49) -* NF variable <1>: Auto-set. (line 119) +* 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. @@ -33602,9 +33719,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 139) +* NR variable <1>: Auto-set. (line 144) * NR variable: Records. (line 6) -* NR variable, changing: Auto-set. (line 328) +* 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. @@ -33718,7 +33835,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 203) +* 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) @@ -33884,24 +34001,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 idIDof gawk process: Auto-set. (line 197) -* process ID of gawk process: Auto-set. (line 200) +* process group idIDof 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 144) +* 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 256) +* 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 178) -* program identifiers: Auto-set. (line 162) +* program identifiers: Auto-set. (line 171) * program, definition of: Getting Started. (line 21) * programming conventions, --non-decimal-data option: Nondecimal Data. (line 35) @@ -34036,6 +34153,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) @@ -34059,7 +34177,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 266) +* 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 70) @@ -34085,9 +34203,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 272) +* RSTART variable: Auto-set. (line 285) * RSTART variable, match() function and: String Functions. (line 228) -* RT variable <1>: Auto-set. (line 279) +* 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) @@ -34107,7 +34225,7 @@ Index * 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 311) +* Schorr, Andrew <2>: Auto-set. (line 324) * Schorr, Andrew: Acknowledgments. (line 60) * Schreiber, Bert: Acknowledgments. (line 38) * Schreiber, Rita: Acknowledgments. (line 38) @@ -34190,7 +34308,7 @@ Index (line 106) * sidebar, Changing FS Does Not Affect the Fields: Full Line Fields. (line 14) -* sidebar, Changing NR and FNR: Auto-set. (line 326) +* 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. @@ -34352,9 +34470,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 251) +* supplementary groups of gawk process: Auto-set. (line 260) * switch statement: Switch Statement. (line 6) -* SYMTAB array: Auto-set. (line 283) +* SYMTAB array: Auto-set. (line 296) * syntactic ambiguity: /= operator vs. /=.../ regexp constant: Assignment Ops. (line 148) * system: I/O Functions. (line 107) @@ -34531,10 +34649,10 @@ Index * variables, uninitialized, as array subscripts: Uninitialized Subscripts. (line 6) * variables, user-defined: Variables. (line 6) -* version of gawk: Auto-set. (line 221) -* version of gawk extension API: Auto-set. (line 246) -* version of GNU MP library: Auto-set. (line 232) -* version of GNU MPFR library: Auto-set. (line 228) +* 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) @@ -34624,560 +34742,562 @@ Index Tag Table: Node: Top1204 -Node: Foreword342225 -Node: Foreword446669 -Node: Preface48200 -Ref: Preface-Footnote-151071 -Ref: Preface-Footnote-251178 -Ref: Preface-Footnote-351411 -Node: History51553 -Node: Names53904 -Ref: Names-Footnote-154997 -Node: This Manual55143 -Ref: This Manual-Footnote-161643 -Node: Conventions61743 -Node: Manual History64080 -Ref: Manual History-Footnote-167073 -Ref: Manual History-Footnote-267114 -Node: How To Contribute67188 -Node: Acknowledgments68317 -Node: Getting Started73134 -Node: Running gawk75573 -Node: One-shot76763 -Node: Read Terminal78027 -Node: Long80058 -Node: Executable Scripts81571 -Ref: Executable Scripts-Footnote-184360 -Node: Comments84463 -Node: Quoting86945 -Node: DOS Quoting92463 -Node: Sample Data Files93138 -Node: Very Simple95733 -Node: Two Rules100632 -Node: More Complex102518 -Node: Statements/Lines105380 -Ref: Statements/Lines-Footnote-1109835 -Node: Other Features110100 -Node: When111036 -Ref: When-Footnote-1112790 -Node: Intro Summary112855 -Node: Invoking Gawk113739 -Node: Command Line115253 -Node: Options116051 -Ref: Options-Footnote-1131846 -Ref: Options-Footnote-2132075 -Node: Other Arguments132100 -Node: Naming Standard Input135048 -Node: Environment Variables136141 -Node: AWKPATH Variable136699 -Ref: AWKPATH Variable-Footnote-1140106 -Ref: AWKPATH Variable-Footnote-2140151 -Node: AWKLIBPATH Variable140411 -Node: Other Environment Variables141667 -Node: Exit Status145185 -Node: Include Files145861 -Node: Loading Shared Libraries149450 -Node: Obsolete150877 -Node: Undocumented151569 -Node: Invoking Summary151836 -Node: Regexp153499 -Node: Regexp Usage154953 -Node: Escape Sequences156990 -Node: Regexp Operators163230 -Ref: Regexp Operators-Footnote-1170640 -Ref: Regexp Operators-Footnote-2170787 -Node: Bracket Expressions170885 -Ref: table-char-classes172900 -Node: Leftmost Longest175842 -Node: Computed Regexps177144 -Node: GNU Regexp Operators180573 -Node: Case-sensitivity184245 -Ref: Case-sensitivity-Footnote-1187130 -Ref: Case-sensitivity-Footnote-2187365 -Node: Regexp Summary187473 -Node: Reading Files188940 -Node: Records191033 -Node: awk split records191766 -Node: gawk split records196695 -Ref: gawk split records-Footnote-1201234 -Node: Fields201271 -Ref: Fields-Footnote-1204049 -Node: Nonconstant Fields204135 -Ref: Nonconstant Fields-Footnote-1206373 -Node: Changing Fields206576 -Node: Field Separators212507 -Node: Default Field Splitting215211 -Node: Regexp Field Splitting216328 -Node: Single Character Fields219678 -Node: Command Line Field Separator220737 -Node: Full Line Fields223954 -Ref: Full Line Fields-Footnote-1225475 -Ref: Full Line Fields-Footnote-2225521 -Node: Field Splitting Summary225622 -Node: Constant Size227696 -Node: Splitting By Content232279 -Ref: Splitting By Content-Footnote-1236244 -Node: Multiple Line236407 -Ref: Multiple Line-Footnote-1242288 -Node: Getline242467 -Node: Plain Getline244674 -Node: Getline/Variable247314 -Node: Getline/File248463 -Node: Getline/Variable/File249848 -Ref: Getline/Variable/File-Footnote-1251451 -Node: Getline/Pipe251538 -Node: Getline/Variable/Pipe254216 -Node: Getline/Coprocess255347 -Node: Getline/Variable/Coprocess256611 -Node: Getline Notes257350 -Node: Getline Summary260144 -Ref: table-getline-variants260556 -Node: Read Timeout261385 -Ref: Read Timeout-Footnote-1265222 -Node: Command-line directories265280 -Node: Input Summary266185 -Node: Input Exercises269570 -Node: Printing270298 -Node: Print272075 -Node: Print Examples273532 -Node: Output Separators276311 -Node: OFMT278329 -Node: Printf279684 -Node: Basic Printf280469 -Node: Control Letters282041 -Node: Format Modifiers286026 -Node: Printf Examples292036 -Node: Redirection294522 -Node: Special FD301360 -Ref: Special FD-Footnote-1304526 -Node: Special Files304600 -Node: Other Inherited Files305217 -Node: Special Network306217 -Node: Special Caveats307079 -Node: Close Files And Pipes308028 -Ref: Close Files And Pipes-Footnote-1315219 -Ref: Close Files And Pipes-Footnote-2315367 -Node: Output Summary315517 -Node: Output Exercises316515 -Node: Expressions317195 -Node: Values318384 -Node: Constants319061 -Node: Scalar Constants319752 -Ref: Scalar Constants-Footnote-1320614 -Node: Nondecimal-numbers320864 -Node: Regexp Constants323874 -Node: Using Constant Regexps324400 -Node: Variables327563 -Node: Using Variables328220 -Node: Assignment Options330131 -Node: Conversion332006 -Node: Strings And Numbers332530 -Ref: Strings And Numbers-Footnote-1335595 -Node: Locale influences conversions335704 -Ref: table-locale-affects338450 -Node: All Operators339042 -Node: Arithmetic Ops339671 -Node: Concatenation342176 -Ref: Concatenation-Footnote-1344995 -Node: Assignment Ops345102 -Ref: table-assign-ops350081 -Node: Increment Ops351391 -Node: Truth Values and Conditions354822 -Node: Truth Values355905 -Node: Typing and Comparison356954 -Node: Variable Typing357770 -Node: Comparison Operators361437 -Ref: table-relational-ops361847 -Node: POSIX String Comparison365342 -Ref: POSIX String Comparison-Footnote-1366414 -Node: Boolean Ops366553 -Ref: Boolean Ops-Footnote-1371031 -Node: Conditional Exp371122 -Node: Function Calls372860 -Node: Precedence376740 -Node: Locales380400 -Node: Expressions Summary382032 -Node: Patterns and Actions384603 -Node: Pattern Overview385723 -Node: Regexp Patterns387402 -Node: Expression Patterns387945 -Node: Ranges391654 -Node: BEGIN/END394761 -Node: Using BEGIN/END395522 -Ref: Using BEGIN/END-Footnote-1398258 -Node: I/O And BEGIN/END398364 -Node: BEGINFILE/ENDFILE400679 -Node: Empty403576 -Node: Using Shell Variables403893 -Node: Action Overview406166 -Node: Statements408492 -Node: If Statement410340 -Node: While Statement411835 -Node: Do Statement413863 -Node: For Statement415011 -Node: Switch Statement418169 -Node: Break Statement420551 -Node: Continue Statement422592 -Node: Next Statement424419 -Node: Nextfile Statement426800 -Node: Exit Statement429428 -Node: Built-in Variables431839 -Node: User-modified432972 -Ref: User-modified-Footnote-1440675 -Node: Auto-set440737 -Ref: Auto-set-Footnote-1454446 -Ref: Auto-set-Footnote-2454651 -Node: ARGC and ARGV454707 -Node: Pattern Action Summary458925 -Node: Arrays461358 -Node: Array Basics462687 -Node: Array Intro463531 -Ref: figure-array-elements465465 -Ref: Array Intro-Footnote-1468085 -Node: Reference to Elements468213 -Node: Assigning Elements470675 -Node: Array Example471166 -Node: Scanning an Array472925 -Node: Controlling Scanning475945 -Ref: Controlling Scanning-Footnote-1481339 -Node: Numeric Array Subscripts481655 -Node: Uninitialized Subscripts483840 -Node: Delete485457 -Ref: Delete-Footnote-1488206 -Node: Multidimensional488263 -Node: Multiscanning491360 -Node: Arrays of Arrays492949 -Node: Arrays Summary497703 -Node: Functions499794 -Node: Built-in500833 -Node: Calling Built-in501911 -Node: Numeric Functions503906 -Ref: Numeric Functions-Footnote-1508724 -Ref: Numeric Functions-Footnote-2509081 -Ref: Numeric Functions-Footnote-3509129 -Node: String Functions509401 -Ref: String Functions-Footnote-1532902 -Ref: String Functions-Footnote-2533031 -Ref: String Functions-Footnote-3533279 -Node: Gory Details533366 -Ref: table-sub-escapes535147 -Ref: table-sub-proposed536662 -Ref: table-posix-sub538024 -Ref: table-gensub-escapes539561 -Ref: Gory Details-Footnote-1540394 -Node: I/O Functions540545 -Ref: I/O Functions-Footnote-1547781 -Node: Time Functions547928 -Ref: Time Functions-Footnote-1558437 -Ref: Time Functions-Footnote-2558505 -Ref: Time Functions-Footnote-3558663 -Ref: Time Functions-Footnote-4558774 -Ref: Time Functions-Footnote-5558886 -Ref: Time Functions-Footnote-6559113 -Node: Bitwise Functions559379 -Ref: table-bitwise-ops559941 -Ref: Bitwise Functions-Footnote-1564253 -Node: Type Functions564425 -Node: I18N Functions565576 -Node: User-defined567221 -Node: Definition Syntax568026 -Ref: Definition Syntax-Footnote-1573658 -Node: Function Example573729 -Ref: Function Example-Footnote-1576648 -Node: Function Caveats576670 -Node: Calling A Function577188 -Node: Variable Scope578146 -Node: Pass By Value/Reference581134 -Node: Return Statement584629 -Node: Dynamic Typing587610 -Node: Indirect Calls588539 -Ref: Indirect Calls-Footnote-1599841 -Node: Functions Summary599969 -Node: Library Functions602671 -Ref: Library Functions-Footnote-1606280 -Ref: Library Functions-Footnote-2606423 -Node: Library Names606594 -Ref: Library Names-Footnote-1610048 -Ref: Library Names-Footnote-2610271 -Node: General Functions610357 -Node: Strtonum Function611460 -Node: Assert Function614482 -Node: Round Function617806 -Node: Cliff Random Function619347 -Node: Ordinal Functions620363 -Ref: Ordinal Functions-Footnote-1623426 -Ref: Ordinal Functions-Footnote-2623678 -Node: Join Function623889 -Ref: Join Function-Footnote-1625658 -Node: Getlocaltime Function625858 -Node: Readfile Function629602 -Node: Shell Quoting631572 -Node: Data File Management632973 -Node: Filetrans Function633605 -Node: Rewind Function637661 -Node: File Checking639048 -Ref: File Checking-Footnote-1640380 -Node: Empty Files640581 -Node: Ignoring Assigns642560 -Node: Getopt Function644111 -Ref: Getopt Function-Footnote-1655573 -Node: Passwd Functions655773 -Ref: Passwd Functions-Footnote-1664610 -Node: Group Functions664698 -Ref: Group Functions-Footnote-1672592 -Node: Walking Arrays672805 -Node: Library Functions Summary674408 -Node: Library Exercises675809 -Node: Sample Programs677089 -Node: Running Examples677859 -Node: Clones678587 -Node: Cut Program679811 -Node: Egrep Program689530 -Ref: Egrep Program-Footnote-1697028 -Node: Id Program697138 -Node: Split Program700783 -Ref: Split Program-Footnote-1704231 -Node: Tee Program704359 -Node: Uniq Program707148 -Node: Wc Program714567 -Ref: Wc Program-Footnote-1718817 -Node: Miscellaneous Programs718911 -Node: Dupword Program720124 -Node: Alarm Program722155 -Node: Translate Program726959 -Ref: Translate Program-Footnote-1731524 -Node: Labels Program731794 -Ref: Labels Program-Footnote-1735145 -Node: Word Sorting735229 -Node: History Sorting739300 -Node: Extract Program741136 -Node: Simple Sed748661 -Node: Igawk Program751729 -Ref: Igawk Program-Footnote-1766053 -Ref: Igawk Program-Footnote-2766254 -Ref: Igawk Program-Footnote-3766376 -Node: Anagram Program766491 -Node: Signature Program769548 -Node: Programs Summary770795 -Node: Programs Exercises771988 -Ref: Programs Exercises-Footnote-1776119 -Node: Advanced Features776210 -Node: Nondecimal Data778158 -Node: Array Sorting779748 -Node: Controlling Array Traversal780445 -Ref: Controlling Array Traversal-Footnote-1788778 -Node: Array Sorting Functions788896 -Ref: Array Sorting Functions-Footnote-1792785 -Node: Two-way I/O792981 -Ref: Two-way I/O-Footnote-1797926 -Ref: Two-way I/O-Footnote-2798112 -Node: TCP/IP Networking798194 -Node: Profiling801067 -Node: Advanced Features Summary809344 -Node: Internationalization811277 -Node: I18N and L10N812757 -Node: Explaining gettext813443 -Ref: Explaining gettext-Footnote-1818468 -Ref: Explaining gettext-Footnote-2818652 -Node: Programmer i18n818817 -Ref: Programmer i18n-Footnote-1823683 -Node: Translator i18n823732 -Node: String Extraction824526 -Ref: String Extraction-Footnote-1825657 -Node: Printf Ordering825743 -Ref: Printf Ordering-Footnote-1828529 -Node: I18N Portability828593 -Ref: I18N Portability-Footnote-1831048 -Node: I18N Example831111 -Ref: I18N Example-Footnote-1833914 -Node: Gawk I18N833986 -Node: I18N Summary834624 -Node: Debugger835963 -Node: Debugging836985 -Node: Debugging Concepts837426 -Node: Debugging Terms839279 -Node: Awk Debugging841851 -Node: Sample Debugging Session842745 -Node: Debugger Invocation843265 -Node: Finding The Bug844649 -Node: List of Debugger Commands851124 -Node: Breakpoint Control852457 -Node: Debugger Execution Control856153 -Node: Viewing And Changing Data859517 -Node: Execution Stack862895 -Node: Debugger Info864532 -Node: Miscellaneous Debugger Commands868549 -Node: Readline Support873578 -Node: Limitations874470 -Node: Debugging Summary876584 -Node: Arbitrary Precision Arithmetic877752 -Node: Computer Arithmetic879168 -Ref: table-numeric-ranges882766 -Ref: Computer Arithmetic-Footnote-1883625 -Node: Math Definitions883682 -Ref: table-ieee-formats886970 -Ref: Math Definitions-Footnote-1887574 -Node: MPFR features887679 -Node: FP Math Caution889350 -Ref: FP Math Caution-Footnote-1890400 -Node: Inexactness of computations890769 -Node: Inexact representation891728 -Node: Comparing FP Values893085 -Node: Errors accumulate894167 -Node: Getting Accuracy895600 -Node: Try To Round898262 -Node: Setting precision899161 -Ref: table-predefined-precision-strings899845 -Node: Setting the rounding mode901634 -Ref: table-gawk-rounding-modes901998 -Ref: Setting the rounding mode-Footnote-1905453 -Node: Arbitrary Precision Integers905632 -Ref: Arbitrary Precision Integers-Footnote-1910532 -Node: POSIX Floating Point Problems910681 -Ref: POSIX Floating Point Problems-Footnote-1914554 -Node: Floating point summary914592 -Node: Dynamic Extensions916786 -Node: Extension Intro918338 -Node: Plugin License919604 -Node: Extension Mechanism Outline920401 -Ref: figure-load-extension920829 -Ref: figure-register-new-function922309 -Ref: figure-call-new-function923313 -Node: Extension API Description925299 -Node: Extension API Functions Introduction926749 -Node: General Data Types931573 -Ref: General Data Types-Footnote-1937312 -Node: Memory Allocation Functions937611 -Ref: Memory Allocation Functions-Footnote-1940450 -Node: Constructor Functions940546 -Node: Registration Functions942280 -Node: Extension Functions942965 -Node: Exit Callback Functions945262 -Node: Extension Version String946510 -Node: Input Parsers947175 -Node: Output Wrappers957054 -Node: Two-way processors961569 -Node: Printing Messages963773 -Ref: Printing Messages-Footnote-1964849 -Node: Updating `ERRNO'965001 -Node: Requesting Values965741 -Ref: table-value-types-returned966469 -Node: Accessing Parameters967426 -Node: Symbol Table Access968657 -Node: Symbol table by name969171 -Node: Symbol table by cookie971152 -Ref: Symbol table by cookie-Footnote-1975296 -Node: Cached values975359 -Ref: Cached values-Footnote-1978858 -Node: Array Manipulation978949 -Ref: Array Manipulation-Footnote-1980047 -Node: Array Data Types980084 -Ref: Array Data Types-Footnote-1982739 -Node: Array Functions982831 -Node: Flattening Arrays986685 -Node: Creating Arrays993577 -Node: Extension API Variables998348 -Node: Extension Versioning998984 -Node: Extension API Informational Variables1000885 -Node: Extension API Boilerplate1001950 -Node: Finding Extensions1005759 -Node: Extension Example1006319 -Node: Internal File Description1007091 -Node: Internal File Ops1011158 -Ref: Internal File Ops-Footnote-11022828 -Node: Using Internal File Ops1022968 -Ref: Using Internal File Ops-Footnote-11025351 -Node: Extension Samples1025624 -Node: Extension Sample File Functions1027150 -Node: Extension Sample Fnmatch1034788 -Node: Extension Sample Fork1036279 -Node: Extension Sample Inplace1037494 -Node: Extension Sample Ord1039169 -Node: Extension Sample Readdir1040005 -Ref: table-readdir-file-types1040881 -Node: Extension Sample Revout1041692 -Node: Extension Sample Rev2way1042282 -Node: Extension Sample Read write array1043022 -Node: Extension Sample Readfile1044962 -Node: Extension Sample Time1046057 -Node: Extension Sample API Tests1047406 -Node: gawkextlib1047897 -Node: Extension summary1050555 -Node: Extension Exercises1054244 -Node: Language History1054966 -Node: V7/SVR3.11056622 -Node: SVR41058803 -Node: POSIX1060248 -Node: BTL1061637 -Node: POSIX/GNU1062371 -Node: Feature History1067995 -Node: Common Extensions1081093 -Node: Ranges and Locales1082417 -Ref: Ranges and Locales-Footnote-11087035 -Ref: Ranges and Locales-Footnote-21087062 -Ref: Ranges and Locales-Footnote-31087296 -Node: Contributors1087517 -Node: History summary1093058 -Node: Installation1094428 -Node: Gawk Distribution1095374 -Node: Getting1095858 -Node: Extracting1096681 -Node: Distribution contents1098316 -Node: Unix Installation1104381 -Node: Quick Installation1105064 -Node: Shell Startup Files1107475 -Node: Additional Configuration Options1108554 -Node: Configuration Philosophy1110293 -Node: Non-Unix Installation1112662 -Node: PC Installation1113120 -Node: PC Binary Installation1114439 -Node: PC Compiling1116287 -Ref: PC Compiling-Footnote-11119308 -Node: PC Testing1119417 -Node: PC Using1120593 -Node: Cygwin1124708 -Node: MSYS1125531 -Node: VMS Installation1126031 -Node: VMS Compilation1126823 -Ref: VMS Compilation-Footnote-11128045 -Node: VMS Dynamic Extensions1128103 -Node: VMS Installation Details1129787 -Node: VMS Running1132039 -Node: VMS GNV1134875 -Node: VMS Old Gawk1135609 -Node: Bugs1136079 -Node: Other Versions1139962 -Node: Installation summary1146386 -Node: Notes1147442 -Node: Compatibility Mode1148307 -Node: Additions1149089 -Node: Accessing The Source1150014 -Node: Adding Code1151449 -Node: New Ports1157606 -Node: Derived Files1162088 -Ref: Derived Files-Footnote-11167563 -Ref: Derived Files-Footnote-21167597 -Ref: Derived Files-Footnote-31168193 -Node: Future Extensions1168307 -Node: Implementation Limitations1168913 -Node: Extension Design1170161 -Node: Old Extension Problems1171315 -Ref: Old Extension Problems-Footnote-11172832 -Node: Extension New Mechanism Goals1172889 -Ref: Extension New Mechanism Goals-Footnote-11176249 -Node: Extension Other Design Decisions1176438 -Node: Extension Future Growth1178546 -Node: Old Extension Mechanism1179382 -Node: Notes summary1181144 -Node: Basic Concepts1182330 -Node: Basic High Level1183011 -Ref: figure-general-flow1183283 -Ref: figure-process-flow1183882 -Ref: Basic High Level-Footnote-11187111 -Node: Basic Data Typing1187296 -Node: Glossary1190624 -Node: Copying1222553 -Node: GNU Free Documentation License1260109 -Node: Index1285245 +Node: Foreword342385 +Node: Foreword446829 +Node: Preface48360 +Ref: Preface-Footnote-151231 +Ref: Preface-Footnote-251338 +Ref: Preface-Footnote-351571 +Node: History51713 +Node: Names54064 +Ref: Names-Footnote-155157 +Node: This Manual55303 +Ref: This Manual-Footnote-161803 +Node: Conventions61903 +Node: Manual History64240 +Ref: Manual History-Footnote-167233 +Ref: Manual History-Footnote-267274 +Node: How To Contribute67348 +Node: Acknowledgments68477 +Node: Getting Started73294 +Node: Running gawk75733 +Node: One-shot76923 +Node: Read Terminal78187 +Node: Long80218 +Node: Executable Scripts81731 +Ref: Executable Scripts-Footnote-184520 +Node: Comments84623 +Node: Quoting87105 +Node: DOS Quoting92623 +Node: Sample Data Files93298 +Node: Very Simple95893 +Node: Two Rules100792 +Node: More Complex102678 +Node: Statements/Lines105540 +Ref: Statements/Lines-Footnote-1109995 +Node: Other Features110260 +Node: When111196 +Ref: When-Footnote-1112950 +Node: Intro Summary113015 +Node: Invoking Gawk113899 +Node: Command Line115413 +Node: Options116211 +Ref: Options-Footnote-1132006 +Ref: Options-Footnote-2132235 +Node: Other Arguments132260 +Node: Naming Standard Input135208 +Node: Environment Variables136301 +Node: AWKPATH Variable136859 +Ref: AWKPATH Variable-Footnote-1140266 +Ref: AWKPATH Variable-Footnote-2140311 +Node: AWKLIBPATH Variable140571 +Node: Other Environment Variables141827 +Node: Exit Status145345 +Node: Include Files146021 +Node: Loading Shared Libraries149610 +Node: Obsolete151037 +Node: Undocumented151729 +Node: Invoking Summary151996 +Node: Regexp153659 +Node: Regexp Usage155113 +Node: Escape Sequences157150 +Node: Regexp Operators163390 +Ref: Regexp Operators-Footnote-1170800 +Ref: Regexp Operators-Footnote-2170947 +Node: Bracket Expressions171045 +Ref: table-char-classes173060 +Node: Leftmost Longest176002 +Node: Computed Regexps177304 +Node: GNU Regexp Operators180733 +Node: Case-sensitivity184405 +Ref: Case-sensitivity-Footnote-1187290 +Ref: Case-sensitivity-Footnote-2187525 +Node: Regexp Summary187633 +Node: Reading Files189100 +Node: Records191262 +Node: awk split records191995 +Node: gawk split records196924 +Ref: gawk split records-Footnote-1201463 +Node: Fields201500 +Ref: Fields-Footnote-1204278 +Node: Nonconstant Fields204364 +Ref: Nonconstant Fields-Footnote-1206602 +Node: Changing Fields206805 +Node: Field Separators212736 +Node: Default Field Splitting215440 +Node: Regexp Field Splitting216557 +Node: Single Character Fields219907 +Node: Command Line Field Separator220966 +Node: Full Line Fields224183 +Ref: Full Line Fields-Footnote-1225704 +Ref: Full Line Fields-Footnote-2225750 +Node: Field Splitting Summary225851 +Node: Constant Size227925 +Node: Splitting By Content232508 +Ref: Splitting By Content-Footnote-1236473 +Node: Multiple Line236636 +Ref: Multiple Line-Footnote-1242517 +Node: Getline242696 +Node: Plain Getline245175 +Node: Getline/Variable247815 +Node: Getline/File248964 +Node: Getline/Variable/File250349 +Ref: Getline/Variable/File-Footnote-1251952 +Node: Getline/Pipe252039 +Node: Getline/Variable/Pipe254717 +Node: Getline/Coprocess255848 +Node: Getline/Variable/Coprocess257112 +Node: Getline Notes257851 +Node: Getline Summary260645 +Ref: table-getline-variants261057 +Node: Read Timeout261886 +Ref: Read Timeout-Footnote-1265789 +Node: Retrying Input265847 +Node: Command-line directories267042 +Node: Input Summary267949 +Node: Input Exercises271334 +Node: Printing272062 +Node: Print273839 +Node: Print Examples275296 +Node: Output Separators278075 +Node: OFMT280093 +Node: Printf281448 +Node: Basic Printf282233 +Node: Control Letters283805 +Node: Format Modifiers287790 +Node: Printf Examples293800 +Node: Redirection296286 +Node: Special FD303124 +Ref: Special FD-Footnote-1306290 +Node: Special Files306364 +Node: Other Inherited Files306981 +Node: Special Network307981 +Node: Special Caveats308843 +Node: Close Files And Pipes309792 +Ref: Close Files And Pipes-Footnote-1316983 +Ref: Close Files And Pipes-Footnote-2317131 +Node: Output Summary317281 +Node: Output Exercises318279 +Node: Expressions318959 +Node: Values320148 +Node: Constants320825 +Node: Scalar Constants321516 +Ref: Scalar Constants-Footnote-1322378 +Node: Nondecimal-numbers322628 +Node: Regexp Constants325638 +Node: Using Constant Regexps326164 +Node: Variables329327 +Node: Using Variables329984 +Node: Assignment Options331895 +Node: Conversion333770 +Node: Strings And Numbers334294 +Ref: Strings And Numbers-Footnote-1337359 +Node: Locale influences conversions337468 +Ref: table-locale-affects340214 +Node: All Operators340806 +Node: Arithmetic Ops341435 +Node: Concatenation343940 +Ref: Concatenation-Footnote-1346759 +Node: Assignment Ops346866 +Ref: table-assign-ops351845 +Node: Increment Ops353155 +Node: Truth Values and Conditions356586 +Node: Truth Values357669 +Node: Typing and Comparison358718 +Node: Variable Typing359534 +Node: Comparison Operators363201 +Ref: table-relational-ops363611 +Node: POSIX String Comparison367106 +Ref: POSIX String Comparison-Footnote-1368178 +Node: Boolean Ops368317 +Ref: Boolean Ops-Footnote-1372795 +Node: Conditional Exp372886 +Node: Function Calls374624 +Node: Precedence378504 +Node: Locales382164 +Node: Expressions Summary383796 +Node: Patterns and Actions386367 +Node: Pattern Overview387487 +Node: Regexp Patterns389166 +Node: Expression Patterns389709 +Node: Ranges393418 +Node: BEGIN/END396525 +Node: Using BEGIN/END397286 +Ref: Using BEGIN/END-Footnote-1400022 +Node: I/O And BEGIN/END400128 +Node: BEGINFILE/ENDFILE402443 +Node: Empty405340 +Node: Using Shell Variables405657 +Node: Action Overview407930 +Node: Statements410256 +Node: If Statement412104 +Node: While Statement413599 +Node: Do Statement415627 +Node: For Statement416775 +Node: Switch Statement419933 +Node: Break Statement422315 +Node: Continue Statement424356 +Node: Next Statement426183 +Node: Nextfile Statement428564 +Node: Exit Statement431192 +Node: Built-in Variables433603 +Node: User-modified434736 +Ref: User-modified-Footnote-1442439 +Node: Auto-set442501 +Ref: Auto-set-Footnote-1456734 +Ref: Auto-set-Footnote-2456939 +Node: ARGC and ARGV456995 +Node: Pattern Action Summary461213 +Node: Arrays463646 +Node: Array Basics464975 +Node: Array Intro465819 +Ref: figure-array-elements467753 +Ref: Array Intro-Footnote-1470373 +Node: Reference to Elements470501 +Node: Assigning Elements472963 +Node: Array Example473454 +Node: Scanning an Array475213 +Node: Controlling Scanning478233 +Ref: Controlling Scanning-Footnote-1483627 +Node: Numeric Array Subscripts483943 +Node: Uninitialized Subscripts486128 +Node: Delete487745 +Ref: Delete-Footnote-1490494 +Node: Multidimensional490551 +Node: Multiscanning493648 +Node: Arrays of Arrays495237 +Node: Arrays Summary499991 +Node: Functions502082 +Node: Built-in503121 +Node: Calling Built-in504199 +Node: Numeric Functions506194 +Ref: Numeric Functions-Footnote-1511012 +Ref: Numeric Functions-Footnote-2511369 +Ref: Numeric Functions-Footnote-3511417 +Node: String Functions511689 +Ref: String Functions-Footnote-1535190 +Ref: String Functions-Footnote-2535319 +Ref: String Functions-Footnote-3535567 +Node: Gory Details535654 +Ref: table-sub-escapes537435 +Ref: table-sub-proposed538950 +Ref: table-posix-sub540312 +Ref: table-gensub-escapes541849 +Ref: Gory Details-Footnote-1542682 +Node: I/O Functions542833 +Ref: I/O Functions-Footnote-1550069 +Node: Time Functions550216 +Ref: Time Functions-Footnote-1560725 +Ref: Time Functions-Footnote-2560793 +Ref: Time Functions-Footnote-3560951 +Ref: Time Functions-Footnote-4561062 +Ref: Time Functions-Footnote-5561174 +Ref: Time Functions-Footnote-6561401 +Node: Bitwise Functions561667 +Ref: table-bitwise-ops562229 +Ref: Bitwise Functions-Footnote-1566541 +Node: Type Functions566713 +Node: I18N Functions567864 +Node: User-defined569509 +Node: Definition Syntax570314 +Ref: Definition Syntax-Footnote-1575946 +Node: Function Example576017 +Ref: Function Example-Footnote-1578936 +Node: Function Caveats578958 +Node: Calling A Function579476 +Node: Variable Scope580434 +Node: Pass By Value/Reference583422 +Node: Return Statement586917 +Node: Dynamic Typing589898 +Node: Indirect Calls590827 +Ref: Indirect Calls-Footnote-1602129 +Node: Functions Summary602257 +Node: Library Functions604959 +Ref: Library Functions-Footnote-1608568 +Ref: Library Functions-Footnote-2608711 +Node: Library Names608882 +Ref: Library Names-Footnote-1612336 +Ref: Library Names-Footnote-2612559 +Node: General Functions612645 +Node: Strtonum Function613748 +Node: Assert Function616770 +Node: Round Function620094 +Node: Cliff Random Function621635 +Node: Ordinal Functions622651 +Ref: Ordinal Functions-Footnote-1625714 +Ref: Ordinal Functions-Footnote-2625966 +Node: Join Function626177 +Ref: Join Function-Footnote-1627946 +Node: Getlocaltime Function628146 +Node: Readfile Function631890 +Node: Shell Quoting633860 +Node: Data File Management635261 +Node: Filetrans Function635893 +Node: Rewind Function639949 +Node: File Checking641336 +Ref: File Checking-Footnote-1642668 +Node: Empty Files642869 +Node: Ignoring Assigns644848 +Node: Getopt Function646399 +Ref: Getopt Function-Footnote-1657861 +Node: Passwd Functions658061 +Ref: Passwd Functions-Footnote-1666898 +Node: Group Functions666986 +Ref: Group Functions-Footnote-1674880 +Node: Walking Arrays675093 +Node: Library Functions Summary676696 +Node: Library Exercises678097 +Node: Sample Programs679377 +Node: Running Examples680147 +Node: Clones680875 +Node: Cut Program682099 +Node: Egrep Program691818 +Ref: Egrep Program-Footnote-1699316 +Node: Id Program699426 +Node: Split Program703071 +Ref: Split Program-Footnote-1706519 +Node: Tee Program706647 +Node: Uniq Program709436 +Node: Wc Program716855 +Ref: Wc Program-Footnote-1721105 +Node: Miscellaneous Programs721199 +Node: Dupword Program722412 +Node: Alarm Program724443 +Node: Translate Program729247 +Ref: Translate Program-Footnote-1733812 +Node: Labels Program734082 +Ref: Labels Program-Footnote-1737433 +Node: Word Sorting737517 +Node: History Sorting741588 +Node: Extract Program743424 +Node: Simple Sed750949 +Node: Igawk Program754017 +Ref: Igawk Program-Footnote-1768341 +Ref: Igawk Program-Footnote-2768542 +Ref: Igawk Program-Footnote-3768664 +Node: Anagram Program768779 +Node: Signature Program771836 +Node: Programs Summary773083 +Node: Programs Exercises774276 +Ref: Programs Exercises-Footnote-1778407 +Node: Advanced Features778498 +Node: Nondecimal Data780446 +Node: Array Sorting782036 +Node: Controlling Array Traversal782733 +Ref: Controlling Array Traversal-Footnote-1791066 +Node: Array Sorting Functions791184 +Ref: Array Sorting Functions-Footnote-1795073 +Node: Two-way I/O795269 +Ref: Two-way I/O-Footnote-1800214 +Ref: Two-way I/O-Footnote-2800400 +Node: TCP/IP Networking800482 +Node: Profiling803355 +Node: Advanced Features Summary811632 +Node: Internationalization813565 +Node: I18N and L10N815045 +Node: Explaining gettext815731 +Ref: Explaining gettext-Footnote-1820756 +Ref: Explaining gettext-Footnote-2820940 +Node: Programmer i18n821105 +Ref: Programmer i18n-Footnote-1825971 +Node: Translator i18n826020 +Node: String Extraction826814 +Ref: String Extraction-Footnote-1827945 +Node: Printf Ordering828031 +Ref: Printf Ordering-Footnote-1830817 +Node: I18N Portability830881 +Ref: I18N Portability-Footnote-1833336 +Node: I18N Example833399 +Ref: I18N Example-Footnote-1836202 +Node: Gawk I18N836274 +Node: I18N Summary836912 +Node: Debugger838251 +Node: Debugging839273 +Node: Debugging Concepts839714 +Node: Debugging Terms841567 +Node: Awk Debugging844139 +Node: Sample Debugging Session845033 +Node: Debugger Invocation845553 +Node: Finding The Bug846937 +Node: List of Debugger Commands853412 +Node: Breakpoint Control854745 +Node: Debugger Execution Control858441 +Node: Viewing And Changing Data861805 +Node: Execution Stack865183 +Node: Debugger Info866820 +Node: Miscellaneous Debugger Commands870837 +Node: Readline Support875866 +Node: Limitations876758 +Node: Debugging Summary878872 +Node: Arbitrary Precision Arithmetic880040 +Node: Computer Arithmetic881456 +Ref: table-numeric-ranges885054 +Ref: Computer Arithmetic-Footnote-1885913 +Node: Math Definitions885970 +Ref: table-ieee-formats889258 +Ref: Math Definitions-Footnote-1889862 +Node: MPFR features889967 +Node: FP Math Caution891638 +Ref: FP Math Caution-Footnote-1892688 +Node: Inexactness of computations893057 +Node: Inexact representation894016 +Node: Comparing FP Values895373 +Node: Errors accumulate896455 +Node: Getting Accuracy897888 +Node: Try To Round900550 +Node: Setting precision901449 +Ref: table-predefined-precision-strings902133 +Node: Setting the rounding mode903922 +Ref: table-gawk-rounding-modes904286 +Ref: Setting the rounding mode-Footnote-1907741 +Node: Arbitrary Precision Integers907920 +Ref: Arbitrary Precision Integers-Footnote-1912820 +Node: POSIX Floating Point Problems912969 +Ref: POSIX Floating Point Problems-Footnote-1916842 +Node: Floating point summary916880 +Node: Dynamic Extensions919074 +Node: Extension Intro920626 +Node: Plugin License921892 +Node: Extension Mechanism Outline922689 +Ref: figure-load-extension923117 +Ref: figure-register-new-function924597 +Ref: figure-call-new-function925601 +Node: Extension API Description927587 +Node: Extension API Functions Introduction929121 +Node: General Data Types933993 +Ref: General Data Types-Footnote-1939732 +Node: Memory Allocation Functions940031 +Ref: Memory Allocation Functions-Footnote-1942870 +Node: Constructor Functions942966 +Node: Registration Functions944700 +Node: Extension Functions945385 +Node: Exit Callback Functions947682 +Node: Extension Version String948930 +Node: Input Parsers949595 +Node: Output Wrappers959474 +Node: Two-way processors963989 +Node: Printing Messages966193 +Ref: Printing Messages-Footnote-1967269 +Node: Updating `ERRNO'967421 +Node: Requesting Values968161 +Ref: table-value-types-returned968889 +Node: Accessing Parameters969846 +Node: Symbol Table Access971077 +Node: Symbol table by name971591 +Node: Symbol table by cookie973572 +Ref: Symbol table by cookie-Footnote-1977716 +Node: Cached values977779 +Ref: Cached values-Footnote-1981278 +Node: Array Manipulation981369 +Ref: Array Manipulation-Footnote-1982459 +Node: Array Data Types982496 +Ref: Array Data Types-Footnote-1985151 +Node: Array Functions985243 +Node: Flattening Arrays989097 +Node: Creating Arrays995989 +Node: Redirection API1000760 +Node: Extension API Variables1003531 +Node: Extension Versioning1004164 +Node: Extension API Informational Variables1006065 +Node: Extension API Boilerplate1007130 +Node: Finding Extensions1010939 +Node: Extension Example1011499 +Node: Internal File Description1012271 +Node: Internal File Ops1016338 +Ref: Internal File Ops-Footnote-11028008 +Node: Using Internal File Ops1028148 +Ref: Using Internal File Ops-Footnote-11030531 +Node: Extension Samples1030804 +Node: Extension Sample File Functions1032330 +Node: Extension Sample Fnmatch1039968 +Node: Extension Sample Fork1041459 +Node: Extension Sample Inplace1042674 +Node: Extension Sample Ord1044349 +Node: Extension Sample Readdir1045185 +Ref: table-readdir-file-types1046061 +Node: Extension Sample Revout1046872 +Node: Extension Sample Rev2way1047462 +Node: Extension Sample Read write array1048202 +Node: Extension Sample Readfile1050142 +Node: Extension Sample Time1051237 +Node: Extension Sample API Tests1052586 +Node: gawkextlib1053077 +Node: Extension summary1055735 +Node: Extension Exercises1059424 +Node: Language History1060146 +Node: V7/SVR3.11061802 +Node: SVR41063983 +Node: POSIX1065428 +Node: BTL1066817 +Node: POSIX/GNU1067551 +Node: Feature History1073175 +Node: Common Extensions1086273 +Node: Ranges and Locales1087597 +Ref: Ranges and Locales-Footnote-11092215 +Ref: Ranges and Locales-Footnote-21092242 +Ref: Ranges and Locales-Footnote-31092476 +Node: Contributors1092697 +Node: History summary1098238 +Node: Installation1099608 +Node: Gawk Distribution1100554 +Node: Getting1101038 +Node: Extracting1101861 +Node: Distribution contents1103496 +Node: Unix Installation1109561 +Node: Quick Installation1110244 +Node: Shell Startup Files1112655 +Node: Additional Configuration Options1113734 +Node: Configuration Philosophy1115473 +Node: Non-Unix Installation1117842 +Node: PC Installation1118300 +Node: PC Binary Installation1119619 +Node: PC Compiling1121467 +Ref: PC Compiling-Footnote-11124488 +Node: PC Testing1124597 +Node: PC Using1125773 +Node: Cygwin1129888 +Node: MSYS1130711 +Node: VMS Installation1131211 +Node: VMS Compilation1132003 +Ref: VMS Compilation-Footnote-11133225 +Node: VMS Dynamic Extensions1133283 +Node: VMS Installation Details1134967 +Node: VMS Running1137219 +Node: VMS GNV1140055 +Node: VMS Old Gawk1140789 +Node: Bugs1141259 +Node: Other Versions1145142 +Node: Installation summary1151566 +Node: Notes1152622 +Node: Compatibility Mode1153487 +Node: Additions1154269 +Node: Accessing The Source1155194 +Node: Adding Code1156629 +Node: New Ports1162786 +Node: Derived Files1167268 +Ref: Derived Files-Footnote-11172743 +Ref: Derived Files-Footnote-21172777 +Ref: Derived Files-Footnote-31173373 +Node: Future Extensions1173487 +Node: Implementation Limitations1174093 +Node: Extension Design1175341 +Node: Old Extension Problems1176495 +Ref: Old Extension Problems-Footnote-11178012 +Node: Extension New Mechanism Goals1178069 +Ref: Extension New Mechanism Goals-Footnote-11181429 +Node: Extension Other Design Decisions1181618 +Node: Extension Future Growth1183726 +Node: Old Extension Mechanism1184562 +Node: Notes summary1186324 +Node: Basic Concepts1187510 +Node: Basic High Level1188191 +Ref: figure-general-flow1188463 +Ref: figure-process-flow1189062 +Ref: Basic High Level-Footnote-11192291 +Node: Basic Data Typing1192476 +Node: Glossary1195804 +Node: Copying1227733 +Node: GNU Free Documentation License1265289 +Node: Index1290425 End Tag Table |