* [PATCH 0/1] distro_features_check.bbclass: show all error info at one time
@ 2018-12-06 13:41 kai.kang
2018-12-06 13:41 ` [PATCH 1/1] " kai.kang
2018-12-14 2:43 ` [PATCH 0/1] " Kang Kai
0 siblings, 2 replies; 4+ messages in thread
From: kai.kang @ 2018-12-06 13:41 UTC (permalink / raw)
To: openembedded-core
From: Kai Kang <kai.kang@windriver.com>
The following changes since commit aa93957c8353d222961f08e54fe8d4095dad72c1:
tcl: Upgrade to 8.6.9 (2018-12-05 22:30:19 +0000)
are available in the Git repository at:
git://git.pokylinux.org/poky-contrib kangkai/distro-check
http://git.pokylinux.org/cgit.cgi/poky-contrib/log/?h=kangkai/distro-check
Kai Kang (1):
distro_features_check.bbclass: show all error info at one time
meta/classes/distro_features_check.bbclass | 29 +++++++++-------------
1 file changed, 12 insertions(+), 17 deletions(-)
--
2.19.0.rc2
^ permalink raw reply [flat|nested] 4+ messages in thread
* [PATCH 1/1] distro_features_check.bbclass: show all error info at one time
2018-12-06 13:41 [PATCH 0/1] distro_features_check.bbclass: show all error info at one time kai.kang
@ 2018-12-06 13:41 ` kai.kang
2018-12-19 1:53 ` Kang Kai
2018-12-14 2:43 ` [PATCH 0/1] " Kang Kai
1 sibling, 1 reply; 4+ messages in thread
From: kai.kang @ 2018-12-06 13:41 UTC (permalink / raw)
To: openembedded-core
From: Kai Kang <kai.kang@windriver.com>
In distro_features_check.bbclass it checks whether items in
REQUIRED_DISTRO_FEATURES and CONFLICT_DISTRO_FEATURES exist in
DISTRO_FEATURES. But it only shows one required or conflict distro
feature when error occurs. Update to show them all at one time.
Signed-off-by: Kai Kang <kai.kang@windriver.com>
---
meta/classes/distro_features_check.bbclass | 29 +++++++++-------------
1 file changed, 12 insertions(+), 17 deletions(-)
diff --git a/meta/classes/distro_features_check.bbclass b/meta/classes/distro_features_check.bbclass
index 9b78b03ef6..eeaa3b44cb 100644
--- a/meta/classes/distro_features_check.bbclass
+++ b/meta/classes/distro_features_check.bbclass
@@ -11,27 +11,22 @@
python () {
# Assume at least one var is set.
- distro_features = (d.getVar('DISTRO_FEATURES') or "").split()
+ distro_features = set((d.getVar('DISTRO_FEATURES') or '').split())
- any_of_distro_features = d.getVar('ANY_OF_DISTRO_FEATURES')
+ any_of_distro_features = set((d.getVar('ANY_OF_DISTRO_FEATURES') or '').split())
if any_of_distro_features:
- any_of_distro_features = any_of_distro_features.split()
- if set.isdisjoint(set(any_of_distro_features),set(distro_features)):
- raise bb.parse.SkipRecipe("one of '%s' needs to be in DISTRO_FEATURES" % any_of_distro_features)
+ if set.isdisjoint(any_of_distro_features, distro_features):
+ raise bb.parse.SkipRecipe("one of '%s' needs to be in DISTRO_FEATURES" % ' '.join(any_of_distro_features))
- required_distro_features = d.getVar('REQUIRED_DISTRO_FEATURES')
+ required_distro_features = set((d.getVar('REQUIRED_DISTRO_FEATURES') or '').split())
if required_distro_features:
- required_distro_features = required_distro_features.split()
- for f in required_distro_features:
- if f in distro_features:
- continue
- else:
- raise bb.parse.SkipRecipe("missing required distro feature '%s' (not in DISTRO_FEATURES)" % f)
+ missing = set.difference(required_distro_features, distro_features)
+ if missing:
+ raise bb.parse.SkipRecipe("missing required distro feature%s '%s' (not in DISTRO_FEATURES)" % ('s' if len(missing) > 1 else '', ' '.join(missing)))
- conflict_distro_features = d.getVar('CONFLICT_DISTRO_FEATURES')
+ conflict_distro_features = set((d.getVar('CONFLICT_DISTRO_FEATURES') or '').split())
if conflict_distro_features:
- conflict_distro_features = conflict_distro_features.split()
- for f in conflict_distro_features:
- if f in distro_features:
- raise bb.parse.SkipRecipe("conflicting distro feature '%s' (in DISTRO_FEATURES)" % f)
+ conflicts = set.intersection(conflict_distro_features, distro_features)
+ if conflicts:
+ raise bb.parse.SkipRecipe("conflicting distro feature%s '%s' (in DISTRO_FEATURES)" % ('s' if len(conflicts) > 1 else '', ' '.join(conflicts)))
}
--
2.19.0.rc2
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH 0/1] distro_features_check.bbclass: show all error info at one time
2018-12-06 13:41 [PATCH 0/1] distro_features_check.bbclass: show all error info at one time kai.kang
2018-12-06 13:41 ` [PATCH 1/1] " kai.kang
@ 2018-12-14 2:43 ` Kang Kai
1 sibling, 0 replies; 4+ messages in thread
From: Kang Kai @ 2018-12-14 2:43 UTC (permalink / raw)
To: openembedded-core
On 2018/12/6 下午9:41, kai.kang@windriver.com wrote:
> From: Kai Kang <kai.kang@windriver.com>
>
> The following changes since commit aa93957c8353d222961f08e54fe8d4095dad72c1:
>
> tcl: Upgrade to 8.6.9 (2018-12-05 22:30:19 +0000)
>
> are available in the Git repository at:
>
> git://git.pokylinux.org/poky-contrib kangkai/distro-check
> http://git.pokylinux.org/cgit.cgi/poky-contrib/log/?h=kangkai/distro-check
>
> Kai Kang (1):
> distro_features_check.bbclass: show all error info at one time
>
> meta/classes/distro_features_check.bbclass | 29 +++++++++-------------
> 1 file changed, 12 insertions(+), 17 deletions(-)
>
Ping.
--
Kai Kang
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH 1/1] distro_features_check.bbclass: show all error info at one time
2018-12-06 13:41 ` [PATCH 1/1] " kai.kang
@ 2018-12-19 1:53 ` Kang Kai
0 siblings, 0 replies; 4+ messages in thread
From: Kang Kai @ 2018-12-19 1:53 UTC (permalink / raw)
To: openembedded-core
On 2018/12/6 下午9:41, kai.kang@windriver.com wrote:
> From: Kai Kang <kai.kang@windriver.com>
>
> In distro_features_check.bbclass it checks whether items in
> REQUIRED_DISTRO_FEATURES and CONFLICT_DISTRO_FEATURES exist in
> DISTRO_FEATURES. But it only shows one required or conflict distro
> feature when error occurs. Update to show them all at one time.
>
> Signed-off-by: Kai Kang <kai.kang@windriver.com>
> ---
> meta/classes/distro_features_check.bbclass | 29 +++++++++-------------
> 1 file changed, 12 insertions(+), 17 deletions(-)
>
> diff --git a/meta/classes/distro_features_check.bbclass b/meta/classes/distro_features_check.bbclass
> index 9b78b03ef6..eeaa3b44cb 100644
> --- a/meta/classes/distro_features_check.bbclass
> +++ b/meta/classes/distro_features_check.bbclass
> @@ -11,27 +11,22 @@
>
> python () {
> # Assume at least one var is set.
> - distro_features = (d.getVar('DISTRO_FEATURES') or "").split()
> + distro_features = set((d.getVar('DISTRO_FEATURES') or '').split())
>
> - any_of_distro_features = d.getVar('ANY_OF_DISTRO_FEATURES')
> + any_of_distro_features = set((d.getVar('ANY_OF_DISTRO_FEATURES') or '').split())
> if any_of_distro_features:
> - any_of_distro_features = any_of_distro_features.split()
> - if set.isdisjoint(set(any_of_distro_features),set(distro_features)):
> - raise bb.parse.SkipRecipe("one of '%s' needs to be in DISTRO_FEATURES" % any_of_distro_features)
> + if set.isdisjoint(any_of_distro_features, distro_features):
> + raise bb.parse.SkipRecipe("one of '%s' needs to be in DISTRO_FEATURES" % ' '.join(any_of_distro_features))
>
> - required_distro_features = d.getVar('REQUIRED_DISTRO_FEATURES')
> + required_distro_features = set((d.getVar('REQUIRED_DISTRO_FEATURES') or '').split())
> if required_distro_features:
> - required_distro_features = required_distro_features.split()
> - for f in required_distro_features:
> - if f in distro_features:
> - continue
> - else:
> - raise bb.parse.SkipRecipe("missing required distro feature '%s' (not in DISTRO_FEATURES)" % f)
> + missing = set.difference(required_distro_features, distro_features)
> + if missing:
> + raise bb.parse.SkipRecipe("missing required distro feature%s '%s' (not in DISTRO_FEATURES)" % ('s' if len(missing) > 1 else '', ' '.join(missing)))
>
> - conflict_distro_features = d.getVar('CONFLICT_DISTRO_FEATURES')
> + conflict_distro_features = set((d.getVar('CONFLICT_DISTRO_FEATURES') or '').split())
> if conflict_distro_features:
> - conflict_distro_features = conflict_distro_features.split()
> - for f in conflict_distro_features:
> - if f in distro_features:
> - raise bb.parse.SkipRecipe("conflicting distro feature '%s' (in DISTRO_FEATURES)" % f)
> + conflicts = set.intersection(conflict_distro_features, distro_features)
> + if conflicts:
> + raise bb.parse.SkipRecipe("conflicting distro feature%s '%s' (in DISTRO_FEATURES)" % ('s' if len(conflicts) > 1 else '', ' '.join(conflicts)))
> }
Any comment on this patch? Thanks.
--
Kai Kang
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2018-12-19 1:56 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2018-12-06 13:41 [PATCH 0/1] distro_features_check.bbclass: show all error info at one time kai.kang
2018-12-06 13:41 ` [PATCH 1/1] " kai.kang
2018-12-19 1:53 ` Kang Kai
2018-12-14 2:43 ` [PATCH 0/1] " Kang Kai
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox