I have come across a problem where the code generated by autoconf does not subsitute correct values for the
followingvariables:
bindir sbindir libexecdir datadir sysconfdir sharedstatedir localstatedir libdir
includedir oldincludedir infodir mandir
The normal usage is fine for things like Makefiles that know about
environment variables and do their own expansion (i.e., the vast
majority of the usage of these variables). In this one instance we
are constructing *.sql files that can't expand environment variables
and hence need to do that in advance during configuration.
It seems much cleaner to do the following:
- keep the unexpanded versions in the Makefiles (since it reduces cluttered duplication and uses variables as they
shouldbe used for indirect references), and
- introduce a new expanded variable for this purpose
The patches below replace Billie's and accomplish his intent of having
the *.sql files refer to the correct libraries without needlessly
expanding ALL the variables everywhere.
Note that the only difference from his patches for *.sql files is to
use @expanded_libdir@ instead of @libdir@. The difference for
configure.in is to create the variable $expanded_libdir without
affecting the rest of the "normal" variables.
Please use this set of patches instead of his.
Cheers,
Brook
===========================================================================
--- configure.in.orig Fri Oct 23 01:00:15 1998
+++ configure.in Sat Oct 24 12:06:13 1998
@@ -905,6 +905,15 @@ AC_SUBST(USE_ODBC)fi
+dnl expand some variables for use in files (e.g., *.sql)
+dnl without environment variables defined
+
+ice_save_exec_prefix=${exec_prefix}
+test "x$exec_prefix" = xNONE && eval exec_prefix=${prefix}
+eval expanded_libdir=${libdir}
+exec_prefix=${ice_save_exec_prefix}
+AC_SUBST(expanded_libdir)
+AC_OUTPUT( GNUmakefile Makefile.global
===========================================================================
--- pl/plpgsql/src/mklang.sql.in.orig Sun Oct 11 22:55:03 1998
+++ pl/plpgsql/src/mklang.sql.in Sat Oct 24 11:34:16 1998
@@ -5,7 +5,7 @@--create function plpgsql_call_handler() returns opaque
- as '@libdir@/plpgsql.so'
+ as '@expanded_libdir@/plpgsql.so' language 'C';create trusted procedural language 'plpgsql'
===========================================================================
*** pl/plpgsql/test/mklang.sql.in.orig Fri Oct 23 23:44:39 1998
--- pl/plpgsql/test/mklang.sql.in Fri Oct 23 23:44:00 1998
***************
*** 0 ****
--- 1,14 ----
+ --
+ -- PL/pgSQL language declaration
+ --
+ -- $Header: /usr/local/cvsroot/pgsql/src/pl/plpgsql/src/mklang.sql.in,v 1.1 1998/10/12 04:55:03 momjian Exp $
+ --
+
+ create function plpgsql_call_handler() returns opaque
+ as '@expanded_libdir@/plpgsql.so'
+ language 'C';
+
+ create trusted procedural language 'plpgsql'
+ handler plpgsql_call_handler
+ lancompiler 'PL/pgSQL';
+
*** pl/tcl/test/test_mklang.sql.in.orig Fri Oct 23 23:46:14 1998
--- pl/tcl/test/test_mklang.sql.in Sat Oct 24 00:18:35 1998
***************
*** 0 ****
--- 1,9 ----
+
+ create function pltcl_call_handler() returns opaque
+ as '@expanded_libdir@/pltcl.so'
+ language 'C';
+
+ create trusted procedural language 'pltcl'
+ handler pltcl_call_handler
+ lancompiler 'PL/Tcl';
+
*** pl/tcl/mklang.sql.in.orig Sat Oct 24 00:20:31 1998
--- pl/tcl/mklang.sql.in Sat Oct 24 00:18:23 1998
***************
*** 0 ****
--- 1,14 ----
+ --
+ -- PL/TCL language declaration
+ --
+ -- ## Insert RCS Header Here ##
+ --
+
+ create function pltcl_call_handler() returns opaque
+ as '@expanded_libdir@/pltcl.so'
+ language 'C';
+
+ create trusted procedural language 'pltcl'
+ handler pltcl_call_handler
+ lancompiler 'PL/Tcl';
+
*** configure.in.orig Fri Oct 23 23:42:40 1998
--- configure.in Fri Oct 23 23:56:13 1998
***************
*** 954,958 ****
--- 954,961 ---- interfaces/odbc/Makefile.global pl/plpgsql/src/Makefile pl/plpgsql/src/mklang.sql
+ pl/plpgsql/test/mklang.sql pl/tcl/mkMakefile.tcldefs.sh
+ pl/tcl/mklang.sql
+ pl/tcl/test/test_mklang.sql )