00001 // -*- C++ -*- 00002 // 00003 // Package: WriteEcalMiscalibConstants 00004 // Class: WriteEcalMiscalibConstants 00005 // 00013 // 00014 // Original Author: Stephanie BEAUCERON 00015 // Created: Tue May 15 16:23:21 CEST 2007 00016 // $Id: WriteEcalMiscalibConstants.cc,v 1.4 2009/12/17 20:59:29 wmtan Exp $ 00017 // 00018 // 00019 00020 00021 // system include files 00022 00023 // user include files 00024 00025 00026 00027 00028 #include "FWCore/Framework/interface/ESHandle.h" 00029 #include "FWCore/Framework/interface/EventSetup.h" 00030 00031 // DB includes 00032 #include "FWCore/ServiceRegistry/interface/Service.h" 00033 #include "CondCore/DBOutputService/interface/PoolDBOutputService.h" 00034 00035 // user include files 00036 #include "CondFormats/EcalObjects/interface/EcalIntercalibConstants.h" 00037 #include "CondFormats/DataRecord/interface/EcalIntercalibConstantsRcd.h" 00038 //For Checks 00039 00040 //this one 00041 #include "CalibCalorimetry/CaloMiscalibTools/interface/WriteEcalMiscalibConstants.h" 00042 00043 // 00044 // static data member definitions 00045 // 00046 00047 // 00048 // constructors and destructor 00049 // 00050 WriteEcalMiscalibConstants::WriteEcalMiscalibConstants(const edm::ParameterSet& iConfig) 00051 { 00052 //now do what ever initialization is needed 00053 newTagRequest_ = iConfig.getParameter< std::string > ("NewTagRequest"); 00054 00055 00056 } 00057 00058 00059 WriteEcalMiscalibConstants::~WriteEcalMiscalibConstants() 00060 { 00061 00062 // do anything here that needs to be done at desctruction time 00063 // (e.g. close files, deallocate resources etc.) 00064 00065 } 00066 00067 00068 // 00069 // member functions 00070 // 00071 00072 // ------------ method called to for each event ------------ 00073 void 00074 WriteEcalMiscalibConstants::analyze(const edm::Event& iEvent, const edm::EventSetup& iSetup) 00075 { 00076 using namespace edm; 00077 // Intercalib constants 00078 edm::ESHandle<EcalIntercalibConstants> pIcal; 00079 iSetup.get<EcalIntercalibConstantsRcd>().get(pIcal); 00080 const EcalIntercalibConstants* Mcal = pIcal.product(); 00081 00082 edm::Service<cond::service::PoolDBOutputService> poolDbService; 00083 if( poolDbService.isAvailable() ){ 00084 if ( poolDbService->isNewTagRequest(newTagRequest_) ){ 00085 std::cout<<" Creating a new one "<<std::endl; 00086 poolDbService->createNewIOV<const EcalIntercalibConstants>( Mcal, poolDbService->beginOfTime(), poolDbService->endOfTime(),newTagRequest_); 00087 std::cout<<"Done" << std::endl; 00088 }else{ 00089 std::cout<<"Old One "<<std::endl; 00090 poolDbService->appendSinceTime<const EcalIntercalibConstants>( Mcal, poolDbService->currentTime(),newTagRequest_); 00091 } 00092 } 00093 } 00094 00095 00096 // ------------ method called once each job just before starting event loop ------------ 00097 void 00098 WriteEcalMiscalibConstants::beginJob() 00099 { 00100 } 00101 00102 // ------------ method called once each job just after ending the event loop ------------ 00103 void 00104 00105 WriteEcalMiscalibConstants::endJob() { 00106 std::cout << "Here is the end" << std::endl; 00107 } 00108