Imported Upstream version 1.4.17
[platform/upstream/m4.git] / doc / m4.info-2
1 This is m4.info, produced by makeinfo version 5.1 from m4.texi.
2
3 This manual (22 September 2013) is for GNU M4 (version 1.4.17), a
4 package containing an implementation of the m4 macro language.
5
6    Copyright (C) 1989-1994, 2004-2013 Free Software Foundation, Inc.
7
8      Permission is granted to copy, distribute and/or modify this
9      document under the terms of the GNU Free Documentation License,
10      Version 1.3 or any later version published by the Free Software
11      Foundation; with no Invariant Sections, no Front-Cover Texts, and
12      no Back-Cover Texts.  A copy of the license is included in the
13      section entitled "GNU Free Documentation License."
14 INFO-DIR-SECTION Text creation and manipulation
15 START-INFO-DIR-ENTRY
16 * M4: (m4).                     A powerful macro processor.
17 END-INFO-DIR-ENTRY
18
19 \1f
20 File: m4.info,  Node: Copying This Manual,  Next: Indices,  Prev: Copying This Package,  Up: Top
21
22 Appendix B How to make copies of this manual
23 ********************************************
24
25 This appendix covers the license for copying this manual.  Note that
26 some of the longer examples in this manual are also distributed in the
27 directory 'm4-1.4.17/examples/', where a more permissive license is in
28 effect when copying just the examples.
29
30 * Menu:
31
32 * GNU Free Documentation License::  License for copying this manual
33
34 \1f
35 File: m4.info,  Node: GNU Free Documentation License,  Up: Copying This Manual
36
37 B.1 License for copying this manual
38 ===================================
39
40                      Version 1.3, 3 November 2008
41
42      Copyright (C) 2000, 2001, 2002, 2007, 2008 Free Software Foundation, Inc.
43      <http://fsf.org/>
44
45      Everyone is permitted to copy and distribute verbatim copies
46      of this license document, but changing it is not allowed.
47
48   0. PREAMBLE
49
50      The purpose of this License is to make a manual, textbook, or other
51      functional and useful document "free" in the sense of freedom: to
52      assure everyone the effective freedom to copy and redistribute it,
53      with or without modifying it, either commercially or
54      noncommercially.  Secondarily, this License preserves for the
55      author and publisher a way to get credit for their work, while not
56      being considered responsible for modifications made by others.
57
58      This License is a kind of "copyleft", which means that derivative
59      works of the document must themselves be free in the same sense.
60      It complements the GNU General Public License, which is a copyleft
61      license designed for free software.
62
63      We have designed this License in order to use it for manuals for
64      free software, because free software needs free documentation: a
65      free program should come with manuals providing the same freedoms
66      that the software does.  But this License is not limited to
67      software manuals; it can be used for any textual work, regardless
68      of subject matter or whether it is published as a printed book.  We
69      recommend this License principally for works whose purpose is
70      instruction or reference.
71
72   1. APPLICABILITY AND DEFINITIONS
73
74      This License applies to any manual or other work, in any medium,
75      that contains a notice placed by the copyright holder saying it can
76      be distributed under the terms of this License.  Such a notice
77      grants a world-wide, royalty-free license, unlimited in duration,
78      to use that work under the conditions stated herein.  The
79      "Document", below, refers to any such manual or work.  Any member
80      of the public is a licensee, and is addressed as "you".  You accept
81      the license if you copy, modify or distribute the work in a way
82      requiring permission under copyright law.
83
84      A "Modified Version" of the Document means any work containing the
85      Document or a portion of it, either copied verbatim, or with
86      modifications and/or translated into another language.
87
88      A "Secondary Section" is a named appendix or a front-matter section
89      of the Document that deals exclusively with the relationship of the
90      publishers or authors of the Document to the Document's overall
91      subject (or to related matters) and contains nothing that could
92      fall directly within that overall subject.  (Thus, if the Document
93      is in part a textbook of mathematics, a Secondary Section may not
94      explain any mathematics.)  The relationship could be a matter of
95      historical connection with the subject or with related matters, or
96      of legal, commercial, philosophical, ethical or political position
97      regarding them.
98
99      The "Invariant Sections" are certain Secondary Sections whose
100      titles are designated, as being those of Invariant Sections, in the
101      notice that says that the Document is released under this License.
102      If a section does not fit the above definition of Secondary then it
103      is not allowed to be designated as Invariant.  The Document may
104      contain zero Invariant Sections.  If the Document does not identify
105      any Invariant Sections then there are none.
106
107      The "Cover Texts" are certain short passages of text that are
108      listed, as Front-Cover Texts or Back-Cover Texts, in the notice
109      that says that the Document is released under this License.  A
110      Front-Cover Text may be at most 5 words, and a Back-Cover Text may
111      be at most 25 words.
112
113      A "Transparent" copy of the Document means a machine-readable copy,
114      represented in a format whose specification is available to the
115      general public, that is suitable for revising the document
116      straightforwardly with generic text editors or (for images composed
117      of pixels) generic paint programs or (for drawings) some widely
118      available drawing editor, and that is suitable for input to text
119      formatters or for automatic translation to a variety of formats
120      suitable for input to text formatters.  A copy made in an otherwise
121      Transparent file format whose markup, or absence of markup, has
122      been arranged to thwart or discourage subsequent modification by
123      readers is not Transparent.  An image format is not Transparent if
124      used for any substantial amount of text.  A copy that is not
125      "Transparent" is called "Opaque".
126
127      Examples of suitable formats for Transparent copies include plain
128      ASCII without markup, Texinfo input format, LaTeX input format,
129      SGML or XML using a publicly available DTD, and standard-conforming
130      simple HTML, PostScript or PDF designed for human modification.
131      Examples of transparent image formats include PNG, XCF and JPG.
132      Opaque formats include proprietary formats that can be read and
133      edited only by proprietary word processors, SGML or XML for which
134      the DTD and/or processing tools are not generally available, and
135      the machine-generated HTML, PostScript or PDF produced by some word
136      processors for output purposes only.
137
138      The "Title Page" means, for a printed book, the title page itself,
139      plus such following pages as are needed to hold, legibly, the
140      material this License requires to appear in the title page.  For
141      works in formats which do not have any title page as such, "Title
142      Page" means the text near the most prominent appearance of the
143      work's title, preceding the beginning of the body of the text.
144
145      The "publisher" means any person or entity that distributes copies
146      of the Document to the public.
147
148      A section "Entitled XYZ" means a named subunit of the Document
149      whose title either is precisely XYZ or contains XYZ in parentheses
150      following text that translates XYZ in another language.  (Here XYZ
151      stands for a specific section name mentioned below, such as
152      "Acknowledgements", "Dedications", "Endorsements", or "History".)
153      To "Preserve the Title" of such a section when you modify the
154      Document means that it remains a section "Entitled XYZ" according
155      to this definition.
156
157      The Document may include Warranty Disclaimers next to the notice
158      which states that this License applies to the Document.  These
159      Warranty Disclaimers are considered to be included by reference in
160      this License, but only as regards disclaiming warranties: any other
161      implication that these Warranty Disclaimers may have is void and
162      has no effect on the meaning of this License.
163
164   2. VERBATIM COPYING
165
166      You may copy and distribute the Document in any medium, either
167      commercially or noncommercially, provided that this License, the
168      copyright notices, and the license notice saying this License
169      applies to the Document are reproduced in all copies, and that you
170      add no other conditions whatsoever to those of this License.  You
171      may not use technical measures to obstruct or control the reading
172      or further copying of the copies you make or distribute.  However,
173      you may accept compensation in exchange for copies.  If you
174      distribute a large enough number of copies you must also follow the
175      conditions in section 3.
176
177      You may also lend copies, under the same conditions stated above,
178      and you may publicly display copies.
179
180   3. COPYING IN QUANTITY
181
182      If you publish printed copies (or copies in media that commonly
183      have printed covers) of the Document, numbering more than 100, and
184      the Document's license notice requires Cover Texts, you must
185      enclose the copies in covers that carry, clearly and legibly, all
186      these Cover Texts: Front-Cover Texts on the front cover, and
187      Back-Cover Texts on the back cover.  Both covers must also clearly
188      and legibly identify you as the publisher of these copies.  The
189      front cover must present the full title with all words of the title
190      equally prominent and visible.  You may add other material on the
191      covers in addition.  Copying with changes limited to the covers, as
192      long as they preserve the title of the Document and satisfy these
193      conditions, can be treated as verbatim copying in other respects.
194
195      If the required texts for either cover are too voluminous to fit
196      legibly, you should put the first ones listed (as many as fit
197      reasonably) on the actual cover, and continue the rest onto
198      adjacent pages.
199
200      If you publish or distribute Opaque copies of the Document
201      numbering more than 100, you must either include a machine-readable
202      Transparent copy along with each Opaque copy, or state in or with
203      each Opaque copy a computer-network location from which the general
204      network-using public has access to download using public-standard
205      network protocols a complete Transparent copy of the Document, free
206      of added material.  If you use the latter option, you must take
207      reasonably prudent steps, when you begin distribution of Opaque
208      copies in quantity, to ensure that this Transparent copy will
209      remain thus accessible at the stated location until at least one
210      year after the last time you distribute an Opaque copy (directly or
211      through your agents or retailers) of that edition to the public.
212
213      It is requested, but not required, that you contact the authors of
214      the Document well before redistributing any large number of copies,
215      to give them a chance to provide you with an updated version of the
216      Document.
217
218   4. MODIFICATIONS
219
220      You may copy and distribute a Modified Version of the Document
221      under the conditions of sections 2 and 3 above, provided that you
222      release the Modified Version under precisely this License, with the
223      Modified Version filling the role of the Document, thus licensing
224      distribution and modification of the Modified Version to whoever
225      possesses a copy of it.  In addition, you must do these things in
226      the Modified Version:
227
228        A. Use in the Title Page (and on the covers, if any) a title
229           distinct from that of the Document, and from those of previous
230           versions (which should, if there were any, be listed in the
231           History section of the Document).  You may use the same title
232           as a previous version if the original publisher of that
233           version gives permission.
234
235        B. List on the Title Page, as authors, one or more persons or
236           entities responsible for authorship of the modifications in
237           the Modified Version, together with at least five of the
238           principal authors of the Document (all of its principal
239           authors, if it has fewer than five), unless they release you
240           from this requirement.
241
242        C. State on the Title page the name of the publisher of the
243           Modified Version, as the publisher.
244
245        D. Preserve all the copyright notices of the Document.
246
247        E. Add an appropriate copyright notice for your modifications
248           adjacent to the other copyright notices.
249
250        F. Include, immediately after the copyright notices, a license
251           notice giving the public permission to use the Modified
252           Version under the terms of this License, in the form shown in
253           the Addendum below.
254
255        G. Preserve in that license notice the full lists of Invariant
256           Sections and required Cover Texts given in the Document's
257           license notice.
258
259        H. Include an unaltered copy of this License.
260
261        I. Preserve the section Entitled "History", Preserve its Title,
262           and add to it an item stating at least the title, year, new
263           authors, and publisher of the Modified Version as given on the
264           Title Page.  If there is no section Entitled "History" in the
265           Document, create one stating the title, year, authors, and
266           publisher of the Document as given on its Title Page, then add
267           an item describing the Modified Version as stated in the
268           previous sentence.
269
270        J. Preserve the network location, if any, given in the Document
271           for public access to a Transparent copy of the Document, and
272           likewise the network locations given in the Document for
273           previous versions it was based on.  These may be placed in the
274           "History" section.  You may omit a network location for a work
275           that was published at least four years before the Document
276           itself, or if the original publisher of the version it refers
277           to gives permission.
278
279        K. For any section Entitled "Acknowledgements" or "Dedications",
280           Preserve the Title of the section, and preserve in the section
281           all the substance and tone of each of the contributor
282           acknowledgements and/or dedications given therein.
283
284        L. Preserve all the Invariant Sections of the Document, unaltered
285           in their text and in their titles.  Section numbers or the
286           equivalent are not considered part of the section titles.
287
288        M. Delete any section Entitled "Endorsements".  Such a section
289           may not be included in the Modified Version.
290
291        N. Do not retitle any existing section to be Entitled
292           "Endorsements" or to conflict in title with any Invariant
293           Section.
294
295        O. Preserve any Warranty Disclaimers.
296
297      If the Modified Version includes new front-matter sections or
298      appendices that qualify as Secondary Sections and contain no
299      material copied from the Document, you may at your option designate
300      some or all of these sections as invariant.  To do this, add their
301      titles to the list of Invariant Sections in the Modified Version's
302      license notice.  These titles must be distinct from any other
303      section titles.
304
305      You may add a section Entitled "Endorsements", provided it contains
306      nothing but endorsements of your Modified Version by various
307      parties--for example, statements of peer review or that the text
308      has been approved by an organization as the authoritative
309      definition of a standard.
310
311      You may add a passage of up to five words as a Front-Cover Text,
312      and a passage of up to 25 words as a Back-Cover Text, to the end of
313      the list of Cover Texts in the Modified Version.  Only one passage
314      of Front-Cover Text and one of Back-Cover Text may be added by (or
315      through arrangements made by) any one entity.  If the Document
316      already includes a cover text for the same cover, previously added
317      by you or by arrangement made by the same entity you are acting on
318      behalf of, you may not add another; but you may replace the old
319      one, on explicit permission from the previous publisher that added
320      the old one.
321
322      The author(s) and publisher(s) of the Document do not by this
323      License give permission to use their names for publicity for or to
324      assert or imply endorsement of any Modified Version.
325
326   5. COMBINING DOCUMENTS
327
328      You may combine the Document with other documents released under
329      this License, under the terms defined in section 4 above for
330      modified versions, provided that you include in the combination all
331      of the Invariant Sections of all of the original documents,
332      unmodified, and list them all as Invariant Sections of your
333      combined work in its license notice, and that you preserve all
334      their Warranty Disclaimers.
335
336      The combined work need only contain one copy of this License, and
337      multiple identical Invariant Sections may be replaced with a single
338      copy.  If there are multiple Invariant Sections with the same name
339      but different contents, make the title of each such section unique
340      by adding at the end of it, in parentheses, the name of the
341      original author or publisher of that section if known, or else a
342      unique number.  Make the same adjustment to the section titles in
343      the list of Invariant Sections in the license notice of the
344      combined work.
345
346      In the combination, you must combine any sections Entitled
347      "History" in the various original documents, forming one section
348      Entitled "History"; likewise combine any sections Entitled
349      "Acknowledgements", and any sections Entitled "Dedications".  You
350      must delete all sections Entitled "Endorsements."
351
352   6. COLLECTIONS OF DOCUMENTS
353
354      You may make a collection consisting of the Document and other
355      documents released under this License, and replace the individual
356      copies of this License in the various documents with a single copy
357      that is included in the collection, provided that you follow the
358      rules of this License for verbatim copying of each of the documents
359      in all other respects.
360
361      You may extract a single document from such a collection, and
362      distribute it individually under this License, provided you insert
363      a copy of this License into the extracted document, and follow this
364      License in all other respects regarding verbatim copying of that
365      document.
366
367   7. AGGREGATION WITH INDEPENDENT WORKS
368
369      A compilation of the Document or its derivatives with other
370      separate and independent documents or works, in or on a volume of a
371      storage or distribution medium, is called an "aggregate" if the
372      copyright resulting from the compilation is not used to limit the
373      legal rights of the compilation's users beyond what the individual
374      works permit.  When the Document is included in an aggregate, this
375      License does not apply to the other works in the aggregate which
376      are not themselves derivative works of the Document.
377
378      If the Cover Text requirement of section 3 is applicable to these
379      copies of the Document, then if the Document is less than one half
380      of the entire aggregate, the Document's Cover Texts may be placed
381      on covers that bracket the Document within the aggregate, or the
382      electronic equivalent of covers if the Document is in electronic
383      form.  Otherwise they must appear on printed covers that bracket
384      the whole aggregate.
385
386   8. TRANSLATION
387
388      Translation is considered a kind of modification, so you may
389      distribute translations of the Document under the terms of section
390      4.  Replacing Invariant Sections with translations requires special
391      permission from their copyright holders, but you may include
392      translations of some or all Invariant Sections in addition to the
393      original versions of these Invariant Sections.  You may include a
394      translation of this License, and all the license notices in the
395      Document, and any Warranty Disclaimers, provided that you also
396      include the original English version of this License and the
397      original versions of those notices and disclaimers.  In case of a
398      disagreement between the translation and the original version of
399      this License or a notice or disclaimer, the original version will
400      prevail.
401
402      If a section in the Document is Entitled "Acknowledgements",
403      "Dedications", or "History", the requirement (section 4) to
404      Preserve its Title (section 1) will typically require changing the
405      actual title.
406
407   9. TERMINATION
408
409      You may not copy, modify, sublicense, or distribute the Document
410      except as expressly provided under this License.  Any attempt
411      otherwise to copy, modify, sublicense, or distribute it is void,
412      and will automatically terminate your rights under this License.
413
414      However, if you cease all violation of this License, then your
415      license from a particular copyright holder is reinstated (a)
416      provisionally, unless and until the copyright holder explicitly and
417      finally terminates your license, and (b) permanently, if the
418      copyright holder fails to notify you of the violation by some
419      reasonable means prior to 60 days after the cessation.
420
421      Moreover, your license from a particular copyright holder is
422      reinstated permanently if the copyright holder notifies you of the
423      violation by some reasonable means, this is the first time you have
424      received notice of violation of this License (for any work) from
425      that copyright holder, and you cure the violation prior to 30 days
426      after your receipt of the notice.
427
428      Termination of your rights under this section does not terminate
429      the licenses of parties who have received copies or rights from you
430      under this License.  If your rights have been terminated and not
431      permanently reinstated, receipt of a copy of some or all of the
432      same material does not give you any rights to use it.
433
434   10. FUTURE REVISIONS OF THIS LICENSE
435
436      The Free Software Foundation may publish new, revised versions of
437      the GNU Free Documentation License from time to time.  Such new
438      versions will be similar in spirit to the present version, but may
439      differ in detail to address new problems or concerns.  See
440      <http://www.gnu.org/copyleft/>.
441
442      Each version of the License is given a distinguishing version
443      number.  If the Document specifies that a particular numbered
444      version of this License "or any later version" applies to it, you
445      have the option of following the terms and conditions either of
446      that specified version or of any later version that has been
447      published (not as a draft) by the Free Software Foundation.  If the
448      Document does not specify a version number of this License, you may
449      choose any version ever published (not as a draft) by the Free
450      Software Foundation.  If the Document specifies that a proxy can
451      decide which future versions of this License can be used, that
452      proxy's public statement of acceptance of a version permanently
453      authorizes you to choose that version for the Document.
454
455   11. RELICENSING
456
457      "Massive Multiauthor Collaboration Site" (or "MMC Site") means any
458      World Wide Web server that publishes copyrightable works and also
459      provides prominent facilities for anybody to edit those works.  A
460      public wiki that anybody can edit is an example of such a server.
461      A "Massive Multiauthor Collaboration" (or "MMC") contained in the
462      site means any set of copyrightable works thus published on the MMC
463      site.
464
465      "CC-BY-SA" means the Creative Commons Attribution-Share Alike 3.0
466      license published by Creative Commons Corporation, a not-for-profit
467      corporation with a principal place of business in San Francisco,
468      California, as well as future copyleft versions of that license
469      published by that same organization.
470
471      "Incorporate" means to publish or republish a Document, in whole or
472      in part, as part of another Document.
473
474      An MMC is "eligible for relicensing" if it is licensed under this
475      License, and if all works that were first published under this
476      License somewhere other than this MMC, and subsequently
477      incorporated in whole or in part into the MMC, (1) had no cover
478      texts or invariant sections, and (2) were thus incorporated prior
479      to November 1, 2008.
480
481      The operator of an MMC Site may republish an MMC contained in the
482      site under CC-BY-SA on the same site at any time before August 1,
483      2009, provided the MMC is eligible for relicensing.
484
485 ADDENDUM: How to use this License for your documents
486 ====================================================
487
488 To use this License in a document you have written, include a copy of
489 the License in the document and put the following copyright and license
490 notices just after the title page:
491
492        Copyright (C)  YEAR  YOUR NAME.
493        Permission is granted to copy, distribute and/or modify this document
494        under the terms of the GNU Free Documentation License, Version 1.3
495        or any later version published by the Free Software Foundation;
496        with no Invariant Sections, no Front-Cover Texts, and no Back-Cover
497        Texts.  A copy of the license is included in the section entitled ``GNU
498        Free Documentation License''.
499
500    If you have Invariant Sections, Front-Cover Texts and Back-Cover
501 Texts, replace the "with...Texts." line with this:
502
503          with the Invariant Sections being LIST THEIR TITLES, with
504          the Front-Cover Texts being LIST, and with the Back-Cover Texts
505          being LIST.
506
507    If you have Invariant Sections without Cover Texts, or some other
508 combination of the three, merge those two alternatives to suit the
509 situation.
510
511    If your document contains nontrivial examples of program code, we
512 recommend releasing these examples in parallel under your choice of free
513 software license, such as the GNU General Public License, to permit
514 their use in free software.
515
516 \1f
517 File: m4.info,  Node: Indices,  Prev: Copying This Manual,  Up: Top
518
519 Appendix C Indices of concepts and macros
520 *****************************************
521
522 * Menu:
523
524 * Macro index::                 Index for all 'm4' macros
525 * Concept index::               Index for many concepts
526
527 \1f
528 File: m4.info,  Node: Macro index,  Next: Concept index,  Up: Indices
529
530 C.1 Index for all 'm4' macros
531 =============================
532
533 This index covers all 'm4' builtins, as well as several useful composite
534 macros.  References are exclusively to the places where a macro is
535 introduced the first time.
536
537 \0\b[index\0\b]
538 * Menu:
539
540 * __file__:                              Location.            (line   9)
541 * __gnu__:                               Platform macros.     (line  11)
542 * __line__:                              Location.            (line  10)
543 * __os2__:                               Platform macros.     (line  12)
544 * __program__:                           Location.            (line  11)
545 * __unix__:                              Platform macros.     (line  14)
546 * __windows__:                           Platform macros.     (line  16)
547 * argn:                                  Shift.               (line 255)
548 * array:                                 Define.              (line  55)
549 * array_set:                             Define.              (line  56)
550 * builtin:                               Builtin.             (line   8)
551 * capitalize:                            Patsubst.            (line  54)
552 * changecom:                             Changecom.           (line   9)
553 * changequote:                           Changequote.         (line   9)
554 * changeword:                            Changeword.          (line  22)
555 * cleardivert:                           Cleardivert.         (line  25)
556 * cond:                                  Shift.               (line  51)
557 * copy:                                  Composition.         (line 119)
558 * curry:                                 Composition.         (line  67)
559 * debugfile:                             Debug Output.        (line  10)
560 * debugmode:                             Debug Levels.        (line  77)
561 * decr:                                  Incr.                (line  10)
562 * define:                                Define.              (line   9)
563 * define_blind:                          Composition.         (line  10)
564 * defn:                                  Defn.                (line   9)
565 * divert:                                Divert.              (line   8)
566 * divnum:                                Divnum.              (line   8)
567 * dnl:                                   Dnl.                 (line   8)
568 * downcase:                              Patsubst.            (line  53)
569 * dquote:                                Shift.               (line 193)
570 * dquote_elt:                            Shift.               (line 194)
571 * dumpdef:                               Dumpdef.             (line   9)
572 * errprint:                              Errprint.            (line   8)
573 * esyscmd:                               Esyscmd.             (line   8)
574 * eval:                                  Eval.                (line   8)
575 * example:                               Manual.              (line  39)
576 * exch:                                  Arguments.           (line  12)
577 * fatal_error:                           M4exit.              (line  24)
578 * foreach:                               Foreach.             (line   8)
579 * foreachq:                              Foreach.             (line   9)
580 * forloop:                               Forloop.             (line   8)
581 * format:                                Format.              (line   8)
582 * ifdef:                                 Ifdef.               (line   9)
583 * ifelse:                                Ifelse.              (line  10)
584 * ifelse <1>:                            Ifelse.              (line  11)
585 * ifelse <2>:                            Ifelse.              (line  12)
586 * include:                               Include.             (line   8)
587 * incr:                                  Incr.                (line   9)
588 * index:                                 Index macro.         (line   8)
589 * indir:                                 Indir.               (line   8)
590 * join:                                  Shift.               (line 101)
591 * joinall:                               Shift.               (line 102)
592 * len:                                   Len.                 (line   8)
593 * m4exit:                                M4exit.              (line   9)
594 * m4wrap:                                M4wrap.              (line  13)
595 * maketemp:                              Mkstemp.             (line  11)
596 * mkstemp:                               Mkstemp.             (line  10)
597 * nargs:                                 Pseudo Arguments.    (line  12)
598 * os2:                                   Platform macros.     (line  13)
599 * patsubst:                              Patsubst.            (line   8)
600 * popdef:                                Pushdef.             (line  11)
601 * pushdef:                               Pushdef.             (line  10)
602 * quote:                                 Shift.               (line 192)
603 * regexp:                                Regexp.              (line   8)
604 * rename:                                Composition.         (line 120)
605 * reverse:                               Shift.               (line  31)
606 * shift:                                 Shift.               (line  16)
607 * sinclude:                              Include.             (line   9)
608 * stack_foreach:                         Stacks.              (line  11)
609 * stack_foreach_lifo:                    Stacks.              (line  12)
610 * stack_foreach_sep:                     Improved copy.       (line  15)
611 * stack_foreach_sep_lifo:                Improved copy.       (line  16)
612 * substr:                                Substr.              (line   8)
613 * syscmd:                                Syscmd.              (line   8)
614 * sysval:                                Sysval.              (line   8)
615 * traceoff:                              Trace.               (line  10)
616 * traceon:                               Trace.               (line   9)
617 * translit:                              Translit.            (line   8)
618 * undefine:                              Undefine.            (line   8)
619 * undivert:                              Undivert.            (line   8)
620 * unix:                                  Platform macros.     (line  15)
621 * upcase:                                Patsubst.            (line  52)
622 * windows:                               Platform macros.     (line  17)
623
624 \1f
625 File: m4.info,  Node: Concept index,  Prev: Macro index,  Up: Indices
626
627 C.2 Index for many concepts
628 ===========================
629
630 \0\b[index\0\b]
631 * Menu:
632
633 * argument currying:                     Composition.         (line  63)
634 * arguments to macros:                   Macro Arguments.     (line   6)
635 * arguments to macros <1>:               Arguments.           (line   6)
636 * arguments to macros, special:          Pseudo Arguments.    (line   6)
637 * arguments, joining:                    Shift.               (line  98)
638 * arguments, more than nine:             Arguments.           (line  54)
639 * arguments, more than nine <1>:         Shift.               (line 250)
640 * arguments, more than nine <2>:         Improved foreach.    (line 156)
641 * arguments, quoted macro:               Quoting Arguments.   (line   6)
642 * arguments, reversing:                  Shift.               (line  31)
643 * arithmetic:                            Arithmetic.          (line   6)
644 * arrays:                                Define.              (line  52)
645 * avoiding quadratic behavior:           Improved foreach.    (line  38)
646 * basic regular expressions:             Regexp.              (line   6)
647 * basic regular expressions <1>:         Patsubst.            (line   6)
648 * blind macro:                           Inhibiting Invocation.
649                                                               (line  13)
650 * blind macro <1>:                       Ifelse.              (line  52)
651 * blind macro <2>:                       Composition.         (line  10)
652 * bug reports:                           Bugs.                (line   6)
653 * builtins, indirect call of:            Builtin.             (line   6)
654 * builtins, special tokens:              Defn.                (line 101)
655 * call of builtins, indirect:            Builtin.             (line   6)
656 * call of macros, indirect:              Indir.               (line   6)
657 * case statement:                        Ifelse.              (line  69)
658 * changing comment delimiters:           Changecom.           (line   6)
659 * changing quote delimiters:             Changequote.         (line   6)
660 * changing syntax:                       Changeword.          (line   6)
661 * characters, translating:               Translit.            (line   6)
662 * command line:                          Invoking m4.         (line   6)
663 * command line, file names on the:       Command line files.  (line   6)
664 * command line, macro definitions on the: Preprocessor features.
665                                                               (line   6)
666 * command line, options:                 Invoking m4.         (line  10)
667 * commands, exit status from shell:      Sysval.              (line   6)
668 * commands, running shell:               Shell commands.      (line   6)
669 * comment delimiters, changing:          Changecom.           (line   6)
670 * comments:                              Comments.            (line   6)
671 * comments, copied to output:            Changecom.           (line  29)
672 * comparing strings:                     Ifelse.              (line   6)
673 * compatibility:                         Compatibility.       (line   6)
674 * composing macros:                      Composition.         (line   6)
675 * concatenating arguments:               Shift.               (line  98)
676 * conditional, short-circuiting:         Shift.               (line  51)
677 * conditionals:                          Ifdef.               (line   6)
678 * controlling debugging output:          Debug Levels.        (line   6)
679 * copying macros:                        Composition.         (line 116)
680 * counting loops:                        Forloop.             (line   6)
681 * currying arguments:                    Composition.         (line  63)
682 * debugging macros:                      Debugging.           (line   6)
683 * debugging output, controlling:         Debug Levels.        (line   6)
684 * debugging output, saving:              Debug Output.        (line   6)
685 * decrement operator:                    Incr.                (line   6)
686 * deferring expansion:                   M4wrap.              (line   6)
687 * deferring output:                      Diversions.          (line   6)
688 * defining new macros:                   Definitions.         (line   6)
689 * definition stack:                      Pushdef.             (line   6)
690 * definition stack <1>:                  Stacks.              (line   6)
691 * definitions, displaying macro:         Defn.                (line   6)
692 * definitions, displaying macro <1>:     Dumpdef.             (line   6)
693 * deleting macros:                       Undefine.            (line   6)
694 * deleting whitespace in input:          Dnl.                 (line   6)
695 * delimiters, changing:                  Changequote.         (line   6)
696 * delimiters, changing <1>:              Changecom.           (line   6)
697 * discarding diverted text:              Cleardivert.         (line   6)
698 * discarding input:                      Ifelse.              (line   6)
699 * discarding input <1>:                  Dnl.                 (line   6)
700 * discarding input <2>:                  Divert.              (line  42)
701 * displaying macro definitions:          Dumpdef.             (line   6)
702 * diversion numbers:                     Divnum.              (line   6)
703 * diverted text, discarding:             Cleardivert.         (line   6)
704 * diverting output to files:             Divert.              (line   6)
705 * dumping into frozen file:              Using frozen files.  (line   6)
706 * error messages, printing:              Errprint.            (line   6)
707 * errors, fatal:                         Operation modes.     (line  19)
708 * evaluation, of integer expressions:    Eval.                (line   6)
709 * examples, understanding:               Manual.              (line   6)
710 * executing shell commands:              Shell commands.      (line   6)
711 * exit status from shell commands:       Sysval.              (line   6)
712 * exiting from 'm4':                     M4exit.              (line   6)
713 * expansion of macros:                   Macro expansion.     (line   6)
714 * expansion, deferring:                  M4wrap.              (line   6)
715 * expansion, tracing macro:              Trace.               (line   6)
716 * expressions, evaluation of integer:    Eval.                (line   6)
717 * expressions, regular:                  Regexp.              (line   6)
718 * expressions, regular <1>:              Patsubst.            (line   6)
719 * extracting substrings:                 Substr.              (line   6)
720 * fast loading of frozen files:          Using frozen files.  (line   6)
721 * fatal errors:                          Operation modes.     (line  19)
722 * FDL, GNU Free Documentation License:   GNU Free Documentation License.
723                                                               (line   6)
724 * file format, frozen file:              Frozen file format.  (line   6)
725 * file inclusion:                        File Inclusion.      (line   6)
726 * file inclusion <1>:                    Undivert.            (line  13)
727 * file inclusion <2>:                    Undivert.            (line  89)
728 * file names, on the command line:       Command line files.  (line   6)
729 * files, diverting output to:            Divert.              (line   6)
730 * files, names of temporary:             Mkstemp.             (line   6)
731 * for each loops:                        Foreach.             (line   6)
732 * for loops:                             Forloop.             (line   6)
733 * formatted output:                      Format.              (line   6)
734 * Free Documentation License (FDL), GNU: GNU Free Documentation License.
735                                                               (line   6)
736 * frozen file format:                    Frozen file format.  (line   6)
737 * frozen files for fast loading:         Using frozen files.  (line   6)
738 * General Public License (GPL), GNU:     GNU General Public License.
739                                                               (line   6)
740 * GNU extensions:                        Inhibiting Invocation.
741                                                               (line  13)
742 * GNU extensions <1>:                    Define.              (line  41)
743 * GNU extensions <2>:                    Arguments.           (line  54)
744 * GNU extensions <3>:                    Indir.               (line   6)
745 * GNU extensions <4>:                    Builtin.             (line   6)
746 * GNU extensions <5>:                    Debug Levels.        (line  74)
747 * GNU extensions <6>:                    Debug Output.        (line   6)
748 * GNU extensions <7>:                    Search Path.         (line   6)
749 * GNU extensions <8>:                    Divert.              (line  54)
750 * GNU extensions <9>:                    Undivert.            (line  13)
751 * GNU extensions <10>:                   Undivert.            (line  89)
752 * GNU extensions <11>:                   Regexp.              (line   6)
753 * GNU extensions <12>:                   Patsubst.            (line   6)
754 * GNU extensions <13>:                   Format.              (line   6)
755 * GNU extensions <14>:                   Eval.                (line 113)
756 * GNU extensions <15>:                   Esyscmd.             (line   6)
757 * GNU extensions <16>:                   Mkstemp.             (line  58)
758 * GNU extensions <17>:                   Using frozen files.  (line   6)
759 * GNU extensions <18>:                   Extensions.          (line   6)
760 * GNU Free Documentation License:        GNU Free Documentation License.
761                                                               (line   6)
762 * GNU General Public License:            GNU General Public License.
763                                                               (line   6)
764 * GNU M4, history of:                    History.             (line   6)
765 * GPL, GNU General Public License:       GNU General Public License.
766                                                               (line   6)
767 * history of 'm4':                       History.             (line   6)
768 * included files, search path for:       Search Path.         (line   6)
769 * inclusion, of files:                   File Inclusion.      (line   6)
770 * inclusion, of files <1>:               Undivert.            (line  13)
771 * inclusion, of files <2>:               Undivert.            (line  89)
772 * increment operator:                    Incr.                (line   6)
773 * indirect call of builtins:             Builtin.             (line   6)
774 * indirect call of macros:               Indir.               (line   6)
775 * initialization, frozen state:          Using frozen files.  (line   6)
776 * input location:                        Preprocessor features.
777                                                               (line  28)
778 * input location <1>:                    Location.            (line   6)
779 * input tokens:                          Syntax.              (line   6)
780 * input, discarding:                     Ifelse.              (line   6)
781 * input, discarding <1>:                 Dnl.                 (line   6)
782 * input, discarding <2>:                 Divert.              (line  42)
783 * input, saving:                         M4wrap.              (line   6)
784 * integer arithmetic:                    Arithmetic.          (line   6)
785 * integer expression evaluation:         Eval.                (line   6)
786 * invoking 'm4':                         Invoking m4.         (line   6)
787 * invoking macros:                       Invocation.          (line   6)
788 * iterating over lists:                  Foreach.             (line   6)
789 * joining arguments:                     Shift.               (line  98)
790 * length of strings:                     Len.                 (line   6)
791 * lexical structure of words:            Changeword.          (line   6)
792 * License, code:                         Copying This Package.
793                                                               (line   6)
794 * License, manual:                       Copying This Manual. (line   6)
795 * limit, nesting:                        Limits control.      (line  43)
796 * literal output:                        Pseudo Arguments.    (line 106)
797 * local variables:                       Pushdef.             (line  79)
798 * location, input:                       Preprocessor features.
799                                                               (line  28)
800 * location, input <1>:                   Location.            (line   6)
801 * loops:                                 Shift.               (line  10)
802 * loops, counting:                       Forloop.             (line   6)
803 * loops, list iteration:                 Foreach.             (line   6)
804 * 'M4PATH':                              Search Path.         (line   9)
805 * macro composition:                     Composition.         (line   6)
806 * macro definitions, on the command line: Preprocessor features.
807                                                               (line   6)
808 * macro expansion, tracing:              Trace.               (line   6)
809 * macro invocation:                      Invocation.          (line   6)
810 * macro, blind:                          Inhibiting Invocation.
811                                                               (line  13)
812 * macro, blind <1>:                      Ifelse.              (line  52)
813 * macro, blind <2>:                      Composition.         (line  10)
814 * macros, arguments to:                  Macro Arguments.     (line   6)
815 * macros, arguments to <1>:              Arguments.           (line   6)
816 * macros, copying:                       Composition.         (line 116)
817 * macros, debugging:                     Debugging.           (line   6)
818 * macros, displaying definitions:        Defn.                (line   6)
819 * macros, displaying definitions <1>:    Dumpdef.             (line   6)
820 * macros, expansion of:                  Macro expansion.     (line   6)
821 * macros, how to define new:             Definitions.         (line   6)
822 * macros, how to delete:                 Undefine.            (line   6)
823 * macros, how to rename:                 Defn.                (line   6)
824 * macros, indirect call of:              Indir.               (line   6)
825 * macros, quoted arguments to:           Quoting Arguments.   (line   6)
826 * macros, recursive:                     Shift.               (line   6)
827 * macros, special arguments to:          Pseudo Arguments.    (line   6)
828 * macros, temporary redefinition of:     Pushdef.             (line   6)
829 * manipulating quotes:                   Shift.               (line 189)
830 * messages, printing error:              Errprint.            (line   6)
831 * more than nine arguments:              Arguments.           (line  54)
832 * more than nine arguments <1>:          Shift.               (line 250)
833 * more than nine arguments <2>:          Improved foreach.    (line 156)
834 * multibranches:                         Ifelse.              (line  69)
835 * names:                                 Names.               (line   6)
836 * nesting limit:                         Limits control.      (line  43)
837 * nine arguments, more than:             Arguments.           (line  54)
838 * nine arguments, more than <1>:         Shift.               (line 250)
839 * nine arguments, more than <2>:         Improved foreach.    (line 156)
840 * numbers:                               Manual.              (line  57)
841 * options, command line:                 Invoking m4.         (line  10)
842 * output, diverting to files:            Divert.              (line   6)
843 * output, formatted:                     Format.              (line   6)
844 * output, literal:                       Pseudo Arguments.    (line 106)
845 * output, saving debugging:              Debug Output.        (line   6)
846 * overview of 'm4':                      Intro.               (line   6)
847 * pattern substitution:                  Patsubst.            (line   6)
848 * platform macros:                       Platform macros.     (line   6)
849 * positional parameters, more than nine: Arguments.           (line  54)
850 * POSIX:                                 Extensions.          (line   6)
851 * 'POSIXLY_CORRECT':                     Invoking m4.         (line  10)
852 * 'POSIXLY_CORRECT' <1>:                 Incompatibilities.   (line 144)
853 * preprocessor features:                 Preprocessor features.
854                                                               (line   6)
855 * printing error messages:               Errprint.            (line   6)
856 * pushdef stack:                         Pushdef.             (line   6)
857 * pushdef stack <1>:                     Stacks.              (line   6)
858 * quadratic behavior, avoiding:          Improved foreach.    (line  38)
859 * quote delimiters, changing:            Changequote.         (line   6)
860 * quote manipulation:                    Shift.               (line 189)
861 * quoted macro arguments:                Quoting Arguments.   (line   6)
862 * quoted string:                         Quoted strings.      (line   6)
863 * quoting rule of thumb:                 Quoting Arguments.   (line  22)
864 * recursive macros:                      Shift.               (line   6)
865 * redefinition of macros, temporary:     Pushdef.             (line   6)
866 * regular expressions:                   Changeword.          (line   6)
867 * regular expressions <1>:               Regexp.              (line   6)
868 * regular expressions <2>:               Patsubst.            (line   6)
869 * reloading a frozen file:               Using frozen files.  (line   6)
870 * renaming macros:                       Defn.                (line   6)
871 * renaming macros <1>:                   Composition.         (line 116)
872 * reporting bugs:                        Bugs.                (line   6)
873 * rescanning:                            Limits control.      (line  56)
874 * rescanning <1>:                        Inhibiting Invocation.
875                                                               (line  86)
876 * rescanning <2>:                        Pseudo Arguments.    (line 106)
877 * rescanning <3>:                        Defn.                (line  61)
878 * rescanning <4>:                        Other Incompatibilities.
879                                                               (line  52)
880 * reversing arguments:                   Shift.               (line  31)
881 * rule of thumb, quoting:                Quoting Arguments.   (line  22)
882 * running shell commands:                Shell commands.      (line   6)
883 * saving debugging output:               Debug Output.        (line   6)
884 * saving input:                          M4wrap.              (line   6)
885 * search path for included files:        Search Path.         (line   6)
886 * shell commands, exit status from:      Sysval.              (line   6)
887 * shell commands, running:               Shell commands.      (line   6)
888 * short-circuiting conditional:          Shift.               (line  51)
889 * special arguments to macros:           Pseudo Arguments.    (line   6)
890 * stack, macro definition:               Pushdef.             (line   6)
891 * stack, macro definition <1>:           Stacks.              (line   6)
892 * standard error, output to:             Dumpdef.             (line   6)
893 * standard error, output to <1>:         Trace.               (line   6)
894 * standard error, output to <2>:         Errprint.            (line   6)
895 * status of shell commands:              Sysval.              (line   6)
896 * status, setting 'm4' exit:             M4exit.              (line   6)
897 * string, quoted:                        Quoted strings.      (line   6)
898 * strings, length of:                    Len.                 (line   6)
899 * substitution by regular expression:    Patsubst.            (line   6)
900 * substrings, extracting:                Substr.              (line   6)
901 * substrings, locating:                  Index macro.         (line   6)
902 * suggestions, reporting:                Bugs.                (line   6)
903 * suppressing warnings:                  Macro Arguments.     (line  38)
904 * switch statement:                      Ifelse.              (line  69)
905 * synchronization lines:                 Preprocessor features.
906                                                               (line  28)
907 * syntax, changing:                      Changeword.          (line   6)
908 * temporary file names:                  Mkstemp.             (line   6)
909 * temporary redefinition of macros:      Pushdef.             (line   6)
910 * 'TMPDIR':                              Diversions.          (line  10)
911 * tokens:                                Syntax.              (line   6)
912 * tokens, builtin macro:                 Defn.                (line 101)
913 * tokens, special:                       Other tokens.        (line   6)
914 * tracing macro expansion:               Trace.               (line   6)
915 * translating characters:                Translit.            (line   6)
916 * undefining macros:                     Undefine.            (line   6)
917 * UNIX commands, exit status from:       Sysval.              (line   6)
918 * UNIX commands, running:                Shell commands.      (line   6)
919 * variables, local:                      Pushdef.             (line  79)
920 * warnings, suppressing:                 Macro Arguments.     (line  38)
921 * words:                                 Names.               (line   6)
922 * words, lexical structure of:           Changeword.          (line   6)
923