00001 #ifndef LMFLASERIREDCOEFFDAT_H 00002 #define LMFLASERIREDCOEFFDAT_H 00003 00004 #include <map> 00005 #include <stdexcept> 00006 00007 #include "OnlineDB/EcalCondDB/interface/IDataItem.h" 00008 #include "OnlineDB/EcalCondDB/interface/LMFRunTag.h" 00009 #include "OnlineDB/EcalCondDB/interface/LMFRunIOV.h" 00010 #include "OnlineDB/EcalCondDB/interface/EcalLogicID.h" 00011 00012 class LMFLaserIRedCoeffDat : public IDataItem { 00013 public: 00014 friend class EcalCondDBInterface; 00015 LMFLaserIRedCoeffDat(); 00016 ~LMFLaserIRedCoeffDat(); 00017 00018 // User data methods 00019 inline std::string getTable() { return "LMF_LASER_IRED_COEFF_DAT"; } 00020 00021 inline void setXportCoeff(float c) { m_xportCoeff = c; } 00022 inline float getXportCoeff() const { return m_xportCoeff; } 00023 00024 inline void setXportCoeffRMS(float rms) { m_xportCoeffRMS = rms; } 00025 inline float getXportCoeffRMS() const { return m_xportCoeffRMS; } 00026 00027 00028 private: 00029 void prepareWrite() 00030 throw(std::runtime_error); 00031 00032 void writeDB(const EcalLogicID* ecid, const LMFLaserIRedCoeffDat* item, LMFRunIOV* iov) 00033 throw(std::runtime_error); 00034 00035 void fetchData(std::map< EcalLogicID, LMFLaserIRedCoeffDat >* fillVec, LMFRunIOV* iov) 00036 throw(std::runtime_error); 00037 00038 // User data 00039 float m_xportCoeff; 00040 float m_xportCoeffRMS; 00041 00042 }; 00043 00044 #endif