#include <TFile.h>
#include <TClass.h>
#include <TTree.h>
+#include <TROOT.h>
#include "AliAnalysisTask.h"
#include "AliAnalysisDataSlot.h"
}
AliAnalysisDataSlot::EnableBranch(bname, tree);
}
+
+//______________________________________________________________________________
+void AliAnalysisTask::FinishTaskOutput()
+{
+// Optional method that is called in SlaveTerminate phase.
+// Used for calling aditional methods just after the last event was processed ON
+// THE WORKING NODE. The call is made also in local case.
+// Do NOT delete output objects here since they will have to be sent for
+// merging in PROOF mode - use class destructor for cleanup.
+}
//______________________________________________________________________________
void AliAnalysisTask::ConnectInputData(Option_t *)
return NULL;
}
// We allow file opening also on the slaves (AG)
-// AliAnalysisManager *mgr = AliAnalysisManager::GetAnalysisManager();
-// if (!mgr || mgr->GetAnalysisType()==AliAnalysisManager::kProofAnalysis) return;
+ AliAnalysisManager *mgr = AliAnalysisManager::GetAnalysisManager();
AliAnalysisDataContainer *cont = GetOutputSlot(iout)->GetContainer();
TFile *f = NULL;
- if (strlen(cont->GetFileName())) f = new TFile(cont->GetFileName(), option);
- if (f && !f->IsZombie()) return f;
+ if (!strlen(cont->GetFileName())) {
+ Error("OpenFile", "No file name specified for container %s", cont->GetName());
+ return f;
+ }
+ if (mgr->GetAnalysisType()==AliAnalysisManager::kProofAnalysis && cont->IsSpecialOutput())
+ f = mgr->OpenProofFile(cont->GetFileName(),option);
+ else {
+ // Check first if the file is already opened
+ f = (TFile*)gROOT->GetListOfFiles()->FindObject(cont->GetFileName());
+ if (!f) f = new TFile(cont->GetFileName(), option);
+ }
+ if (f && !f->IsZombie()) {
+ cont->SetFile(f);
+ return f;
+ }
+ cont->SetFile(NULL);
return NULL;
}
return kTRUE;
}
+//______________________________________________________________________________
+Bool_t AliAnalysisTask::NotifyBinChange()
+{
+// Overload this IF you need to treat bin change in event mixing.
+ return kTRUE;
+}
+
//______________________________________________________________________________
void AliAnalysisTask::Terminate(Option_t *)
{