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:
@@ -32,12 +32,19 @@
|
||||
# SUCH DAMAGE.
|
||||
#
|
||||
|
||||
do_all=no
|
||||
do_libs=no
|
||||
do_lib_deps=no
|
||||
do_cflags=no
|
||||
do_usage=no
|
||||
print_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
|
||||
do_usage=yes
|
||||
@@ -50,6 +57,13 @@ for i in $*; do
|
||||
do_usage=yes
|
||||
usage_exit=0
|
||||
;;
|
||||
--all)
|
||||
do_all=yes
|
||||
;;
|
||||
--vendor)
|
||||
echo "Heimdal"
|
||||
exit 0;
|
||||
;;
|
||||
--version)
|
||||
echo "@PACKAGE@ @VERSION@"
|
||||
exit 0
|
||||
@@ -69,23 +83,31 @@ for i in $*; do
|
||||
--libs)
|
||||
do_libs=yes
|
||||
;;
|
||||
--deps)
|
||||
do_lib_deps=yes
|
||||
;;
|
||||
--cflags)
|
||||
do_cflags=yes
|
||||
;;
|
||||
krb5)
|
||||
library=krb5
|
||||
lib_krb5=yes
|
||||
;;
|
||||
gssapi)
|
||||
library=gssapi
|
||||
lib_gssapi=yes
|
||||
;;
|
||||
kadm-client)
|
||||
library=kadm-client
|
||||
lib_kadm_client=yes
|
||||
;;
|
||||
kadm-server)
|
||||
library=kadm-server
|
||||
lib_kadm_server=yes
|
||||
;;
|
||||
kafs)
|
||||
library=kafs
|
||||
lib_kafs=yes
|
||||
;;
|
||||
*)
|
||||
echo "unknown option: $i"
|
||||
@@ -96,11 +118,28 @@ done
|
||||
|
||||
if test "$do_usage" = "yes"; then
|
||||
echo "usage: $0 [options] [libraries]"
|
||||
echo "options: [--prefix[=dir]] [--exec-prefix[=dir]] [--libs] [--cflags]"
|
||||
echo "libraries: krb5 gssapi kadm-client kadm-server kafs"
|
||||
echo "options: [--help] show this message"
|
||||
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
|
||||
fi
|
||||
|
||||
if test X"$library" = X; then
|
||||
lib_krb5=yes
|
||||
fi
|
||||
|
||||
if test "$prefix" = ""; then
|
||||
prefix=@prefix@
|
||||
fi
|
||||
@@ -111,38 +150,74 @@ fi
|
||||
libdir=@libdir@
|
||||
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
|
||||
echo $prefix
|
||||
exit 0
|
||||
fi
|
||||
|
||||
if test "$print_exec_prefix" = "yes"; then
|
||||
echo $exec_prefix
|
||||
exit 0
|
||||
fi
|
||||
|
||||
if test "$do_libs" = "yes"; then
|
||||
lib_flags="-L${libdir}"
|
||||
case $library in
|
||||
gssapi)
|
||||
lib_flags="$lib_flags -lgssapi -lheimntlm"
|
||||
;;
|
||||
kadm-client)
|
||||
deplibs=""
|
||||
if test "$lib_gssapi" = yes; then
|
||||
lib_flags="$lib_flags -lgssapi"
|
||||
deplibs="$deplibs -lheimntlm"
|
||||
if test X"$do_lib_deps" = Xyes; then
|
||||
lib_krb5=yes
|
||||
fi
|
||||
fi
|
||||
if test "$lib_kadm_client" = yes; then
|
||||
lib_flags="$lib_flags -lkadm5clnt"
|
||||
;;
|
||||
kadm-server)
|
||||
lib_flags="$lib_flags -lkadm5srv @LIB_dbopen@"
|
||||
;;
|
||||
kafs)
|
||||
if test X"$do_lib_deps" = Xyes; then
|
||||
lib_krb5=yes
|
||||
fi
|
||||
fi
|
||||
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"
|
||||
;;
|
||||
esac
|
||||
lib_flags="$lib_flags -lkrb5 @LIB_pkinit@ -lcom_err"
|
||||
lib_flags="$lib_flags @LIB_hcrypto_appl@ -lasn1 -lwind -lheimbase -lroken"
|
||||
lib_flags="$lib_flags @LIB_crypt@ @PTHREAD_LIBADD@ @LIB_dlopen@"
|
||||
lib_flags="$lib_flags @LIB_door_create@ @LIBS@"
|
||||
echo $lib_flags
|
||||
if test X"$do_lib_deps" = Xyes; then
|
||||
lib_krb5=yes
|
||||
fi
|
||||
fi
|
||||
if test "$lib_krb5" = yes; then
|
||||
lib_flags="$lib_flags -lkrb5"
|
||||
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
|
||||
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
|
||||
|
||||
exit 0
|
||||
|
Reference in New Issue
Block a user