xbps-src: create dynamically virtualpkg plist files.

This commit is contained in:
Juan RP 2011-10-26 16:43:11 +02:00
parent 592f6b8d87
commit 15f01ebf76
2 changed files with 28 additions and 1 deletions

View file

@ -98,6 +98,33 @@ xbps_write_metadata_pkg_real()
lver="${version}"
fi
#
# If package provides virtual packages, create dynamically the
# required virtualpkg.d files.
#
if [ -n "$provides" -a -n "$replaces" ]; then
_tmpf=$(mktemp) || msg_error "$pkgver: failed to create tempfile.\n"
cat > ${_tmpf} <<_EOF
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>virtual-pkgver</key>
<string>$provides</string>
<key>target-pkgpattern</key>
<string>$replaces</string>
</dict>
</plist>
_EOF
install -Dm644 ${_tmpf} \
${DESTDIR}/etc/xbps/virtualpkg.d/${pkgname}.plist
vmkdir etc/xbps/virtualpkg.d.wants && curcwd=$(pwd) && \
cd ${DESTDIR}/etc/xbps/virtualpkg.d.wants && \
ln -sf ../virtualpkg.d/${pkgname}.plist . && \
cd ${curcwd} && rm -f ${_tmpf} || \
msg_error "$pkgver: failed to create virtualpkg.d file in DESTDIR!\n"
fi
#
# Find out if this package contains info files and compress
# all them with gzip.

View file

@ -171,7 +171,7 @@ unstow_pkg_real()
ver=$($XBPS_PKGDB_CMD version $pkgname)
if [ -z "$ver" ]; then
msg_warn "'${pkgname}' not installed in masterdir!\n"
return 0
return 1
fi
if [ "$build_style" = "meta-template" ]; then