diff options
Diffstat (limited to 'src/support')
| -rw-r--r-- | src/support/dom/document_cache.cc | 32 | ||||
| -rw-r--r-- | src/support/dom/document_cache.h | 10 | ||||
| -rw-r--r-- | src/support/dom/document_cache_item.cc | 43 | ||||
| -rw-r--r-- | src/support/dom/document_cache_item.h | 10 | ||||
| -rw-r--r-- | src/support/xerces_string_guard.cc | 18 | ||||
| -rw-r--r-- | src/support/xerces_string_guard.h | 28 | 
6 files changed, 62 insertions, 79 deletions
| diff --git a/src/support/dom/document_cache.cc b/src/support/dom/document_cache.cc index 1573af8..c4c57d3 100644 --- a/src/support/dom/document_cache.cc +++ b/src/support/dom/document_cache.cc @@ -5,23 +5,33 @@  namespace InputXSLT {  DomDocumentCache::DomDocumentCache(): +	write_mutex_(),  	map_() { } -DomDocumentCache::item* DomDocumentCache::get(const std::string& key) { +DomDocumentCache::optional_item DomDocumentCache::get(const std::string& key) {  	auto itemIter = this->map_.find(key);  	if ( itemIter == this->map_.end() ) { -		auto result = this->map_.emplace( -			std::make_pair(key, std::unique_ptr<item>(new item("content"))) -		); - -		if ( result.second ) { -			return (*(result.first)).second.get(); -		} else { -			throw std::out_of_range("failed to instantiate DomDocumentCache"); -		} +		return optional_item(false, nullptr);  	} else { -		return (*itemIter).second.get(); +		return optional_item(true, (*itemIter).second.get()); +	} +} + +DomDocumentCache::optional_item DomDocumentCache::create( +	const std::string&    key, +	xercesc::DOMDocument* document +) { +	std::lock_guard<std::mutex> guard(this->write_mutex_); + +	auto result = this->map_.emplace( +		std::make_pair(key, std::unique_ptr<item>(new item(document))) +	); + +	if ( result.second ) { +		return optional_item(true, (*(result.first)).second.get()); +	} else { +		return optional_item(false, nullptr);  	}  } diff --git a/src/support/dom/document_cache.h b/src/support/dom/document_cache.h index 287a316..af99102 100644 --- a/src/support/dom/document_cache.h +++ b/src/support/dom/document_cache.h @@ -1,8 +1,11 @@  #ifndef INPUTXSLT_SRC_SUPPORT_DOM_DOCUMENT_CACHE_H_  #define INPUTXSLT_SRC_SUPPORT_DOM_DOCUMENT_CACHE_H_ -#include <unordered_map> +#include <xercesc/dom/DOMDocument.hpp> +  #include <string> +#include <mutex> +#include <unordered_map>  #include <memory>  namespace InputXSLT { @@ -10,12 +13,15 @@ namespace InputXSLT {  class DomDocumentCache {  	public:  		class item; +		typedef std::pair<bool, item*> optional_item;  		DomDocumentCache(); -		item* get(const std::string&); +		optional_item get(const std::string&); +		optional_item create(const std::string&, xercesc::DOMDocument*);  	private: +		std::mutex write_mutex_;  		std::unordered_map<std::string, std::unique_ptr<item>> map_;  }; diff --git a/src/support/dom/document_cache_item.cc b/src/support/dom/document_cache_item.cc index 8cc1c24..9798bfa 100644 --- a/src/support/dom/document_cache_item.cc +++ b/src/support/dom/document_cache_item.cc @@ -1,50 +1,23 @@  #include "support/dom/document_cache_item.h" -#include <xercesc/dom/DOMImplementation.hpp> -#include <xercesc/util/XMLString.hpp> - -#include "support/xerces_string_guard.h" -  namespace InputXSLT { -DomDocumentCache::item::item(const std::string& rootNode): +DomDocumentCache::item::item(xercesc::DOMDocument* document):  	parser_(),  	dom_support_(parser_), -	document_( -		xercesc::DOMImplementation::getImplementation()->createDocument( -			nullptr, -			*XercesStringGuard(rootNode), -			nullptr -		) -	), -	parsed_source_() { } +	document_(document), +	parsed_source_( +		document_, +		parser_, +		dom_support_ +	) { }  DomDocumentCache::item::~item() {  	this->document_->release();  } -bool DomDocumentCache::item::isFinalized() const { -	return static_cast<bool>(this->parsed_source_); -} - -xercesc::DOMDocument* DomDocumentCache::item::getXercesDocument() const { -	return this->document_; -} -  xalan::XalanDocument* DomDocumentCache::item::getXalanDocument() { -	if ( this->parsed_source_ ) { -		return this->parsed_source_->getDocument(); -	} else { -		this->parsed_source_.reset( -			new xalan::XercesDOMWrapperParsedSource( -					document_, -					parser_, -					dom_support_ -			) -		); - -		return this->parsed_source_->getDocument(); -	} +	return this->parsed_source_.getDocument();  }  } diff --git a/src/support/dom/document_cache_item.h b/src/support/dom/document_cache_item.h index 1f7152b..13fddfc 100644 --- a/src/support/dom/document_cache_item.h +++ b/src/support/dom/document_cache_item.h @@ -7,9 +7,6 @@  #include <xercesc/dom/DOMDocument.hpp> -#include <string> -#include <memory> -  #include "common.h"  #include "document_cache.h" @@ -19,21 +16,18 @@ class DomDocumentCache::item {  	public:  		~item(); -		bool isFinalized() const; - -		xercesc::DOMDocument* getXercesDocument() const;  		xalan::XalanDocument* getXalanDocument();  	protected:  		friend DomDocumentCache; -		item(const std::string&); +		item(xercesc::DOMDocument*);  	private:  		xalan::XercesParserLiaison parser_;  		xalan::XercesDOMSupport dom_support_;  		xercesc::DOMDocument* const document_; -		std::unique_ptr<xalan::XercesDOMWrapperParsedSource> parsed_source_; +		xalan::XercesDOMWrapperParsedSource parsed_source_;  }; diff --git a/src/support/xerces_string_guard.cc b/src/support/xerces_string_guard.cc deleted file mode 100644 index 14ad29b..0000000 --- a/src/support/xerces_string_guard.cc +++ /dev/null @@ -1,18 +0,0 @@ -#include "xerces_string_guard.h" - -namespace InputXSLT { - -XercesStringGuard::XercesStringGuard(const std::string& src): -	string_(xercesc::XMLString::transcode(src.data())) { } - -XercesStringGuard::~XercesStringGuard() { -	xercesc::XMLString::release( -		const_cast<XMLCh**>(&this->string_) -	); -} - -XMLCh* XercesStringGuard::operator*() { -	return this->string_; -} - -} diff --git a/src/support/xerces_string_guard.h b/src/support/xerces_string_guard.h index f64a53e..7b9517a 100644 --- a/src/support/xerces_string_guard.h +++ b/src/support/xerces_string_guard.h @@ -7,15 +7,33 @@  namespace InputXSLT { +template <typename Type>  class XercesStringGuard {  	public: -		XercesStringGuard(const std::string&); -		~XercesStringGuard(); - -		XMLCh* operator*(); +		XercesStringGuard(const Type* src): +			string_(src) { } + +		XercesStringGuard( +			const std::basic_string< +				typename std::remove_pointer<decltype( +					xercesc::XMLString::transcode(new Type[1]) +				)>::type +			>& src +		): +			string_(xercesc::XMLString::transcode(src.data())) { } + +		~XercesStringGuard() { +			xercesc::XMLString::release( +				const_cast<Type**>(&this->string_) +			); +		} + +		inline const Type* operator*() const { +			return this->string_; +		}  	private: -		XMLCh* const string_; +		const Type* const string_;  }; | 
