| 72 |
GL_S4_CALIB *glS4calib = new GL_S4_CALIB(); |
GL_S4_CALIB *glS4calib = new GL_S4_CALIB(); |
| 73 |
// |
// |
| 74 |
if ( !dbc->IsConnected() ) throw -504; |
if ( !dbc->IsConnected() ) throw -504; |
| 75 |
glS4calib->Query_GL_S4_CALIB(atime, dbc); |
Int_t s4sig = glS4calib->Query_GL_S4_CALIB(atime, dbc); |
| 76 |
|
if ( s4sig != -57 && s4sig < 0 ){ |
| 77 |
|
parametri->AddAt(0.,0); |
| 78 |
|
parametri->AddAt(0.,1); |
| 79 |
|
return parametri; |
| 80 |
|
}; |
| 81 |
|
if ( s4sig < 0 ) throw s4sig; |
| 82 |
// |
// |
| 83 |
GL_ROOT *glroot = new GL_ROOT(); |
GL_ROOT *glroot = new GL_ROOT(); |
| 84 |
if ( !dbc->IsConnected() ) throw -504; |
if ( !dbc->IsConnected() ) throw -504; |
| 176 |
const char* outDir = gSystem->DirName(gSystem->DirName(file->GetPath())); |
const char* outDir = gSystem->DirName(gSystem->DirName(file->GetPath())); |
| 177 |
// |
// |
| 178 |
Int_t i = 0; |
Int_t i = 0; |
| 179 |
TString processFolder = "S4Folder_"+run; |
TString processFolder = Form("S4Folder_%u",run); |
| 180 |
if ( S4argc > 0 ){ |
if ( S4argc > 0 ){ |
| 181 |
i = 0; |
i = 0; |
| 182 |
while ( i < S4argc ){ |
while ( i < S4argc ){ |
| 189 |
}; |
}; |
| 190 |
if ( (!strcmp(S4argv[i],"--debug")) || (!strcmp(S4argv[i],"-g"))) { |
if ( (!strcmp(S4argv[i],"--debug")) || (!strcmp(S4argv[i],"-g"))) { |
| 191 |
verbose = true; |
verbose = true; |
| 192 |
|
debug = true; |
| 193 |
}; |
}; |
| 194 |
if ( (!strcmp(S4argv[i],"--verbose")) || (!strcmp(S4argv[i],"-v"))) { |
if ( (!strcmp(S4argv[i],"--verbose")) || (!strcmp(S4argv[i],"-v"))) { |
| 195 |
verbose = true; |
verbose = true; |
| 267 |
TTree *tempS4 = 0; |
TTree *tempS4 = 0; |
| 268 |
stringstream tempname; |
stringstream tempname; |
| 269 |
stringstream S4folder; |
stringstream S4folder; |
| 270 |
|
Bool_t myfold = false; |
| 271 |
tempname.str(""); |
tempname.str(""); |
| 272 |
tempname << outDir; |
tempname << outDir; |
| 273 |
tempname << "/" << processFolder.Data(); |
tempname << "/" << processFolder.Data(); |
| 274 |
S4folder.str(""); |
S4folder.str(""); |
| 275 |
S4folder << tempname.str().c_str(); |
S4folder << tempname.str().c_str(); |
|
gSystem->MakeDirectory(S4folder.str().c_str()); |
|
| 276 |
tempname << "/S4tree_run"; |
tempname << "/S4tree_run"; |
| 277 |
tempname << run << ".root"; |
tempname << run << ".root"; |
| 278 |
// |
// |
| 332 |
// number of run to be processed |
// number of run to be processed |
| 333 |
// |
// |
| 334 |
numbofrun = runinfo->GetNoRun(); |
numbofrun = runinfo->GetNoRun(); |
| 335 |
|
UInt_t totnorun = runinfo->GetRunEntries(); |
| 336 |
// |
// |
| 337 |
// Try to access the S4 tree in the file, if it exists we are reprocessing data if not we are processing a new run |
// Try to access the S4 tree in the file, if it exists we are reprocessing data if not we are processing a new run |
| 338 |
// |
// |
| 360 |
// |
// |
| 361 |
if (verbose) printf("\n Preparing the pre-processing...\n"); |
if (verbose) printf("\n Preparing the pre-processing...\n"); |
| 362 |
// |
// |
| 363 |
if ( run == 0 ){ |
if ( run == 0 || totnorun == 1 ){ |
| 364 |
// |
// |
| 365 |
// we are reprocessing all the file |
// we are reprocessing all the file |
| 366 |
// if we are reprocessing everything we don't need to copy any old event and we can just work with the new tree and delete the old one immediately |
// if we are reprocessing everything we don't need to copy any old event and we can just work with the new tree and delete the old one immediately |
| 379 |
// |
// |
| 380 |
// copying old tree to a new file |
// copying old tree to a new file |
| 381 |
// |
// |
| 382 |
|
gSystem->MakeDirectory(S4folder.str().c_str()); |
| 383 |
|
myfold = true; |
| 384 |
tempfile = new TFile(tempname.str().c_str(),"RECREATE"); |
tempfile = new TFile(tempname.str().c_str(),"RECREATE"); |
| 385 |
tempS4 = S4trclone->CloneTree(-1,"fast"); |
tempS4 = S4trclone->CloneTree(-1,"fast"); |
| 386 |
tempS4->SetName("S4-old"); |
tempS4->SetName("S4-old"); |
| 656 |
// |
// |
| 657 |
if ( l0File ) l0File->Close(); |
if ( l0File ) l0File->Close(); |
| 658 |
if ( tempfile ) tempfile->Close(); |
if ( tempfile ) tempfile->Close(); |
| 659 |
gSystem->Unlink(tempname.str().c_str()); |
if ( myfold) gSystem->Unlink(tempname.str().c_str()); |
| 660 |
// |
// |
| 661 |
if ( runinfo ) runinfo->Close(); |
if ( runinfo ) runinfo->Close(); |
| 662 |
if ( S4tr ) S4tr->SetName("S4"); |
if ( S4tr ) S4tr->SetName("S4"); |
| 665 |
file->Write(); |
file->Write(); |
| 666 |
}; |
}; |
| 667 |
// |
// |
| 668 |
gSystem->Unlink(S4folder.str().c_str()); |
if ( myfold ) gSystem->Unlink(S4folder.str().c_str()); |
| 669 |
// |
// |
| 670 |
// the end |
// the end |
| 671 |
// |
// |