CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
RPCTempSH.cc
Go to the documentation of this file.
1 /*
2  * See headers for a description
3  *
4  * \author D. Pagano - Dip. Fis. Nucl. e Teo. & INFN Pavia
5  */
6 
11 
12 #include <iostream>
13 
15  : m_name(pset.getUntrackedParameter<std::string>("name", "RpcData")),
16  host(pset.getUntrackedParameter<std::string>("host", "source db host")),
17  user(pset.getUntrackedParameter<std::string>("user", "source username")),
18  passw(pset.getUntrackedParameter<std::string>("passw", "source password")),
19  m_since(pset.getUntrackedParameter<unsigned long long>("since", 5)),
20  m_till(pset.getUntrackedParameter<unsigned long long>("till", 0)) {}
21 
23 
25  std::cout << "------- " << m_name << " - > getNewObjects\n"
26  << "got offlineInfo " << tagInfo().name << ", size " << tagInfo().size << ", last object valid since "
27  << tagInfo().lastInterval.since << " token " << tagInfo().lastInterval.payloadId << std::endl;
28 
29  std::cout << " ------ last entry info regarding the payload (if existing): " << logDBEntry().usertext
30  << "last record with the correct tag has been written in the db: " << logDBEntry().destinationDB
31  << std::endl;
32 
33  // snc = tagInfo().lastInterval.first;
34 
35  std::cout << std::endl << "=============================================" << std::endl;
36  std::cout << std::endl << "================ TEMPERATURE ==============" << std::endl;
37  std::cout << std::endl << "=============================================" << std::endl << std::endl;
38  snc = m_since;
39  std::cout << ">> Range mode [" << snc << ", " << m_till << "]" << std::endl;
40  std::cout << std::endl << "=============================================" << std::endl << std::endl;
41 
42  RPCFw caen(host, user, passw);
43  std::vector<RPCObTemp::T_Item> Tcheck;
44 
45  Tcheck = caen.createT(snc, m_till);
46  Tdata = new RPCObTemp();
47  RPCObTemp::T_Item Tfill;
48  std::vector<RPCObTemp::T_Item>::iterator Tit;
49  for (Tit = Tcheck.begin(); Tit != Tcheck.end(); Tit++) {
50  Tfill = *(Tit);
51  Tdata->ObTemp_rpc.push_back(Tfill);
52  }
53  std::cout << " >> Final object size: " << Tdata->ObTemp_rpc.size() << std::endl;
54 
55  if (!Tdata->ObTemp_rpc.empty()) {
56  niov = snc;
57  } else {
58  niov = snc;
59  std::cout << "NO DATA TO BE STORED" << std::endl;
60  }
61 
62  ::timeval tv;
63  tv.tv_sec = niov;
64  tv.tv_usec = 0;
65  edm::Timestamp tmstamp((unsigned long long)tv.tv_sec * 1000000 + (unsigned long long)tv.tv_usec);
66  std::cout << "UNIX time = " << tmstamp.value() << std::endl;
67 
68  edm::TimeValue_t daqtime = 0LL;
69  daqtime = tv.tv_sec;
70  daqtime = (daqtime << 32) + tv.tv_usec;
71  edm::Timestamp daqstamp(daqtime);
72  edm::TimeValue_t dtime = daqstamp.value();
73  std::cout << "DAQ time = " << dtime << std::endl;
74 
75  niov = dtime;
76 
77  std::cout << "===> New IOV: since is = " << niov << std::endl;
78 
79  m_to_transfer.push_back(std::make_pair((RPCObTemp*)Tdata, niov));
80 }
Definition: RPCFw.h:29
~RpcDataT() override
Definition: RPCTempSH.cc:22
std::vector< RPCObTemp::T_Item > createT(long long since, long long till)
Definition: RPCFw.cc:455
unsigned long long TimeValue_t
Definition: Timestamp.h:28
string host
Definition: query.py:115
void getNewObjects() override
Definition: RPCTempSH.cc:24
tuple cout
Definition: gather_cfg.py:144
RpcDataT(const edm::ParameterSet &pset)
Definition: RPCTempSH.cc:14
TimeValue_t value() const
Definition: Timestamp.h:45