14 Create a full set of consistent geometry payloads for nominal geometry, phase 2
15 geometry, and early phase 3 gometry from XML files.
17 Optionally one can give a list of payload names to keep only a subset of payloads
29 interested = sys.argv[1:]
32 shutil.rmtree(
"localdb", ignore_errors=
True)
36 phase3.add_module(
"EventInfoSetter")
37 phase3.add_module(
"Gearbox")
38 phase3.add_module(
"Geometry", createPayloads=
True, payloadIov=[0, 0, 0, -1])
42 postLS1 = basf2.Path()
43 postLS1.add_module(
"EventInfoSetter")
44 postLS1.add_module(
"Gearbox")
45 postLS1.add_module(
"Geometry", createPayloads=
True, payloadIov=[1004, 0, 1004, -1])
50 phase2_detectors =
"BeamPipe PXD SVD ServiceGapsMaterial MICROTPC PINDIODE BEAMABORT HE3TUBE CLAWS FANGS PLUME QCSMONITOR".split()
51 phase2 = basf2.create_path()
52 phase2.add_module(
"EventInfoSetter")
53 phase2.add_module(
"Gearbox")
54 phase2.add_module(
"Geometry", createPayloads=
True, payloadIov=[1002, 0, 1002, -1],
55 excludedComponents=[
"BeamPipe",
"PXD",
"SVD",
"VXDService",
"ServiceGapsMaterial"],
56 additionalComponents=[e +
"-phase2" for e
in phase2_detectors])
61 early3.add_module(
"EventInfoSetter")
62 early3.add_module(
"Gearbox")
63 early3.add_module(
"Geometry", createPayloads=
True, payloadIov=[1003, 0, 1003, -1],
64 excludedComponents=[
'PXD',
"ServiceGapsMaterial"],
65 additionalComponents=[
'PXD-earlyPhase3',
'ServiceGapsMaterial-earlyPhase3'])
71 phase2 = [
"GeoConfiguration",
"PXDGeometryPar",
"SVDGeometryPar",
"BeamPipeGeo",
"ServiceGapsMaterialsPar"]
74 early3 = [
"PXDGeometryPar"]
76 line_match = re.compile(
r"^dbstore/(.*?) ([0-9a-f]+) ([0-9\-,]*)$")
78 with open(
"localdb/database.txt")
as dbfile:
80 match = line_match.search(line)
81 name, revision, iov = match.groups()
83 if interested
and name
not in interested:
86 iov = tuple(int(e)
for e
in iov.split(
','))
89 keep.add((name, str(revision)))
90 database_content.append(f
'dbstore/{name} {revision} 0,0,0,-1\n')
91 if name
not in early3:
92 database_content.append(f
'dbstore/{name} {revision} 1003,0,1003,-1\n')
97 elif iov[0] == 1002
and name
not in phase2:
99 elif iov[0] == 1003
and name
not in early3:
103 keep.add((name, str(revision)))
104 database_content.append(line)
107 database_content.sort()
108 with open(
"localdb/database.txt",
"w")
as dbfile:
109 dbfile.writelines(database_content)
112 for filename
in os.scandir(
'localdb/'):
113 match = re.match(
r"dbstore_(.*?)_rev_(\d*).root", filename.name)
116 if match
and match.groups()
not in keep:
117 print(f
"Removing {filename.name}: not needed")
118 os.unlink(filename.path)
120 print(f
"Normalizing {filename.name} as '{match.group(1)}'")
121 subprocess.call([
"b2file-normalize",
"-i",
"-n", match.group(1), filename.path])
def safe_process(*args, **kwargs)