diff options
author | Tristan Van Berkom <tristan.vanberkom@codethink.co.uk> | 2017-11-20 19:40:49 +0900 |
---|---|---|
committer | Tristan Van Berkom <tristan.vanberkom@codethink.co.uk> | 2017-11-20 21:01:25 +0900 |
commit | d0ae7a5d2a8c51a11c95f517c3503e7311e2f524 (patch) | |
tree | b42b443fd7de8d37642ff001b02a00076b731f24 /buildstream/plugins | |
parent | 900ffde4ceee1393d7ff5d6695e589f7773c0ceb (diff) | |
download | buildstream-d0ae7a5d2a8c51a11c95f517c3503e7311e2f524.tar.gz |
plugins/elements/compose.py: post merge fixing of compose element
o Some things changed in master since this patch, notably the
keyword only arguments have changed
o Enhanced the user feedback to mention removed, added and modified
files resulting from running integration
o Dont silence messages while integrating the sandbox
Diffstat (limited to 'buildstream/plugins')
-rw-r--r-- | buildstream/plugins/elements/compose.py | 46 |
1 files changed, 27 insertions, 19 deletions
diff --git a/buildstream/plugins/elements/compose.py b/buildstream/plugins/elements/compose.py index 2d6a94d47..6acd8d5d4 100644 --- a/buildstream/plugins/elements/compose.py +++ b/buildstream/plugins/elements/compose.py @@ -97,14 +97,14 @@ class ComposeElement(Element): with self.timed_activity("Staging dependencies", silent_nested=True): self.stage_dependency_artifacts(sandbox, Scope.BUILD) - split = set() + manifest = set() if require_split: with self.timed_activity("Computing split", silent_nested=True): for dep in self.dependencies(Scope.BUILD): - files = dep.compute_manifest(self.include, - self.exclude, - self.include_orphans) - split.update(files) + files = dep.compute_manifest(include=self.include, + exclude=self.exclude, + orphans=self.include_orphans) + manifest.update(files) # Make a snapshot of all the files. basedir = sandbox.get_directory() @@ -112,36 +112,44 @@ class ComposeElement(Element): f: getmtime(os.path.join(basedir, f)) for f in utils.list_relative_paths(basedir) } - integration_files = [] + modified_files = [] removed_files = [] + added_files = [] # Run any integration commands provided by the dependencies # once they are all staged and ready if self.integration: - with self.timed_activity("Integrating sandbox", silent_nested=True): + with self.timed_activity("Integrating sandbox"): for dep in self.dependencies(Scope.BUILD): dep.integrate(sandbox) if require_split: - integration_files = [ - path for path in utils.list_relative_paths(basedir) - if (snapshot.get(path) is None or - snapshot[path] != getmtime(os.path.join(basedir, path))) - ] + + # Calculate added modified files + for path in utils.list_relative_paths(basedir): + if snapshot.get(path) is None: + added_files.append(path) + elif snapshot[path] != getmtime(os.path.join(basedir, path)): + modified_files.append(path) + + # Calculate removed files removed_files = [ - path for path in split + path for path in manifest if not os.path.lexists(os.path.join(basedir, path)) ] - self.info("Integration effected {} files and removed {} files" - .format(len(integration_files), len(removed_files))) + self.info("Integration modified {}, added {} and removed {} files" + .format(len(modified_files), len(added_files), len(removed_files))) # The remainder of this is expensive, make an early exit if # we're not being selective about what is to be included. if not require_split: return '/' - split.update(integration_files) - split.difference_update(removed_files) + # Do we want to force include files which were modified by + # the integration commands, even if they were not added ? + # + manifest.update(added_files) + manifest.difference_update(removed_files) # XXX We should be moving things outside of the build sandbox # instead of into a subdir. The element assemble() method should @@ -171,8 +179,8 @@ class ComposeElement(Element): detail = "\n".join(lines) with self.timed_activity("Creating composition", detail=detail, silent_nested=True): - self.info("Composing {} files".format(len(split))) - utils.link_files(basedir, installdir, split) + self.info("Composing {} files".format(len(manifest))) + utils.link_files(basedir, installdir, files=manifest) # And we're done return os.path.join(os.sep, 'buildstream', 'install') |