1 void MakeAllDETsResMisAlignment(Char_t* CDBstorage = "local://$HOME/Residual"){
2 // Make residual misalignment objects for all detectors
3 // Pass different "CDBstorage" argument if needed (e.g. to fill
4 // conditions' data base on alien) or set it to null string to have
5 // the objects saved locally on file
6 // This macro defines the default name and place for the detector-macros
7 // in charge of producing the full misalignment objects as
8 // $ALICE_ROOT/DET/MakeDETResidualMisAlignment.C
10 TString strStorage(CDBstorage);
11 if(strStorage.IsNull()){
12 gSystem->Setenv("$TOCDB","kFALSE");
14 gSystem->Setenv("$TOCDB","kTRUE");
15 gSystem->Setenv("$STORAGE",strStorage.Data());
16 gSystem->Setenv("$ARVERSION","v4-04-Release");
19 // if not already present, create geometry file needed by those detectors
20 // producing their objects in the local RS
21 if(gSystem->AccessPathName("./geometry.root")){
23 gGeoManager->Export("geometry.root");
25 TGeoManager::Import("geometry.root");
28 TString dets="EMCAL,FMD,ITS,MUON,PHOS,PMD,HMPID,T0,TOF,TPC,TRD,VZERO,ZDC";
29 TObjArray *detArray = dets.Tokenize(',');
32 TString exec_det_macro;
34 while((ostr = (TObjString*) iter.Next())){
35 TString str(ostr->String());
36 exec_det_macro="aliroot -b -q $ALICE_ROOT/";
38 exec_det_macro+="/Make";
40 exec_det_macro+="ResMisAlignment.C";
42 gSystem->Exec(exec_det_macro.Data());