Update krb5-config.

We update krb5-config to support --all, --deps, and --vendor.  So,
now if you specify --libs, you will only get those libraries that
are required for dynamic linking.  If you are linking statically,
you must provide --deps.  We also allow multiple libraries to be
specified on the command line for applications that use, say, gssapi
and krb5.  And we elide -L and -I args if they have the prefix=/usr
as that's implied.  We also update the --help output to be a little
more verbose.
This commit is contained in:
Roland C. Dowdeswell
2012-02-29 17:27:58 +00:00
parent a8c51aa594
commit 3ec78180ce

View File

@@ -32,12 +32,19 @@
# SUCH DAMAGE. # SUCH DAMAGE.
# #
do_all=no
do_libs=no do_libs=no
do_lib_deps=no
do_cflags=no do_cflags=no
do_usage=no do_usage=no
print_prefix=no print_prefix=no
print_exec_prefix=no print_exec_prefix=no
library=krb5 library=
lib_krb5=no
lib_gssapi=no
lib_kadm_client=no
lib_kadm_server=no
lib_kafs=no
if test $# -eq 0; then if test $# -eq 0; then
do_usage=yes do_usage=yes
@@ -50,6 +57,13 @@ for i in $*; do
do_usage=yes do_usage=yes
usage_exit=0 usage_exit=0
;; ;;
--all)
do_all=yes
;;
--vendor)
echo "Heimdal"
exit 0;
;;
--version) --version)
echo "@PACKAGE@ @VERSION@" echo "@PACKAGE@ @VERSION@"
exit 0 exit 0
@@ -69,23 +83,31 @@ for i in $*; do
--libs) --libs)
do_libs=yes do_libs=yes
;; ;;
--deps)
do_lib_deps=yes
;;
--cflags) --cflags)
do_cflags=yes do_cflags=yes
;; ;;
krb5) krb5)
library=krb5 library=krb5
lib_krb5=yes
;; ;;
gssapi) gssapi)
library=gssapi library=gssapi
lib_gssapi=yes
;; ;;
kadm-client) kadm-client)
library=kadm-client library=kadm-client
lib_kadm_client=yes
;; ;;
kadm-server) kadm-server)
library=kadm-server library=kadm-server
lib_kadm_server=yes
;; ;;
kafs) kafs)
library=kafs library=kafs
lib_kafs=yes
;; ;;
*) *)
echo "unknown option: $i" echo "unknown option: $i"
@@ -96,11 +118,28 @@ done
if test "$do_usage" = "yes"; then if test "$do_usage" = "yes"; then
echo "usage: $0 [options] [libraries]" echo "usage: $0 [options] [libraries]"
echo "options: [--prefix[=dir]] [--exec-prefix[=dir]] [--libs] [--cflags]" echo "options: [--help] show this message"
echo "libraries: krb5 gssapi kadm-client kadm-server kafs" echo " [--all] display version, vendor, etc."
echo " [--version] display version information"
echo " [--prefix] display the prefix of Kerberos"
echo " [--exec-prefix] display the exec_prefix of Kerberos"
echo " [--cflags] display the CFLAGS required"
echo " [--libs] display the libraries required to link"
echo " [--deps] display the dependent libs required"
echo " for static linking"
echo
echo "libraries: krb5 Kerberos 5 applications"
echo " gssapi GSSAPI applications"
echo " kadm-client libkadm5 client"
echo " kadm-server libkadm5 server"
echo " kafs kafs"
exit $usage_exit exit $usage_exit
fi fi
if test X"$library" = X; then
lib_krb5=yes
fi
if test "$prefix" = ""; then if test "$prefix" = ""; then
prefix=@prefix@ prefix=@prefix@
fi fi
@@ -111,38 +150,74 @@ fi
libdir=@libdir@ libdir=@libdir@
includedir=@includedir@ includedir=@includedir@
if test "$do_all" = "yes"; then
echo "Version: @PACKAGE@ @VERSION@"
echo "Vendor: Heimdal"
echo "Prefix: $prefix"
echo "Exec_prefix: $exec_prefix"
exit 0
fi
if test "$print_prefix" = "yes"; then if test "$print_prefix" = "yes"; then
echo $prefix echo $prefix
exit 0
fi fi
if test "$print_exec_prefix" = "yes"; then if test "$print_exec_prefix" = "yes"; then
echo $exec_prefix echo $exec_prefix
exit 0
fi fi
if test "$do_libs" = "yes"; then if test "$do_libs" = "yes"; then
lib_flags="-L${libdir}" deplibs=""
case $library in if test "$lib_gssapi" = yes; then
gssapi) lib_flags="$lib_flags -lgssapi"
lib_flags="$lib_flags -lgssapi -lheimntlm" deplibs="$deplibs -lheimntlm"
;; if test X"$do_lib_deps" = Xyes; then
kadm-client) lib_krb5=yes
fi
fi
if test "$lib_kadm_client" = yes; then
lib_flags="$lib_flags -lkadm5clnt" lib_flags="$lib_flags -lkadm5clnt"
;; if test X"$do_lib_deps" = Xyes; then
kadm-server) lib_krb5=yes
lib_flags="$lib_flags -lkadm5srv @LIB_dbopen@" fi
;; fi
kafs) if test "$lib_kadm_server" = yes; then
lib_flags="$lib_flags -lkadm5srv"
deplibs="$deplibs @LIB_dbopen@"
if test X"$do_lib_deps" = Xyes; then
lib_krb5=yes
fi
fi
if test "$lib_kafs" = yes; then
lib_flags="$lib_flags -lkafs" lib_flags="$lib_flags -lkafs"
;; if test X"$do_lib_deps" = Xyes; then
esac lib_krb5=yes
lib_flags="$lib_flags -lkrb5 @LIB_pkinit@ -lcom_err" fi
lib_flags="$lib_flags @LIB_hcrypto_appl@ -lasn1 -lwind -lheimbase -lroken" fi
lib_flags="$lib_flags @LIB_crypt@ @PTHREAD_LIBADD@ @LIB_dlopen@" if test "$lib_krb5" = yes; then
lib_flags="$lib_flags @LIB_door_create@ @LIBS@" lib_flags="$lib_flags -lkrb5"
echo $lib_flags fi
deplibs="$deplibs @LIB_pkinit@ -lcom_err"
deplibs="$deplibs @LIB_hcrypto_appl@ -lasn1 -lwind -lheimbase -lroken"
deplibs="$deplibs @LIB_crypt@ @PTHREAD_LIBADD@ @LIB_dlopen@"
deplibs="$deplibs @LIB_door_create@ @LIBS@"
if test X"$do_lib_deps" = X"yes"; then
lib_flags="$lib_flags $deplibs"
fi
if test X"$libdir" != X/usr/lib; then
lib_flags="-L${libdir} $lib_flags"
fi
echo ${lib_flags}
fi fi
if test "$do_cflags" = "yes"; then if test "$do_cflags" = "yes"; then
echo "-I${includedir} @INCLUDE_hcrypto@" cflags="@INCLUDE_hcrypto@"
if test X"${includedir}" != X/usr/include; then
cflags="-I${includedir} $cflags"
fi
echo $cflags
fi fi
exit 0 exit 0