ATLAS Offline Software
Loading...
Searching...
No Matches
eventloop_grid_merge.cxx
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
3*/
4
9#include <TList.h>
10#include <TSystem.h>
11#include <TFile.h>
12#include <regex>
13
14void try_exec(const std::string& cmd)
15{
16 if (gSystem->Exec(cmd.c_str()) != 0) {
17 RCU_THROW_MSG("command failed: " + cmd);
18 }
19}
20
21int main (int argc, char **argv)
22{
23 using namespace asg::msgUserCode;
25
27
28 if (argc != 4)
29 {
30 ANA_MSG_ERROR ("invalid number of arguments");
31 return -1;
32 }
33
34 std::string jobDefFile = argv[1];
35 std::string output = argv[2];
36 std::string input = argv[3];
37
38 std::string type = "DEFAULT";
39 std::string mergeCmd = "";
40
41 TFile jd(jobDefFile.c_str());
42
43 std::unique_ptr<TList> outs{dynamic_cast<TList*>(jd.Get("outputs"))};
44 if (outs.get() == nullptr) {
45 RCU_THROW_MSG("Unable to get list of output streams");
46 }
47 TIter itr(outs.get());
48 TObject* obj;
49 while ((obj = itr())) {
50 EL::OutputStream* os = dynamic_cast<EL::OutputStream*>(obj);
51 if (std::regex_match(output, std::regex(os->label() + "\\.root.*")) ||
52 std::regex_match(output, std::regex(".*\\." + os->label() + "\\.root.*")))
53 {
55 mergeCmd = os->options()->castString(EL::OutputStream::optMergeCmd, "", SH::MetaObject::CAST_NOCAST_DEFAULT);
56 break;
57 }
58 }
59
60 if (mergeCmd.empty()) {
61 if (type == "xAOD") {
62 mergeCmd = "xAODMerge -s";
63 } else if (type == "xAODNoMeta") {
64 mergeCmd = "xAODMerge";
65 } else {
66 mergeCmd = "hadd -f";
67 }
68 }
69 mergeCmd += " " + output + " " + input;
70 try_exec(mergeCmd);
71}
macros for messaging and checking status codes
#define ANA_MSG_ERROR(xmsg)
Macro printing error messages.
#define ANA_CHECK(EXP)
check whether the given expression was successful
#define ANA_CHECK_SET_TYPE(TYPE)
set the type for ANA_CHECK to report failures
#define RCU_THROW_MSG(message)
Definition PrintMsg.h:58
static const std::string optType
static const std::string optMergeCmd
@ CAST_NOCAST_DEFAULT
cast and return the default value if the input has the wrong type
Definition MetaObject.h:78
void try_exec(const std::string &cmd)
int main()
Definition hello.cxx:18
StatusCode Init(const char *appname)
Function initialising ROOT/PyROOT for using the ATLAS EDM.
Definition Init.cxx:31