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.
|
# 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
|
||||||
|
Reference in New Issue
Block a user