[oe-commits] Martin Jansa : generate-packages-dynamic-list: contrib script to generate disjunctive PACKAGES_DYNAMIC for each pack base /good/bad/ugly

git version control git at git.openembedded.org
Mon Apr 11 14:08:45 UTC 2011


Module: openembedded.git
Branch: master
Commit: 6e48ec031cad9c5d7c57ade6ffe102c929c7b3fe
URL:    http://gitweb.openembedded.net/?p=openembedded.git&a=commit;h=6e48ec031cad9c5d7c57ade6ffe102c929c7b3fe

Author: Martin Jansa <martin.jansa at gmail.com>
Date:   Thu Apr  7 00:12:23 2011 +0000

generate-packages-dynamic-list: contrib script to generate disjunctive PACKAGES_DYNAMIC for each pack base/good/bad/ugly

Signed-off-by: Martin Jansa <Martin.Jansa at gmail.com>
Acked-by: Mike Westerhof <mike at mwester.net>

---

 .../gstreamer/generate-packages-dynamic-list.sh    |   60 ++++++++++++++++++++
 1 files changed, 60 insertions(+), 0 deletions(-)

diff --git a/contrib/gstreamer/generate-packages-dynamic-list.sh b/contrib/gstreamer/generate-packages-dynamic-list.sh
new file mode 100755
index 0000000..932aca4
--- /dev/null
+++ b/contrib/gstreamer/generate-packages-dynamic-list.sh
@@ -0,0 +1,60 @@
+#!/bin/sh
+
+# PATH to tmpdir
+TMPDIR=tmp
+
+if [ $# -lt 1 ] ; then
+  echo "Usage: $0 path/to/recipe.bb"
+  exit 1
+fi
+
+if [ $# -eq 2 ] ; then
+  TMPDIR=$2
+fi
+
+if [ ! -d ${TMPDIR} ] ; then
+  echo "TMPDIR '${TMPDIR}' does not exist, update TMPDIR in script or use 2nd parameter"
+  exit 2
+fi
+
+RECIPE=$1
+
+if grep PACKAGES_DYNAMIC ${RECIPE} >/dev/null; then
+  echo "${RECIPE} already has PACKAGES_DYNAMIC defined, please remove it first"
+  exit 3
+fi
+
+# force old behavior spliting all
+echo 'PACKAGES_DYNAMIC = "gst-plugin-*"' >> ${RECIPE}
+
+echo "Cleaning ${RECIPE}"
+# don't know better way to get right WORKDIR from shell, we need to clean it anyways
+WORKDIR=`bitbake -c clean -v -b ${RECIPE} | grep "NOTE: removing work" | sed 's/NOTE: removing //g'`
+
+TMPDIR_PKGS=${TMPDIR}/${WORKDIR}/packages-split/
+echo "Packages are expected in ${TMPDIR_PKGS}"
+
+echo "Building ${RECIPE}"
+# -c build because some people use rm_work
+bitbake -c build -b ${RECIPE}
+
+if [ $? -ne 0 ] ; then
+  echo "${RECIPE} build failed, fix build first"
+  sed -i '/^PACKAGES_DYNAMIC = "gst-plugin-\*"$/d' ${RECIPE}
+  exit 4
+fi
+
+
+if ls -1d ${TMPDIR_PKGS}/gst-plugin-*-dev | grep gst-plugin-.*-dev >/dev/null; then
+  # replace temporary PACKAGES_DYNAMIC spliting all with list of created packages
+  sed -i '/^PACKAGES_DYNAMIC = "gst-plugin-\*"$/d' ${RECIPE}
+  echo '' >> ${RECIPE}
+  echo 'PACKAGES_DYNAMIC = "\' >> ${RECIPE}
+  ls -1d ${TMPDIR_PKGS}/gst-plugin-*-dev | grep gst-plugin-.*-dev| sed "s#${TMPDIR_PKGS}/\(.*\)-dev#\1* \\\#g" >> ${RECIPE}
+  echo '"' >> ${RECIPE}
+  echo "${RECIPE} PACKAGES_DYNAMIC were hopefully updated"
+else
+  echo "No directories found ${TMPDIR_PKGS}/gst-plugin-*-dev"
+  exit 5
+fi
+





More information about the Openembedded-commits mailing list