[oe] [PATCHv2 3/3] generate-packages-dynamic-list: contrib script to generate disjunctive PACKAGES_DYNAMIC for each pack base/good/bad/ugly
Mike Westerhof
mike at mwester.net
Sun Apr 10 14:29:39 UTC 2011
On 4/6/2011 11:12 AM, Martin Jansa wrote:
> 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(-)
> create mode 100755 contrib/gstreamer/generate-packages-dynamic-list.sh
>
> 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-devel
mailing list