prep_locale_tree() predates the usrmerge DISTRO_FEATURE, which meant it
was not prepared for the case when ${base_libdir} == ${libdir}. This
lead to it extracting files and directories where it shouldn't.

Signed-off-by: Peter Kjellerstedt <[email protected]>
---
 meta/classes/libc-package.bbclass | 7 ++++++-
 1 file changed, 6 insertions(+), 1 deletion(-)

diff --git a/meta/classes/libc-package.bbclass 
b/meta/classes/libc-package.bbclass
index 60000a9547..ee598905b0 100644
--- a/meta/classes/libc-package.bbclass
+++ b/meta/classes/libc-package.bbclass
@@ -67,7 +67,12 @@ do_prep_locale_tree() {
        for i in $treedir/${datadir}/i18n/charmaps/*gz; do 
                gunzip $i
        done
-       tar -cf - -C ${LOCALETREESRC}${base_libdir} -p . | tar -xf - -C 
$treedir/${base_libdir}
+       # The extract pattern "./l*.so*" is carefully selected so that it will
+       # match ld*.so and lib*.so*, but not any files in the gconv directory
+       # (if it exists). This makes sure we only unpack the files we need.
+       # This is important in case usrmerge is set in DISTRO_FEATURES, which
+       # means ${base_libdir} == ${libdir}.
+       tar -cf - -C ${LOCALETREESRC}${base_libdir} -p . | tar -xf - -C 
$treedir/${base_libdir} './l*.so*'
        if [ -f ${STAGING_LIBDIR_NATIVE}/libgcc_s.* ]; then
                tar -cf - -C ${STAGING_LIBDIR_NATIVE} -p libgcc_s.* | tar -xf - 
-C $treedir/${base_libdir}
        fi
-- 
2.12.0

-- 
_______________________________________________
Openembedded-core mailing list
[email protected]
http://lists.openembedded.org/mailman/listinfo/openembedded-core

Reply via email to