Skip to content

Commit

Permalink
Sequence zap_regen_all to generate .matter first. (#26806)
Browse files Browse the repository at this point in the history
* Sequence zap_regen_all to generate .matter first.

We have codegen depending on .matter. This PR makes
the .matter file generation run first and then the
rest second when running parallel builds.

* Restyled by autopep8

---------

Co-authored-by: Restyled.io <[email protected]>
  • Loading branch information
2 people authored and pull[bot] committed Nov 1, 2023
1 parent 825bb87 commit 9335929
Showing 1 changed file with 20 additions and 3 deletions.
23 changes: 20 additions & 3 deletions scripts/tools/zap_regen_all.py
Original file line number Diff line number Diff line change
Expand Up @@ -107,6 +107,10 @@ def __init__(self, zap_config, template, output_dir=None):
else:
self.output_dir = None

@property
def is_matter_idl_generation(self):
return (self.output_dir is None)

def distinct_output(self):
if not self.template and not self.output_dir:
# Matter IDL templates have no template/output dir as they go with the
Expand Down Expand Up @@ -463,9 +467,22 @@ def main():
if args.parallel:
# Ensure each zap run is independent
os.environ['ZAP_TEMPSTATE'] = '1'
with multiprocessing.Pool() as pool:
for timing in pool.imap_unordered(_ParallelGenerateOne, targets):
timings.append(timing)

# There is a sequencing here:
# - ZAP will generate ".matter" files
# - various codegen may generate from ".matter" files (like java)
# We split codegen into two generations to not be racy
first, second = [], []
for target in targets:
if isinstance(target, ZAPGenerateTarget) and target.is_matter_idl_generation:
first.append(target)
else:
second.append(target)

for items in [first, second]:
with multiprocessing.Pool() as pool:
for timing in pool.imap_unordered(_ParallelGenerateOne, items):
timings.append(timing)
else:
for target in targets:
timings.append(target.generate())
Expand Down

0 comments on commit 9335929

Please sign in to comment.