#include <RunDCSMagnetDat.h>
Public Types | |
typedef oracle::occi::ResultSet | ResultSet |
Public Member Functions | |
std::string | getMagnetAccount () |
float | getMagnetCurrent () const |
std::string | getTable () |
Tm | getTime () const |
RunDCSMagnetDat () | |
void | setMagnetCurrent (float t) |
void | setTime (Tm start) |
~RunDCSMagnetDat () | |
Private Member Functions | |
void | fetchData (std::map< EcalLogicID, RunDCSMagnetDat > *fillMap, RunIOV *iov) throw (std::runtime_error) |
void | fetchLastData (std::map< EcalLogicID, RunDCSMagnetDat > *fillMap) throw (std::runtime_error) |
void | fillTheMap (ResultSet *, std::map< EcalLogicID, RunDCSMagnetDat > *) |
ResultSet * | getMagnetRset () |
int | nowMicroseconds () |
void | prepareWrite () throw (std::runtime_error) |
void | writeDB (const EcalLogicID *ecid, const RunDCSMagnetDat *item, RunIOV *iov) throw (std::runtime_error) |
Private Attributes | |
float | m_current |
Tm | m_time |
Friends | |
class | EcalCondDBInterface |
Definition at line 15 of file RunDCSMagnetDat.h.
Definition at line 17 of file RunDCSMagnetDat.h.
RunDCSMagnetDat::RunDCSMagnetDat | ( | ) |
Definition at line 15 of file RunDCSMagnetDat.cc.
References NULL.
RunDCSMagnetDat::~RunDCSMagnetDat | ( | ) |
Definition at line 28 of file RunDCSMagnetDat.cc.
{ }
void RunDCSMagnetDat::fetchData | ( | std::map< EcalLogicID, RunDCSMagnetDat > * | fillMap, |
RunIOV * | iov | ||
) | throw (std::runtime_error) [private] |
void RunDCSMagnetDat::fetchLastData | ( | std::map< EcalLogicID, RunDCSMagnetDat > * | fillMap | ) | throw (std::runtime_error) [private] |
Definition at line 355 of file RunDCSHVDat.cc.
References edm::pset::fillMap(), and L1TEmulatorMonitor_cff::p.
{ this->checkConnection(); fillMap->clear(); try { std::pair< EcalLogicID, RunDCSHVDat > p; RunDCSHVDat dat; ResultSet* rset = getBarrelRset(); fillTheMap(rset, fillMap); rset = getEndcapAnodeRset(); fillTheMap(rset, fillMap); rset = getEndcapDynodeRset(); fillTheMap(rset, fillMap); } catch (SQLException &e) { throw(std::runtime_error("RunDCSHVDat::fetchData(): "+e.getMessage())); } }
void RunDCSMagnetDat::fillTheMap | ( | ResultSet * | , |
std::map< EcalLogicID, RunDCSMagnetDat > * | |||
) | [private] |
Definition at line 204 of file RunDCSHVDat.cc.
References DateHandler::dateToTm(), L1TEmulatorMonitor_cff::p, RunDCSHVDat::setHV(), RunDCSHVDat::setHVNominal(), and RunDCSHVDat::setStatus().
{ // method for last value queries std::pair< EcalLogicID, RunDCSHVDat > p; RunDCSHVDat dat; DateHandler dh(m_env, m_conn); try { while(rset->next()) { p.first = EcalLogicID( rset->getString(1), // name rset->getInt(2), // logic_id rset->getInt(3), // id1 rset->getInt(4), // id2 rset->getInt(5), // id3 rset->getString(6)); // maps_to dat.setHV( rset->getFloat(7) ); dat.setHVNominal( rset->getFloat(8) ); Date sinceDate = rset->getDate(9); Tm sinceTm = dh.dateToTm( sinceDate ); dat.setStatus(0); if (p.first.getName() == "EB_HV_channel") { setStatusForBarrel(dat, sinceTm); } else { setStatusForEndcaps(dat, sinceTm); } p.second = dat; fillMap->insert(p); } } catch (SQLException &e) { throw(std::runtime_error("RunDCSHVDat::fetchData(): "+e.getMessage())); } }
std::string RunDCSMagnetDat::getMagnetAccount | ( | ) | [inline] |
Definition at line 25 of file RunDCSMagnetDat.h.
{ return "CMS_DCS_ENV_PVSS_COND"; }
float RunDCSMagnetDat::getMagnetCurrent | ( | ) | const [inline] |
Definition at line 27 of file RunDCSMagnetDat.h.
References m_current.
Referenced by popcon::EcalIntercalibHandler::getNewObjects().
{ return m_current; }
ResultSet * RunDCSMagnetDat::getMagnetRset | ( | ) | [private] |
Definition at line 73 of file RunDCSMagnetDat.cc.
References gather_cfg::cout, NULL, and o2o::query.
{ DateHandler dh(m_env, m_conn); ResultSet* rset = NULL; string query="SELECT c.name, c.logic_id, c.id1, c.id2, c.id3, c.maps_to , v.value_number, v.change_date from "+ getMagnetAccount()+ ".CMSFWMAGNET_LV v, channelview c where v.dpe_name= 'CURRENT' and c.name=maps_to and c.name='EB' " ; try { std::cout<<"query:"<<query<<std::endl; m_readStmt->setSQL(query); rset = m_readStmt->executeQuery(); } catch (SQLException e) { throw(std::runtime_error("RunDCSMagnetDat::getBarrelRset(): " + e.getMessage() + " " + query)); } return rset; }
std::string RunDCSMagnetDat::getTable | ( | ) | [inline, virtual] |
Tm RunDCSMagnetDat::getTime | ( | void | ) | const |
Definition at line 37 of file RunDCSMagnetDat.cc.
{ return m_time; }
int RunDCSMagnetDat::nowMicroseconds | ( | ) | [private] |
Definition at line 135 of file RunDCSMagnetDat.cc.
References Tm::microsTime(), and Tm::setToCurrentGMTime().
{ Tm t_now_gmt; t_now_gmt.setToCurrentGMTime(); int t_now_gmt_micros = t_now_gmt.microsTime(); return t_now_gmt_micros; }
void RunDCSMagnetDat::prepareWrite | ( | ) | throw (std::runtime_error) [private, virtual] |
void RunDCSMagnetDat::setMagnetCurrent | ( | float | t | ) | [inline] |
Definition at line 26 of file RunDCSMagnetDat.h.
References m_current, and matplotRender::t.
void RunDCSMagnetDat::setTime | ( | Tm | start | ) |
Definition at line 32 of file RunDCSMagnetDat.cc.
{ m_time = start; }
void RunDCSMagnetDat::writeDB | ( | const EcalLogicID * | ecid, |
const RunDCSMagnetDat * | item, | ||
RunIOV * | iov | ||
) | throw (std::runtime_error) [private] |
Definition at line 55 of file RunDCSMagnetDat.cc.
{ }
friend class EcalCondDBInterface [friend] |
Reimplemented from IDBObject.
Definition at line 19 of file RunDCSMagnetDat.h.
float RunDCSMagnetDat::m_current [private] |
Definition at line 53 of file RunDCSMagnetDat.h.
Referenced by getMagnetCurrent(), and setMagnetCurrent().
Tm RunDCSMagnetDat::m_time [private] |
Definition at line 54 of file RunDCSMagnetDat.h.