diff options
author | Richard Purdie <richard.purdie@linuxfoundation.org> | 2015-08-17 12:12:25 +0100 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2015-08-19 18:05:47 +0100 |
commit | 67a6a4d6c0f060dd3b383aa28195c1c6a8e581d6 (patch) | |
tree | 8b8eadbf4befe869416dc54cd409517aed4889a4 /bitbake | |
parent | 3c3ff928822a525024c7a679a517bcf53af5022f (diff) | |
download | poky-67a6a4d6c0f060dd3b383aa28195c1c6a8e581d6.tar.gz |
bitbake: bitbake-layers: Convert flatten to use collections.bbappends
flatten support currently looks broken since it doesn't appear to
deal with handling "%" support in bbappend file names.
This patch converts it to use collections.get_file_appends() which
correctly handles "%" support.
(Bitbake rev: 0448714c52bc1e9584a5282cffdcaa404fb0618a)
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bitbake')
-rwxr-xr-x | bitbake/bin/bitbake-layers | 44 |
1 files changed, 20 insertions, 24 deletions
diff --git a/bitbake/bin/bitbake-layers b/bitbake/bin/bitbake-layers index 5116e598b3..62b51b0583 100755 --- a/bitbake/bin/bitbake-layers +++ b/bitbake/bin/bitbake-layers | |||
@@ -595,7 +595,7 @@ build results (as the layer priority order has effectively changed). | |||
595 | return layerdir | 595 | return layerdir |
596 | return None | 596 | return None |
597 | 597 | ||
598 | appended_recipes = [] | 598 | applied_appends = [] |
599 | for layer in layers: | 599 | for layer in layers: |
600 | overlayed = [] | 600 | overlayed = [] |
601 | for f in self.bbhandler.cooker.collection.overlayed.iterkeys(): | 601 | for f in self.bbhandler.cooker.collection.overlayed.iterkeys(): |
@@ -623,31 +623,27 @@ build results (as the layer priority order has effectively changed). | |||
623 | logger.warn('Overwriting file %s', fdest) | 623 | logger.warn('Overwriting file %s', fdest) |
624 | bb.utils.copyfile(f1full, fdest) | 624 | bb.utils.copyfile(f1full, fdest) |
625 | if ext == '.bb': | 625 | if ext == '.bb': |
626 | if f1 in self.bbhandler.cooker.collection.appendlist: | 626 | for append in self.bbhandler.cooker.collection.get_file_appends(f1full): |
627 | appends = self.bbhandler.cooker.collection.appendlist[f1] | 627 | if layer_path_match(append): |
628 | if appends: | 628 | logger.plain(' Applying append %s to %s' % (append, fdest)) |
629 | logger.plain(' Applying appends to %s' % fdest ) | 629 | self.apply_append(append, fdest) |
630 | for appendname in appends: | 630 | applied_appends.append(append) |
631 | if layer_path_match(appendname): | ||
632 | self.apply_append(appendname, fdest) | ||
633 | appended_recipes.append(f1) | ||
634 | 631 | ||
635 | # Take care of when some layers are excluded and yet we have included bbappends for those recipes | 632 | # Take care of when some layers are excluded and yet we have included bbappends for those recipes |
636 | for recipename in self.bbhandler.cooker.collection.appendlist.iterkeys(): | 633 | for b in self.bbhandler.cooker.collection.bbappends: |
637 | if recipename not in appended_recipes: | 634 | (recipename, appendname) = b |
638 | appends = self.bbhandler.cooker.collection.appendlist[recipename] | 635 | if appendname not in applied_appends: |
639 | first_append = None | 636 | first_append = None |
640 | for appendname in appends: | 637 | layer = layer_path_match(appendname) |
641 | layer = layer_path_match(appendname) | 638 | if layer: |
642 | if layer: | 639 | if first_append: |
643 | if first_append: | 640 | self.apply_append(appendname, first_append) |
644 | self.apply_append(appendname, first_append) | 641 | else: |
645 | else: | 642 | fdest = appendname[len(layer):] |
646 | fdest = appendname[len(layer):] | 643 | fdest = os.path.normpath(os.sep.join([outputdir,fdest])) |
647 | fdest = os.path.normpath(os.sep.join([outputdir,fdest])) | 644 | bb.utils.mkdirhier(os.path.dirname(fdest)) |
648 | bb.utils.mkdirhier(os.path.dirname(fdest)) | 645 | bb.utils.copyfile(appendname, fdest) |
649 | bb.utils.copyfile(appendname, fdest) | 646 | first_append = fdest |
650 | first_append = fdest | ||
651 | 647 | ||
652 | # Get the regex for the first layer in our list (which is where the conf/layer.conf file will | 648 | # Get the regex for the first layer in our list (which is where the conf/layer.conf file will |
653 | # have come from) | 649 | # have come from) |
@@ -723,7 +719,7 @@ build results (as the layer priority order has effectively changed). | |||
723 | Lists recipes with the bbappends that apply to them as subitems. | 719 | Lists recipes with the bbappends that apply to them as subitems. |
724 | """ | 720 | """ |
725 | self.init_bbhandler() | 721 | self.init_bbhandler() |
726 | if not self.bbhandler.cooker.collection.appendlist: | 722 | if not self.bbhandler.cooker.collection.bbappends: |
727 | logger.plain('No append files found') | 723 | logger.plain('No append files found') |
728 | return 0 | 724 | return 0 |
729 | 725 | ||