autoconf-patches
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: Rewrite of "Quotation Rule Of Thumb"


From: Pavel Roskin
Subject: Re: Rewrite of "Quotation Rule Of Thumb"
Date: Thu, 8 Mar 2001 01:22:42 -0500 (EST)

> ChangeLog:
>       * doc/autoconf.texi (Quotation Rule Of Thumb): Document
>       quadrigraphs. Better examples. Mostly rewritten.

Oops! Here's the patch.

___________________________________________
--- doc/autoconf.texi
+++ doc/autoconf.texi
@@ -7545,86 +7545,112 @@

 @center @emph{One pair of quotes per pair of parentheses.}

-Never over-quote, never under-quote, in particular in the definition of
-macros.  In the few places where the macros need to use brackets
-(usually in C program text or regular expressions), quote properly
address@hidden arguments}!
-
-It is frequent to read Autoconf programs with snippets like:
+Remember that Autoconf deals with shell and C code which is abundant
+of constructs that can be accidentally interpreted by @code{m4}.  That's
+why care should be taken to keep @code{m4} off that code throughout the
+expansion process, but in the same time allow macros to be expanded.
+
+Following is an example of proper quoting. Note that @code{AC_MSG_ERROR}
+will be expanded after @code{AC_CHECK_LIB} so that the later is not
+confused by the results of expansion of the former:

 @example
-AC_TRY_LINK(
-changequote(<<, >>)dnl
-<<#include <time.h>
-#ifndef tzname /* For SGI.  */
-extern char *tzname[]; /* RS6000 and others reject char **tzname.  */
-#endif>>,
-changequote([, ])dnl
-[atoi (*tzname);], ac_cv_var_tzname=yes, ac_cv_var_tzname=no)
address@hidden
+AC_CHECK_LIB([z], [adler32], [],
+             [AC_MSG_ERROR([zlib is required])])
address@hidden group
 @end example

address@hidden
-which is incredibly useless since @code{AC_TRY_LINK} is @emph{already}
-double quoting, so you just need:
+Sometimes you can find that the arguments are not quoted, but it's
+a bad practice.  Some macros can expand to simple constructs, so that
+the caller swallows the already expanded code without any adverse
+effects.  However, as the time goes on and Autoconf develops, macros
+like @code{AC_MSG_ERROR} grow in complexity, and then you suddenly
+have a problem, usually an @code{m4} error or invalid shell code in
address@hidden  Here's a @emph{bad} example:

 @example
-AC_TRY_LINK(
-[#include <time.h>
-#ifndef tzname /* For SGI.  */
-extern char *tzname[]; /* RS6000 and others reject char **tzname.  */
-#endif],
-            [atoi (*tzname);],
-            [ac_cv_var_tzname=yes],
-            [ac_cv_var_tzname=no])
address@hidden
+AC_CHECK_LIB(z, adler32, ,
+             AC_MSG_ERROR(zlib is required))
address@hidden group
 @end example

address@hidden
-The M4 fluent reader noted that these two writings are rigorously
-equivalent, since @code{m4} swallows both the @samp{changequote(<<, >>)}
-and @samp{<<} @samp{>>} when it @dfn{collects} the arguments: these
-quotes are not part of the arguments!
-
-Simplified, the example above is just doing this:
+Note that you technically don't have to quote the arguments that don't
+contain macros, commas and other @code{m4} active symbols, but the
+Autoconf style recommends you to quote anyways.
+
+If you double quote the arguments, the macros will not be expanded -
+they will be left in the @code{configure} script as is, causing it to
+be invalid shell code.  The @code{autoconf} program can detect such
+cases and report an error.
+
+However, you may need to use double quotes if the argument contains
+no macros, but it has square brackets and hash signs that must be
+interpreted literally:

 @example
-changequote(<<, >>)dnl
-<<[]>>
-changequote([, ])dnl
address@hidden
+AC_LINK_IFELSE([AC_LANG_PROGRAM(
+[[#include <time.h>
+#ifndef tzname /* For SGI. */
+extern char *tzname[]; /* RS6000 rejects char **tzname. */
+#endif]],
+                                [atoi (*tzname);])],
+               [ac_cv_var_tzname=yes],
+               [ac_cv_var_tzname=no])
address@hidden group
 @end example

address@hidden
-instead of simply
+Note that you still cannot use non-matching square brackets.  Also,
+the dollar sign followed by a number is interpreted by @code{m4} no
+matter how many quotes you are using.

address@hidden
-[[]]
address@hidden example
+In order to circumvent this limitation (albeit at the expense of
+readability), Autoconf provides so called quadrigraphs, which are
+replaced with the ``problematic'' characters after the m4 processing
+is done.  The quadrigraphs are substituted according to the following
+table:
+
address@hidden @samp
address@hidden @@<:@@
+[
+
address@hidden @@:>@@
+]
+
address@hidden @@S\@@
+$
+
address@hidden @@%:@@
+#

address@hidden table

-With macros which do not double quote their arguments (which is the
-rule), double quote the (risky) literals:
+The above example can now be rewritten as:

 @example
address@hidden
 AC_LINK_IFELSE([AC_LANG_PROGRAM(
-[[#include <time.h>
-#ifndef tzname /* For SGI.  */
-extern char *tzname[]; /* RS6000 and others reject char **tzname.  */
-#endif]],
+[@@%:@@include <time.h>
+@@%:@@ifndef tzname /* For SGI. */
+extern char *tzname@@<:@@@@:>@@; /* RS6000 rejects char **tzname. */
+@@%:@@endif],
                                 [atoi (*tzname);])],
                [ac_cv_var_tzname=yes],
                [ac_cv_var_tzname=no])
address@hidden group
 @end example

address@hidden FIXME: Quadrigraphs and hopeless cases.
+Never over-quote, never under-quote, in particular in the definition of
+macros.  In the few places where the macros need to use brackets
+(usually in C program text or regular expressions), quote properly
address@hidden arguments}!

-When you create a @code{configure} script using newly written macros,
-examine it carefully to check whether you need to add more quotes in
-your macros.  If one or more words have disappeared in the @code{m4}
-output, you need more quotes.  When in doubt, quote.
-
-However, it's also possible to put on too many layers of quotes.  If
-this happens, the resulting @code{configure} script will contain
-unexpanded macros.  The @code{autoconf} program checks for this problem
-by doing @samp{grep AC_ configure}.
+Note that some macros, for example as @code{AC_TRY_LINK}, are trying to
+help you pass C code to them by quoting some of their arguments
+themselves.  This practice is now deprecated.  Such macros will be
+gradually eliminated.


 @node Reporting Messages, Dependencies Between Macros, Quoting, Writing Macros
___________________________________________

Regards,
Pavel Roskin




reply via email to

[Prev in Thread] Current Thread [Next in Thread]