explicit_lib_depends.sh:

- check if an installed libtool records dependencies recursively and
   print a warning if it does
       currently it prints the warning on every system which has libtool
       installed from ports (only my local version doesn't do this, the
       version in the ports is not correctly patched for this, a patch
       similar in complexity (= simple) like the ltdl.m4 one in the
       libtool-port-patch-directory is needed)
 - enhance the regex which is responsible to not print a dependency to
   the port we are just checking
 - add a work in progress (not executed) to collapse the USE_* which
   can have more than one value

neededlibs.sh:
 - we also care about shared libs

resolveportsfromlibs.sh:
 - take care about USE_OPENSSL, USE_EFL, USE_GL, USE_FAM, USE_OPENLDAP,
   USE_SDL
 - search in the "ldconfig -r" output if we can not find the lib ourself
 - a better way of getting the first part of the LIB_DEPENDS stuff
   (lib/libXYZ.so can be specified now too)
 - some line wrapping + whitespace
 - print the origin for the USE_* too (except USE_OPENSSL), so an user
   can make some sanity checks and the explicit_lib_depends.sh can DTRT
   if we check the USE_* port itself
 - warn if we can not determine the right component (can happen for XORG)
   unambiguously.
This commit is contained in:
Alexander Leidinger 2007-09-04 19:32:36 +00:00
parent 0ec0a28143
commit 0d7a3e7e9f
Notes: svn2git 2021-03-31 03:12:20 +00:00
svn path=/head/; revision=198758
3 changed files with 120 additions and 14 deletions

View file

@ -83,6 +83,15 @@ if [ -z "${PKG_DBDIR} -o ! -d "${PKG_DBDIR}" ]; then
PKG_DBDIR=/var/db/pkg PKG_DBDIR=/var/db/pkg
fi fi
libtool=$(which libtool 2>/dev/null)
if [ -x ${libtool} ]; then
libtool_deplibs=$(grep link_all_deplibs ${libtool} | head -1 | \
cut -d = -f 2)
if [ "X${libtool_deplibs}" != Xno ]; then
echo WARNING: your libtool records dependencies recursively, you can not trust the following output. | fmt
fi
fi
for i in $@; do for i in $@; do
if [ -d "${i}" ]; then if [ -d "${i}" ]; then
current_port="${i}" current_port="${i}"
@ -118,6 +127,34 @@ for i in $@; do
' < ${current_port}/+CONTENTS | \ ' < ${current_port}/+CONTENTS | \
xargs ${PORTSDIR}/Tools/scripts/neededlibs.sh | \ xargs ${PORTSDIR}/Tools/scripts/neededlibs.sh | \
xargs ${PORTSDIR}/Tools/scripts/resolveportsfromlibs.sh ${bases} | \ xargs ${PORTSDIR}/Tools/scripts/resolveportsfromlibs.sh ${bases} | \
egrep -v "${myorigin}\$" egrep -v "(\(${myorigin}\)|${myorigin})\$"
done | sort -u done | sort -u
exit 0
# NOT YET: untested, just an outline of what needs to be done
awk ' /USE_GNOME+=/ {
if (have_gnome != 1) {
use_gnome = sprintf("%s", $2);
} else {
use_gnome = sprintf("%s %s", use_gnome, $2);
have_gnome = 1;
}
}
/USE_XORG+=/ {
if (have_gnome != 1) {
use_gnome = sprintf("%s", $2);
} else {
use_gnome = sprintf("%s %s", use_gnome, $2);
have_gnome = 1;
}
}
END {
if (have_gnome == 1) {
printf("USE_GNOME= %s\n", have_gnome);
}
if (have_xorg == 1) {
printf("USE_XORG= %s\n", have_xorg);
}
}'

View file

@ -48,7 +48,7 @@ for i in "$@"; do
kind=$(file -bi "$i") kind=$(file -bi "$i")
case "${kind}" in case "${kind}" in
application/x-executable*) application/x-executable*|application/x-sharedlib*)
# ok, fall through # ok, fall through
;; ;;
*) *)

View file

@ -88,6 +88,13 @@ fi
for i in $@; do for i in $@; do
result="" result=""
case $i in
libcrypto.so|libssl.so)
echo "USE_OPENSSL= yes"
continue
;;
esac
if [ -e /lib/$i -o -e /usr/lib/$i ]; then if [ -e /lib/$i -o -e /usr/lib/$i ]; then
# base system lib, skipping # base system lib, skipping
shift shift
@ -95,45 +102,107 @@ for i in $@; do
fi fi
lib="$(echo $i | sed -e 's:^lib:: ; s:\.so.*::')" lib=${i##*/}
lib="$(echo ${lib} | sed -e 's:^lib:: ; s:\.so.*::')"
# I didn't managed to make awk accept a pattern with a '/' inside,
# so don't complain about using grep+awk instead of awk only.
lib_pathname=$(ldconfig -r | grep $i | awk '{print $3}')
origin=unknown origin=unknown
for base in ${bases}; do for base in ${bases}; do
port=$(pkg_which "${base}/lib/$i") port=$(pkg_which "${base}/lib/$i")
if [ -f /var/db/pkg/$port/+CONTENTS ]; then if [ -f /var/db/pkg/$port/+CONTENTS ]; then
origin=$(grep "@comment ORIGIN:" /var/db/pkg/$port/+CONTENTS | sed -e 's/@comment ORIGIN://') origin=$(grep "@comment ORIGIN:" \
/var/db/pkg/$port/+CONTENTS \
| sed -e 's/@comment ORIGIN://')
break break
else else
continue continue
fi fi
done done
XORG="$(egrep ${origin}\$ ${PORTSDIR}/Mk/bsd.xorg.mk 2>/dev/null \ if [ ${origin} = unknown ]; then
| grep _LIB | sed -e 's:_LIB.*::')" if [ -f ${lib_pathname} ]; then
port=$(pkg_which "${lib_pathname}")
if [ -f /var/db/pkg/$port/+CONTENTS ]; then
origin=$(grep "@comment ORIGIN:" \
/var/db/pkg/$port/+CONTENTS \
| sed -e 's/@comment ORIGIN://')
else
result="${lib} ($i) not found, unknown origin"
fi
fi
fi
GNOME="$(egrep ${origin}\$ ${PORTSDIR}/Mk/bsd.gnome.mk 2>/dev/null \ if [ ${origin} != unknown ]; then
| grep _LIB | sed -e 's:_LIB.*::')" category=${origin%/*}
portname=${origin##*/}
XORG="$(egrep ${origin}\$ ${PORTSDIR}/Mk/bsd.xorg.mk \
2>/dev/null | grep _LIB | sed -e 's:_LIB.*::')"
GNOME="$(egrep ${origin}\$ ${PORTSDIR}/Mk/bsd.gnome.mk \
2>/dev/null | grep _LIB | sed -e 's:_LIB.*::')"
EFL="$([ "X$(make ${PORTSDIR}/Mk/bsd.efl.mk -V \
_${portname}_CATEGORY )" = "X${category}" ] && \
echo ${portname})"
GL="$(egrep ${origin}\$ ${PORTSDIR}/Mk/bsd.port.mk \
2>/dev/null | grep _LIB_DEPENDS \
| sed -e 's:_GL_:: ; s:_LIB_DEPENDS.*::')"
fi
if [ -n "${XORG}" ]; then if [ -n "${XORG}" ]; then
result="USE_XORG+=${XORG}" result="USE_XORG+= ${XORG} (${origin})"
if [ $(echo ${XORG} | wc -w) -ne 1 ]; then
result="${result} # result ambiguous, check yourself: ${lib}"
fi
fi fi
if [ -n "${GNOME}" ]; then if [ -n "${GNOME}" ]; then
result="USE_GNOME+=${GNOME}" result="USE_GNOME+= ${GNOME} (${origin})"
if [ $(echo ${GNOME} | wc -w) -ne 1 ]; then
result="${result} # result ambiguous, check yourself: ${lib}"
fi
fi
if [ -n "${EFL}" ]; then
result="USE_EFL+= ${EFL} (${origin})"
fi
if [ -n "${GL}" ]; then
result="USE_GL+= ${GL} (${origin})"
fi fi
# USE_xxx exceptions, sorting key is the USE_xxx name # USE_xxx exceptions, sorting key is the USE_xxx name
# START and STOP are needed for a perfect match # START and STOP are needed for a perfect match
case "START${origin}STOP" in case "START${origin}STOP" in
STARTdevel/famSTOP|STARTdevel/gaminSTOP)
result="USE_FAM= yes (${origin})"
;;
STARTprint/freetypeSTOP) STARTprint/freetypeSTOP)
result="USE_FREETYPE=yes" result="USE_FREETYPE= yes (${origin})"
;; ;;
STARTdevel/gettextSTOP) STARTdevel/gettextSTOP)
result="USE_GETTEXT=yes" result="USE_GETTEXT= yes (${origin})"
;; ;;
STARTconverters/libiconvSTOP) STARTconverters/libiconvSTOP)
result="USE_ICONV=yes" result="USE_ICONV= yes (${origin})"
;;
STARTnet/openldap*sasl*clientSTOP)
result="USE_OPENLDAP= yes WANT_OPENLDAP_SASL= yes"
;;
STARTnet/openldap*clientSTOP)
result="USE_OPENLDAP= yes (${origin})"
;;
STARTdevel/sdl12STOP)
result="USE_SDL= sdl (${origin})"
;;
/sdl_)
result="USE_SDL= $(echo $origin | sed -e 's:.*/sdl_::g') (${origin})"
;; ;;
esac esac
@ -141,6 +210,6 @@ for i in $@; do
result="${lib}:\${PORTSDIR}/${origin}" result="${lib}:\${PORTSDIR}/${origin}"
fi fi
echo ${result} echo "${result}"
shift shift
done | sort -u done | sort -u