5 #include <xercesc/dom/DOMNode.hpp>
6 #include <xercesc/dom/DOM.hpp>
7 #include <xercesc/parsers/XercesDOMParser.hpp>
8 #include <xercesc/util/PlatformUtils.hpp>
9 #include <xercesc/util/XMLString.hpp>
10 #include <xercesc/sax/SAXException.hpp>
11 #include <xercesc/framework/LocalFileFormatTarget.hpp>
16 using namespace XERCES_CPP_NAMESPACE;
27 XMLPlatformUtils::Initialize();
29 XercesDOMParser*
parser =
new XercesDOMParser;
30 parser->setValidationScheme( XercesDOMParser::Val_Never );
31 parser->setDoNamespaces(
false );
32 parser->setDoSchema(
false );
34 parser->parse(filename.c_str());
36 DOMDocument* xmlDoc = parser->getDocument();
40 std::cout <<
"EcalClusterEnergyCorrectionXMLTranslator::Error parsing document" << std::endl;
44 DOMElement* elementRoot = xmlDoc->getDocumentElement();
51 XMLPlatformUtils::Terminate();
60 XMLPlatformUtils::Initialize();
62 DOMImplementation* impl =
63 DOMImplementationRegistry::getDOMImplementation(
fromNative(
"LS").c_str());
66 static_cast<DOMImplementationLS*
>(impl)->createDOMWriter( );
67 writer->setFeature(XMLUni::fgDOMWRTFormatPrettyPrint,
true);
69 DOMDocumentType* doctype =
70 impl->createDocumentType(
fromNative(
"XML").c_str(), 0, 0 );
71 const std::string EcalClusterEnergyCorrection_tag(
"EcalClusterEnergyCorrection");
73 impl->createDocument( 0,
fromNative(EcalClusterEnergyCorrection_tag).c_str(), doctype );
76 doc->setEncoding(
fromNative(
"UTF-8").c_str() );
77 doc->setStandalone(
true);
81 DOMElement*
root = doc->getDocumentElement();
84 const std::string ECEC_tag(
"ClusterEnergy");
85 for ( EcalFunctionParameters::const_iterator it = record.
params().begin(); it != record.
params().end(); ++it ) {
87 root->getOwnerDocument()->createElement(
fromNative(ECEC_tag).c_str());
88 root->appendChild(ECEC);
93 std::string
dump=
toNative(writer->writeToString(*root));
104 std::fstream fs(filename.c_str(),
ios::out);
static int writeXML(const std::string &filename, const EcalCondHeader &header, const EcalFunParams &record)
static std::string dumpXML(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")
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
XercesString fromNative(const char *str)
std::string toNative(const XMLCh *str)
string root
initialization