From e6d52ecfa2379b1f7f3007e65ded5e4076abc5e9 Mon Sep 17 00:00:00 2001 From: Boris Kolpackov Date: Fri, 8 Jan 2010 17:01:08 +0200 Subject: Add support in buffer class for reusing existing buffer without freeing it --- libxsd/xsd/cxx/tree/buffer.txx | 24 +++++++++--------------- 1 file changed, 9 insertions(+), 15 deletions(-) (limited to 'libxsd/xsd/cxx/tree/buffer.txx') diff --git a/libxsd/xsd/cxx/tree/buffer.txx b/libxsd/xsd/cxx/tree/buffer.txx index ab11f40..f88f140 100644 --- a/libxsd/xsd/cxx/tree/buffer.txx +++ b/libxsd/xsd/cxx/tree/buffer.txx @@ -60,20 +60,10 @@ namespace xsd if (size > capacity) throw bounds (); - if (own) - { - data_ = reinterpret_cast (data); - size_ = size; - capacity_ = capacity; - } - else - { - this->capacity (capacity); - size_ = size; - - if (size_) - std::memcpy (data_, data, size_); - } + data_ = reinterpret_cast (data); + size_ = size; + capacity_ = capacity; + free_ = own; } template @@ -111,14 +101,17 @@ namespace xsd char* tmp_data (data_); size_t tmp_size (size_); size_t tmp_capacity (capacity_); + bool tmp_free (free_); data_ = other.data_; size_ = other.size_; capacity_ = other.capacity_; + free_ = other.free_; other.data_ = tmp_data; other.size_ = tmp_size; other.capacity_ = tmp_capacity; + other.free_ = tmp_free; } template @@ -139,11 +132,12 @@ namespace xsd if (copy && size_ > 0) std::memcpy (data, data_, size_); - if (data_) + if (free_ && data_) operator delete (data_); data_ = data; capacity_ = capacity; + free_ = true; return true; } -- cgit v1.1