]> ncurses.scripts.mit.edu Git - ncurses.git/blobdiff - misc/ncurses-config.in
ncurses 6.2 - patch 20210220
[ncurses.git] / misc / ncurses-config.in
index 73cbfff6bfbf2f684abfeded2cfb0f866a2aa1ce..eae39a516ff3bbd9f99723939434023d8eaa1bc2 100644 (file)
@@ -1,7 +1,8 @@
 #!@SHELL@
-# $Id: ncurses-config.in,v 1.35 2015/04/22 00:54:19 tom Exp $
+# $Id: ncurses-config.in,v 1.46 2021/01/23 23:47:46 tom Exp $
 ##############################################################################
-# Copyright (c) 2006-2012,2015 Free Software Foundation, Inc.                #
+# Copyright 2018-2020,2021 Thomas E. Dickey                                  #
+# Copyright 2006-2015,2017 Free Software Foundation, Inc.                    #
 #                                                                            #
 # Permission is hereby granted, free of charge, to any person obtaining a    #
 # copy of this software and associated documentation files (the "Software"), #
@@ -54,7 +55,7 @@ includesubdir="@includedir@/${THIS}"
 # Ensure that RPATH_LIST contains only absolute pathnames, if it is nonempty.
 # We cannot filter it out within the build-process since the variable is used
 # in some special cases of installation using a relative path.
-if test -n "$RPATH_LIST"
+if [ -n "$RPATH_LIST" ]
 then
        save_IFS="$IFS"
        IFS='@PATH_SEPARATOR@'
@@ -65,7 +66,7 @@ then
                ./*|../*|*/..|*/../*)
                        ;;
                *)
-                       test -n "$filtered" && filtered="${filtered}@PATH_SEPARATOR@"
+                       [ -n "$filtered" ] && filtered="${filtered}@PATH_SEPARATOR@"
                        filtered="${filtered}${item}"
                        ;;
                esac
@@ -78,7 +79,7 @@ fi
 # with --disable-overwrite, we installed into a subdirectory, but transformed
 # the headers to include like this:
 #      <ncurses@LIB_SUFFIX@/curses.h>
-if test x@WITH_OVERWRITE@ = xno ; then
+if [ x@WITH_OVERWRITE@ = xno ]; then
        case $includedir in
        $prefix/include/ncurses@LIB_SUFFIX@@EXTRA_SUFFIX@)
                includedir=`echo "$includedir" | sed -e 's,/[^/]*$,,'`
@@ -86,9 +87,89 @@ if test x@WITH_OVERWRITE@ = xno ; then
        esac
 fi
 
-test $# = 0 && exec @SHELL@ $0 --error
+LIBS="@LIBS@"
+if [ "@TINFO_NAME@" = "@LIB_NAME@" ]; then
+       LIBS="-l${THIS} $LIBS"
+else
+       LIBS="-l${THIS} -l${TINFO_LIB} $LIBS"
+fi
+
+# Ignore -L options which do not correspond to an actual directory, or which
+# are standard library directories (i.e., the linker is supposed to search
+# those directories).
+#
+# There is no portable way to find the list of standard library directories. 
+# Require a POSIX shell anyway, to keep this simple.
+lib_flags=
+for opt in -L$libdir @LDFLAGS@ @EXTRA_PKG_LDFLAGS@ $LIBS
+do
+       case $opt in
+       -specs*) # ignore linker specs-files which were used to build library
+               continue
+               ;;
+       -Wl,-z,*) # ignore flags used to manipulate shared image
+               continue
+               ;;
+       -L*)
+               lib_check=${opt##-L} 
+               [ -d "$lib_check" ] || continue
+               case "$lib_check" in
+               @LD_SEARCHPATH@) # skip standard libdir
+                       if [ "$lib_check" = "$libdir" ]
+                       then
+                               lib_first=yes
+                               IFS_save="$IFS"
+                               IFS='|'
+                               LIBDIRS="@LD_SEARCHPATH@"
+                               for lib_check in $LIBDIRS
+                               do
+                                       if [ -d "$lib_check" ]
+                                       then
+                                               if [ "$lib_check" != "$libdir" ]
+                                               then
+                                                       lib_first=no
+                                               fi
+                                               break
+                                       fi
+                               done
+                               IFS="$IFS_save"
+                               [ $lib_first = yes ] && continue
+                               found=no
+                               for check in $lib_flags
+                               do
+                                       if [ "x$check" = "x$opt" ]
+                                       then
+                                               found=yes
+                                               break
+                                       fi
+                               done
+                               [ $found = yes ] && continue
+                               :
+                       else
+                               continue
+                       fi
+                       ;;
+               *)
+                       found=no
+                       for check in $lib_flags
+                       do
+                               if [ "x$check" = "x$opt" ]
+                               then
+                                       found=yes
+                                       break
+                               fi
+                       done
+                       [ $found = yes ] && continue
+                       ;;
+               esac
+               ;;
+       esac
+       lib_flags="$lib_flags $opt"
+done
 
-while test $# -gt 0; do
+[ $# = 0 ] && exec @SHELL@ $0 --error
+
+while [ $# -gt 0 ]; do
        case "$1" in
        # basic configuration
        --prefix)
@@ -100,10 +181,10 @@ while test $# -gt 0; do
        # compile/link
        --cflags)
                INCS="@PKG_CFLAGS@"
-               if test "x@WITH_OVERWRITE@" = xno ; then
+               if [ "x@WITH_OVERWRITE@" = xno ]; then
                        INCS="$INCS -I${includesubdir}"
                fi
-               if test "${includedir}" != /usr/include ; then
+               if [ "${includedir}" != /usr/include ]; then
                        INCS="$INCS -I${includedir}"
                fi
                sed -e 's,^[ ]*,,' -e 's, [ ]*, ,g' -e 's,[ ]*$,,' <<-ENDECHO
@@ -111,21 +192,54 @@ while test $# -gt 0; do
 ENDECHO
                ;;
        --libs)
-               if test "$libdir" = /usr/lib
-               then
-                       LIBDIR=
-               else
-                       LIBDIR=-L$libdir
-               fi
-               if test @TINFO_NAME@ = @LIB_NAME@ ; then
-               sed -e 's,^[ ]*,,' -e 's, [ ]*, ,g' -e 's,[ ]*$,,' <<-ENDECHO
-                       $LIBDIR @EXTRA_LDFLAGS@ -l${THIS} @LIBS@
-ENDECHO
-               else
-               sed -e 's,^[ ]*,,' -e 's, [ ]*, ,g' -e 's,[ ]*$,,' <<-ENDECHO
-                       $LIBDIR @EXTRA_LDFLAGS@ -l${THIS} -l${TINFO_LIB} @LIBS@
-ENDECHO
-               fi
+               OPTS=
+               for opt in $lib_flags
+               do
+                       [ -n "$OPTS" ] && OPTS="$OPTS "
+                       OPTS="${OPTS}${opt}"
+               done
+               printf "%s\n" "$OPTS"
+               ;;
+       --libs-only-L)
+               OPTS=
+               for opt in $lib_flags
+               do
+                       case "x$opt" in
+                       x-L*)
+                               [ -n "$OPTS" ] && OPTS="$OPTS "
+                               OPTS="${OPTS}${opt}"
+                               ;;
+                       esac
+               done
+               printf "%s\n" "$OPTS"
+               ;;
+       --libs-only-l)
+               OPTS=
+               for opt in $lib_flags
+               do
+                       case "x$opt" in
+                       x-l*)
+                               [ -n "$OPTS" ] && OPTS="$OPTS "
+                               OPTS="${OPTS}${opt}"
+                               ;;
+                       esac
+               done
+               printf "%s\n" "$OPTS"
+               ;;
+       --libs-only-other)
+               OPTS=
+               for opt in $lib_flags
+               do
+                       case "x$opt" in
+                       x-[lL]*)
+                               ;;
+                       *)
+                               [ -n "$OPTS" ] && OPTS="$OPTS "
+                               OPTS="${OPTS}${opt}"
+                               ;;
+                       esac
+               done
+               printf "%s\n" "$OPTS"
                ;;
        # identification
        --version)
@@ -145,7 +259,13 @@ ENDECHO
                echo "${datadir}"
                ;;
        --includedir)
-               echo "${includedir}"
+               INCS=
+               if [ "x@WITH_OVERWRITE@" = xno ]; then
+                       INCS="${includesubdir}"
+               elif [ "${includedir}" != /usr/include ]; then
+                       INCS="${includedir}"
+               fi
+               echo $INCS
                ;;
        --libdir)
                echo "${libdir}"
@@ -174,6 +294,10 @@ Options:
   --cflags           echos the C compiler flags needed to compile with ${THIS}
   --libs             echos the libraries needed to link with ${THIS}
 
+  --libs-only-L      echos -L linker options (search path) for ${THIS}
+  --libs-only-l      echos -l linker options (libraries) for ${THIS}
+  --libs-only-other  echos linker options other than -L/-l
+
   --version          echos the release+patchdate version of ${THIS}
   --abi-version      echos the ABI version of ${THIS}
   --mouse-version    echos the mouse-interface version of ${THIS}