| 71 | // | // | 
| 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; | 
| 85 | glroot->Query_GL_ROOT(glS4calib->ID_ROOT_L0,dbc); | glroot->Query_GL_ROOT(glS4calib->ID_ROOT_L0,dbc); | 
| 86 | // | // | 
| 87 | stringstream ftmpname; | stringstream ftmpname; | 
| 163 | // CORE ROUTINE | // CORE ROUTINE | 
| 164 | // | // | 
| 165 | // | // | 
| 166 | int S4Core(UInt_t run, TFile *file, TSQLServer *dbc, Int_t S4argc, char *S4argv[]){ | int S4Core(UInt_t run, TFile *file,GL_TABLES *glt, Int_t S4argc, char *S4argv[]){ | 
| 167 | // | // | 
| 168 | // Set these to true to have a verbose output. | // Set these to true to have a verbose output. | 
| 169 | // | // | 
| 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 | // | // | 
| 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"); | 
| 478 | // | // | 
| 479 | // prepare the timesync for the db | // prepare the timesync for the db | 
| 480 | // | // | 
| 481 |  | TString host = glt->CGetHost(); | 
| 482 |  | TString user = glt->CGetUser(); | 
| 483 |  | TString psw = glt->CGetPsw(); | 
| 484 |  | TSQLServer *dbc = TSQLServer::Connect(host.Data(),user.Data(),psw.Data()); | 
| 485 | if ( !dbc->IsConnected() ) throw -504; | if ( !dbc->IsConnected() ) throw -504; | 
| 486 | dbtime = new GL_TIMESYNC(runinfo->ID_ROOT_L0,"ID",dbc); | dbtime = new GL_TIMESYNC(runinfo->ID_ROOT_L0,"ID",dbc); | 
| 487 | // | // | 
| 488 | // Search in the DB the path and name of the LEVEL0 file to be processed. | // Search in the DB the path and name of the LEVEL0 file to be processed. | 
| 489 | // | // | 
| 490 | if ( !dbc->IsConnected() ) throw -504; | //    if ( !dbc->IsConnected() ) throw -504; | 
| 491 | glroot->Query_GL_ROOT(runinfo->ID_ROOT_L0,dbc); | glroot->Query_GL_ROOT(runinfo->ID_ROOT_L0,dbc); | 
| 492 | // | // | 
| 493 | ftmpname.str(""); | ftmpname.str(""); | 
| 572 | // | // | 
| 573 | if (verbose) printf("\n Ready to start! \n\n Processed events: \n\n"); | if (verbose) printf("\n Ready to start! \n\n Processed events: \n\n"); | 
| 574 | // | // | 
| 575 |  | if ( dbc ){ | 
| 576 |  | dbc->Close(); | 
| 577 |  | //      delete dbc; | 
| 578 |  | }; | 
| 579 |  | // | 
| 580 | for ( re = runinfo->EV_FROM; re < (runinfo->EV_FROM+runinfo->NEVENTS); re++){ | for ( re = runinfo->EV_FROM; re < (runinfo->EV_FROM+runinfo->NEVENTS); re++){ | 
| 581 | // | // | 
| 582 | if ( procev%1000 == 0 && procev > 0 && verbose ) printf(" %iK \n",procev/1000); | if ( procev%1000 == 0 && procev > 0 && verbose ) printf(" %iK \n",procev/1000); | 
| 665 | // | // | 
| 666 | if ( l0File ) l0File->Close(); | if ( l0File ) l0File->Close(); | 
| 667 | if ( tempfile ) tempfile->Close(); | if ( tempfile ) tempfile->Close(); | 
| 668 | gSystem->Unlink(tempname.str().c_str()); | if ( myfold) gSystem->Unlink(tempname.str().c_str()); | 
| 669 | // | // | 
| 670 | if ( runinfo ) runinfo->Close(); | if ( runinfo ) runinfo->Close(); | 
| 671 | if ( S4tr ) S4tr->SetName("S4"); | if ( S4tr ) S4tr->SetName("S4"); | 
| 674 | file->Write(); | file->Write(); | 
| 675 | }; | }; | 
| 676 | // | // | 
| 677 | gSystem->Unlink(S4folder.str().c_str()); | if ( myfold ) gSystem->Unlink(S4folder.str().c_str()); | 
| 678 | // | // | 
| 679 | // the end | // the end | 
| 680 | // | // |