Don't inherit siteinfo in base.bbclass
[openembedded.git] / classes / rootfs_deb.bbclass
index 67fa661..dc2b2cb 100644 (file)
@@ -1,18 +1,22 @@
 #
 # Copyright 2006-2007 Openedhand Ltd.
 #
+ROOTFS_PKGMANAGE = "run-postinsts dpkg"
+ROOTFS_PKGMANAGE_BOOTSTRAP  = "run-postinsts"
 
 do_rootfs[depends] += "dpkg-native:do_populate_staging apt-native:do_populate_staging"
+do_rootfs[recrdeptask] += "do_package_write_deb"
 
 fakeroot rootfs_deb_do_rootfs () {
        set +e
-       mkdir -p ${IMAGE_ROOTFS}/var/dpkg/{info,updates}
+       mkdir -p ${IMAGE_ROOTFS}/var/dpkg/info
+       mkdir -p ${IMAGE_ROOTFS}/var/dpkg/updates
 
-       rm -f ${STAGING_DIR}/etc/apt/sources.list.rev
-       rm -f ${STAGING_DIR}/etc/apt/preferences
+       rm -f ${STAGING_ETCDIR_NATIVE}/apt/sources.list.rev
+       rm -f ${STAGING_ETCDIR_NATIVE}/apt/preferences
        > ${IMAGE_ROOTFS}/var/dpkg/status
        > ${IMAGE_ROOTFS}/var/dpkg/available
-       # > ${STAGING_DIR}/var/dpkg/status
+       mkdir -p ${IMAGE_ROOTFS}/var/dpkg/alternatives
 
        priority=1
        for arch in ${PACKAGE_ARCHS}; do
@@ -20,30 +24,35 @@ fakeroot rootfs_deb_do_rootfs () {
                        continue;
                fi
                cd ${DEPLOY_DIR_DEB}/$arch
-               # if [ -z "${DEPLOY_KEEP_PACKAGES}" ]; then
-                       rm -f Packages.gz Packages Packages.bz2
-               # fi
-               apt-ftparchive packages . | bzip2 > Packages.bz2
+               rm -f Packages.gz Packages Packages.bz2
+
+               # apt-native ignores Packages.bz2 unless /bin/bzip2 exists
+               # on the build host, so stick with gzip
+               dpkg-scanpackages . | gzip > Packages.gz
+
                echo "Label: $arch" > Release
 
-               echo "deb file:${DEPLOY_DIR_DEB}/$arch/ ./" >> ${STAGING_DIR}/etc/apt/sources.list.rev
+               echo "deb file:${DEPLOY_DIR_DEB}/$arch/ ./" >> ${STAGING_ETCDIR_NATIVE}/apt/sources.list.rev
                (echo "Package: *"
                echo "Pin: release l=$arch"
                echo "Pin-Priority: $((800 + $priority))"
-               echo) >> ${STAGING_DIR}/etc/apt/preferences
+               echo) >> ${STAGING_ETCDIR_NATIVE}/apt/preferences
                priority=$(expr $priority + 5)
        done
 
-       tac ${STAGING_DIR}/etc/apt/sources.list.rev > ${STAGING_DIR}/etc/apt/sources.list
+       tac ${STAGING_ETCDIR_NATIVE}/apt/sources.list.rev > ${STAGING_ETCDIR_NATIVE}/apt/sources.list
 
-       cat "${STAGING_DIR}/etc/apt/apt.conf.sample" \
-               | sed -e 's#Architecture ".*";#Architecture "${TARGET_ARCH}";#' \
-               > "${STAGING_DIR}/etc/apt/apt-rootfs.conf"
+       cat "${STAGING_ETCDIR_NATIVE}/apt/apt.conf.sample" \
+               | sed -e 's#Architecture ".*";#Architecture "${DPKG_ARCH}";#' \
+               | sed -e 's#status ".*";#status "${IMAGE_ROOTFS}/var/dpkg/status";#' \ 
+               | sed -e 's#DPkg::Options {".*"};#DPkg::Options {"--root=${IMAGE_ROOTFS}";"--admindir=${IMAGE_ROOTFS}/var/dpkg";"--force-all";"--no-debsig"};#' \
+               > "${STAGING_ETCDIR_NATIVE}/apt/apt-rootfs.conf"
 
-       export APT_CONFIG="${STAGING_DIR}/etc/apt/apt-rootfs.conf"
+       export APT_CONFIG="${STAGING_ETCDIR_NATIVE}/apt/apt-rootfs.conf"
        export D=${IMAGE_ROOTFS}
        export OFFLINE_ROOT=${IMAGE_ROOTFS}
        export IPKG_OFFLINE_ROOT=${IMAGE_ROOTFS}
+       export OPKG_OFFLINE_ROOT=${IMAGE_ROOTFS}
 
        apt-get update
 
@@ -54,31 +63,41 @@ fakeroot rootfs_deb_do_rootfs () {
                cat ${IMAGE_ROOTFS}/var/dpkg/status | sed -n -e "/^Package: $2\$/{n; s/Status: install ok .*/$1/; p}"
        }
 
-       if [ ! -z "${LINGUAS_INSTALL}" ]; then
-               apt-get install glibc-localedata-i18n --force-yes --allow-unauthenticated
-               if [ $? -ne 0 ]; then
-                       exit $?
-               fi
-               for i in ${LINGUAS_INSTALL}; do
-                       apt-get install $i --force-yes --allow-unauthenticated
+       if [ x${TARGET_OS} = "xlinux" ] || [ x${TARGET_OS} = "xlinux-gnueabi" ] ; then
+               if [ ! -z "${LINGUAS_INSTALL}" ]; then
+                       apt-get install glibc-localedata-i18n --force-yes --allow-unauthenticated
                        if [ $? -ne 0 ]; then
-                               exit $?
+                               exit 1
                        fi
-               done
+                       for i in ${LINGUAS_INSTALL}; do
+                               apt-get install $i --force-yes --allow-unauthenticated
+                               if [ $? -ne 0 ]; then
+                                       exit 1
+                               fi
+                       done
+               fi
        fi
 
        if [ ! -z "${PACKAGE_INSTALL}" ]; then
                for i in ${PACKAGE_INSTALL}; do
                        apt-get install $i --force-yes --allow-unauthenticated
-                       if [ $? -eq 1 ]; then
+                       if [ $? -ne 0 ]; then
                                exit 1
                        fi
-                       find ${IMAGE_ROOTFS} -name \*.dpkg-new | for i in `cat`; do
-                               mv $i `echo $i | sed -e's,\.dpkg-new$,,'`
-                       done
                done
        fi
 
+       rm ${WORKDIR}/temp/log.do_$target-attemptonly.${PID}
+       if [ ! -z "${PACKAGE_INSTALL_ATTEMPTONLY}" ]; then
+               for i in ${PACKAGE_INSTALL_ATTEMPTONLY}; do
+                       apt-get install $i --force-yes --allow-unauthenticated >> ${WORKDIR}/temp/log.do_rootfs-attemptonly.${PID} || true
+               done
+       fi
+
+       find ${IMAGE_ROOTFS} -name \*.dpkg-new | for i in `cat`; do
+               mv $i `echo $i | sed -e's,\.dpkg-new$,,'`
+       done
+
        install -d ${IMAGE_ROOTFS}/${sysconfdir}
        echo ${BUILDNAME} > ${IMAGE_ROOTFS}/${sysconfdir}/version
 
@@ -103,14 +122,14 @@ fakeroot rootfs_deb_do_rootfs () {
 
        set -e
 
-       # Hacks to make dpkg/ipkg coexist for now
-       mv ${IMAGE_ROOTFS}/var/dpkg ${IMAGE_ROOTFS}/usr/
-       if [ -e ${IMAGE_ROOTFS}/usr/dpkg/alternatives ]; then
-               rmdir ${IMAGE_ROOTFS}/usr/dpkg/alternatives
+       # Hacks to allow opkg's update-alternatives and opkg to coexist for now
+       mkdir -p ${IMAGE_ROOTFS}${libdir}/opkg
+       if [ -e ${IMAGE_ROOTFS}/var/dpkg/alternatives ]; then
+               rmdir ${IMAGE_ROOTFS}/var/dpkg/alternatives
        fi
-       ln -s /usr/lib/ipkg/alternatives ${IMAGE_ROOTFS}/usr/dpkg/alternatives
-       ln -s /usr/dpkg/info ${IMAGE_ROOTFS}/usr/lib/ipkg/info
-       ln -s /usr/dpkg/status ${IMAGE_ROOTFS}/usr/lib/ipkg/status
+       ln -s ${libdir}/opkg/alternatives ${IMAGE_ROOTFS}/var/dpkg/alternatives
+       ln -s /var/dpkg/info ${IMAGE_ROOTFS}${libdir}/opkg/info
+       ln -s /var/dpkg/status ${IMAGE_ROOTFS}${libdir}/opkg/status
 
        ${ROOTFS_POSTPROCESS_COMMAND}
 
@@ -130,7 +149,7 @@ rootfs_deb_log_check() {
                        echo -e "log_check: Matched keyword: [$keyword_die]\n"
                        echo "$lf_txt" | grep -v log_check | grep -C 5 -i "$keyword_die"
                        echo ""
-                       do_exit=1                               
+                       do_exit=1
                fi
        done
        test "$do_exit" = 1 && exit 1                                           
@@ -138,6 +157,6 @@ rootfs_deb_log_check() {
 }
 
 remove_packaging_data_files() {
-       rm -rf ${IMAGE_ROOTFS}/usr/lib/ipkg/
+       rm -rf ${IMAGE_ROOTFS}${libdir}/opkg/
        rm -rf ${IMAGE_ROOTFS}/usr/dpkg/
 }