[OE-core] [PATCH] externalsrc.bbclass: Add task buildclean
Paul Eggleton
paul.eggleton at linux.intel.com
Thu Dec 22 17:20:41 UTC 2016
Hi Ola,
I like this, thanks. Just one thing commented below.
On Thu, 22 Dec 2016 14:28:03 Ola x Nilsson wrote:
> The buildclean task should call the package build system clean
> command, just implemented for Make for now.
>
> This is meant for recipes where S == B, but can be useful as a
> standalone task for other recipes too.
>
> Setting it to run before do_clean will do what most developers expect
> when calling bitbake -c clean.
>
> Signed-off-by: Ola x Nilsson <ola.x.nilsson at axis.com>
> ---
> meta/classes/externalsrc.bbclass | 17 ++++++++++++++++-
> 1 file changed, 16 insertions(+), 1 deletion(-)
>
> diff --git a/meta/classes/externalsrc.bbclass
> b/meta/classes/externalsrc.bbclass index e115a47..bc82f1f 100644
> --- a/meta/classes/externalsrc.bbclass
> +++ b/meta/classes/externalsrc.bbclass
> @@ -4,7 +4,7 @@
> # Copyright (C) 2009 Chris Larson <clarson at kergoth.com>
> # Released under the MIT license (see COPYING.MIT for the terms)
> #
> -# externalsrc.bbclass enables use of an existing source tree, usually
> external to
> +# externalsrc.bbclass enables use of an existing source tree,
> usually external to
> # the build system to build a piece of software rather
> than the usual fetch/unpack/patch # process.
> #
> @@ -108,6 +108,8 @@ python () {
> # We don't want the workdir to go away
> d.appendVar('RM_WORK_EXCLUDE', ' ' + d.getVar('PN'))
>
> + bb.build.addtask('do_makeclean', 'do_clean', None, d)
> +
Shouldn't this be do_buildclean here?
> # If B=S the same builddir is used even for different
> architectures. # Thus, use a shared CONFIGURESTAMPFILE and STAMP directory
> so that # change of do_configure task hash is correctly detected and stamps
> are @@ -142,6 +144,17 @@ python externalsrc_compile_prefunc() {
> bb.plain('NOTE: %s: compiling from external source tree %s' %
> (d.getVar('PN'), d.getVar('EXTERNALSRC'))) }
>
> +do_buildclean[dirs] = "${S} ${B}"
> +do_buildclean[nostamp] = "1"
> +do_buildclean[doc] = "Call 'make clean' or equivalent in ${B}"
> +externalsrc_do_buildclean() {
> + if [ -e Makefile -o -e makefile -o -e GNUmakefile ]; then
> + oe_runmake clean || die "make failed"
> + else
> + bbnote "nothing to compile - no makefile found"
> + fi
> +}
> +
> def srctree_hash_files(d):
> import shutil
> import subprocess
> @@ -188,3 +201,5 @@ def srctree_configure_hash_files(d):
> if f in search_files:
> out_items.append('%s:True' % os.path.join(root, f))
> return ' '.join(out_items)
> +
> +EXPORT_FUNCTIONS do_buildclean
Cheers,
Paul
--
Paul Eggleton
Intel Open Source Technology Centre
More information about the Openembedded-core
mailing list