mirror of
				https://github.com/pocoproject/poco.git
				synced 2025-10-26 10:32:56 +01:00 
			
		
		
		
	made XMLConfiguration fully writable
This commit is contained in:
		| @@ -1,13 +1,13 @@ | ||||
| // | ||||
| // XMLConfiguration.cpp | ||||
| // | ||||
| // $Id: //poco/1.3/Util/src/XMLConfiguration.cpp#1 $ | ||||
| // $Id: //poco/Main/Util/src/XMLConfiguration.cpp#8 $ | ||||
| // | ||||
| // Library: Util | ||||
| // Package: Configuration | ||||
| // Module:  XMLConfiguration | ||||
| // | ||||
| // Copyright (c) 2004-2008, Applied Informatics Software Engineering GmbH. | ||||
| // Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH. | ||||
| // and Contributors. | ||||
| // | ||||
| // Permission is hereby granted, free of charge, to any person or organization | ||||
| @@ -39,8 +39,6 @@ | ||||
| #include "Poco/DOM/DOMParser.h" | ||||
| #include "Poco/DOM/Element.h" | ||||
| #include "Poco/DOM/Attr.h" | ||||
| #include "Poco/DOM/DOMWriter.h" | ||||
| #include "Poco/DOM/DOMException.h" | ||||
| #include "Poco/DOM/Text.h" | ||||
| #include "Poco/XML/XMLWriter.h" | ||||
| #include "Poco/Exception.h" | ||||
| @@ -144,7 +142,15 @@ void XMLConfiguration::load(const Poco::XML::Node* pNode) | ||||
| } | ||||
|  | ||||
|  | ||||
| void XMLConfiguration::save(const std::string& path) | ||||
| void XMLConfiguration::loadEmpty(const std::string& rootElementName) | ||||
| { | ||||
| 	_pDocument = new Poco::XML::Document; | ||||
| 	_pRoot     = _pDocument->createElement(rootElementName); | ||||
| 	_pDocument->appendChild(_pRoot); | ||||
| } | ||||
|  | ||||
|  | ||||
| void XMLConfiguration::save(const std::string& path) const | ||||
| { | ||||
| 	Poco::XML::DOMWriter writer; | ||||
| 	writer.setNewLine("\n"); | ||||
| @@ -153,7 +159,7 @@ void XMLConfiguration::save(const std::string& path) | ||||
| } | ||||
|  | ||||
|  | ||||
| void XMLConfiguration::save(std::ostream& ostr) | ||||
| void XMLConfiguration::save(std::ostream& ostr) const | ||||
| { | ||||
| 	Poco::XML::DOMWriter writer; | ||||
| 	writer.setNewLine("\n"); | ||||
| @@ -162,6 +168,18 @@ void XMLConfiguration::save(std::ostream& ostr) | ||||
| } | ||||
|  | ||||
|  | ||||
| void XMLConfiguration::save(Poco::XML::DOMWriter& writer, const std::string& path) const | ||||
| { | ||||
| 	writer.writeNode(path, _pDocument); | ||||
| } | ||||
|  | ||||
|  | ||||
| void XMLConfiguration::save(Poco::XML::DOMWriter& writer, std::ostream& ostr) const | ||||
| { | ||||
| 	writer.writeNode(ostr, _pDocument); | ||||
| } | ||||
|  | ||||
|  | ||||
| bool XMLConfiguration::getRaw(const std::string& key, std::string& value) const | ||||
| { | ||||
| 	const Poco::XML::Node* pNode = findNode(key); | ||||
| @@ -176,8 +194,8 @@ bool XMLConfiguration::getRaw(const std::string& key, std::string& value) const | ||||
|  | ||||
| void XMLConfiguration::setRaw(const std::string& key, const std::string& value) | ||||
| { | ||||
|     Poco::XML::Node* pNode = const_cast<Poco::XML::Node*>(findNode(key)); | ||||
|  | ||||
| 	std::string::const_iterator it = key.begin(); | ||||
| 	Poco::XML::Node* pNode = findNode(it, key.end(), _pRoot, true); | ||||
| 	if (pNode) | ||||
| 	{ | ||||
|         unsigned short nodeType = pNode->nodeType(); | ||||
| @@ -195,6 +213,11 @@ void XMLConfiguration::setRaw(const std::string& key, const std::string& value) | ||||
|                     pChildNode->setNodeValue(value); | ||||
|                 } | ||||
|             } | ||||
|             else | ||||
|             { | ||||
| 				Poco::AutoPtr<Poco::XML::Node> pText = _pDocument->createTextNode(value); | ||||
| 				pNode->appendChild(pText); | ||||
|             } | ||||
|         } | ||||
| 	} | ||||
|     else throw NotFoundException("Node not found in XMLConfiguration", key); | ||||
| @@ -231,11 +254,12 @@ void XMLConfiguration::enumerate(const std::string& key, Keys& range) const | ||||
| const Poco::XML::Node* XMLConfiguration::findNode(const std::string& key) const | ||||
| { | ||||
| 	std::string::const_iterator it = key.begin(); | ||||
| 	return findNode(it, key.end(), _pRoot); | ||||
| 	Poco::XML::Node* pRoot = const_cast<Poco::XML::Node*>(_pRoot.get()); | ||||
| 	return findNode(it, key.end(), pRoot); | ||||
| } | ||||
|  | ||||
|  | ||||
| const Poco::XML::Node* XMLConfiguration::findNode(std::string::const_iterator& it, const std::string::const_iterator& end, const Poco::XML::Node* pNode) | ||||
| Poco::XML::Node* XMLConfiguration::findNode(std::string::const_iterator& it, const std::string::const_iterator& end, Poco::XML::Node* pNode, bool create) | ||||
| { | ||||
| 	if (pNode && it != end) | ||||
| 	{ | ||||
| @@ -248,14 +272,14 @@ const Poco::XML::Node* XMLConfiguration::findNode(std::string::const_iterator& i | ||||
| 				std::string attr; | ||||
| 				while (it != end && *it != ']') attr += *it++; | ||||
| 				if (it != end) ++it; | ||||
| 				return findAttribute(attr, pNode); | ||||
| 				return findAttribute(attr, pNode, create); | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				std::string index; | ||||
| 				while (it != end && *it != ']') index += *it++; | ||||
| 				if (it != end) ++it; | ||||
| 				return findNode(it, end, findElement(Poco::NumberParser::parse(index), pNode)); | ||||
| 				return findNode(it, end, findElement(Poco::NumberParser::parse(index), pNode, create), create); | ||||
| 			} | ||||
| 		} | ||||
| 		else | ||||
| @@ -263,29 +287,35 @@ const Poco::XML::Node* XMLConfiguration::findNode(std::string::const_iterator& i | ||||
| 			while (it != end && *it == '.') ++it; | ||||
| 			std::string key; | ||||
| 			while (it != end && *it != '.' && *it != '[') key += *it++; | ||||
| 			return findNode(it, end, findElement(key, pNode)); | ||||
| 			return findNode(it, end, findElement(key, pNode, create), create); | ||||
| 		} | ||||
| 	} | ||||
| 	else return pNode; | ||||
| } | ||||
|  | ||||
|  | ||||
| const Poco::XML::Node* XMLConfiguration::findElement(const std::string& name, const Poco::XML::Node* pNode) | ||||
| Poco::XML::Node* XMLConfiguration::findElement(const std::string& name, Poco::XML::Node* pNode, bool create) | ||||
| { | ||||
| 	const Poco::XML::Node* pChild = pNode->firstChild(); | ||||
| 	Poco::XML::Node* pChild = pNode->firstChild(); | ||||
| 	while (pChild) | ||||
| 	{ | ||||
| 		if (pChild->nodeType() == Poco::XML::Node::ELEMENT_NODE && pChild->nodeName() == name) | ||||
| 			return pChild; | ||||
| 		pChild = pChild->nextSibling(); | ||||
| 	} | ||||
| 	return 0; | ||||
| 	if (create) | ||||
| 	{ | ||||
| 		Poco::AutoPtr<Poco::XML::Element> pElem = pNode->ownerDocument()->createElement(name); | ||||
| 		pNode->appendChild(pElem); | ||||
| 		return pElem; | ||||
| 	} | ||||
| 	else return 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| const Poco::XML::Node* XMLConfiguration::findElement(int index, const Poco::XML::Node* pNode) | ||||
| Poco::XML::Node* XMLConfiguration::findElement(int index, Poco::XML::Node* pNode, bool create) | ||||
| { | ||||
| 	const Poco::XML::Node* pRefNode = pNode; | ||||
| 	Poco::XML::Node* pRefNode = pNode; | ||||
| 	if (index > 0) | ||||
| 	{ | ||||
| 		pNode = pNode->nextSibling(); | ||||
| @@ -298,17 +328,35 @@ const Poco::XML::Node* XMLConfiguration::findElement(int index, const Poco::XML: | ||||
| 			pNode = pNode->nextSibling(); | ||||
| 		} | ||||
| 	} | ||||
| 	if (!pNode && create) | ||||
| 	{ | ||||
| 		if (index == 1) | ||||
| 		{ | ||||
| 			Poco::AutoPtr<Poco::XML::Element> pElem = pRefNode->ownerDocument()->createElement(pRefNode->nodeName()); | ||||
| 			pRefNode->parentNode()->appendChild(pElem); | ||||
| 			return pElem; | ||||
| 		} | ||||
| 		else throw Poco::InvalidArgumentException("Element index out of range."); | ||||
| 	} | ||||
| 	return pNode; | ||||
| } | ||||
|  | ||||
|  | ||||
| const Poco::XML::Node* XMLConfiguration::findAttribute(const std::string& name, const Poco::XML::Node* pNode) | ||||
| Poco::XML::Node* XMLConfiguration::findAttribute(const std::string& name, Poco::XML::Node* pNode, bool create) | ||||
| { | ||||
| 	const Poco::XML::Element* pElem = dynamic_cast<const Poco::XML::Element*>(pNode); | ||||
| 	Poco::XML::Node* pResult(0); | ||||
| 	Poco::XML::Element* pElem = dynamic_cast<Poco::XML::Element*>(pNode); | ||||
| 	if (pElem) | ||||
| 		return pElem->getAttributeNode(name); | ||||
| 	else | ||||
| 		return 0; | ||||
| 	{ | ||||
| 		pResult = pElem->getAttributeNode(name); | ||||
| 		if (!pResult && create) | ||||
| 		{ | ||||
| 			Poco::AutoPtr<Poco::XML::Attr> pAttr = pNode->ownerDocument()->createAttribute(name); | ||||
| 			pElem->setAttributeNode(pAttr); | ||||
| 			return pAttr; | ||||
| 		} | ||||
| 	} | ||||
| 	return pResult; | ||||
| } | ||||
|  | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Guenter Obiltschnig
					Guenter Obiltschnig