Sorry for answering to myself, but
- Platform depend dependencies (is this possible at all)?
why should it not be possible? Attached the ebuild with a sunusb USE-Flag
# Copyright 1999-2009 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 # $Header: /var/cvsroot/gentoo-x86/media-libs/libgphoto2/libgphoto2-2.4.4.ebuild,v 1.1 2009/01/31 16:10:17 eva Exp $ # TODO # 1. Track upstream bug --disable-docs does not work. # http://sourceforge.net/tracker/index.php?func=detail&aid=1643870&group_id=8874&atid=108874 # 3. Track upstream bug regarding rpm usage. # http://sourceforge.net/tracker/index.php?func=detail&aid=1643813&group_id=8874&atid=358874 EAPI="prefix 2" inherit autotools eutils multilib DESCRIPTION="Library that implements support for numerous digital cameras" HOMEPAGE="http://www.gphoto.org/" SRC_URI="mirror://sourceforge/gphoto/${P}.tar.bz2" LICENSE="GPL-2" SLOT="0" KEYWORDS="~amd64-linux ~ia64-linux ~x86-linux ~x86-solaris" IUSE="bonjour doc exif hal nls kernel_linux sunusb" RESTRICT="test" # By default, drivers for all supported cameras will be compiled. # If you want to only compile for specific camera(s), set CAMERAS # environment to a space-separated list (no commas) of drivers that # you want to build. IUSE_CAMERAS="adc65 agfa_cl20 aox barbie canon casio_qv clicksmart310 digigr8 digita dimera3500 directory enigma13 fuji gsmart300 hp215 iclick jamcam jd11 jl2005a kodak_dc120 kodak_dc210 kodak_dc240 kodak_dc3200 kodak_ez200 konica konica_qm150 largan lg_gsm mars dimagev mustek panasonic_coolshot panasonic_l859 panasonic_dc1000 panasonic_dc1580 pccam300 pccam600 polaroid_pdc320 polaroid_pdc640 polaroid_pdc700 ptp2 ricoh ricoh_g3 samsung sierra sipix_blink sipix_blink2 sipix_web2 smal sonix sony_dscf1 sony_dscf55 soundvision spca50x sq905 stv0674 stv0680 sx330z template toshiba_pdrm11 topfield" # jl2005c is still experimental -> not enabled for camera in ${IUSE_CAMERAS}; do IUSE="${IUSE} cameras_${camera}" done # libgphoto2 actually links to libtool RDEPEND="!sunusb? ( >=dev-libs/libusb-0.1.8 ) bonjour? ( || ( net-dns/avahi[mdnsresponder-compat] net-misc/mDNSResponder ) ) exif? ( >=media-libs/libexif-0.5.9 ) hal? ( >=sys-apps/hal-0.5 >=sys-apps/dbus-1 ) sys-devel/libtool" DEPEND="${RDEPEND} dev-util/pkgconfig sys-devel/flex >=sys-devel/gettext-0.14.1 doc? ( app-doc/doxygen )" # FIXME: gtk-doc is broken # >=dev-util/gtk-doc-1.10 )" RDEPEND="${RDEPEND} !<sys-fs/udev-114" pkg_setup() { if ! echo "${USE}" | grep "cameras_" > /dev/null 2>&1; then einfo "libgphoto2 supports: all ${IUSE_CAMERAS}" einfo "All camera drivers will be built since you did not specify" einfo "via the CAMERAS variable what camera you use." ewarn "NOTICE: Upstream will not support you if you do not compile all camera drivers first" fi if use cameras_template || use cameras_sipix_blink; then einfo "Upstream considers sipix_blink & template driver as obsolete" fi enewgroup plugdev } src_prepare() { epatch "${FILESDIR}"/${PN}-2.4.0-rpm.patch # Fix pkgconfig file when USE="-exif" use exif || sed -i "s/, @REQUIREMENTS_FOR_LIBEXIF@//" libgphoto2.pc.in || die " libgphoto2.pc sed failed" # Fix bug #216206, libusb detection sed -i "s:usb_busses:usb_find_busses:g" libgphoto2_port/configure || die "libusb sed failed" # Fix building on alpha, bug #221853 comment #6 epatch "${FILESDIR}/gphoto2-ixany.patch" # Fix automagic dependencies, bug #242470 epatch "${FILESDIR}/${PN}-2.4.3-automagic.patch" cd "${S}/libgphoto2_port" eautoreconf } src_configure() { local cameras local cam for cam in ${IUSE_CAMERAS} ; do use "cameras_${cam}" && cameras="${cameras},${cam}" done [ -z "${cameras}" ] \ && cameras="all" \ || cameras="${cameras:1}" einfo "Enabled camera drivers: ${cameras}" [ "${cameras}" != "all" ] && \ ewarn "Upstream will not support you if you do not compile all camera drivers first" local myconf use exif \ && myconf="${myconf} --with-libexif=${EPREFIX}/usr" \ || myconf="${myconf} --with-libexif=no" use sunusb \ && myconf="${myconf} --with-libusb=/usr/sfw" econf \ ${myconf} \ --disable-docs \ --disable-gp2ddb \ $(use_enable bonjour) \ $(use_enable hal) \ $(use_enable nls) \ --with-drivers=${cameras} \ --with-doc-dir=${EPREFIX}/usr/share/doc/${PF} \ --with-html-dir=${EPREFIX}/usr/share/doc/${PF}/html \ --with-hotplug-doc-dir=${EPREFIX}/usr/share/doc/${PF}/hotplug \ --with-rpmbuild=/bin/true \ udevscriptdir=${EPREFIX}/$(get_libdir)/udev # FIXME: gtk-doc is currently broken # $(use_enable doc docs) } src_compile() { emake || die "make failed" if use doc; then doxygen doc/Doxyfile || die "Documentation generation failed" fi } src_install() { emake DESTDIR="${D}" install || die "install failed" # FIXME: fixup autoconf bug if ! use doc && [ -d "${ED}/usr/share/doc/${PF}/apidocs.html" ]; then rm -fr "${ED}/usr/share/doc/${PF}/apidocs.html" fi # end fixup dodoc ChangeLog NEWS* README AUTHORS TESTERS MAINTAINERS HACKING HAL_FDI="/usr/share/hal/fdi/information/20thirdparty/10-camera-libgphoto2.fdi" UDEV_RULES="/etc/udev/rules.d/70-libgphoto2.rules" CAM_LIST="/usr/$(get_libdir)/libgphoto2/print-camera-list" if [ -x "${ED}"${CAM_LIST} ]; then # Let print-camera-list find libgphoto2.so export LD_LIBRARY_PATH="${ED}/usr/$(get_libdir)" # Let libgphoto2 find its camera-modules export CAMLIBS="${ED}/usr/$(get_libdir)/libgphoto2/${PV}" if use hal && [ -n "$("${ED}"${CAM_LIST} idlist)" ]; then einfo "Generating HAL FDI files ..." mkdir -p "${ED}"/${HAL_FDI%/*} "${ED}"${CAM_LIST} hal-fdi >> "${ED}"/${HAL_FDI} \ || die "failed to create hal-fdi" else ewarn "No HAL FDI file generated because no real camera driver enabled" fi einfo "Generating UDEV-rules ..." mkdir -p "${ED}"/${UDEV_RULES%/*} echo -e "# do not edit this file, it will be overwritten on update\n#" \ > "${ED}"/${UDEV_RULES} "${ED}"${CAM_LIST} udev-rules version 0.98 group plugdev >> "${ED}"/${UDEV_RULES} \ || die "failed to create udev-rules" else eerror "Unable to find print-camera-list" eerror "and therefore unable to generate hotplug usermap or HAL FDI files." eerror "You will have to manually generate it by running:" eerror " ${CAM_LIST} udev-rules version 0.98 group plugdev > ${UDEV_RULES}" eerror " ${CAM_LIST} hal-fdi > ${HAL_FDI}" fi } pkg_postinst() { elog "Don't forget to add yourself to the plugdev group " elog "if you want to be able to access your camera." local OLD_UDEV_RULES="${EROOT}"etc/udev/rules.d/99-libgphoto2.rules if [[ -f ${OLD_UDEV_RULES} ]]; then rm -f "${OLD_UDEV_RULES}" fi }
--- libgphoto2/libgphoto2-2.4.4.ebuild.1 2009-01-31 17:10:17.000000000 +0100 +++ libgphoto2/libgphoto2-2.4.4.ebuild 2009-02-12 18:38:34.798538191 +0100 @@ -8,7 +8,7 @@ # 3. Track upstream bug regarding rpm usage. # http://sourceforge.net/tracker/index.php?func=detail&aid=1643813&group_id=8874&atid=358874 -EAPI="2" +EAPI="prefix 2" inherit autotools eutils multilib @@ -18,9 +18,9 @@ LICENSE="GPL-2" SLOT="0" -KEYWORDS="~alpha ~amd64 ~hppa ~ia64 ~ppc ~ppc64 ~sparc ~x86" +KEYWORDS="~amd64-linux ~ia64-linux ~x86-linux ~x86-solaris" -IUSE="bonjour doc exif hal nls kernel_linux" +IUSE="bonjour doc exif hal nls kernel_linux sunusb" RESTRICT="test" # By default, drivers for all supported cameras will be compiled. @@ -44,7 +44,7 @@ done # libgphoto2 actually links to libtool -RDEPEND=">=dev-libs/libusb-0.1.8 +RDEPEND="!sunusb? ( >=dev-libs/libusb-0.1.8 ) bonjour? ( || ( net-dns/avahi[mdnsresponder-compat] net-misc/mDNSResponder ) ) @@ -116,9 +116,12 @@ local myconf use exif \ - && myconf="${myconf} --with-libexif=/usr" \ + && myconf="${myconf} --with-libexif=${EPREFIX}/usr" \ || myconf="${myconf} --with-libexif=no" + use sunusb \ + && myconf="${myconf} --with-libusb=/usr/sfw" + econf \ ${myconf} \ --disable-docs \ @@ -127,11 +130,11 @@ $(use_enable hal) \ $(use_enable nls) \ --with-drivers=${cameras} \ - --with-doc-dir=/usr/share/doc/${PF} \ - --with-html-dir=/usr/share/doc/${PF}/html \ - --with-hotplug-doc-dir=/usr/share/doc/${PF}/hotplug \ + --with-doc-dir=${EPREFIX}/usr/share/doc/${PF} \ + --with-html-dir=${EPREFIX}/usr/share/doc/${PF}/html \ + --with-hotplug-doc-dir=${EPREFIX}/usr/share/doc/${PF}/hotplug \ --with-rpmbuild=/bin/true \ - udevscriptdir=/$(get_libdir)/udev + udevscriptdir=${EPREFIX}/$(get_libdir)/udev # FIXME: gtk-doc is currently broken # $(use_enable doc docs) @@ -149,8 +152,8 @@ emake DESTDIR="${D}" install || die "install failed" # FIXME: fixup autoconf bug - if ! use doc && [ -d "${D}/usr/share/doc/${PF}/apidocs.html" ]; then - rm -fr "${D}/usr/share/doc/${PF}/apidocs.html" + if ! use doc && [ -d "${ED}/usr/share/doc/${PF}/apidocs.html" ]; then + rm -fr "${ED}/usr/share/doc/${PF}/apidocs.html" fi # end fixup @@ -160,26 +163,26 @@ UDEV_RULES="/etc/udev/rules.d/70-libgphoto2.rules" CAM_LIST="/usr/$(get_libdir)/libgphoto2/print-camera-list" - if [ -x "${D}"${CAM_LIST} ]; then + if [ -x "${ED}"${CAM_LIST} ]; then # Let print-camera-list find libgphoto2.so - export LD_LIBRARY_PATH="${D}/usr/$(get_libdir)" + export LD_LIBRARY_PATH="${ED}/usr/$(get_libdir)" # Let libgphoto2 find its camera-modules - export CAMLIBS="${D}/usr/$(get_libdir)/libgphoto2/${PV}" + export CAMLIBS="${ED}/usr/$(get_libdir)/libgphoto2/${PV}" - if use hal && [ -n "$("${D}"${CAM_LIST} idlist)" ]; then + if use hal && [ -n "$("${ED}"${CAM_LIST} idlist)" ]; then einfo "Generating HAL FDI files ..." - mkdir -p "${D}"/${HAL_FDI%/*} - "${D}"${CAM_LIST} hal-fdi >> "${D}"/${HAL_FDI} \ + mkdir -p "${ED}"/${HAL_FDI%/*} + "${ED}"${CAM_LIST} hal-fdi >> "${ED}"/${HAL_FDI} \ || die "failed to create hal-fdi" else ewarn "No HAL FDI file generated because no real camera driver enabled" fi einfo "Generating UDEV-rules ..." - mkdir -p "${D}"/${UDEV_RULES%/*} + mkdir -p "${ED}"/${UDEV_RULES%/*} echo -e "# do not edit this file, it will be overwritten on update\n#" \ - > "${D}"/${UDEV_RULES} - "${D}"${CAM_LIST} udev-rules version 0.98 group plugdev >> "${D}"/${UDEV_RULES} \ + > "${ED}"/${UDEV_RULES} + "${ED}"${CAM_LIST} udev-rules version 0.98 group plugdev >> "${ED}"/${UDEV_RULES} \ || die "failed to create udev-rules" else eerror "Unable to find print-camera-list" @@ -194,7 +197,7 @@ pkg_postinst() { elog "Don't forget to add yourself to the plugdev group " elog "if you want to be able to access your camera." - local OLD_UDEV_RULES="${ROOT}"etc/udev/rules.d/99-libgphoto2.rules + local OLD_UDEV_RULES="${EROOT}"etc/udev/rules.d/99-libgphoto2.rules if [[ -f ${OLD_UDEV_RULES} ]]; then rm -f "${OLD_UDEV_RULES}" fi
