DriveHQ Start Menu
Cloud Drive Mapping
Folder Sync
Cloud Backup
True Drop Box
FTP/SFTP Hosting
Group Account
DriveHQ Start Menu
Online File Server
My Storage
|
Manage Shares
|
Publishes
|
Drop Boxes
|
Group Account
WebDAV Drive Mapping
Cloud Drive Home
|
WebDAV Guide
|
Drive Mapping Tool
|
Drive Mapping URL
Complete Data Backup
Backup Guide
|
Online Backup Tool
|
Cloud-to-Cloud Backup
FTP, Email & Web Service
FTP Home
|
FTP Hosting FAQ
|
Email Hosting
|
EmailManager
|
Web Hosting
Help & Resources
About
|
Enterprise Service
|
Partnership
|
Comparisons
|
Support
Quick Links
Security and Privacy
Download Software
Service Manual
Use Cases
Group Account
Online Help
Blog
Contact
Cloud Surveillance
Sign Up
Login
Features
Business Features
Online File Server
FTP Hosting
Cloud Drive Mapping
Cloud File Backup
Email Backup & Hosting
Cloud File Sharing
Folder Synchronization
Group Management
True Drop Box
Full-text Search
AD Integration/SSO
Mobile Access
IP Camera & DVR Solution
More...
Personal Features
Personal Cloud Drive
Backup All Devices
Mobile APPs
Personal Web Hosting
Sub-Account (for Kids)
Home/PC/Kids Monitoring
More...
Software
DriveHQ Drive Mapping Tool
DriveHQ FileManager
DriveHQ Online Backup
DriveHQ Mobile Apps
Pricing
Business Plans & Pricing
Personal Plans & Pricing
Price Comparison with Others
Feature Comparison with Others
Install Mobile App
Sign up
Creating account...
Invalid character in username! Only 0-9, a-z, A-Z, _, -, . allowed.
Username is required!
Invalid email address!
E-mail is required!
Password is required!
Password is invalid!
Password and confirmation do not match.
Confirm password is required!
I accept
Membership Agreement
Please read the Membership Agreement and check "I accept"!
Free Quick Sign-up
Sign-up Page
Log in
Signing in...
Username or e-mail address is required!
Password is required!
Keep me logged in
Quick Login
Forgot Password
Up
Upload
Download
Share
Publish
New Folder
New File
Copy
Cut
Delete
Paste
Rate
Upgrade
Rotate
Effect
Edit
Slide
History
// Helper classes and functions for the circular buffer. // Copyright (c) 2003-2007 Jan Gaspar // Use, modification, and distribution is subject to the Boost Software // License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at // http://www.boost.org/LICENSE_1_0.txt) #if !defined(BOOST_CIRCULAR_BUFFER_DETAILS_HPP) #define BOOST_CIRCULAR_BUFFER_DETAILS_HPP #if defined(_MSC_VER) && _MSC_VER >= 1200 #pragma once #endif #include
#include
#include
#include
namespace boost { namespace cb_details { template
struct nonconst_traits; template
void uninitialized_fill_n_with_alloc( ForwardIterator first, Diff n, const T& item, Alloc& alloc); template
ForwardIterator uninitialized_copy_with_alloc( InputIterator first, InputIterator last, ForwardIterator dest, Alloc& alloc); /*! \struct const_traits \brief Defines the data types for a const iterator. */ template
struct const_traits { // Basic types typedef typename Traits::value_type value_type; typedef typename Traits::const_pointer pointer; typedef typename Traits::const_reference reference; typedef typename Traits::size_type size_type; typedef typename Traits::difference_type difference_type; // Non-const traits typedef nonconst_traits
nonconst_self; }; /*! \struct nonconst_traits \brief Defines the data types for a non-const iterator. */ template
struct nonconst_traits { // Basic types typedef typename Traits::value_type value_type; typedef typename Traits::pointer pointer; typedef typename Traits::reference reference; typedef typename Traits::size_type size_type; typedef typename Traits::difference_type difference_type; // Non-const traits typedef nonconst_traits
nonconst_self; }; /*! \struct helper_pointer \brief Helper pointer used in the iterator. */ template
struct helper_pointer { bool m_end; typename Traits::pointer m_it; }; /*! \struct iterator_wrapper \brief Helper iterator dereference wrapper. */ template
struct iterator_wrapper { mutable Iterator m_it; explicit iterator_wrapper(Iterator it) : m_it(it) {} Iterator operator () () const { return m_it++; } private: iterator_wrapper
& operator = (const iterator_wrapper
&); // do not generate }; /*! \struct item_wrapper \brief Helper item dereference wrapper. */ template
struct item_wrapper { Value m_item; explicit item_wrapper(Value item) : m_item(item) {} Pointer operator () () const { return &m_item; } private: item_wrapper
& operator = (const item_wrapper
&); // do not generate }; /*! \struct assign_n \brief Helper functor for assigning n items. */ template
struct assign_n { typedef typename Alloc::size_type size_type; size_type m_n; Value m_item; Alloc& m_alloc; assign_n(size_type n, Value item, Alloc& alloc) : m_n(n), m_item(item), m_alloc(alloc) {} template
void operator () (Pointer p) const { uninitialized_fill_n_with_alloc(p, m_n, m_item, m_alloc); } private: assign_n
& operator = (const assign_n
&); // do not generate }; /*! \struct assign_range \brief Helper functor for assigning range of items. */ template
struct assign_range { const Iterator& m_first; const Iterator& m_last; Alloc& m_alloc; assign_range(const Iterator& first, const Iterator& last, Alloc& alloc) : m_first(first), m_last(last), m_alloc(alloc) {} template
void operator () (Pointer p) const { uninitialized_copy_with_alloc(m_first, m_last, p, m_alloc); } private: assign_range
& operator = (const assign_range
&); // do not generate }; /*! \struct capacity_control \brief Capacity controller of the space optimized circular buffer. */ template
class capacity_control { //! The capacity of the space optimized circular buffer. Size m_capacity; //! The lowest guaranteed capacity of the adapted circular buffer. Size m_min_capacity; public: //! Constructor. capacity_control(Size capacity, Size min_capacity = 0) : m_capacity(capacity), m_min_capacity(min_capacity) { BOOST_CB_ASSERT(capacity >= min_capacity); // check for capacity lower than min_capacity } // Default copy constructor. // Default assign operator. //! Get the capacity of the space optimized circular buffer. Size capacity() const { return m_capacity; } //! Get the minimal capacity of the space optimized circular buffer. Size min_capacity() const { return m_min_capacity; } //! Size operator - returns the capacity of the space optimized circular buffer. operator Size() const { return m_capacity; } }; /*! \class iterator \brief Random access iterator for the circular buffer. \param Buff The type of the underlying circular buffer. \param Traits Basic iterator types. \note This iterator is not circular. It was designed for iterating from begin() to end() of the circular buffer. */ template
class iterator : public boost::iterator< std::random_access_iterator_tag, typename Traits::value_type, typename Traits::difference_type, typename Traits::pointer, typename Traits::reference> #if BOOST_CB_ENABLE_DEBUG , public debug_iterator_base #endif // #if BOOST_CB_ENABLE_DEBUG { private: // Helper types //! Base iterator. typedef boost::iterator< std::random_access_iterator_tag, typename Traits::value_type, typename Traits::difference_type, typename Traits::pointer, typename Traits::reference> base_iterator; //! Non-const iterator. typedef iterator
nonconst_self; public: // Basic types //! The type of the elements stored in the circular buffer. typedef typename base_iterator::value_type value_type; //! Pointer to the element. typedef typename base_iterator::pointer pointer; //! Reference to the element. typedef typename base_iterator::reference reference; //! Size type. typedef typename Traits::size_type size_type; //! Difference type. typedef typename base_iterator::difference_type difference_type; public: // Member variables //! The circular buffer where the iterator points to. const Buff* m_buff; //! An internal iterator. pointer m_it; public: // Construction & assignment // Default copy constructor. //! Default constructor. iterator() : m_buff(0), m_it(0) {} #if BOOST_CB_ENABLE_DEBUG //! Copy constructor (used for converting from a non-const to a const iterator). iterator(const nonconst_self& it) : debug_iterator_base(it), m_buff(it.m_buff), m_it(it.m_it) {} //! Internal constructor. /*! \note This constructor is not intended to be used directly by the user. */ iterator(const Buff* cb, const pointer p) : debug_iterator_base(cb), m_buff(cb), m_it(p) {} #else iterator(const nonconst_self& it) : m_buff(it.m_buff), m_it(it.m_it) {} iterator(const Buff* cb, const pointer p) : m_buff(cb), m_it(p) {} #endif // #if BOOST_CB_ENABLE_DEBUG //! Assign operator. iterator& operator = (const iterator& it) { if (this == &it) return *this; #if BOOST_CB_ENABLE_DEBUG debug_iterator_base::operator =(it); #endif // #if BOOST_CB_ENABLE_DEBUG m_buff = it.m_buff; m_it = it.m_it; return *this; } // Random access iterator methods //! Dereferencing operator. reference operator * () const { BOOST_CB_ASSERT(is_valid(m_buff)); // check for uninitialized or invalidated iterator BOOST_CB_ASSERT(m_it != 0); // check for iterator pointing to end() return *m_it; } //! Dereferencing operator. pointer operator -> () const { return &(operator*()); } //! Difference operator. difference_type operator - (const iterator& it) const { BOOST_CB_ASSERT(is_valid(m_buff)); // check for uninitialized or invalidated iterator BOOST_CB_ASSERT(it.is_valid(m_buff)); // check for uninitialized or invalidated iterator helper_pointer
lhs = create_helper_pointer(*this); helper_pointer
rhs = create_helper_pointer(it); if (less(rhs, lhs) && lhs.m_it <= rhs.m_it) return (lhs.m_it - rhs.m_it) + static_cast
(m_buff->capacity()); if (less(lhs, rhs) && lhs.m_it >= rhs.m_it) return (lhs.m_it - rhs.m_it) - static_cast
(m_buff->capacity()); return lhs.m_it - rhs.m_it; } //! Increment operator (prefix). iterator& operator ++ () { BOOST_CB_ASSERT(is_valid(m_buff)); // check for uninitialized or invalidated iterator BOOST_CB_ASSERT(m_it != 0); // check for iterator pointing to end() m_buff->increment(m_it); if (m_it == m_buff->m_last) m_it = 0; return *this; } //! Increment operator (postfix). iterator operator ++ (int) { iterator
tmp = *this; ++*this; return tmp; } //! Decrement operator (prefix). iterator& operator -- () { BOOST_CB_ASSERT(is_valid(m_buff)); // check for uninitialized or invalidated iterator BOOST_CB_ASSERT(m_it != m_buff->m_first); // check for iterator pointing to begin() if (m_it == 0) m_it = m_buff->m_last; m_buff->decrement(m_it); return *this; } //! Decrement operator (postfix). iterator operator -- (int) { iterator
tmp = *this; --*this; return tmp; } //! Iterator addition. iterator& operator += (difference_type n) { BOOST_CB_ASSERT(is_valid(m_buff)); // check for uninitialized or invalidated iterator if (n > 0) { BOOST_CB_ASSERT(m_buff->end() - *this >= n); // check for too large n m_it = m_buff->add(m_it, n); if (m_it == m_buff->m_last) m_it = 0; } else if (n < 0) { *this -= -n; } return *this; } //! Iterator addition. iterator operator + (difference_type n) const { return iterator
(*this) += n; } //! Iterator subtraction. iterator& operator -= (difference_type n) { BOOST_CB_ASSERT(is_valid(m_buff)); // check for uninitialized or invalidated iterator if (n > 0) { BOOST_CB_ASSERT(m_buff->begin() - *this <= -n); // check for too large n m_it = m_buff->sub(m_it == 0 ? m_buff->m_last : m_it, n); } else if (n < 0) { *this += -n; } return *this; } //! Iterator subtraction. iterator operator - (difference_type n) const { return iterator
(*this) -= n; } //! Element access operator. reference operator [] (difference_type n) const { return *(*this + n); } // Equality & comparison //! Equality. template
bool operator == (const iterator
& it) const { BOOST_CB_ASSERT(is_valid(m_buff)); // check for uninitialized or invalidated iterator BOOST_CB_ASSERT(it.is_valid(m_buff)); // check for uninitialized or invalidated iterator return m_it == it.m_it; } //! Inequality. template
bool operator != (const iterator
& it) const { BOOST_CB_ASSERT(is_valid(m_buff)); // check for uninitialized or invalidated iterator BOOST_CB_ASSERT(it.is_valid(m_buff)); // check for uninitialized or invalidated iterator return m_it != it.m_it; } //! Less. template
bool operator < (const iterator
& it) const { BOOST_CB_ASSERT(is_valid(m_buff)); // check for uninitialized or invalidated iterator BOOST_CB_ASSERT(it.is_valid(m_buff)); // check for uninitialized or invalidated iterator return less(create_helper_pointer(*this), create_helper_pointer(it)); } //! Greater. template
bool operator > (const iterator
& it) const { return it < *this; } //! Less or equal. template
bool operator <= (const iterator
& it) const { return !(it < *this); } //! Greater or equal. template
bool operator >= (const iterator
& it) const { return !(*this < it); } private: // Helpers //! Create helper pointer. template
helper_pointer
create_helper_pointer(const iterator
& it) const { helper_pointer
helper; helper.m_end = (it.m_it == 0); helper.m_it = helper.m_end ? m_buff->m_last : it.m_it; return helper; } //! Less. template
bool less(const InternalIterator0& lhs, const InternalIterator1& rhs) const { difference_type ldiff = lhs.m_it - m_buff->m_first; difference_type rdiff = rhs.m_it - m_buff->m_first; if (ldiff < 0) { if (rdiff < 0) return lhs.m_it < rhs.m_it; else if (rdiff == 0) return rhs.m_end; } else if (ldiff == 0) { if (rdiff < 0) return !lhs.m_end; else if (rdiff == 0) return !lhs.m_end && rhs.m_end; else return !lhs.m_end; } else { // ldiff > 0 if (rdiff < 0) return true; else if (rdiff == 0) return rhs.m_end; else return lhs.m_it < rhs.m_it; } return false; } }; //! Iterator addition. template
inline iterator
operator + (typename Traits::difference_type n, const iterator
& it) { return it + n; } #if defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION) && !defined(BOOST_MSVC_STD_ITERATOR) //! Iterator category. template
inline std::random_access_iterator_tag iterator_category(const iterator
&) { return std::random_access_iterator_tag(); } //! The type of the elements stored in the circular buffer. template
inline typename Traits::value_type* value_type(const iterator
&) { return 0; } //! Distance type. template
inline typename Traits::difference_type* distance_type(const iterator
&) { return 0; } #endif // #if defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION) && !defined(BOOST_MSVC_STD_ITERATOR) /*! \fn ForwardIterator uninitialized_copy_with_alloc(InputIterator first, InputIterator last, ForwardIterator dest, Alloc& alloc) \brief Equivalent of
std::uninitialized_copy
with allocator. */ template
inline ForwardIterator uninitialized_copy_with_alloc(InputIterator first, InputIterator last, ForwardIterator dest, Alloc& alloc) { ForwardIterator next = dest; BOOST_TRY { for (; first != last; ++first, ++dest) alloc.construct(dest, *first); } BOOST_CATCH(...) { for (; next != dest; ++next) alloc.destroy(next); BOOST_RETHROW } BOOST_CATCH_END return dest; } /*! \fn void uninitialized_fill_n_with_alloc(ForwardIterator first, Diff n, const T& item, Alloc& alloc) \brief Equivalent of
std::uninitialized_fill_n
with allocator. */ template
inline void uninitialized_fill_n_with_alloc(ForwardIterator first, Diff n, const T& item, Alloc& alloc) { ForwardIterator next = first; BOOST_TRY { for (; n > 0; ++first, --n) alloc.construct(first, item); } BOOST_CATCH(...) { for (; next != first; ++next) alloc.destroy(next); BOOST_RETHROW } BOOST_CATCH_END } } // namespace cb_details } // namespace boost #endif // #if !defined(BOOST_CIRCULAR_BUFFER_DETAILS_HPP)
details.hpp
Page URL
File URL
Prev
3/4
Next
Download
( 16 KB )
Note: The DriveHQ service banners will NOT be displayed if the file owner is a paid member.
Comments
Total ratings:
0
Average rating:
Not Rated
Would you like to comment?
Join DriveHQ
for a free account, or
Logon
if you are already a member.