CMS 3D CMS Logo

/afs/cern.ch/work/a/aaltunda/public/www/CMSSW_5_3_13_patch3/src/CondTools/Ecal/interface/EcalTPGBadStripHandler.h

Go to the documentation of this file.
00001 #ifndef ECAL_TPG_BADSTRIP_HANDLER_H
00002 #define ECAL_TPG_BADSTRIP_HANDLER_H
00003 
00004 #include <vector>
00005 #include <typeinfo>
00006 #include <string>
00007 #include <map>
00008 #include <iostream>
00009 #include <time.h>
00010 
00011 #include "CondCore/PopCon/interface/PopConSourceHandler.h"
00012 #include "FWCore/ParameterSet/interface/ParameterSetfwd.h"
00013 
00014 
00015 #include "FWCore/ServiceRegistry/interface/Service.h"
00016 #include "CondCore/DBOutputService/interface/PoolDBOutputService.h"
00017 #include "FWCore/Framework/interface/ESHandle.h"
00018 #include "FWCore/Framework/interface/Event.h"
00019 #include "FWCore/Framework/interface/MakerMacros.h"
00020 #include "FWCore/MessageLogger/interface/MessageLogger.h"
00021 #include "FWCore/ParameterSet/interface/ParameterSet.h"
00022 #include "DataFormats/Common/interface/Handle.h"
00023 #include "FWCore/Framework/interface/EventSetup.h"
00024 #include "FWCore/Framework/interface/EventSetupRecordKey.h"
00025 
00026 
00027 
00028 #include "CondFormats/EcalObjects/interface/EcalTPGStripStatus.h"
00029 #include "CondFormats/DataRecord/interface/EcalTPGStripStatusRcd.h"
00030 
00031 #include "OnlineDB/EcalCondDB/interface/all_monitoring_types.h"
00032 #include "OnlineDB/Oracle/interface/Oracle.h"
00033 #include "OnlineDB/EcalCondDB/interface/EcalCondDBInterface.h"
00034 
00035 #include "DataFormats/EcalDetId/interface/EEDetId.h"
00036 #include "DataFormats/EcalDetId/interface/EBDetId.h"
00037 #include "DataFormats/Provenance/interface/Timestamp.h"
00038 
00039 namespace edm {
00040   class ParameterSet;
00041   class Event;
00042   class EventSetup;
00043 }
00044 
00045 namespace popcon
00046 {
00047 
00048 
00049         class EcalTPGBadStripHandler : public popcon::PopConSourceHandler<EcalTPGStripStatus>
00050         {
00051 
00052                 public:
00053                         EcalTPGBadStripHandler(edm::ParameterSet const & );
00054                         ~EcalTPGBadStripHandler(); 
00055                         
00056                         void getNewObjects();
00057                         
00058                         std::map<std::string, int> makeTTEEDetId();
00059                         
00060                         std::string id() const { return m_name;}
00061                         
00062                         void readFromFile(const char* inputFile) ;
00063                         void writeFile(const char* inputFile);
00064                         
00065                         EcalCondDBInterface* econn;
00066 
00067                 private:
00068                         std::string to_string( char value[]) {
00069                           std::ostringstream streamOut;
00070                           streamOut << value;
00071                           return streamOut.str();
00072                         }
00073                         
00074                         const EcalTPGStripStatus * mystripStat;
00075 
00076                         unsigned int m_firstRun ;
00077                         unsigned int m_lastRun ;
00078                         std::map <std::string, int> mapDetEEId;
00079                         
00080                         std::string m_location;
00081                         std::string m_gentag;
00082                         std::string m_sid;
00083                         std::string m_user;
00084                         std::string m_pass;
00085                         std::string m_locationsource;
00086                         std::string m_name;
00087                         unsigned int m_runnr;
00088                         std::string m_runtype;
00089                         std::string m_i_tag;
00090                         int m_i_version;
00091                         unsigned int m_i_run_number;
00092                         int m_i_badStrip;
00093         };
00094 }
00095 #endif
00096