summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKhem Raj <raj.khem@gmail.com>2012-07-29 14:27:05 -0700
committerRichard Purdie <richard.purdie@linuxfoundation.org>2012-07-31 12:22:06 +0100
commit4029ce1a15e1dbd374444ee77ccf2a915e463b7b (patch)
tree1a8e357b8302c8d2d6b45841fedeade7a28655c6
parent4a85d8a4026cf1d1603513ed9780f80c603cc611 (diff)
downloadopenembedded-core-4029ce1a15e1dbd374444ee77ccf2a915e463b7b.tar.gz
openembedded-core-4029ce1a15e1dbd374444ee77ccf2a915e463b7b.tar.bz2
openembedded-core-4029ce1a15e1dbd374444ee77ccf2a915e463b7b.zip
package_rpm.bbclass: Accomodate dash when using arrays
we were assigning local variable to an array coming through positional arguments. local is a non posix contruct thats also supported by dash luckily but operates differently in this case it exapnds the array before assignment. so local pkgs="$@" turns into pkgs=locale-base-en-us locale-base-en-gb ant we see errors run.do_rootfs.25593: 932: local: locale-base-en-gb: bad variable name So lets not use defining and assigning local in one go first define a local and then the assignment Signed-off-by: Khem Raj <raj.khem@gmail.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r--meta/classes/package_rpm.bbclass7
1 files changed, 6 insertions, 1 deletions
diff --git a/meta/classes/package_rpm.bbclass b/meta/classes/package_rpm.bbclass
index b4bc52e69b..50e9b31517 100644
--- a/meta/classes/package_rpm.bbclass
+++ b/meta/classes/package_rpm.bbclass
@@ -200,7 +200,12 @@ rpm_update_pkg () {
process_pkg_list_rpm() {
local insttype=$1
shift
- local pkgs="$@"
+ # $@ is special POSIX linear array can not be assigned
+ # to a local variable directly in dash since its separated by
+ # space and dash expands it before assignment
+ # and local x=1 2 3 and not x="1 2 3"
+ local pkgs
+ pkgs="$@"
local confbase=${INSTALL_CONFBASE_RPM}
echo -n > ${target_rootfs}/install/base_archs.pkglist