summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Hatle <mark.hatle@windriver.com>2010-09-02 13:28:37 -0500
committerRichard Purdie <rpurdie@linux.intel.com>2010-09-03 09:45:29 +0100
commitd6c45f0f1184e94a45381af9813f831aaa9052ef (patch)
tree5177c7e361c519130c3e8d155805f123ab12a1e4
parent2f68de1e88fb196c301039ad994782b1a0c6ac94 (diff)
downloadopenembedded-core-d6c45f0f1184e94a45381af9813f831aaa9052ef.tar.gz
openembedded-core-d6c45f0f1184e94a45381af9813f831aaa9052ef.tar.bz2
openembedded-core-d6c45f0f1184e94a45381af9813f831aaa9052ef.zip
rootfs_rpm: Support install_all_locales
Support installing all locales similarly to how it is done within the ipk support. This has had basic testing, but it's not a normally used function so there could still be some flaws. Signed-off-by: Mark Hatle <mark.hatle@windriver.com>
-rw-r--r--meta/classes/rootfs_rpm.bbclass63
1 files changed, 33 insertions, 30 deletions
diff --git a/meta/classes/rootfs_rpm.bbclass b/meta/classes/rootfs_rpm.bbclass
index ace9677f06..00da8e514e 100644
--- a/meta/classes/rootfs_rpm.bbclass
+++ b/meta/classes/rootfs_rpm.bbclass
@@ -14,9 +14,14 @@ do_rootfs[recrdeptask] += "do_package_write_rpm"
AWKPOSTINSTSCRIPT = "${POKYBASE}/scripts/rootfs_rpm-extract-postinst.awk"
-RPM_PREPROCESS_COMMANDS = "package_update_index_rpm; package_generate_rpm_conf"
+RPM_PREPROCESS_COMMANDS = "package_update_index_rpm; package_generate_rpm_conf; "
RPM_POSTPROCESS_COMMANDS = ""
+# To test the install_all_locales.. enable the following...
+#RPM_POSTPROCESS_COMMANDS = "install_all_locales; "
+#
+#IMAGE_LOCALES="en-gb"
+
rpmlibdir = "/var/lib/rpm"
opkglibdir = "${localstatedir}/lib/opkg"
@@ -42,7 +47,7 @@ fakeroot rootfs_rpm_do_rootfs () {
for pkg in ${LINGUAS_INSTALL}; do
echo "Processing $pkg..."
pkg_name=$(resolve_package $pkg)
- if [ -z '$pkg_name' ]; then
+ if [ -z "$pkg_name" ]; then
echo "Unable to find package $pkg!"
exit 1
fi
@@ -55,7 +60,7 @@ fakeroot rootfs_rpm_do_rootfs () {
for pkg in ${PACKAGE_INSTALL} ; do
echo "Processing $pkg..."
pkg_name=$(resolve_package $pkg)
- if [ -z '$pkg_name' ]; then
+ if [ -z "$pkg_name" ]; then
echo "Unable to find package $pkg!"
exit 1
fi
@@ -75,7 +80,7 @@ fakeroot rootfs_rpm_do_rootfs () {
for pkg in ${PACKAGE_INSTALL_ATTEMPTONLY} ; do
echo "Processing $pkg..."
pkg_name=$(resolve_package $pkg)
- if [ -z '$pkg_name' ]; then
+ if [ -z "$pkg_name" ]; then
echo "Unable to find package $pkg!"
exit 1
fi
@@ -109,7 +114,7 @@ fakeroot rootfs_rpm_do_rootfs () {
# Ohh there was a new one, we'll need to loop again...
loop=1
echo "Processing $pkg..."
- pkg_name=$(resolve_package $pkg || true)
+ pkg_name=$(resolve_package $pkg)
if [ -z "$pkg_name" ]; then
echo "Unable to find package $pkg." >> "${WORKDIR}/temp/log.do_rootfs_recommend.${PID}"
continue
@@ -223,41 +228,39 @@ remove_packaging_data_files() {
# Resolve package names to filepaths
resolve_package() {
pkg="$1"
+ pkg_name=""
for solve in `cat ${DEPLOY_DIR_RPM}/solvedb.conf`; do
pkg_name=$(${RPM} -D "_dbpath $solve" -D "_dbi_tags_3 Packages:Name:Basenames:Providename:Nvra" -D "__dbi_cdb create mp_mmapsize=128Mb mp_size=1Mb nofsync" -q --yaml $pkg | grep -i 'Packageorigin' | cut -d : -f 2)
if [ -n "$pkg_name" ]; then
break;
fi
done
- if [ -z "$pkg_name" ]; then
- return 1
- fi
echo $pkg_name
- return 0
}
install_all_locales() {
- echo "install_all_locales: not yet implemented!"
- exit 1
-
- PACKAGES_TO_INSTALL=""
-
- INSTALLED_PACKAGES=`grep ^Package: ${IMAGE_ROOTFS}${opkglibdir}/status |sed "s/^Package: //"|egrep -v -- "(-locale-|-dev$|-doc$|^kernel|^glibc|^ttf|^task|^perl|^python)"`
-
- for pkg in $INSTALLED_PACKAGES
- do
- for lang in ${IMAGE_LOCALES}
- do
- if [ `opkg-cl ${IPKG_ARGS} info $pkg-locale-$lang | wc -l` -gt 2 ]
- then
- PACKAGES_TO_INSTALL="$PACKAGES_TO_INSTALL $pkg-locale-$lang"
- fi
- done
- done
- if [ "$PACKAGES_TO_INSTALL" != "" ]
- then
- opkg-cl ${IPKG_ARGS} install $PACKAGES_TO_INSTALL
- fi
+ PACKAGES_TO_INSTALL=""
+
+ # Generate list of installed packages...
+ INSTALLED_PACKAGES=$( \
+ ${RPM} --root ${IMAGE_ROOTFS} -D "_dbpath ${rpmlibdir}" \
+ -D "__dbi_cdb create mp_mmapsize=128Mb mp_size=1Mb nofsync private" \
+ -qa --qf "[%{NAME}\n]" | egrep -v -- "(-locale-|-dev$|-doc$|^kernel|^glibc|^ttf|^task|^perl|^python)" \
+ )
+
+ # This would likely be faster if we did it in one transaction
+ # but this should be good enough for the few users of this function...
+ for pkg in $INSTALLED_PACKAGES; do
+ for lang in ${IMAGE_LOCALES}; do
+ pkg_name=$(resolve_package $pkg-locale-$lang)
+ if [ -n "$pkg_name" ]; then
+ ${RPM} --root ${IMAGE_ROOTFS} -D "_dbpath ${rpmlibdir}" \
+ --noscripts --notriggers --noparentdirs --nolinktos \
+ -D "__dbi_cdb create mp_mmapsize=128Mb mp_size=1Mb nofsync private" \
+ -Uhv $pkg_name || true
+ fi
+ done
+ done
}
python () {