auto/config: Rewrite add_task to use a Python script that cribs the logic from lp:ubuntu-archive-publishing's generate_extra_overrides.py. This means we can avoid some dubious hacks around seeding snaps and no longer depend on the Task headers in the archive.
parent
db029cd387
commit
a65c181596
@ -0,0 +1,84 @@
|
|||||||
|
#!/usr/bin/python3
|
||||||
|
|
||||||
|
import argparse
|
||||||
|
import glob
|
||||||
|
import os
|
||||||
|
import re
|
||||||
|
|
||||||
|
p = argparse.ArgumentParser()
|
||||||
|
p.add_argument('output_dir')
|
||||||
|
p.add_argument('flavour')
|
||||||
|
p.add_argument('task')
|
||||||
|
p.add_argument('what', choices=['packages', 'snaps'])
|
||||||
|
args = p.parse_args()
|
||||||
|
|
||||||
|
if args.what == 'snaps':
|
||||||
|
ext = '.snaps'
|
||||||
|
else:
|
||||||
|
ext = ''
|
||||||
|
|
||||||
|
|
||||||
|
# begin copy/paste from ubuntu-archive-publishing's generate_extra_overrides.
|
||||||
|
def parseTaskHeaders(seedtext):
|
||||||
|
"""Parse a seed for Task headers.
|
||||||
|
|
||||||
|
seedtext is a file-like object. Return a dictionary of Task headers,
|
||||||
|
with keys canonicalised to lower-case.
|
||||||
|
"""
|
||||||
|
task_headers = {}
|
||||||
|
task_header_regex = re.compile(
|
||||||
|
r"task-(.*?):(.*)", flags=re.IGNORECASE)
|
||||||
|
for line in seedtext:
|
||||||
|
match = task_header_regex.match(line)
|
||||||
|
if match is not None:
|
||||||
|
key, value = match.groups()
|
||||||
|
task_headers[key.lower()] = value.strip()
|
||||||
|
return task_headers
|
||||||
|
|
||||||
|
|
||||||
|
def getTaskName(task_headers, flavour, seedname, primary_flavour):
|
||||||
|
"""Work out the name of the Task to be generated from this seed.
|
||||||
|
|
||||||
|
If there is a Task-Name header, it wins; otherwise, seeds with a
|
||||||
|
Task-Per-Derivative header are honoured for all flavours and put in
|
||||||
|
an appropriate namespace, while other seeds are only honoured for
|
||||||
|
the first flavour and have archive-global names.
|
||||||
|
"""
|
||||||
|
if "name" in task_headers:
|
||||||
|
return task_headers["name"]
|
||||||
|
elif "per-derivative" in task_headers:
|
||||||
|
return "%s-%s" % (flavour, seedname)
|
||||||
|
elif primary_flavour:
|
||||||
|
return seedname
|
||||||
|
else:
|
||||||
|
return None
|
||||||
|
|
||||||
|
|
||||||
|
def getTaskSeeds(task_headers, seedname):
|
||||||
|
"""Return the list of seeds used to generate a task from this seed.
|
||||||
|
|
||||||
|
The list of packages in this task comes from this seed plus any
|
||||||
|
other seeds listed in a Task-Seeds header.
|
||||||
|
"""
|
||||||
|
scan_seeds = set([seedname])
|
||||||
|
if "seeds" in task_headers:
|
||||||
|
scan_seeds.update(task_headers["seeds"].split())
|
||||||
|
return sorted(scan_seeds)
|
||||||
|
# end copy/paste from ubuntu-archive-publishing's generate_extra_overrides.
|
||||||
|
|
||||||
|
|
||||||
|
for seedtext in glob.glob(f'{args.output_dir}/*.seedtext'):
|
||||||
|
hs = parseTaskHeaders(open(seedtext))
|
||||||
|
if not hs:
|
||||||
|
continue
|
||||||
|
seedname = os.path.splitext(os.path.basename(seedtext))[0]
|
||||||
|
tn = getTaskName(hs, args.flavour, seedname, args.flavour == 'ubuntu')
|
||||||
|
if tn != args.task:
|
||||||
|
continue
|
||||||
|
for seed in getTaskSeeds(hs, seedname):
|
||||||
|
for line in open(f'{args.output_dir}/{seed}{ext}'):
|
||||||
|
if re.match('^[a-z0-9]', line):
|
||||||
|
print(line.split()[0])
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
raise Exception("did not find task %r" % (args.task,))
|
Loading…
Reference in new issue