diff options
| author | NIIBE Yutaka <[email protected]> | 2022-11-15 04:40:57 +0000 | 
|---|---|---|
| committer | NIIBE Yutaka <[email protected]> | 2022-11-15 04:40:57 +0000 | 
| commit | abd51848bdc8a5ea5929f9cfb819a408dc53d463 (patch) | |
| tree | e8605ab98d46a25893096aa141d090f5e71cb446 /src | |
| parent | m4: Update gpg-error.m4. (diff) | |
| download | gpgme-abd51848bdc8a5ea5929f9cfb819a408dc53d463.tar.gz gpgme-abd51848bdc8a5ea5929f9cfb819a408dc53d463.zip | |
gpgme.m4: Include _AM_PATH_GPGRT_CONFIG implementation.
* src/gpgme.m4 (_AM_PATH_GPGRT_CONFIG): New.
(_AM_PATH_GPGME_CONFIG): Require _AM_PATH_GPGRT_CONFIG.
--
GnuPG-bug-id: 6273
Signed-off-by: NIIBE Yutaka <[email protected]>
Diffstat (limited to 'src')
| -rw-r--r-- | src/gpgme.m4 | 101 | 
1 files changed, 95 insertions, 6 deletions
| diff --git a/src/gpgme.m4 b/src/gpgme.m4 index 09a282d0..363a84f3 100644 --- a/src/gpgme.m4 +++ b/src/gpgme.m4 @@ -1,5 +1,5 @@  # gpgme.m4 - autoconf macro to detect GPGME. -# Copyright (C) 2002, 2003, 2004, 2014, 2018 g10 Code GmbH +# Copyright (C) 2002, 2003, 2004, 2014, 2018, 2022 g10 Code GmbH  #  # This file is free software; as a special exception the author gives  # unlimited permission to copy and/or distribute it, with or without @@ -9,13 +9,102 @@  # WITHOUT ANY WARRANTY, to the extent permitted by law; without even the  # implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  # -# Last-changed: 2022-11-02 +# Last-changed: 2022-11-15 -AC_DEFUN([_AM_PATH_GPGME_CONFIG], -[ AC_ARG_WITH(gpgme-prefix, -            AS_HELP_STRING([--with-gpgme-prefix=PFX], -                           [prefix where GPGME is installed (optional)]), +dnl +dnl Find gpgrt-config, which uses .pc file +dnl (minimum pkg-config functionality, supporting cross build) +dnl +dnl _AM_PATH_GPGRT_CONFIG +AC_DEFUN([_AM_PATH_GPGRT_CONFIG],[dnl +  AC_PATH_PROG(GPGRT_CONFIG, gpgrt-config, no, [$prefix/bin:$PATH]) +  if test "$GPGRT_CONFIG" != "no"; then +    # Determine gpgrt_libdir +    # +    # Get the prefix of gpgrt-config assuming it's something like: +    #   <PREFIX>/bin/gpgrt-config +    gpgrt_prefix=${GPGRT_CONFIG%/*/*} +    possible_libdir1=${gpgrt_prefix}/lib +    # Determine by using system libdir-format with CC, it's like: +    #   Normal style: /usr/lib +    #   GNU cross style: /usr/<triplet>/lib +    #   Debian style: /usr/lib/<multiarch-name> +    #   Fedora/openSUSE style: /usr/lib, /usr/lib32 or /usr/lib64 +    # It is assumed that CC is specified to the one of host on cross build. +    if libdir_candidates=$(${CC:-cc} -print-search-dirs | \ +          sed -n -e "/^libraries/{s/libraries: =//;s/:/\\ +/g;p;}"); then +      # From the output of -print-search-dirs, select valid pkgconfig dirs. +      libdir_candidates=$(for dir in $libdir_candidates; do +        if p=$(cd $dir 2>/dev/null && pwd); then +          test -d "$p/pkgconfig" && echo $p; +        fi +      done) + +      for possible_libdir0 in $libdir_candidates; do +        # possible_libdir0: +        #   Fallback candidate, the one of system-installed (by $CC) +        #   (/usr/<triplet>/lib, /usr/lib/<multiarch-name> or /usr/lib32) +        # possible_libdir1: +        #   Another candidate, user-locally-installed +        #   (<gpgrt_prefix>/lib) +        # possible_libdir2 +        #   Most preferred +        #   (<gpgrt_prefix>/<triplet>/lib, +        #    <gpgrt_prefix>/lib/<multiarch-name> or <gpgrt_prefix>/lib32) +        if test "${possible_libdir0##*/}" = "lib"; then +          possible_prefix0=${possible_libdir0%/lib} +          possible_prefix0_triplet=${possible_prefix0##*/} +          if test -z "$possible_prefix0_triplet"; then +            continue +          fi +          possible_libdir2=${gpgrt_prefix}/$possible_prefix0_triplet/lib +        else +          possible_prefix0=${possible_libdir0%%/lib*} +          possible_libdir2=${gpgrt_prefix}${possible_libdir0#$possible_prefix0} +        fi +        if test -f ${possible_libdir2}/pkgconfig/gpg-error.pc; then +          gpgrt_libdir=${possible_libdir2} +        elif test -f ${possible_libdir1}/pkgconfig/gpg-error.pc; then +          gpgrt_libdir=${possible_libdir1} +        elif test -f ${possible_libdir0}/pkgconfig/gpg-error.pc; then +          gpgrt_libdir=${possible_libdir0} +        fi +        if test -n "$gpgrt_libdir"; then break; fi +      done +      if test -z "$libdir_candidates"; then +        # No valid pkgconfig dir in any of the system directories, fallback +        gpgrt_libdir=${possible_libdir1} +      fi +    else +      # When we cannot determine system libdir-format, use this: +      gpgrt_libdir=${possible_libdir1} +    fi +  else +    unset GPGRT_CONFIG +  fi + +  if test -n "$gpgrt_libdir"; then +    GPGRT_CONFIG="$GPGRT_CONFIG --libdir=$gpgrt_libdir" +    if $GPGRT_CONFIG gpg-error >/dev/null 2>&1; then +      GPG_ERROR_CONFIG="$GPGRT_CONFIG gpg-error" +      AC_MSG_NOTICE([Use gpgrt-config with $gpgrt_libdir as gpg-error-config]) +      gpg_error_config_version=`$GPG_ERROR_CONFIG --modversion` +    else +      unset GPGRT_CONFIG +    fi +  elif test "$GPG_ERROR_CONFIG" != "no"; then +    gpg_error_config_version=`$GPG_ERROR_CONFIG --version` +    unset GPGRT_CONFIG +  fi +]) + +AC_DEFUN([_AM_PATH_GPGME_CONFIG],[dnl +AC_REQUIRE([_AM_PATH_GPGRT_CONFIG])dnl +  AC_ARG_WITH(gpgme-prefix, +              AS_HELP_STRING([--with-gpgme-prefix=PFX], +                             [prefix where GPGME is installed (optional)]),       gpgme_config_prefix="$withval", gpgme_config_prefix="")    if test x"${GPGME_CONFIG}" = x ; then       if test x"${gpgme_config_prefix}" != x ; then | 
