m4.xml 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. <?xml version="1.0" encoding="ISO-8859-1"?>
  2. <!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
  3. "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
  4. <!ENTITY % general-entities SYSTEM "../general.ent">
  5. %general-entities;
  6. ]>
  7. <sect1 id="ch-system-m4" role="wrap">
  8. <?dbhtml filename="m4.html"?>
  9. <sect1info condition="script">
  10. <productname>m4</productname>
  11. <productnumber>&m4-version;</productnumber>
  12. <address>&m4-url;</address>
  13. </sect1info>
  14. <title>M4-&m4-version;</title>
  15. <indexterm zone="ch-system-m4">
  16. <primary sortas="a-M4">M4</primary>
  17. </indexterm>
  18. <sect2 role="package">
  19. <title/>
  20. <para>The M4 package contains a macro processor.</para>
  21. <segmentedlist>
  22. <segtitle>&buildtime;</segtitle>
  23. <segtitle>&diskspace;</segtitle>
  24. <seglistitem>
  25. <seg>&m4-fin-sbu;</seg>
  26. <seg>&m4-fin-du;</seg>
  27. </seglistitem>
  28. </segmentedlist>
  29. </sect2>
  30. <sect2 role="installation">
  31. <title>Installation of M4</title>
  32. <para>First, make some fixes required by glibc-2.28 and later:</para>
  33. <screen><userinput remap="pre">sed -i 's/IO_ftrylockfile/IO_EOF_SEEN/' lib/*.c
  34. echo "#define _IO_IN_BACKUP 0x100" >> lib/stdio-impl.h</userinput></screen>
  35. <para>Prepare M4 for compilation:</para>
  36. <screen><userinput remap="configure">./configure --prefix=/usr</userinput></screen>
  37. <para>Compile the package:</para>
  38. <screen><userinput remap="make">make</userinput></screen>
  39. <para>To test the results, issue:</para>
  40. <screen><userinput remap="test">make check</userinput></screen>
  41. <para>Install the package:</para>
  42. <screen><userinput remap="install">make install</userinput></screen>
  43. </sect2>
  44. <sect2 id="contents-m4" role="content">
  45. <title>Contents of M4</title>
  46. <segmentedlist>
  47. <segtitle>Installed program</segtitle>
  48. <seglistitem>
  49. <seg>m4</seg>
  50. </seglistitem>
  51. </segmentedlist>
  52. <variablelist>
  53. <bridgehead renderas="sect3">Short Descriptions</bridgehead>
  54. <?dbfo list-presentation="list"?>
  55. <?dbhtml list-presentation="table"?>
  56. <varlistentry id="m4">
  57. <!-- Don't remove the extra space, it prevet a FOP warning. -->
  58. <term><command>m4 </command></term>
  59. <listitem>
  60. <para>Copies the given files while expanding the macros that they
  61. contain. These macros are either built-in or user-defined and can
  62. take any number of arguments. Besides performing macro expansion,
  63. <command>m4</command> has built-in functions for including named
  64. files, running Unix commands, performing integer arithmetic,
  65. manipulating text, recursion, etc. The <command>m4</command> program
  66. can be used either as a front-end to a compiler or as a macro processor
  67. in its own right</para>
  68. <indexterm zone="ch-system-m4 m4">
  69. <primary sortas="b-m4">m4</primary>
  70. </indexterm>
  71. </listitem>
  72. </varlistentry>
  73. </variablelist>
  74. </sect2>
  75. </sect1>