diff options
| -rw-r--r-- | meta/classes/archiver.bbclass | 14 |
1 files changed, 8 insertions, 6 deletions
diff --git a/meta/classes/archiver.bbclass b/meta/classes/archiver.bbclass index af9f010dfc..13b05bb5f2 100644 --- a/meta/classes/archiver.bbclass +++ b/meta/classes/archiver.bbclass | |||
| @@ -78,6 +78,9 @@ python () { | |||
| 78 | bb.debug(1, 'archiver: %s is excluded, covered by gcc-source' % pn) | 78 | bb.debug(1, 'archiver: %s is excluded, covered by gcc-source' % pn) |
| 79 | return | 79 | return |
| 80 | 80 | ||
| 81 | def hasTask(task): | ||
| 82 | return bool(d.getVarFlag(task, "task", False)) and not bool(d.getVarFlag(task, "noexec", False)) | ||
| 83 | |||
| 81 | ar_src = d.getVarFlag('ARCHIVER_MODE', 'src') | 84 | ar_src = d.getVarFlag('ARCHIVER_MODE', 'src') |
| 82 | ar_dumpdata = d.getVarFlag('ARCHIVER_MODE', 'dumpdata') | 85 | ar_dumpdata = d.getVarFlag('ARCHIVER_MODE', 'dumpdata') |
| 83 | ar_recipe = d.getVarFlag('ARCHIVER_MODE', 'recipe') | 86 | ar_recipe = d.getVarFlag('ARCHIVER_MODE', 'recipe') |
| @@ -98,9 +101,6 @@ python () { | |||
| 98 | 101 | ||
| 99 | # There is a corner case with "gcc-source-${PV}" recipes, they don't have | 102 | # There is a corner case with "gcc-source-${PV}" recipes, they don't have |
| 100 | # the "do_configure" task, so we need to use "do_preconfigure" | 103 | # the "do_configure" task, so we need to use "do_preconfigure" |
| 101 | def hasTask(task): | ||
| 102 | return bool(d.getVarFlag(task, "task", False)) and not bool(d.getVarFlag(task, "noexec", False)) | ||
| 103 | |||
| 104 | if hasTask("do_preconfigure"): | 104 | if hasTask("do_preconfigure"): |
| 105 | d.appendVarFlag('do_ar_configured', 'depends', ' %s:do_preconfigure' % pn) | 105 | d.appendVarFlag('do_ar_configured', 'depends', ' %s:do_preconfigure' % pn) |
| 106 | elif hasTask("do_configure"): | 106 | elif hasTask("do_configure"): |
| @@ -118,7 +118,11 @@ python () { | |||
| 118 | 118 | ||
| 119 | # Output the SRPM package | 119 | # Output the SRPM package |
| 120 | if d.getVarFlag('ARCHIVER_MODE', 'srpm') == "1" and d.getVar('PACKAGES'): | 120 | if d.getVarFlag('ARCHIVER_MODE', 'srpm') == "1" and d.getVar('PACKAGES'): |
| 121 | if "package_rpm" in d.getVar('PACKAGE_CLASSES'): | 121 | if "package_rpm" not in d.getVar('PACKAGE_CLASSES'): |
| 122 | bb.fatal("ARCHIVER_MODE[srpm] needs package_rpm in PACKAGE_CLASSES") | ||
| 123 | |||
| 124 | # Some recipes do not have any packaging tasks | ||
| 125 | if hasTask("do_package_write_rpm"): | ||
| 122 | d.appendVarFlag('do_deploy_archives', 'depends', ' %s:do_package_write_rpm' % pn) | 126 | d.appendVarFlag('do_deploy_archives', 'depends', ' %s:do_package_write_rpm' % pn) |
| 123 | d.appendVarFlag('do_package_write_rpm', 'dirs', ' ${ARCHIVER_RPMTOPDIR}') | 127 | d.appendVarFlag('do_package_write_rpm', 'dirs', ' ${ARCHIVER_RPMTOPDIR}') |
| 124 | d.appendVarFlag('do_package_write_rpm', 'sstate-inputdirs', ' ${ARCHIVER_RPMTOPDIR}') | 128 | d.appendVarFlag('do_package_write_rpm', 'sstate-inputdirs', ' ${ARCHIVER_RPMTOPDIR}') |
| @@ -133,8 +137,6 @@ python () { | |||
| 133 | d.appendVarFlag('do_package_write_rpm', 'depends', ' %s:do_ar_patched' % pn) | 137 | d.appendVarFlag('do_package_write_rpm', 'depends', ' %s:do_ar_patched' % pn) |
| 134 | elif ar_src == "configured": | 138 | elif ar_src == "configured": |
| 135 | d.appendVarFlag('do_package_write_rpm', 'depends', ' %s:do_ar_configured' % pn) | 139 | d.appendVarFlag('do_package_write_rpm', 'depends', ' %s:do_ar_configured' % pn) |
| 136 | else: | ||
| 137 | bb.fatal("ARCHIVER_MODE[srpm] needs package_rpm in PACKAGE_CLASSES") | ||
| 138 | } | 140 | } |
| 139 | 141 | ||
| 140 | # Take all the sources for a recipe and puts them in WORKDIR/archiver-work/. | 142 | # Take all the sources for a recipe and puts them in WORKDIR/archiver-work/. |
