2 Copyright (C) 2002-2021 CERN for the benefit of the ATLAS collaboration
4 #include "ExpressionEvaluation/SGxAODProxyLoader.h"
5 #include "ExpressionEvaluation/SGNTUPProxyLoader.h"
6 #include "ExpressionEvaluation/MultipleProxyLoader.h"
7 #include "ExpressionEvaluation/ExpressionParser.h"
8 #include "ExpressionParserUser.h"
11 namespace ExpressionParsing {
12 template <unsigned short NUM_PARSER>
13 std::array< std::unique_ptr<ExpressionParsing::ExpressionParser>, NUM_PARSER >
14 MultiParserHelper<NUM_PARSER>::createParser(ExpressionParsing::IProxyLoader &proxy_loader, const std::vector< std::string> &selection_string, unsigned short num_parser) {
15 if (selection_string.size() != num_parser) { throw std::logic_error("Dimension mismtach between selection strings and number of parsers."); }
16 std::array< std::unique_ptr<ExpressionParsing::ExpressionParser>,NUM_PARSER > parser;
18 for (const std::string &a_selection_string : selection_string) {
19 assert( idx < parser.size() );
20 parser[idx]=std::make_unique<ExpressionParsing::ExpressionParser>(&proxy_loader );
21 parser[idx]->loadExpression( a_selection_string );
27 template <unsigned short NUM_PARSER>
28 std::vector<std::string> MultiParserHelper<NUM_PARSER>::getVariables( const std::array< std::unique_ptr<ExpressionParsing::ExpressionParser>, NUM_PARSER > &parser ) {
29 std::vector<std::string> var_names;
30 for (const std::unique_ptr<ExpressionParsing::ExpressionParser> &a_parser : parser) {
31 std::vector<std::string> tmp_var_names ( a_parser->getVariables() );
32 var_names.reserve( var_names.size() + tmp_var_names.size());
33 for (const std::string &a_name : tmp_var_names ) {
34 if (std::find(var_names.begin(),var_names.end(),a_name) == var_names.end()) {
35 var_names.push_back( a_name );
42 std::unique_ptr<ExpressionParsing::ExpressionParser>
43 SingleParserHelper::createParser(ExpressionParsing::IProxyLoader &proxy_loader, const std::string &selection_string, [[maybe_unused]] unsigned short num_parser) {
44 assert( num_parser == 1);
45 std::unique_ptr<ExpressionParsing::ExpressionParser>
46 parser = std::make_unique<ExpressionParsing::ExpressionParser>(&proxy_loader );
47 parser->loadExpression( selection_string );
51 inline std::vector<std::string> SingleParserHelper::getVariables( const std::unique_ptr<ExpressionParsing::ExpressionParser> &parser ) {
52 return parser->getVariables();
57 template <class T_Base, unsigned short const NUM_PARSER>
58 StatusCode ExpressionParserUserBase<T_Base,NUM_PARSER>::_initializeParser(const ExpressionParsing::SelectionArg<NUM_PARSER> &selection_string,
59 ExpressionParsing::AppendLoaderFunc pre_xaod_loader,
60 ExpressionParsing::AppendLoaderFunc post_xaod_loader)
62 std::unique_ptr<ExpressionParsing::MultipleProxyLoader> proxyLoaders = std::make_unique<ExpressionParsing::MultipleProxyLoader>();
64 StatusCode sc = pre_xaod_loader(*proxyLoaders);
65 if (sc.isFailure()) return sc;
67 m_xAODProxyLoader=new ExpressionParsing::SGxAODProxyLoader(this->evtStore(), this->msgLvl(MSG::DEBUG));
68 proxyLoaders->push_back(m_xAODProxyLoader);
70 sc = post_xaod_loader(*proxyLoaders);
71 if (sc.isFailure()) return sc;
73 // load the expressions
74 m_proxyLoaders.reset( proxyLoaders.release() );
75 m_parser = ExpressionParsing::ParserHelper<NUM_PARSER>::createParser( *m_proxyLoaders, selection_string, NUM_PARSER );
79 template <class T_Base, unsigned short const NUM_PARSER>
80 StatusCode ExpressionParserUserBase<T_Base, NUM_PARSER>::finalizeParser() {
82 return StatusCode::SUCCESS;
85 template <class T_Base, unsigned short const NUM_PARSER>
86 bool ExpressionParserUserBase<T_Base,NUM_PARSER>::updateDataNeeds(const std::vector<const DataObjID*> &input_data_in,
87 const std::vector<const DataObjID*> &output_data_in,
88 std::vector<Gaudi::DataHandle *> &new_input_handles,
89 std::vector<Gaudi::DataHandle *> &new_output_handles) {
90 if (!m_xAODProxyLoader) return false;
91 std::vector<std::string> var_names = ExpressionParsing::ParserHelper<NUM_PARSER>::getVariables(m_parser);
93 auto parent = ExpressionParsing::SGxAODProxyLoader::wrapParent(this);
94 return m_xAODProxyLoader->updateDataDependencies(parent,var_names, m_renounce, input_data_in, output_data_in,new_input_handles,new_output_handles);
97 template <class T_Base, unsigned short const NUM_PARSER>
98 bool ExpressionParserUserBase<T_Base,NUM_PARSER>::renounceInput( const DataObjID& output_data_id) {
99 if (m_xAODProxyLoader) {
100 std::vector<std::string> var_names = ExpressionParsing::ParserHelper<NUM_PARSER>::getVariables(m_parser);
102 for (const std::string &var : var_names) {
103 if (output_data_id.key().find(var) != std::string::npos) {
104 m_renounce.push_back(output_data_id.key());
108 return T_Base::renounceInput(output_data_id);
111 template <class T_Base, unsigned short const NUM_PARSER>
112 StatusCode ExpressionParserUser<T_Base, NUM_PARSER>::initializeParser(const ExpressionParsing::SelectionArg<NUM_PARSER> &selection_string) {
113 return this->_initializeParser(selection_string,
114 ExpressionParsing::NoLoaderFunc,
115 [this](ExpressionParsing::MultipleProxyLoader &proxy_loaders) -> StatusCode {
116 proxy_loaders.push_back(new ExpressionParsing::SGNTUPProxyLoader(this->evtStore()));
117 return StatusCode::SUCCESS;