diff options
Diffstat (limited to 'misc/gen-pkgconfig.in')
-rw-r--r-- | misc/gen-pkgconfig.in | 132 |
1 files changed, 99 insertions, 33 deletions
diff --git a/misc/gen-pkgconfig.in b/misc/gen-pkgconfig.in index d3e30e0..8f00b82 100644 --- a/misc/gen-pkgconfig.in +++ b/misc/gen-pkgconfig.in @@ -1,7 +1,8 @@ #!@SHELL@ -# $Id: gen-pkgconfig.in,v 1.19 2014/12/14 00:38:23 tom Exp $ +# $Id: gen-pkgconfig.in,v 1.44 2020/02/12 00:09:26 tom Exp $ ############################################################################## -# Copyright (c) 2009-2013,2014 Free Software Foundation, Inc. # +# Copyright 2018-2019,2020 Thomas E. Dickey # +# Copyright 2009-2015,2018 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"), # @@ -53,46 +54,100 @@ exec_prefix="@exec_prefix@" includedir="@includedir@@includesubdir@" libdir="@libdir@" +RPATH_LIST=@RPATH_LIST@ +PRIVATE_LIBS="@PRIVATE_LIBS@" + show_prefix='@prefix@' show_exec_prefix='@exec_prefix@' show_includedir='@includedir@@includesubdir@' show_libdir='@libdir@' -MAIN_LIBRARY="${LIB_NAME}@DFT_ARG_SUFFIX@" +MAIN_LIBRARY="${LIB_NAME}@USE_ARG_SUFFIX@" SUB_LIBRARY="${TINFO_ARG_SUFFIX}" -PANEL_LIBRARY="${PANEL_NAME}@DFT_ARG_SUFFIX@" -MENU_LIBRARY="${MENU_NAME}@DFT_ARG_SUFFIX@" -FORM_LIBRARY="${FORM_NAME}@DFT_ARG_SUFFIX@" - -if test "$includedir" = "/usr/include" ; then - CFLAGS= -else - includetop=`echo "$includedir" | sed -e 's,/include/[^/]*$,/include/,'` - test "$includetop" = "/usr/include" && includetop="$includedir" - if test "x$includetop" != "$includedir" +PANEL_LIBRARY="${PANEL_NAME}@USE_ARG_SUFFIX@" +MENU_LIBRARY="${MENU_NAME}@USE_ARG_SUFFIX@" +FORM_LIBRARY="${FORM_NAME}@USE_ARG_SUFFIX@" + +CFLAGS="@PKG_CFLAGS@" +if [ "$includedir" != "/usr/include" ]; then + includetop=`echo "$includedir" | sed -e 's,/include/[^/]*$,/include,'` + [ "$includetop" = "/usr/include" ] && includetop="$includedir" + CFLAGS="$CFLAGS -I\${includedir}" + if [ "x$includetop" != "x$includedir" ] then - CFLAGS="-I${includetop} -I\${includedir}" - else - CFLAGS="-I\${includedir}" + CFLAGS="$CFLAGS -I${includetop}" fi fi -if test "$libdir" = "/usr/lib" ; then - LDFLAGS= -else - LDFLAGS="-L\${libdir}" +lib_flags= +for opt in -L$libdir @LDFLAGS@ @EXTRA_LDFLAGS@ @LIBS@ +do + case $opt in + -l*) # LIBS is handled specially below + continue + ;; + -specs*) # ignore linker specs-files which were used to build library + continue + ;; + -Wl,-z,*) # ignore flags used to manipulate shared image + continue + ;; + -L*) + [ -d ${opt##-L} ] || continue + case ${opt##-L} in + @LD_SEARCHPATH@) # skip standard libdir + continue + ;; + *) + 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 + +# Check if we should specify the tinfo library explicitly so that terminfo +# functions or curses variables (which also reside in tinfo) can be linked +# using the -lncurses option. +NEED_TINFO=no +if [ "x@TINFO_LIBS@" != "x" ] && \ + [ "x$TINFO_ARG_SUFFIX" != "x$MAIN_LIBRARY" ] +then + NEED_TINFO=yes fi +# The "URL" feature came in pkg-config 0.17 +USEURL="" +CFGVER=`pkg-config --version 2>/dev/null |head -n 1 | awk -F. '/0.[0-9][0-9]/{print $2;}'` +# A missing version should simply fail, but some packagers insist on building +# packages on machines which do not actually have the tools they depend on at +# runtime. +[ -z "$CFGVER" ] && CFGVER=30 +[ $CFGVER -ge 17 ] || USEURL="#" + for name in @PC_MODULES_TO_MAKE@ do name="${name}" + LIBS="-l$name" desc="ncurses @NCURSES_MAJOR@.@NCURSES_MINOR@" reqs= - if test $name = $MAIN_LIBRARY ; then + if [ $name = $MAIN_LIBRARY ]; then desc="$desc library" - elif test $name = $SUB_LIBRARY ; then + [ $NEED_TINFO = yes ] && LIBS="$LIBS -l$TINFO_ARG_SUFFIX" + [ -n "@LIBS@" ] && LIBS="$LIBS @LIBS@" + elif [ $name = $SUB_LIBRARY ]; then desc="$desc terminal interface library" elif expr $name : ".*${CXX_NAME}.*" >/dev/null ; then reqs="$PANEL_LIBRARY${suffix}, $MENU_LIBRARY${suffix}, $FORM_LIBRARY${suffix}, $MAIN_LIBRARY${suffix}" @@ -102,32 +157,43 @@ do desc="$desc add-on library" fi - if test $name != $SUB_LIBRARY && test $SUB_LIBRARY != $MAIN_LIBRARY ; then - if test $name != $TINFO_NAME ; then - test -n "$reqs" && reqs="$reqs, " - reqs="${reqs}${SUB_LIBRARY}${suffix}" - fi + if [ $name != $SUB_LIBRARY ] && \ + [ $SUB_LIBRARY != $MAIN_LIBRARY ] && \ + [ $name != $TINFO_NAME ] && \ + [ $NEED_TINFO != yes ] ; then + [ -n "$reqs" ] && reqs="$reqs, " + reqs="${reqs}${SUB_LIBRARY}${suffix}" + fi + + if [ $name = $MAIN_LIBRARY ] + then + main_libs="$PRIVATE_LIBS" + else + main_libs= fi - echo "** creating ${name}.pc" + echo "** creating ${name}${suffix}.pc" cat >${name}${suffix}.pc <<EOF +# pkg-config file generated by `basename $0` +# vile:makemode + prefix=$show_prefix exec_prefix=$show_exec_prefix libdir=$show_libdir includedir=$show_includedir +abi_version=@cf_cv_abi_version@ major_version=@NCURSES_MAJOR@ version=@NCURSES_MAJOR@.@NCURSES_MINOR@.@NCURSES_PATCH@ Name: ${name}${suffix} Description: $desc Version: \${version} -URL: http://invisible-island.net/ncurses +${USEURL}URL: https://invisible-island.net/ncurses Requires.private: $reqs -Libs: $LDFLAGS -l$name -Libs.private: @LIBS@ +Libs: $lib_flags $LIBS +Libs.private: @LIBS@ $main_libs Cflags: $CFLAGS EOF - #pr -f ${name}.pc done -# vile:shmode +# vile:shmode ts=4 sw=4 |