5 #include <xercesc/dom/DOMNode.hpp> 6 #include <xercesc/dom/DOM.hpp> 7 #include <xercesc/parsers/XercesDOMParser.hpp> 10 #include <xercesc/util/XMLString.hpp> 11 #include <xercesc/sax/SAXException.hpp> 12 #include <xercesc/framework/LocalFileFormatTarget.hpp> 30 XercesDOMParser*
parser =
new XercesDOMParser;
31 parser->setValidationScheme( XercesDOMParser::Val_Never );
32 parser->setDoNamespaces(
false );
33 parser->setDoSchema(
false );
35 parser->parse(filename.c_str());
37 DOMDocument* xmlDoc = parser->getDocument();
41 std::cout <<
"EcalClusterEnergyCorrectionObjectSpecificXMLTranslator::Error parsing document" 46 DOMElement* elementRoot = xmlDoc->getDocumentElement();
62 unique_ptr<DOMImplementation>
impl( DOMImplementationRegistry::getDOMImplementation(
cms::xerces::uStr(
"LS").ptr()));
64 DOMLSSerializer*
writer = impl->createLSSerializer();
65 if( writer->getDomConfig()->canSetParameter( XMLUni::fgDOMWRTFormatPrettyPrint,
true ))
66 writer->getDomConfig()->setParameter( XMLUni::fgDOMWRTFormatPrettyPrint,
true );
68 DOMDocumentType* doctype =
70 const std::string ECECOS_tag(
"EcalClusterEnergyCorrectionObjectSpecific");
72 impl->createDocument(
nullptr,
cms::xerces::uStr(ECECOS_tag.c_str()).ptr(), doctype );
74 DOMElement*
root = doc->getDocumentElement();
77 const std::string ECEC_tag[9] = {
"fEta",
"fBremEtaElectrons",
"fBremEtaPhotons",
78 "fEtElectronsEB",
"fEtElectronsEE",
"fEtPhotonsEB",
"fEtPhotonsEE",
79 "fEnergyElectronsEE",
"fEnergyPhotonsEE"};
82 for ( EcalFunctionParameters::const_iterator it = record.
params().begin(); it != record.
params().end(); ++it ) {
84 else if(par < 86) tit = 1;
85 else if(par < 170) tit = 2;
86 else if(par < 177) tit = 3;
87 else if(par < 184) tit = 4;
88 else if(par < 191) tit = 5;
89 else if(par < 198) tit = 6;
90 else if(par < 203) tit = 7;
93 root->getOwnerDocument()->createElement(
cms::xerces::uStr(ECEC_tag[tit].c_str()).ptr());
94 root->appendChild(ECEC);
117 std::fstream fs(filename.c_str(),
ios::out);
static int writeXML(const std::string &filename, const EcalCondHeader &header, const EcalFunParams &record)
void WriteNodeWithValue(xercesc::DOMNode *parentNode, const std::string &tag, const T &value)
write a node with
const std::string Value_tag("Value")
std::string toString(XMLCh const *toTranscode)
static int readXML(const std::string &filename, EcalCondHeader &header, EcalFunParams &record)
void readHeader(xercesc::DOMNode *parentNode, EcalCondHeader &header)
read header from
EcalFunctionParameters & params()
void writeHeader(xercesc::DOMNode *parentNode, const EcalCondHeader &header)
write
ZStr< XMLCh > uStr(char const *str)
static std::string dumpXML(const EcalCondHeader &header, const EcalFunParams &record)