diff options
| -rw-r--r-- | meta/classes/copyleft_compliance.bbclass | 21 | 
1 files changed, 18 insertions, 3 deletions
| diff --git a/meta/classes/copyleft_compliance.bbclass b/meta/classes/copyleft_compliance.bbclass index 2fe524b5f3..37ed09e955 100644 --- a/meta/classes/copyleft_compliance.bbclass +++ b/meta/classes/copyleft_compliance.bbclass @@ -16,6 +16,22 @@ COPYLEFT_LICENSE_EXCLUDE ?= 'CLOSED Proprietary'  COPYLEFT_LICENSE_EXCLUDE[type] = 'list'  COPYLEFT_LICENSE_INCLUDE[doc] = 'Space separated list of globs which exclude licenses' +COPYLEFT_RECIPE_TYPE ?= '${@copyleft_recipe_type(d)}' +COPYLEFT_RECIPE_TYPE[doc] = 'The "type" of the current recipe (e.g. target, native, cross)' + +COPYLEFT_RECIPE_TYPES ?= 'target' +COPYLEFT_RECIPE_TYPES[type] = 'list' +COPYLEFT_RECIPE_TYPES[doc] = 'Space separated list of recipe types to include' + +COPYLEFT_AVAILABLE_RECIPE_TYPES = 'target native nativesdk cross crosssdk cross-canadian' +COPYLEFT_AVAILABLE_RECIPE_TYPES[type] = 'list' +COPYLEFT_AVAILABLE_RECIPE_TYPES[doc] = 'Space separated list of available recipe types' + +def copyleft_recipe_type(d): +    for recipe_type in oe.data.typed_value('COPYLEFT_AVAILABLE_RECIPE_TYPES', d): +        if oe.utils.inherits(d, recipe_type): +            return recipe_type +    return 'target'  def copyleft_should_include(d):      """Determine if this recipe's sources should be deployed for compliance""" @@ -23,9 +39,8 @@ def copyleft_should_include(d):      import oe.license      from fnmatch import fnmatchcase as fnmatch -    if oe.utils.inherits(d, 'native', 'nativesdk', 'cross', 'crossdk'): -        # not a target recipe -        return +    if d.getVar('COPYLEFT_RECIPE_TYPE', True) not in oe.data.typed_value('COPYLEFT_RECIPE_TYPES', d): +        return False      include = oe.data.typed_value('COPYLEFT_LICENSE_INCLUDE', d)      exclude = oe.data.typed_value('COPYLEFT_LICENSE_EXCLUDE', d) | 
