MiscalibReaderFromXML

Macros

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43
#ifndef MiscalibReaderFromXML_H
#define MiscalibReaderFromXML_H

/** \class MiscalibReaderFromXML
 * *
 *  Parses the xml file to get miscalibration constants
 * 
 *  \author Lorenzo Agostino
  */

#include <xercesc/dom/DOMNode.hpp>
#include <xercesc/dom/DOM.hpp>
#include <xercesc/dom/DOMCharacterData.hpp>
#include <xercesc/parsers/XercesDOMParser.hpp>
#include "Utilities/Xerces/interface/Xerces.h"
#include <xercesc/framework/LocalFileFormatTarget.hpp>
#include <xercesc/util/XMLUni.hpp>
#include <xercesc/util/XMLURL.hpp>
#include "CalibCalorimetry/CaloMiscalibTools/interface/CaloMiscalibMap.h"

#include <iostream>
#include <string>
#include <vector>
#include <map>

class MiscalibReaderFromXML {
public:
  MiscalibReaderFromXML(CaloMiscalibMap &);
  virtual ~MiscalibReaderFromXML() {}

  bool parseXMLMiscalibFile(std::string configFile);

  virtual DetId parseCellEntry(XERCES_CPP_NAMESPACE::DOMNamedNodeMap *attribute) = 0;
  int getIntAttribute(XERCES_CPP_NAMESPACE::DOMNamedNodeMap *attribute, const std::string &attribute_name);
  double getScalingFactor(XERCES_CPP_NAMESPACE::DOMNamedNodeMap *attribute);
  double getFloatAttribute(XERCES_CPP_NAMESPACE::DOMNamedNodeMap *attribute, const std::string &attribute_name);

private:
  static int s_numberOfInstances;
  CaloMiscalibMap &caloMap_;
};

#endif