vertex finder moved from GlobalESDConverter to a separate component GlobalVertexer
[u/mrichter/AliRoot.git] / HLT / global / AliHLTGlobalAgent.cxx
1 // $Id$
2
3 //**************************************************************************
4 //* This file is property of and copyright by the ALICE HLT Project        * 
5 //* ALICE Experiment at CERN, All rights reserved.                         *
6 //*                                                                        *
7 //* Primary Authors: Matthias Richter <Matthias.Richter@ift.uib.no>        *
8 //*                  for The ALICE HLT Project.                            *
9 //*                                                                        *
10 //* Permission to use, copy, modify and distribute this software and its   *
11 //* documentation strictly for non-commercial purposes is hereby granted   *
12 //* without fee, provided that the above copyright notice appears in all   *
13 //* copies and that both the copyright notice and this permission notice   *
14 //* appear in the supporting documentation. The authors make no claims     *
15 //* about the suitability of this software for any purpose. It is          *
16 //* provided "as is" without express or implied warranty.                  *
17 //**************************************************************************
18
19 /** @file   AliHLTGlobalAgent.cxx
20     @author Matthias Richter
21     @date   
22     @brief  Agent of the libAliHLTGlobal library
23 */
24
25 #include <cassert>
26 #include "AliHLTGlobalAgent.h"
27 #include "AliHLTConfigurationHandler.h"
28 #include "TObjString.h"
29 #include "TObjArray.h"
30
31 // header files of library components
32 #include "AliHLTGlobalTrackMergerComponent.h"
33 #include "AliHLTGlobalEsdConverterComponent.h"
34 #include "AliHLTGlobalVertexerComponent.h"
35 #include "AliHLTV0HistoComponent.h"
36
37 /** global instance for agent registration */
38 AliHLTGlobalAgent gAliHLTGlobalAgent;
39
40 /** ROOT macro for the implementation of ROOT specific class methods */
41 ClassImp(AliHLTGlobalAgent)
42
43 AliHLTGlobalAgent::AliHLTGlobalAgent()
44   :
45   AliHLTModuleAgent("Global")
46 {
47   // see header file for class documentation
48   // or
49   // refer to README to build package
50   // or
51   // visit http://web.ift.uib.no/~kjeks/doc/alice-hlt
52 }
53
54 AliHLTGlobalAgent::~AliHLTGlobalAgent()
55 {
56   // see header file for class documentation
57 }
58
59 int AliHLTGlobalAgent::RegisterComponents(AliHLTComponentHandler* pHandler) const
60 {
61   // see header file for class documentation
62   assert(pHandler);
63   if (!pHandler) return -EINVAL;
64   pHandler->AddComponent(new AliHLTGlobalTrackMergerComponent);
65   pHandler->AddComponent(new AliHLTGlobalEsdConverterComponent);
66   pHandler->AddComponent(new AliHLTGlobalVertexerComponent);
67   pHandler->AddComponent(new AliHLTV0HistoComponent );
68   return 0;
69 }
70
71 int AliHLTGlobalAgent::CreateConfigurations(AliHLTConfigurationHandler* pHandler,
72                                             AliRawReader* /*rawReader*/,
73                                             AliRunLoader* /*runloader*/) const
74 {
75   // see header file for class documentation
76   if (!pHandler) return -EINVAL;
77
78   /////////////////////////////////////////////////////////////////////////////////////
79   //
80   // assembly of the global ESD
81
82   // define the inputs to the global ESD
83   TString esdInputs="TPC-globalmerger TPC-mcTrackMarker";
84
85   // check for the availibility
86   TObjArray* pTokens=esdInputs.Tokenize(" ");
87   esdInputs="";
88   if (pTokens) {
89     for (int n=0; n<pTokens->GetEntriesFast(); n++) {
90       TString module=((TObjString*)pTokens->At(n))->GetString();
91       if (pHandler->FindConfiguration(module.Data())) {
92         esdInputs+=module;
93         esdInputs+=" ";
94       }
95     }
96     delete pTokens;
97   }
98
99   if (esdInputs.Length()>0) {
100     HLTInfo("Configuring inputs to global HLT ESD: %s", esdInputs.Data());
101   } else {
102     HLTWarning("No inputs to global HLT ESD found");
103   }
104
105   pHandler->CreateConfiguration("GLOBAL-esd-converter", "GlobalEsdConverter", esdInputs.Data(), "");
106   
107   return 0;
108 }
109
110 const char* AliHLTGlobalAgent::GetReconstructionChains(AliRawReader* /*rawReader*/,
111                                                     AliRunLoader* runloader) const
112 {
113   // see header file for class documentation
114   if (runloader) {
115     // reconstruction chains for AliRoot simulation
116     // Note: run loader is only available while running embedded into
117     // AliRoot simulation
118     return "GLOBAL-esd-converter";
119   }
120   return NULL;
121 }
122
123 const char* AliHLTGlobalAgent::GetRequiredComponentLibraries() const
124 {
125   // see header file for class documentation
126
127   return "libAliHLTUtil.so libAliHLTRCU.so libAliHLTTPC.so libAliHLTITS.so";
128 }
129
130 int AliHLTGlobalAgent::GetHandlerDescription(AliHLTComponentDataType /*dt*/,
131                                              AliHLTUInt32_t /*spec*/,
132                                              AliHLTOUTHandlerDesc& /*desc*/) const
133 {
134   // see header file for class documentation
135
136   return 0;
137 }
138
139 AliHLTOUTHandler* AliHLTGlobalAgent::GetOutputHandler(AliHLTComponentDataType /*dt*/,
140                                                       AliHLTUInt32_t /*spec*/)
141 {
142   // see header file for class documentation
143
144   return NULL;
145 }
146
147 int AliHLTGlobalAgent::DeleteOutputHandler(AliHLTOUTHandler* pInstance)
148 {
149   // see header file for class documentation
150   if (pInstance==NULL) return -EINVAL;
151
152   return 0;
153 }