[Top][All Lists]
[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