4 from PyJobTransforms.CommonRunArgsToFlags
import commonRunArgsToFlags
5 from PyJobTransforms.TransformUtils
import processPreExec, processPreInclude, processPostExec, processPostInclude
8 from AthenaCommon
import JobProperties
9 JobProperties.jobPropertiesDisallowed =
True
13 from AthenaCommon.Logging
import logging
14 log = logging.getLogger(
"EVNTMerge")
15 log.info(
"****************** STARTING EVNT MERGING *****************")
17 log.info(
"**** Transformation run arguments")
18 log.info(
str(runArgs))
20 log.info(
"**** Setting-up configuration flags")
21 from AthenaConfiguration.AllConfigFlags
import initConfigFlags
24 from AthenaConfiguration.Enums
import ProductionStep, MetadataCategory
25 flags.Common.ProductionStep = ProductionStep.Generation
29 if hasattr(runArgs,
"inputEVNTFile"):
30 flags.Input.Files = runArgs.inputEVNTFile
32 raise RuntimeError(
"No input EVNT file defined")
34 if hasattr(runArgs,
"outputEVNT_MRGFile"):
35 if runArgs.outputEVNT_MRGFile ==
"None":
36 flags.Output.EVNTFileName =
""
39 flags.Output.EVNTFileName = runArgs.outputEVNT_MRGFile
41 raise RuntimeError(
"No outputEVNT_MRGFile defined")
55 from AthenaConfiguration.MainServicesConfig
import MainServicesCfg
58 from AthenaPoolCnvSvc.PoolReadConfig
import PoolReadCfg
61 from OutputStreamAthenaPool.OutputStreamConfig
import OutputStreamCfg
62 cfg.merge(
OutputStreamCfg(flags,
"EVNT", disableEventTag =
True, takeItemsFromInput =
True, extendProvenanceRecord =
False))
65 from xAODMetaDataCnv.InfileMetaDataConfig
import SetupMetaDataForStreamCfg
72 createMetadata=[MetadataCategory.IOVMetaData],
83 from PyUtils.AMITagHelperConfig
import AMITagCfg
87 from AthenaConfiguration.AutoConfigFlags
import GetFileMD
88 hepmc_version =
GetFileMD(flags.Input.Files).
get(
"hepmc_version",
None)
89 if hepmc_version
is not None:
90 if hepmc_version ==
"2":
91 hepmc_version =
"HepMC2"
92 elif hepmc_version ==
"3":
93 hepmc_version =
"HepMC3"
94 log.info(
"Input file was produced with %s", hepmc_version)
95 from EventInfoMgt.TagInfoMgrConfig
import TagInfoMgrCfg
96 cfg.merge(
TagInfoMgrCfg(flags, tagValuePairs={
"hepmc_version": hepmc_version}))
102 log.info(
"Ran EVNTMerge_tf in " +
str(time.time()-tic) +
" seconds")
104 sys.exit(
not sc.isSuccess())