/[PAMELA software]/chewbacca/YodaProfiler/src/GLTables.cpp
ViewVC logotype

Diff of /chewbacca/YodaProfiler/src/GLTables.cpp

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1.2 by mocchiut, Thu Sep 25 09:03:19 2008 UTC revision 1.14 by pam-fi, Tue Nov 29 13:18:37 2011 UTC
# Line 7  Line 7 
7  //  //
8  #include <sstream>  #include <sstream>
9  #include <iostream>  #include <iostream>
10    #include <limits.h>
11  //  //
12  #include <TFile.h>  #include <TFile.h>
13  #include <TTree.h>  #include <TTree.h>
# Line 17  Line 18 
18  #include <GLTables.h>  #include <GLTables.h>
19  #include <sgp4.h>  #include <sgp4.h>
20  //  //
21    ClassImp(Q2TH);
22  ClassImp(GL_TABLES);  ClassImp(GL_TABLES);
23  ClassImp(GL_TRK_CALIB);  ClassImp(GL_TRK_CALIB);
24  ClassImp(GL_RUN);  ClassImp(GL_RUN);
# Line 30  ClassImp(GL_TLE); Line 32  ClassImp(GL_TLE);
32  //  //
33  using namespace std;  using namespace std;
34    
35    Q2TH::Q2TH(TString host, TString user, TString psw){
36      this->Open(host,user,psw);
37    };
38    
39    void Q2TH::Open(TString host, TString user, TString psw){
40      fh = gSystem->ExpandPathName(host.Data());
41      fu = gSystem->ExpandPathName(user.Data());
42      fp = gSystem->ExpandPathName(psw.Data());
43      printf(" Connecting to DB %s \n",fh.Data());
44      dbc = TSQLServer::Connect(fh.Data(),fu.Data(),fp.Data());
45      if ( dbc && dbc->IsConnected() ){
46        printf(" connected! \n");
47      } else {
48        printf(" ERROR! not connected... :( \n");
49      };
50    };
51    
52    TObject *Q2TH::Draw(TString query, Bool_t verbose, TString hname){
53      //
54      if ( !strcmp(query.Data(),"help") ){
55        printf(" USAGE: \n");
56        printf(" 1) start root and create Q2TH object with  \n");
57        printf("    Q2TH *qt = new Q2TH()  \n");
58        printf("    or \n");
59        printf("    Q2TH *qt = new Q2TH(\"mysql://srvg-g2-01.ts.infn.it/pamelaProcessing9_TS\",\"pamelaprod_ro\",\"mypassword\")  \n");
60        printf(" 2) query the DB with  \n");
61        printf("    qt->Draw(\"select REAL_TIME_INIT,BAD_PKT_PERCENTAGE from ROOT_TABLE_MERGING;\");  \n");
62        printf("    qt->Draw(\"select REAL_TIME_INIT,BAD_PKT_PERCENTAGE from ROOT_TABLE_MERGING;\",true); this will print numbers on screen \n");
63        printf("    qt->Draw(\"select REAL_TIME_INIT from ROOT_TABLE_MERGING;\",true,\"myhisto\"); this will print numbers on screen and create histo \"myhisto\"\n");
64        printf(" 3) to use your own THxD create it and then query the DB giving as argument the name of histo:   \n");
65        printf("    TH2D *myhisto=new TH2D(\"myhisto\",\"myhisto\",5000,1140000000.,1240000000.,10000,0.,1.) \n");
66        printf("    qt->Draw(\"select REAL_TIME_INIT,BAD_PKT_PERCENTAGE from ROOT_TABLE_MERGING;\",false,\"myhisto\")\n\n\n");
67    
68        return NULL;
69      };
70      //
71      pResult = dbc->Query(query.Data());
72      //
73      Row = pResult->Next();      
74      //
75      Int_t dim = pResult->GetFieldCount();
76      if ( dim < 1 || dim > 2 ){
77        printf(" Dim == %i not supported yet \n",dim);
78        return NULL;
79      };  
80      //
81      TH1D *h1 = NULL;
82      TH2D *h2 = NULL;
83      Double_t f1 = 0.;
84      Double_t minf1 = numeric_limits<Double_t>::max();
85      Double_t maxf1 = numeric_limits<Double_t>::min();
86      Double_t f2 = 0.;  
87      Double_t minf2 = numeric_limits<Double_t>::max();
88      Double_t maxf2 = numeric_limits<Double_t>::min();
89      //
90      while ( Row ){    
91        f1 = (Double_t)atof(Row->GetField(0));
92        if ( f1 > maxf1 ) maxf1 = f1;
93        if ( f1 < minf1 ) minf1 = f1;
94        if ( dim == 2 ){
95          f2 = (Double_t)atof(Row->GetField(1));
96          if ( f2 > maxf2 ) maxf2 = f2;
97          if ( f2 < minf2 ) minf2 = f2;
98    
99        };
100        Row = pResult->Next();
101      };
102      pResult->Delete();
103      //
104            
105      //
106      Int_t f1bin = 70;
107      Int_t f2bin = 70;
108      if ( dim == 1 ){
109        f1bin = int((maxf1-minf1)/1000.);
110        if ( f1bin < 70 ) f1bin = 70;
111        if ( f1bin > 1000 ) f1bin = 1000;
112            if ( !strcmp(hname.Data(),"q2th") ) hname += "1";
113            //      h1 =  dynamic_cast<TH1D*>(gDirectory->FindObject(hname.Data()));
114            h1 = (TH1D*)(gDirectory->FindObject(hname.Data()));
115            if ( !strcmp(hname.Data(),"q2th1") ){
116             if ( h1 ) h1->Delete();
117            };
118            if ( !h1 ) h1 = new TH1D(hname.Data(),hname.Data(),f1bin,minf1*0.98,maxf1*1.02);
119        //    h1->SetBit(TH1::kCanRebin);
120        if ( verbose ) printf("\n\n Row     %s \n",pResult->GetFieldName(0));
121      };
122      if ( dim == 2 ){
123        f2bin = int((maxf2-minf2)/1000.);
124        if ( f2bin < 70 ) f2bin = 70;
125        if ( f2bin > 1000 ) f2bin = 1000;
126            if ( !strcmp(hname.Data(),"q2th") ) hname += "2";
127            //      h2 =  dynamic_cast<TH2D*>(gDirectory->FindObject(hname.Data()));
128            h2 =  (TH2D*)(gDirectory->FindObject(hname.Data()));
129            if ( !strcmp(hname.Data(),"q2th2") ){
130             if ( h2 ) h2->Delete();
131            };
132            if ( !h2 ) h2 = new TH2D(hname.Data(),hname.Data(),f1bin,minf1*0.98,maxf1*1.02,f2bin,minf2*0.98,maxf2*1.02);
133        //    h2->SetBit(TH2::kCanRebin);
134        if ( verbose ) printf("\n\n Row     %s     %s \n",pResult->GetFieldName(0),pResult->GetFieldName(1));
135      };
136      //
137      pResult = dbc->Query(query.Data());
138      //
139      Row = pResult->Next();      
140      //
141      Int_t r = 0;
142      //
143      while ( Row ){    
144        f1 = (Double_t)atof(Row->GetField(0));
145        if ( dim == 1 ){
146          if ( verbose ) printf(" %i     %f \n",r,f1);
147          h1->Fill(f1);
148        } else {
149          f2 = (Double_t)atof(Row->GetField(1));
150          if ( verbose ) printf(" %i     %f     %f \n",r,f1,f2);
151          h2->Fill(f1,f2);
152        };
153        r++;
154        Row = pResult->Next();
155      };
156      //
157      TCanvas *c = NULL;
158      TString cname = Form("%sc",hname.Data());
159      //  c =  dynamic_cast<TCanvas*>(gDirectory->FindObject(hname.Data()));
160      c =  (TCanvas*)(gDirectory->FindObject(cname.Data()));
161      if ( !c ) c = new TCanvas(Form("%sc",cname.Data()));
162      c->Clear();
163      c->cd();
164      if ( dim == 1 ) h1->Draw();
165      if ( dim == 2 ) h2->Draw();
166      //
167      pResult->Delete();
168      if ( dim == 1 ) return h1;
169      if ( dim == 2 ) return h2;
170      //
171      return NULL;
172    };
173    
174  GL_TABLES::GL_TABLES(){  GL_TABLES::GL_TABLES(){
175  };  };
176    
# Line 56  void GL_TABLES::Set(TString host, TStrin Line 197  void GL_TABLES::Set(TString host, TStrin
197    mp = psw.Data();    mp = psw.Data();
198  };  };
199    
200  Bool_t GL_TABLES::IsConnected(TSQLServer *&dbc){  //Bool_t GL_TABLES::IsConnected(TSQLServer *&dbc){
201    Bool_t GL_TABLES::IsConnected(TSQLServer *dbc){
202    //    //
203    //    //
204    //    //
# Line 92  Bool_t GL_TABLES::IsConnected(TSQLServer Line 234  Bool_t GL_TABLES::IsConnected(TSQLServer
234      TString host = fHost->Data();      TString host = fHost->Data();
235      TString user = fUser->Data();      TString user = fUser->Data();
236      TString psw = fPsw->Data();      TString psw = fPsw->Data();
237      dbc->Close();      if ( dbc ){
238      delete dbc;        dbc->Close();
239          delete dbc;
240        };
241      dbc = TSQLServer::Connect(host.Data(),user.Data(),psw.Data());      dbc = TSQLServer::Connect(host.Data(),user.Data(),psw.Data());
242      //      //
243      myquery.str("");      myquery.str("");
# Line 218  GL_ROOT::GL_ROOT(){ Line 362  GL_ROOT::GL_ROOT(){
362    NAME   = "";    NAME   = "";
363  }  }
364    
365    GL_RAW::GL_RAW(){
366      ID     = 0;
367      PATH   = "";
368      NAME   = "";
369      BOOT_NUMBER = 0;
370    }
371    
372  GL_PARAM::GL_PARAM(){  GL_PARAM::GL_PARAM(){
373    ID     = 0;    ID     = 0;
374    PATH   = "";    PATH   = "";
# Line 523  void GL_RUN::Set_GL_RUN(TSQLRow *Row){ Line 674  void GL_RUN::Set_GL_RUN(TSQLRow *Row){
674  Int_t GL_RUN::DeleteRun(TSQLServer *dbc,UInt_t IDRUN,TString FromTable){  Int_t GL_RUN::DeleteRun(TSQLServer *dbc,UInt_t IDRUN,TString FromTable){
675    // MySQL variables    // MySQL variables
676    TSQLResult *pResult;    TSQLResult *pResult;
677    TSQLRow *Row;    TSQLRow *Row = NULL;
678    stringstream myquery;    stringstream myquery;
679    //    //
680    if ( !IDRUN ) IDRUN = ID;    if ( !IDRUN ) IDRUN = ID;
# Line 587  Int_t GL_RUN::DeleteRun(TSQLServer *dbc, Line 738  Int_t GL_RUN::DeleteRun(TSQLServer *dbc,
738    UInt_t idl0 = 0;    UInt_t idl0 = 0;
739    UInt_t idl2 = 0;    UInt_t idl2 = 0;
740    //    //
741      if (Row)
742        delete Row;
743    Row = pResult->Next();          Row = pResult->Next();      
744    if( Row != NULL ){    if( Row != NULL ){
745      idtrash = (UInt_t)atoll(Row->GetField(0));      idtrash = (UInt_t)atoll(Row->GetField(0));
# Line 606  Int_t GL_RUN::DeleteRun(TSQLServer *dbc, Line 759  Int_t GL_RUN::DeleteRun(TSQLServer *dbc,
759    this->GetGLTABLES()->AddQ();    this->GetGLTABLES()->AddQ();
760    pResult = dbc->Query(myquery.str().c_str());    pResult = dbc->Query(myquery.str().c_str());
761    //    //
762      if (Row)
763        delete Row;
764    Row = pResult->Next();          Row = pResult->Next();      
765    if( Row != NULL ){    if( Row != NULL ){
766      fileL0 = (TString)Row->GetField(0);      fileL0 = (TString)Row->GetField(0);
# Line 623  Int_t GL_RUN::DeleteRun(TSQLServer *dbc, Line 778  Int_t GL_RUN::DeleteRun(TSQLServer *dbc,
778    this->GetGLTABLES()->AddQ();    this->GetGLTABLES()->AddQ();
779    pResult = dbc->Query(myquery.str().c_str());    pResult = dbc->Query(myquery.str().c_str());
780    //    //
781      if (Row)
782        delete Row;
783    Row = pResult->Next();          Row = pResult->Next();      
784    if( Row != NULL ){    if( Row != NULL ){
785      fileL2 = (TString)Row->GetField(0);      fileL2 = (TString)Row->GetField(0);
786    };    }
787      if (Row){
788        delete Row;
789        Row = NULL; // This variable is not used below
790      }
791    //    //
792    //    //
793    //    //
# Line 691  Int_t GL_RUN::RestoreRun(TSQLServer *dbc Line 852  Int_t GL_RUN::RestoreRun(TSQLServer *dbc
852    //insert into GL_RUN_TRASH VALUES (ID , ID_RUN_FRAG , ID_ROOT_L0 , ID_ROOT_L2 , RUNHEADER_TIME , RUNTRAILER_TIME , RUNHEADER_OBT , RUNTRAILER_OBT , RUNHEADER_PKT , RUNTRAILER_PKT , BOOT_NUMBER , EV_FROM , EV_TO  , NEVENTS , PKT_COUNTER , PKT_READY_COUNTER , COMPILATIONTIMESTAMP , FAV_WRK_SCHEDULE , EFF_WRK_SCHEDULE , PRH_VAR_TRG_MODE_A , PRH_VAR_TRG_MODE_B , ACQ_BUILD_INFO , ACQ_VAR_INFO , RM_ACQ_AFTER_CALIB , RM_ACQ_SETTING_MODE, TRK_CALIB_USED,CAL_DSP_MASK, LAST_TIMESYNC, OBT_TIMESYNC, VALIDATION, INSERT_TIME) select * FROM GL_RUN where ID=11;    //insert into GL_RUN_TRASH VALUES (ID , ID_RUN_FRAG , ID_ROOT_L0 , ID_ROOT_L2 , RUNHEADER_TIME , RUNTRAILER_TIME , RUNHEADER_OBT , RUNTRAILER_OBT , RUNHEADER_PKT , RUNTRAILER_PKT , BOOT_NUMBER , EV_FROM , EV_TO  , NEVENTS , PKT_COUNTER , PKT_READY_COUNTER , COMPILATIONTIMESTAMP , FAV_WRK_SCHEDULE , EFF_WRK_SCHEDULE , PRH_VAR_TRG_MODE_A , PRH_VAR_TRG_MODE_B , ACQ_BUILD_INFO , ACQ_VAR_INFO , RM_ACQ_AFTER_CALIB , RM_ACQ_SETTING_MODE, TRK_CALIB_USED,CAL_DSP_MASK, LAST_TIMESYNC, OBT_TIMESYNC, VALIDATION, INSERT_TIME) select * FROM GL_RUN where ID=11;
853    // MySQL variables    // MySQL variables
854    TSQLResult *pResult;    TSQLResult *pResult;
855    TSQLRow *Row;    TSQLRow *Row = NULL;
856    stringstream myquery;    stringstream myquery;
857    //    //
858    if ( !IDRUN ) IDRUN = ID;    if ( !IDRUN ) IDRUN = ID;
# Line 992  Int_t GL_RUN::Fill_GL_RUN_FRAGMENTS(TSQL Line 1153  Int_t GL_RUN::Fill_GL_RUN_FRAGMENTS(TSQL
1153  Int_t GL_RUN::Query_GL_RUN(UInt_t run, TSQLServer *dbc){  Int_t GL_RUN::Query_GL_RUN(UInt_t run, TSQLServer *dbc){
1154    // MySQL variables    // MySQL variables
1155    TSQLResult *pResult;    TSQLResult *pResult;
1156    TSQLRow *Row;    TSQLRow *Row = NULL;
   int t;  
1157    int r;    int r;
1158    stringstream myquery;    stringstream myquery;
1159    // ----------------    // ----------------
# Line 1042  Int_t GL_RUN::Query_GL_RUN(UInt_t run, T Line 1202  Int_t GL_RUN::Query_GL_RUN(UInt_t run, T
1202    //    //
1203    if( !pResult->GetRowCount() ) return(-50);    if( !pResult->GetRowCount() ) return(-50);
1204    //    //
1205    for( r=0; r < 1000; r++){    for( r=0; r < 1000; r++){
1206              if (Row)
1207                delete Row;
1208        Row = pResult->Next();              Row = pResult->Next();      
1209        if( Row == NULL ) break;        if( Row == NULL ) break;
1210  //        Set_GL_RUN(Row);  //        Set_GL_RUN(Row);
1211        for( t = 0; t < pResult->GetFieldCount(); t++){        for( int t = 0; t < pResult->GetFieldCount(); t++){
1212          if (t== 0) ID                = (UInt_t)atoll(Row->GetField(t));          if (t== 0) ID                = (UInt_t)atoll(Row->GetField(t));
1213          if (t== 1) ID_RUN_FRAG       = (UInt_t)atoll(Row->GetField(t));          if (t== 1) ID_RUN_FRAG       = (UInt_t)atoll(Row->GetField(t));
1214          if (t== 2) ID_ROOT_L0        = (UInt_t)atoll(Row->GetField(t));          if (t== 2) ID_ROOT_L0        = (UInt_t)atoll(Row->GetField(t));
# Line 1080  Int_t GL_RUN::Query_GL_RUN(UInt_t run, T Line 1242  Int_t GL_RUN::Query_GL_RUN(UInt_t run, T
1242          if (t==30) PHYSENDRUN_MASK_S11CRC = (UInt_t)atoll(Row->GetField(t));          if (t==30) PHYSENDRUN_MASK_S11CRC = (UInt_t)atoll(Row->GetField(t));
1243          if (t==31) VALIDATION        = (UInt_t)atoll(Row->GetField(t));          if (t==31) VALIDATION        = (UInt_t)atoll(Row->GetField(t));
1244        };        };
1245    };    }
1246    //  delete pResult;  
1247      if (Row)
1248        delete Row;
1249      delete pResult;
1250    return(0);    return(0);
1251  };  };
1252    
# Line 1095  Int_t GL_RUN::Query_GL_RUN(UInt_t run, T Line 1260  Int_t GL_RUN::Query_GL_RUN(UInt_t run, T
1260  Int_t GL_RUN::Query_GL_RUN_FRAGMENTS(TString where, TSQLServer *dbc){  Int_t GL_RUN::Query_GL_RUN_FRAGMENTS(TString where, TSQLServer *dbc){
1261    // MySQL variables    // MySQL variables
1262    TSQLResult *pResult;    TSQLResult *pResult;
1263    TSQLRow *Row;    TSQLRow *Row = NULL;
1264    int t;    int t;
1265    int r;    int r;
1266    stringstream myquery;    stringstream myquery;
# Line 1143  Int_t GL_RUN::Query_GL_RUN_FRAGMENTS(TSt Line 1308  Int_t GL_RUN::Query_GL_RUN_FRAGMENTS(TSt
1308    pResult = dbc->Query(myquery.str().c_str());    pResult = dbc->Query(myquery.str().c_str());
1309    if(!pResult->GetRowCount())return(-50);    if(!pResult->GetRowCount())return(-50);
1310    for( r=0; r < 1000; r++){    for( r=0; r < 1000; r++){
1311            if (Row)
1312              delete Row;
1313      Row = pResult->Next();            Row = pResult->Next();      
1314      if( Row == NULL ) break;      if( Row == NULL ) break;
1315      for( t = 0; t < pResult->GetFieldCount(); t++){      for( t = 0; t < pResult->GetFieldCount(); t++){
# Line 1179  Int_t GL_RUN::Query_GL_RUN_FRAGMENTS(TSt Line 1346  Int_t GL_RUN::Query_GL_RUN_FRAGMENTS(TSt
1346        if (t==30) PHYSENDRUN_MASK_S11CRC = (UInt_t)atoll(Row->GetField(t));        if (t==30) PHYSENDRUN_MASK_S11CRC = (UInt_t)atoll(Row->GetField(t));
1347        if (t==31) VALIDATION        = (UInt_t)atoll(Row->GetField(t));        if (t==31) VALIDATION        = (UInt_t)atoll(Row->GetField(t));
1348      };      };
1349    };    }
1350    //  delete pResult;  
1351      if (Row)
1352        delete Row;
1353      delete pResult;
1354    return(0);    return(0);
1355  };// ****************************************************  };// ****************************************************
1356    
# Line 1193  Int_t GL_RUN::Query_GL_RUN_FRAGMENTS(TSt Line 1363  Int_t GL_RUN::Query_GL_RUN_FRAGMENTS(TSt
1363  Int_t GL_ROOT::Query_GL_ROOT(UInt_t id, TSQLServer *dbc){  Int_t GL_ROOT::Query_GL_ROOT(UInt_t id, TSQLServer *dbc){
1364    // MySQL variables    // MySQL variables
1365    TSQLResult *pResult;    TSQLResult *pResult;
1366    TSQLRow *Row;    TSQLRow *Row = NULL;
1367    int t;    int t;
1368    int r;    int r;
1369    stringstream myquery;    stringstream myquery;
# Line 1212  Int_t GL_ROOT::Query_GL_ROOT(UInt_t id, Line 1382  Int_t GL_ROOT::Query_GL_ROOT(UInt_t id,
1382    pResult = dbc->Query(myquery.str().c_str());    pResult = dbc->Query(myquery.str().c_str());
1383    if(!pResult->GetRowCount())return (-51);    if(!pResult->GetRowCount())return (-51);
1384    for( r=0; r < 1000; r++){    for( r=0; r < 1000; r++){
1385              if (Row)
1386                delete Row;
1387        Row = pResult->Next();              Row = pResult->Next();      
1388        if( Row == NULL ) break;        if( Row == NULL ) break;
1389        for( t = 0; t < pResult->GetFieldCount(); t++){        for( t = 0; t < pResult->GetFieldCount(); t++){
# Line 1220  Int_t GL_ROOT::Query_GL_ROOT(UInt_t id, Line 1392  Int_t GL_ROOT::Query_GL_ROOT(UInt_t id,
1392            if(t==2) ID_TIMESYNC = (UInt_t)atoll(Row->GetField(t));            if(t==2) ID_TIMESYNC = (UInt_t)atoll(Row->GetField(t));
1393            if(t==3) PATH   = (TString)gSystem->ExpandPathName(Row->GetField(t))+'/';            if(t==3) PATH   = (TString)gSystem->ExpandPathName(Row->GetField(t))+'/';
1394            if(t==4) NAME   = Row->GetField(t);            if(t==4) NAME   = Row->GetField(t);
1395        };        }
1396    };    }
1397      if (Row)
1398        delete Row;
1399    delete pResult;      delete pResult;  
1400    return 0;    return 0;
1401  };  };
# Line 1236  Int_t GL_ROOT::Query_GL_ROOT(UInt_t id, Line 1410  Int_t GL_ROOT::Query_GL_ROOT(UInt_t id,
1410  Int_t GL_TRK_CALIB::Query_GL_TRK_CALIB(UInt_t time, TSQLServer *dbc){  Int_t GL_TRK_CALIB::Query_GL_TRK_CALIB(UInt_t time, TSQLServer *dbc){
1411    // MySQL variables    // MySQL variables
1412    TSQLResult *pResult;    TSQLResult *pResult;
1413    TSQLRow *Row;    TSQLRow *Row = NULL;
1414    int t;    int t;
1415    int r;    int r;
1416    stringstream myquery;    stringstream myquery;
# Line 1252  Int_t GL_TRK_CALIB::Query_GL_TRK_CALIB(U Line 1426  Int_t GL_TRK_CALIB::Query_GL_TRK_CALIB(U
1426    pResult = dbc->Query(myquery.str().c_str());    pResult = dbc->Query(myquery.str().c_str());
1427    if(!pResult->GetRowCount())return (-53);    if(!pResult->GetRowCount())return (-53);
1428    for( r=0; r < 1000; r++){    for( r=0; r < 1000; r++){
1429              if (Row)
1430                delete Row;
1431        Row = pResult->Next();            Row = pResult->Next();    
1432        if( Row == NULL ) break;        if( Row == NULL ) break;
1433        for( t = 0; t < pResult->GetFieldCount(); t++){        for( t = 0; t < pResult->GetFieldCount(); t++){
# Line 1272  Int_t GL_TRK_CALIB::Query_GL_TRK_CALIB(U Line 1448  Int_t GL_TRK_CALIB::Query_GL_TRK_CALIB(U
1448            if (t==10) BOOT_NUMBER      = (UInt_t)atoll(Row->GetField(t));            if (t==10) BOOT_NUMBER      = (UInt_t)atoll(Row->GetField(t));
1449            if (t==11) VALIDATION       = (UInt_t)atoll(Row->GetField(t));            if (t==11) VALIDATION       = (UInt_t)atoll(Row->GetField(t));
1450            };            };
1451    };    }
1452      if (Row)
1453        delete Row;
1454    delete pResult;    delete pResult;
1455    //    //
1456  //  if ( TO_TIME < time ) return(51);  //  if ( TO_TIME < time ) return(51);
# Line 1292  Int_t GL_TRK_CALIB::Query_GL_TRK_CALIB(U Line 1470  Int_t GL_TRK_CALIB::Query_GL_TRK_CALIB(U
1470  Int_t GL_CALO_CALIB::Query_GL_CALO_CALIB(UInt_t time, UInt_t &uptime,  UInt_t section, TSQLServer *dbc){  Int_t GL_CALO_CALIB::Query_GL_CALO_CALIB(UInt_t time, UInt_t &uptime,  UInt_t section, TSQLServer *dbc){
1471    // MySQL variables    // MySQL variables
1472    TSQLResult *pResult;    TSQLResult *pResult;
1473    TSQLRow *Row;    TSQLRow *Row = NULL;
1474    int t;    int t;
1475    stringstream myquery;    stringstream myquery;
1476    uptime = 0;    uptime = 0;
# Line 1309  Int_t GL_CALO_CALIB::Query_GL_CALO_CALIB Line 1487  Int_t GL_CALO_CALIB::Query_GL_CALO_CALIB
1487    if ( !this->GetGLTABLES()->IsConnected(dbc) ) return -57;      if ( !this->GetGLTABLES()->IsConnected(dbc) ) return -57;  
1488    this->GetGLTABLES()->AddQ();    this->GetGLTABLES()->AddQ();
1489    pResult = dbc->Query(myquery.str().c_str());    pResult = dbc->Query(myquery.str().c_str());
1490    //  printf(" mysquery is %s\n",myquery.str().c_str());    // printf(" mysquery is %s\n",myquery.str().c_str());
1491    //    //
1492    if( !pResult->GetRowCount() ) return(-54);    if( !pResult->GetRowCount() ) return(-54);
1493      if (Row)
1494        delete Row;
1495    Row = pResult->Next();    Row = pResult->Next();
1496    if( Row == NULL ) return (-54);    if( Row == NULL ) return (-54);
1497    //    //
# Line 1339  Int_t GL_CALO_CALIB::Query_GL_CALO_CALIB Line 1519  Int_t GL_CALO_CALIB::Query_GL_CALO_CALIB
1519      //      //
1520      if( !pResult->GetRowCount() ) return (-54);      if( !pResult->GetRowCount() ) return (-54);
1521      //      //
1522        if (Row)
1523          delete Row;
1524      Row = pResult->Next();      Row = pResult->Next();
1525      //      //
1526      myfromtime = (UInt_t)atoll(Row->GetField(1));      myfromtime = (UInt_t)atoll(Row->GetField(1));
# Line 1347  Int_t GL_CALO_CALIB::Query_GL_CALO_CALIB Line 1529  Int_t GL_CALO_CALIB::Query_GL_CALO_CALIB
1529    //    //
1530    // if the selected calibration is too old (more than 5 orbits old) try to take the closest not corrupted one    // if the selected calibration is too old (more than 5 orbits old) try to take the closest not corrupted one
1531    //    //
1532    if ( (time-myfromtime)>28500 ){    if ( (time-myfromtime)>28500 && myfromtime > 0 ){
1533      //      //
1534      myquery.str("");      myquery.str("");
1535      myquery << "select ID_ROOT_L0, FROM_TIME, TO_TIME, EV_ROOT from GL_CALO_CALIB where SECTION=" << section;      myquery << "select ID_ROOT_L0, FROM_TIME, TO_TIME, EV_ROOT from GL_CALO_CALIB where SECTION=" << section;
# Line 1373  Int_t GL_CALO_CALIB::Query_GL_CALO_CALIB Line 1555  Int_t GL_CALO_CALIB::Query_GL_CALO_CALIB
1555      if (t==1) FROM_TIME = myfromtime;      if (t==1) FROM_TIME = myfromtime;
1556      if (t==2) TO_TIME   = mytotime;                if (t==2) TO_TIME   = mytotime;          
1557      if (t==3) EV_ROOT = (UInt_t)atoll(Row->GetField(t));      if (t==3) EV_ROOT = (UInt_t)atoll(Row->GetField(t));
1558    };    }
1559      if (Row)
1560        delete Row;
1561    pResult->Delete();    pResult->Delete();
1562    return 0;    return 0;
1563  };  };
# Line 1389  Int_t GL_CALO_CALIB::Query_GL_CALO_CALIB Line 1573  Int_t GL_CALO_CALIB::Query_GL_CALO_CALIB
1573  Int_t GL_CALOPULSE_CALIB::Query_GL_CALOPULSE_CALIB(UInt_t time, UInt_t section, UInt_t pampli, TSQLServer *dbc){  Int_t GL_CALOPULSE_CALIB::Query_GL_CALOPULSE_CALIB(UInt_t time, UInt_t section, UInt_t pampli, TSQLServer *dbc){
1574    // MySQL variables    // MySQL variables
1575    TSQLResult *pResult;    TSQLResult *pResult;
1576    TSQLRow *Row;    TSQLRow *Row = NULL;
1577    int t;    int t;
1578    stringstream myquery;    stringstream myquery;
1579    //    //
# Line 1407  Int_t GL_CALOPULSE_CALIB::Query_GL_CALOP Line 1591  Int_t GL_CALOPULSE_CALIB::Query_GL_CALOP
1591    //    //
1592    if( !pResult ) return(-54);    if( !pResult ) return(-54);
1593    //    //
1594      if (Row)
1595        delete Row;
1596    Row = pResult->Next();    Row = pResult->Next();
1597    //    //
1598    if( !Row ) return (-54);    if( !Row ) return (-54);
# Line 1419  Int_t GL_CALOPULSE_CALIB::Query_GL_CALOP Line 1605  Int_t GL_CALOPULSE_CALIB::Query_GL_CALOP
1605      if (t==1) FROM_TIME = (UInt_t)atoll(Row->GetField(t));      if (t==1) FROM_TIME = (UInt_t)atoll(Row->GetField(t));
1606      if (t==2) TO_TIME   = (UInt_t)atoll(Row->GetField(t));                  if (t==2) TO_TIME   = (UInt_t)atoll(Row->GetField(t));            
1607      if (t==3) EV_ROOT = (UInt_t)atoll(Row->GetField(t));      if (t==3) EV_ROOT = (UInt_t)atoll(Row->GetField(t));
1608    };    }
1609      if (Row)
1610        delete Row;
1611    pResult->Delete();    pResult->Delete();
1612    return 0;    return 0;
1613  };  };
# Line 1435  Int_t GL_CALOPULSE_CALIB::Query_GL_CALOP Line 1623  Int_t GL_CALOPULSE_CALIB::Query_GL_CALOP
1623  Int_t GL_S4_CALIB::Query_GL_S4_CALIB(UInt_t time, TSQLServer *dbc){  Int_t GL_S4_CALIB::Query_GL_S4_CALIB(UInt_t time, TSQLServer *dbc){
1624    // MySQL variables    // MySQL variables
1625    TSQLResult *pResult;    TSQLResult *pResult;
1626    TSQLRow *Row;    TSQLRow *Row = NULL;
1627    int t;    int t;
1628    int r;    int r;
1629    stringstream myquery;    stringstream myquery;
# Line 1449  Int_t GL_S4_CALIB::Query_GL_S4_CALIB(UIn Line 1637  Int_t GL_S4_CALIB::Query_GL_S4_CALIB(UIn
1637    pResult = dbc->Query(myquery.str().c_str());    pResult = dbc->Query(myquery.str().c_str());
1638    if(!pResult->GetRowCount())return (-55);//throw -55;    if(!pResult->GetRowCount())return (-55);//throw -55;
1639    for( r=0; r < 1000; r++){    for( r=0; r < 1000; r++){
1640              if (Row)
1641                delete Row;
1642        Row = pResult->Next();            Row = pResult->Next();    
1643        if( Row == NULL ) break;        if( Row == NULL ) break;
1644        for( t = 0; t < pResult->GetFieldCount(); t++){        for( t = 0; t < pResult->GetFieldCount(); t++){
# Line 1458  Int_t GL_S4_CALIB::Query_GL_S4_CALIB(UIn Line 1648  Int_t GL_S4_CALIB::Query_GL_S4_CALIB(UIn
1648          if (t==3) FROM_TIME = (UInt_t)atoll(Row->GetField(t));          if (t==3) FROM_TIME = (UInt_t)atoll(Row->GetField(t));
1649          if (t==4) TO_TIME   = (UInt_t)atoll(Row->GetField(t));          if (t==4) TO_TIME   = (UInt_t)atoll(Row->GetField(t));
1650        };        };
1651    };    }
1652      if (Row)
1653        delete Row;
1654    delete pResult;        delete pResult;    
1655    //    //
1656    if(TO_TIME < time)return(51);    if(TO_TIME < time)return(51);
# Line 1477  Int_t GL_PARAM::Query_GL_PARAM(UInt_t ti Line 1669  Int_t GL_PARAM::Query_GL_PARAM(UInt_t ti
1669    //    Bool_t debug = 1;    //    Bool_t debug = 1;
1670    // MySQL variables    // MySQL variables
1671    TSQLResult *pResult;    TSQLResult *pResult;
1672    TSQLRow *Row;    TSQLRow *Row = NULL;
1673    int t;    int t;
1674    int r;    int r;
1675    stringstream myquery;    stringstream myquery;
# Line 1495  Int_t GL_PARAM::Query_GL_PARAM(UInt_t ti Line 1687  Int_t GL_PARAM::Query_GL_PARAM(UInt_t ti
1687    pResult = dbc->Query(myquery.str().c_str());    pResult = dbc->Query(myquery.str().c_str());
1688    if(!pResult->GetRowCount())return (-52);    if(!pResult->GetRowCount())return (-52);
1689    for( r=0; r < 1000; r++){    for( r=0; r < 1000; r++){
1690              if (Row)
1691                delete Row;
1692        Row = pResult->Next();            Row = pResult->Next();    
1693        if( Row == NULL ) break;        if( Row == NULL ) break;
1694        for( t = 0; t < pResult->GetFieldCount(); t++){        for( t = 0; t < pResult->GetFieldCount(); t++){
# Line 1506  Int_t GL_PARAM::Query_GL_PARAM(UInt_t ti Line 1700  Int_t GL_PARAM::Query_GL_PARAM(UInt_t ti
1700            if (t==5) TO_TIME   = (UInt_t)atoll(Row->GetField(t));                          if (t==5) TO_TIME   = (UInt_t)atoll(Row->GetField(t));              
1701            if (t==6) TYPE     = (UInt_t)atoll(Row->GetField(t));            if (t==6) TYPE     = (UInt_t)atoll(Row->GetField(t));
1702        };        };
1703    };    }
1704      if (Row)
1705        delete Row;
1706    delete pResult;    delete pResult;
1707    //    //
1708    if(TO_TIME==0) TO_TIME = numeric_limits<UInt_t>::max();    if(TO_TIME==0) TO_TIME = numeric_limits<UInt_t>::max();
# Line 1539  void GL_RUN::GetLevel2Struct(cGLRun *l2) Line 1735  void GL_RUN::GetLevel2Struct(cGLRun *l2)
1735  GL_TIMESYNC::GL_TIMESYNC(UInt_t id, TString type, TSQLServer *dbc){  GL_TIMESYNC::GL_TIMESYNC(UInt_t id, TString type, TSQLServer *dbc){
1736    // MySQL variables    // MySQL variables
1737    TFile *file = 0;    TFile *file = 0;
1738    UInt_t idraw = 0;    UInt_t idtsy = 0;
1739    //    //
1740    TSQLResult *pResult;    TSQLResult *pResult;
1741    TSQLRow *Row;    TSQLRow *Row = NULL;
1742    stringstream myquery;    stringstream myquery;
1743    stringstream rname;    stringstream rname;
1744    //  pcksList packetsNames;    //  pcksList packetsNames;
# Line 1553  GL_TIMESYNC::GL_TIMESYNC(UInt_t id, TStr Line 1749  GL_TIMESYNC::GL_TIMESYNC(UInt_t id, TStr
1749    myquery.str("");    myquery.str("");
1750    myquery << "select ";    myquery << "select ";
1751    myquery << "PATH";    myquery << "PATH";
1752    myquery << ",NAME,ID_RAW";    myquery << ",NAME,ID_TIMESYNC";
1753    myquery << " from GL_ROOT where ";    myquery << " from GL_ROOT where ";
1754    myquery << type.Data();    myquery << type.Data();
1755    myquery << "=" << id << ";";        myquery << "=" << id << ";";    
# Line 1562  GL_TIMESYNC::GL_TIMESYNC(UInt_t id, TStr Line 1758  GL_TIMESYNC::GL_TIMESYNC(UInt_t id, TStr
1758    this->GetGLTABLES()->AddQ();    this->GetGLTABLES()->AddQ();
1759    pResult = dbc->Query(myquery.str().c_str());    pResult = dbc->Query(myquery.str().c_str());
1760    if( pResult->GetRowCount() ){    if( pResult->GetRowCount() ){
1761            if (Row)
1762              delete Row;
1763      Row = pResult->Next();            Row = pResult->Next();      
1764      if( Row ){      if( Row ){
1765        stringstream fname;        stringstream fname;
# Line 1569  GL_TIMESYNC::GL_TIMESYNC(UInt_t id, TStr Line 1767  GL_TIMESYNC::GL_TIMESYNC(UInt_t id, TStr
1767        fname << gSystem->ExpandPathName(Row->GetField(0)) << "/" << Row->GetField(1);        fname << gSystem->ExpandPathName(Row->GetField(0)) << "/" << Row->GetField(1);
1768        rname << Row->GetField(1);        rname << Row->GetField(1);
1769        file = new TFile(fname.str().c_str(),"READ");        file = new TFile(fname.str().c_str(),"READ");
1770        idraw = (UInt_t)atoll(Row->GetField(2));        idtsy = (UInt_t)atoll(Row->GetField(2));
1771      };      };
1772    };    };
1773    //    //
# Line 1582  GL_TIMESYNC::GL_TIMESYNC(UInt_t id, TStr Line 1780  GL_TIMESYNC::GL_TIMESYNC(UInt_t id, TStr
1780      T->GetEntry(0);      T->GetEntry(0);
1781      ph = eh->GetPscuHeader();      ph = eh->GetPscuHeader();
1782      pktfirst = ph->GetCounter();      pktfirst = ph->GetCounter();
1783      obtfirst = ph->GetOrbitalTime();        //    obtfirst = ph->GetOrbitalTime();  
     //  
 //     code = eh->GetCounter();  
 //     UInt_t en = 0;  
 //     for(Iter = packetsNames.begin(); Iter != packetsNames.end(); Iter++){  
 //       en = code->Get(GetPacketType(*Iter));  
 //       if ( !strcmp("CalibCalPed",*Iter) || !strcmp("CalibTrk1",*Iter) || !strcmp("CalibTrk2",*Iter) || !strcmp("CalibS4",*Iter) ){  
 //      //  
 //      TTree *TC = 0;  
 //      TC = (TTree*)file->Get("CalibCalPed");  
 //      if ( !TC || TC->IsZombie() ) return;  
 //      EventHeader *ehc = 0;  
 //      PscuHeader *phc = 0;  
 //      TC->SetBranchAddress("Header", &ehc);  
 //      TC->GetEntry(0);  
 //      phc = ehc->GetPscuHeader();  
 //      pktfirst = phc->GetCounter();  
 //      obtfirst = phc->GetOrbitalTime();    
 //       //  
 //       };  
 //     };    
1784      //      //
1785    };    };
1786    //    //
# Line 1610  GL_TIMESYNC::GL_TIMESYNC(UInt_t id, TStr Line 1788  GL_TIMESYNC::GL_TIMESYNC(UInt_t id, TStr
1788    //    //
1789    T0 = 0;    T0 = 0;
1790    //    //
   //  
1791    stringstream oss;    stringstream oss;
   TString frn = rname.str().c_str();  
   frn = frn.ReplaceAll(".root",5,".pam",4);  
   oss.str("");  
   oss << "SELECT YEAR(OFFSET_DATE),MONTH(OFFSET_DATE),DAY(OFFSET_DATE),HOUR(OFFSET_DATE),MINUTE(OFFSET_DATE),SECOND(OFFSET_DATE) FROM GL_RESURS_OFFSET WHERE SPECIAL_FILE='"  
       << frn.Data() << "';";  
   if ( !this->GetGLTABLES()->IsConnected(dbc) ) return;    
   this->GetGLTABLES()->AddQ();  
   pResult = dbc->Query(oss.str().c_str());  
   Row = pResult->Next();  
1792    //    //
1793    TString name=rname.str().c_str();    TString name=rname.str().c_str();
1794    UInt_t dworbit = 0;    UInt_t dworbit = 0;
1795    Int_t nlength = name.Length();    //  Int_t nlength = name.Length();
1796      delete pResult;      
1797    //    //
1798    // Is not a special file    // New code, we have one more column on GL_TIMESYNC so we can trust that one for the Resurs offset
1799    //    //
1800    if ( !Row ){    oss.str("");
1801      delete pResult;          oss << "SELECT OBT0,TIMESYNC,TYPE,ID_RESURS_OFFSET from GL_TIMESYNC where ID=" << idtsy <<";";
1802      //    if ( !this->GetGLTABLES()->IsConnected(dbc) ) return;  
1803      // New code, we have one more column on GL_TIMESYNC so we can trust that one for the Resurs offset    this->GetGLTABLES()->AddQ();
1804      //    pResult = dbc->Query(oss.str().c_str());
1805      oss.str("");    Bool_t fndit = false;
1806      oss << "SELECT ID_RESURS_OFFSET from GL_TIMESYNC where ID_RAW=" << idraw <<";";    if ( pResult ){
1807      if ( !this->GetGLTABLES()->IsConnected(dbc) ) return;            if (Row)
1808      this->GetGLTABLES()->AddQ();            delete Row;
1809      pResult = dbc->Query(oss.str().c_str());      Row = pResult->Next();
1810      Bool_t fndit = false;      if ( Row ){
     if ( pResult ){  
       Row = pResult->Next();  
       if ( Row ){  
         oss.str("");  
         oss << "SELECT YEAR(OFFSET_DATE),MONTH(OFFSET_DATE),DAY(OFFSET_DATE),HOUR(OFFSET_DATE),MINUTE(OFFSET_DATE),SECOND(OFFSET_DATE) FROM GL_RESURS_OFFSET WHERE ID="  
             << Row->GetField(0) << ";";  
         if ( !this->GetGLTABLES()->IsConnected(dbc) ) return;    
         this->GetGLTABLES()->AddQ();  
         pResult = dbc->Query(oss.str().c_str());  
         if ( pResult ){  
           Row = pResult->Next();  
           if ( Row ){  
             //      printf(" GREAT! the DB structure is the new one! \n");  
             fndit = true;  
             dworbit = 1;  
           };  
         };  
       };  
     };  
     if ( !fndit ){  
       delete pResult;        
       //  
       printf(" OK, you got an error because this is the old database\n Using backward compability code, hence you can continue safetly \n");  
       //  
       // Old code, we must trust the filename  
1811        //        //
1812        if ( nlength < 5 ) return;        OBT0 = (UInt_t)atoll(Row->GetField(0));
1813        TString dwo = 0;        obtfirst = OBT0;
1814        for (Int_t i = 0; i<5; i++){        TIMESYNC = (UInt_t)atoll(Row->GetField(1));
1815          dwo.Append(name[i],1);        TYPE = (UInt_t)atoll(Row->GetField(2));      
       };  
       if ( dwo.IsDigit() ){  
         dworbit = (UInt_t)dwo.Atoi();  
       } else {  
         dwo="";  
         for (Int_t i = 8; i<13; i++){  
           dwo.Append(name[i],1);  
         };      
         if ( dwo.IsDigit() ){  
           dworbit = (UInt_t)dwo.Atoi();  
         } else {  
           dworbit = 1;  
         };  
       };      
1816        //        //
1817        oss.str("");        oss.str("");
1818        oss << "SELECT YEAR(OFFSET_DATE),MONTH(OFFSET_DATE),DAY(OFFSET_DATE),HOUR(OFFSET_DATE),MINUTE(OFFSET_DATE),SECOND(OFFSET_DATE) FROM GL_RESURS_OFFSET WHERE FROM_ORBIT< "        oss << "SELECT YEAR(OFFSET_DATE),MONTH(OFFSET_DATE),DAY(OFFSET_DATE),HOUR(OFFSET_DATE),MINUTE(OFFSET_DATE),SECOND(OFFSET_DATE) FROM GL_RESURS_OFFSET WHERE ID="
1819            << dworbit << " order by FROM_ORBIT desc limit 1;";            << Row->GetField(3) << ";";
1820        if ( !this->GetGLTABLES()->IsConnected(dbc) ) return;          if ( !this->GetGLTABLES()->IsConnected(dbc) ) return;  
1821        this->GetGLTABLES()->AddQ();        this->GetGLTABLES()->AddQ();
1822          delete pResult;
1823        pResult = dbc->Query(oss.str().c_str());        pResult = dbc->Query(oss.str().c_str());
1824        Row = pResult->Next();        if (pResult){
1825        if ( !Row ){          if (Row)
1826          printf(" ERROR FROM GLTables! cannot determine Resurs offset \n");            delete Row;
1827          return;              Row = pResult->Next();
1828                if ( Row ){
1829                  //            printf(" GREAT! the DB structure is the new one! \n");
1830                fndit = true;
1831                dworbit = 1;
1832                };
1833        };        };
1834      };      };
1835    };    };
1836      if ( !fndit ){
1837        //
1838        printf(" ERROR OLD DB! \n");
1839        printf(" ERROR FROM GLTables! cannot determine Resurs offset \n");
1840        //
1841      };
1842    //    //
1843    TTimeStamp tu = TTimeStamp((UInt_t)atoi(Row->GetField(0)),(UInt_t)atoi(Row->GetField(1)),(UInt_t)atoi(Row->GetField(2)),(UInt_t)atoi(Row->GetField(3)),(UInt_t)atoi(Row->GetField(4)),(UInt_t)atoi(Row->GetField(5)),0,true,0);    TTimeStamp tu = TTimeStamp((UInt_t)atoi(Row->GetField(0)),(UInt_t)atoi(Row->GetField(1)),(UInt_t)atoi(Row->GetField(2)),(UInt_t)atoi(Row->GetField(3)),(UInt_t)atoi(Row->GetField(4)),(UInt_t)atoi(Row->GetField(5)),0,true,0);
1844    T0 = (UInt_t)tu.GetSec();    T0 = (UInt_t)tu.GetSec();
1845    //    //
1846    // look for the correct timesync entry    toffset = (UInt_t)TIMESYNC - (UInt_t)(this->DBobt(OBT0)/1000) + T0;
1847      //
1848      //  printf(" T0 %u toffset is %u \n",T0,toffset);
1849    //    //
1850      if ( file ) file->Close();
1851      if (Row)
1852        delete Row;
1853      delete pResult;      
1854    };
1855    
1856    GL_TIMESYNC::GL_TIMESYNC(UInt_t id, TString type, TSQLServer *dbc, Bool_t usel0file){
1857      // MySQL variables
1858      TFile *file = 0;
1859      UInt_t idtsy = 0;
1860      //
1861      TSQLResult *pResult;
1862      TSQLRow *Row = NULL;
1863      stringstream myquery;
1864      stringstream rname;
1865      //  pcksList packetsNames;
1866      //  pcksList::iterator Iter;
1867      //  getPacketsNames(packetsNames);
1868      rname.str("");
1869      // ----------------
1870    myquery.str("");    myquery.str("");
1871    myquery << " SELECT OBT0,TIMESYNC,TYPE FROM GL_TIMESYNC "    myquery << "select ";
1872        << " WHERE ID_RAW = " << idraw    myquery << "PATH";
1873        << ";";    myquery << ",NAME,ID_TIMESYNC";
1874      myquery << " from GL_ROOT where ";
1875      myquery << type.Data();
1876      myquery << "=" << id << ";";    
1877      //
1878    if ( !this->GetGLTABLES()->IsConnected(dbc) ) return;      if ( !this->GetGLTABLES()->IsConnected(dbc) ) return;  
1879    this->GetGLTABLES()->AddQ();    this->GetGLTABLES()->AddQ();
1880    pResult = dbc->Query(myquery.str().c_str());    pResult = dbc->Query(myquery.str().c_str());
1881      if( pResult->GetRowCount() ){
1882            if (Row)
1883              delete Row;
1884        Row = pResult->Next();      
1885        if( Row ){
1886          stringstream fname;
1887          fname.str("");
1888          fname << gSystem->ExpandPathName(Row->GetField(0)) << "/" << Row->GetField(1);
1889          rname << Row->GetField(1);
1890          if ( usel0file ) file = new TFile(fname.str().c_str(),"READ");
1891          idtsy = (UInt_t)atoll(Row->GetField(2));
1892        };
1893      };
1894      //
1895      if ( usel0file && file && file->IsOpen() ){
1896        TTree *T=(TTree*)file->Get("Physics");
1897        pamela::EventHeader *eh = 0;
1898        pamela::PscuHeader *ph = 0;
1899        T->SetBranchAddress("Header", &eh);
1900        //
1901        T->GetEntry(0);
1902        ph = eh->GetPscuHeader();
1903        pktfirst = ph->GetCounter();
1904        //    obtfirst = ph->GetOrbitalTime();  
1905        //
1906      };
1907      if ( !usel0file ) pktfirst = 0;
1908      //
1909      // look for Resurs offset
1910      //
1911      T0 = 0;
1912      //
1913      stringstream oss;
1914      //
1915      TString name=rname.str().c_str();
1916      UInt_t dworbit = 0;
1917      //  Int_t nlength = name.Length();
1918      delete pResult;      
1919      //
1920      // New code, we have one more column on GL_TIMESYNC so we can trust that one for the Resurs offset
1921      //
1922      oss.str("");
1923      oss << "SELECT OBT0,TIMESYNC,TYPE,ID_RESURS_OFFSET from GL_TIMESYNC where ID=" << idtsy <<";";
1924      if ( !this->GetGLTABLES()->IsConnected(dbc) ) return;  
1925      this->GetGLTABLES()->AddQ();
1926      pResult = dbc->Query(oss.str().c_str());
1927      Bool_t fndit = false;
1928    if ( pResult ){    if ( pResult ){
1929            if (Row)
1930              delete Row;
1931      Row = pResult->Next();      Row = pResult->Next();
1932      if ( (Row != NULL) && ((UInt_t)atoll(Row->GetField(0)) > 0 ) ){      if ( Row ){
1933          //
1934        OBT0 = (UInt_t)atoll(Row->GetField(0));        OBT0 = (UInt_t)atoll(Row->GetField(0));
1935          obtfirst = OBT0;
1936        TIMESYNC = (UInt_t)atoll(Row->GetField(1));        TIMESYNC = (UInt_t)atoll(Row->GetField(1));
1937        TYPE = (UInt_t)atoll(Row->GetField(2));        TYPE = (UInt_t)atoll(Row->GetField(2));      
1938        toffset = (UInt_t)atoll(Row->GetField(1)) - (UInt_t)(this->DBobt((UInt_t)atoll(Row->GetField(0)))/1000) + T0;        //
1939          oss.str("");
1940          oss << "SELECT YEAR(OFFSET_DATE),MONTH(OFFSET_DATE),DAY(OFFSET_DATE),HOUR(OFFSET_DATE),MINUTE(OFFSET_DATE),SECOND(OFFSET_DATE) FROM GL_RESURS_OFFSET WHERE ID="
1941              << Row->GetField(3) << ";";
1942          if ( !this->GetGLTABLES()->IsConnected(dbc) ) return;  
1943          this->GetGLTABLES()->AddQ();
1944          delete pResult;
1945          pResult = dbc->Query(oss.str().c_str());
1946          if (pResult){
1947            if (Row)
1948              delete Row;
1949            Row = pResult->Next();
1950                if (Row){
1951                  //            printf(" GREAT! the DB structure is the new one! \n");
1952                fndit = true;
1953                dworbit = 1;
1954                };
1955          };
1956      };      };
1957    };    };
1958      if ( !fndit ){
1959        //
1960        printf(" ERROR OLD DB! \n");
1961        printf(" ERROR FROM GLTables! cannot determine Resurs offset \n");
1962        //
1963      };
1964    //    //
1965    file->Close();    TTimeStamp tu = TTimeStamp((UInt_t)atoi(Row->GetField(0)),(UInt_t)atoi(Row->GetField(1)),(UInt_t)atoi(Row->GetField(2)),(UInt_t)atoi(Row->GetField(3)),(UInt_t)atoi(Row->GetField(4)),(UInt_t)atoi(Row->GetField(5)),0,true,0);
1966      T0 = (UInt_t)tu.GetSec();
1967      //
1968      toffset = (UInt_t)TIMESYNC - (UInt_t)(this->DBobt(OBT0)/1000) + T0;
1969      //
1970      //  printf(" T0 %u toffset is %u \n",T0,toffset);
1971      //
1972      if ( file ) file->Close();
1973      if (Row)
1974        delete Row;
1975    delete pResult;          delete pResult;      
1976  };  };
1977    
# Line 1731  GL_TIMESYNC::GL_TIMESYNC(UInt_t id, TStr Line 1982  GL_TIMESYNC::GL_TIMESYNC(UInt_t id, TStr
1982   */   */
1983  UInt_t GL_TIMESYNC::DBabsTime(UInt_t OBT){    UInt_t GL_TIMESYNC::DBabsTime(UInt_t OBT){  
1984    //    //
1985      //  printf(" OBT %u DBobt %llu toffset %u dbabstime %u\n",OBT,this->DBobt(OBT),toffset,((UInt_t)(this->DBobt(OBT)/1000)+toffset));
1986    return(((UInt_t)(this->DBobt(OBT)/1000)+toffset));    return(((UInt_t)(this->DBobt(OBT)/1000)+toffset));
1987    //    //
1988  };  };
# Line 1769  Long64_t GL_TIMESYNC::DBpkt(UInt_t pkt_n Line 2021  Long64_t GL_TIMESYNC::DBpkt(UInt_t pkt_n
2021   */   */
2022  Long64_t GL_TIMESYNC::DBobt(UInt_t obt){    Long64_t GL_TIMESYNC::DBobt(UInt_t obt){  
2023    //    //
2024    if ( obt < (obtfirst/2) && obtfirst > (numeric_limits<UInt_t>::max()/2) ){    if ( obt < ((Long64_t)obtfirst/2) && obtfirst > (numeric_limits<UInt_t>::max()/2) ){
2025      return((Long64_t)obt+(Long64_t)numeric_limits<UInt_t>::max());      return((Long64_t)obt+(Long64_t)numeric_limits<UInt_t>::max());
2026    };    };
2027    //    //
2028    if ( obt > (obtfirst*2) && obt > (numeric_limits<UInt_t>::max()/2) ){    if ( obt > ((Long64_t)obtfirst*2) && obt > (numeric_limits<UInt_t>::max()/2) ){
2029      return((Long64_t)obt-(Long64_t)numeric_limits<UInt_t>::max());      return((Long64_t)obt-(Long64_t)numeric_limits<UInt_t>::max());
2030    };    };
2031    //    //
# Line 1990  Int_t GL_TLE::Query(UInt_t time, TSQLSer Line 2242  Int_t GL_TLE::Query(UInt_t time, TSQLSer
2242  //  //
2243  Int_t GL_TLE::DoQuery(TString myquery, TSQLServer *dbc){  Int_t GL_TLE::DoQuery(TString myquery, TSQLServer *dbc){
2244    TSQLResult *result;    TSQLResult *result;
2245    TSQLRow *row;    TSQLRow *row = NULL;
2246    
2247    // Set the right time_zone (otherwise horrible things will occur! :)    // Set the right time_zone (otherwise horrible things will occur! :)
2248    if ( !this->GetGLTABLES()->IsConnected(dbc) ) return -57;      if ( !this->GetGLTABLES()->IsConnected(dbc) ) return -57;  
# Line 2009  Int_t GL_TLE::DoQuery(TString myquery, T Line 2261  Int_t GL_TLE::DoQuery(TString myquery, T
2261    tle = GiveTle(row);    tle = GiveTle(row);
2262    
2263    tleFromTime = strtol(row->GetField(4), NULL, 10);    tleFromTime = strtol(row->GetField(4), NULL, 10);
2264      if (row)
2265        delete row;
2266    row = result->Next(); // second tle row    row = result->Next(); // second tle row
2267    if(row)    if(row)
2268      tleToTime = strtol(row->GetField(4), NULL, 10);      tleToTime = strtol(row->GetField(4), NULL, 10);
# Line 2018  Int_t GL_TLE::DoQuery(TString myquery, T Line 2271  Int_t GL_TLE::DoQuery(TString myquery, T
2271      tleToTime = UINT_MAX;      tleToTime = UINT_MAX;
2272    }    }
2273    
2274    delete row;    if (row)
2275        delete row;
2276    delete result;    delete result;
2277    
2278    return 0;    return 0;

Legend:
Removed from v.1.2  
changed lines
  Added in v.1.14

  ViewVC Help
Powered by ViewVC 1.1.23