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
// // Boost.Pointer Container // // Copyright Thorsten Ottosen 2003-2005. 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) // // For more information, see http://www.boost.org/libs/ptr_container/ // #ifndef BOOST_PTR_CONTAINER_PTR_SET_ADAPTER_HPP #define BOOST_PTR_CONTAINER_PTR_SET_ADAPTER_HPP #if defined(_MSC_VER) && (_MSC_VER >= 1200) # pragma once #endif #include
#include
#include
namespace boost { namespace ptr_container_detail { template < class Key, class VoidPtrSet > struct set_config { typedef VoidPtrSet void_container_type; typedef BOOST_DEDUCED_TYPENAME VoidPtrSet::allocator_type allocator_type; typedef Key value_type; typedef value_type key_type; typedef BOOST_DEDUCED_TYPENAME VoidPtrSet::value_compare value_compare; typedef value_compare key_compare; typedef void_ptr_iterator< BOOST_DEDUCED_TYPENAME VoidPtrSet::iterator, Key > iterator; typedef void_ptr_iterator< BOOST_DEDUCED_TYPENAME VoidPtrSet::const_iterator, const Key > const_iterator; template< class Iter > static Key* get_pointer( Iter i ) { return static_cast
( *i.base() ); } template< class Iter > static const Key* get_const_pointer( Iter i ) { return static_cast
( *i.base() ); } BOOST_STATIC_CONSTANT(bool, allow_null = false ); }; template < class Key, class VoidPtrSet, class CloneAllocator = heap_clone_allocator > class ptr_set_adapter_base : public ptr_container_detail::associative_ptr_container< set_config
, CloneAllocator > { typedef ptr_container_detail::associative_ptr_container< set_config
, CloneAllocator > base_type; public: typedef BOOST_DEDUCED_TYPENAME base_type::iterator iterator; typedef BOOST_DEDUCED_TYPENAME base_type::const_iterator const_iterator; typedef Key key_type; typedef BOOST_DEDUCED_TYPENAME base_type::size_type size_type; private: ptr_set_adapter_base() : base_type( BOOST_DEDUCED_TYPENAME VoidPtrSet::key_compare(), BOOST_DEDUCED_TYPENAME VoidPtrSet::allocator_type() ) { } public: template< class Compare, class Allocator > ptr_set_adapter_base( const Compare& comp, const Allocator& a ) : base_type( comp, a ) { } template< class InputIterator, class Compare, class Allocator > ptr_set_adapter_base( InputIterator first, InputIterator last, const Compare& comp, const Allocator& a ) : base_type( first, last, comp, a ) { } template< class U, class Set > explicit ptr_set_adapter_base( const ptr_set_adapter_base
& r ) : base_type( r ) { } template< class PtrContainer > explicit ptr_set_adapter_base( std::auto_ptr
clone ) : base_type( clone ) { } template< class U, class Set > ptr_set_adapter_base& operator=( const ptr_set_adapter_base
& r ) { base_type::operator=( r ); return *this; } template< typename PtrContainer > ptr_set_adapter_base& operator=( std::auto_ptr
clone ) { base_type::operator=( clone ); return *this; } using base_type::erase; size_type erase( const key_type& x ) // nothrow { iterator i( this->base().find( const_cast
(&x) ) ); // nothrow if( i == this->end() ) // nothrow return 0u; // nothrow this->remove( i ); // nothrow return this->base().erase( const_cast
(&x) ); // nothrow } iterator find( const key_type& x ) { return iterator( this->base(). find( const_cast
(&x) ) ); } const_iterator find( const key_type& x ) const { return const_iterator( this->base(). find( const_cast
(&x) ) ); } size_type count( const key_type& x ) const { return this->base().count( const_cast
(&x) ); } iterator lower_bound( const key_type& x ) { return iterator( this->base(). lower_bound( const_cast
(&x) ) ); } const_iterator lower_bound( const key_type& x ) const { return const_iterator( this->base(). lower_bound( const_cast
(&x) ) ); } iterator upper_bound( const key_type& x ) { return iterator( this->base(). upper_bound( const_cast
(&x) ) ); } const_iterator upper_bound( const key_type& x ) const { return const_iterator( this->base(). upper_bound( const_cast
(&x) ) ); } iterator_range
equal_range( const key_type& x ) { std::pair
p = this->base(). equal_range( const_cast
(&x) ); return make_iterator_range( iterator( p.first ), iterator( p.second ) ); } iterator_range
equal_range( const key_type& x ) const { std::pair
p = this->base(). equal_range( const_cast
(&x) ); return make_iterator_range( const_iterator( p.first ), const_iterator( p.second ) ); } }; } // ptr_container_detail ///////////////////////////////////////////////////////////////////////// // ptr_set_adapter ///////////////////////////////////////////////////////////////////////// template < class Key, class VoidPtrSet, class CloneAllocator = heap_clone_allocator > class ptr_set_adapter : public ptr_container_detail::ptr_set_adapter_base
{ typedef ptr_container_detail::ptr_set_adapter_base
base_type; public: // typedefs typedef BOOST_DEDUCED_TYPENAME base_type::iterator iterator; typedef BOOST_DEDUCED_TYPENAME base_type::const_iterator const_iterator; typedef BOOST_DEDUCED_TYPENAME base_type::size_type size_type; typedef Key key_type; typedef BOOST_DEDUCED_TYPENAME base_type::auto_type auto_type; typedef BOOST_DEDUCED_TYPENAME VoidPtrSet::key_compare key_compare; typedef BOOST_DEDUCED_TYPENAME VoidPtrSet::allocator_type allocator_type; private: template< typename II > void set_basic_clone_and_insert( II first, II last ) // basic { while( first != last ) { if( this->find( *first ) == this->end() ) insert( CloneAllocator::allocate_clone( *first ) ); // strong, commit ++first; } } public: explicit ptr_set_adapter( const key_compare& comp = key_compare(), const allocator_type& a = allocator_type() ) : base_type( comp, a ) { BOOST_ASSERT( this->empty() ); } template< class InputIterator, class Compare, class Allocator > ptr_set_adapter( InputIterator first, InputIterator last, const Compare& comp = Compare(), const Allocator a = Allocator() ) : base_type( comp, a ) { BOOST_ASSERT( this->empty() ); set_basic_clone_and_insert( first, last ); } template< class U, class Set > explicit ptr_set_adapter( const ptr_set_adapter
& r ) : base_type( r ) { } template< class PtrContainer > explicit ptr_set_adapter( std::auto_ptr
clone ) : base_type( clone ) { } template< class U, class Set > ptr_set_adapter& operator=( const ptr_set_adapter
& r ) { base_type::operator=( r ); return *this; } template< class T > void operator=( std::auto_ptr
r ) { base_type::operator=( r ); } std::pair
insert( key_type* x ) // strong { this->enforce_null_policy( x, "Null pointer in 'ptr_set::insert()'" ); auto_type ptr( x ); std::pair
res = this->base().insert( x ); if( res.second ) ptr.release(); return std::make_pair( iterator( res.first ), res.second ); } template< class U > std::pair
insert( std::auto_ptr
x ) { return insert( x.release() ); } iterator insert( iterator where, key_type* x ) // strong { this->enforce_null_policy( x, "Null pointer in 'ptr_set::insert()'" ); auto_type ptr( x ); BOOST_DEDUCED_TYPENAME base_type::ptr_iterator res = this->base().insert( where.base(), x ); if( *res == x ) ptr.release(); return iterator( res); } template< class U > iterator insert( iterator where, std::auto_ptr
x ) { return insert( where, x.release() ); } template< typename InputIterator > void insert( InputIterator first, InputIterator last ) // basic { set_basic_clone_and_insert( first, last ); } #if defined(BOOST_NO_SFINAE) || defined(BOOST_NO_FUNCTION_TEMPLATE_ORDERING) #else template< class Range > BOOST_DEDUCED_TYPENAME boost::disable_if< ptr_container_detail::is_pointer_or_integral
>::type insert( const Range& r ) { insert( boost::begin(r), boost::end(r) ); } #endif template< class PtrSetAdapter > bool transfer( BOOST_DEDUCED_TYPENAME PtrSetAdapter::iterator object, PtrSetAdapter& from ) // strong { return this->single_transfer( object, from ); } template< class PtrSetAdapter > size_type transfer( BOOST_DEDUCED_TYPENAME PtrSetAdapter::iterator first, BOOST_DEDUCED_TYPENAME PtrSetAdapter::iterator last, PtrSetAdapter& from ) // basic { return this->single_transfer( first, last, from ); } #if defined(BOOST_NO_SFINAE) || defined(BOOST_NO_FUNCTION_TEMPLATE_ORDERING) #else template< class PtrSetAdapter, class Range > BOOST_DEDUCED_TYPENAME boost::disable_if< boost::is_same< Range, BOOST_DEDUCED_TYPENAME PtrSetAdapter::iterator >, size_type >::type transfer( const Range& r, PtrSetAdapter& from ) // basic { return transfer( boost::begin(r), boost::end(r), from ); } #endif template< class PtrSetAdapter > size_type transfer( PtrSetAdapter& from ) // basic { return transfer( from.begin(), from.end(), from ); } }; ///////////////////////////////////////////////////////////////////////// // ptr_multiset_adapter ///////////////////////////////////////////////////////////////////////// template < class Key, class VoidPtrMultiSet, class CloneAllocator = heap_clone_allocator > class ptr_multiset_adapter : public ptr_container_detail::ptr_set_adapter_base
{ typedef ptr_container_detail::ptr_set_adapter_base
base_type; public: // typedefs typedef BOOST_DEDUCED_TYPENAME base_type::iterator iterator; typedef BOOST_DEDUCED_TYPENAME base_type::size_type size_type; typedef Key key_type; typedef BOOST_DEDUCED_TYPENAME base_type::auto_type auto_type; typedef BOOST_DEDUCED_TYPENAME VoidPtrMultiSet::key_compare key_compare; typedef BOOST_DEDUCED_TYPENAME VoidPtrMultiSet::allocator_type allocator_type; private: template< typename II > void set_basic_clone_and_insert( II first, II last ) // basic { while( first != last ) { insert( CloneAllocator::allocate_clone( *first ) ); // strong, commit ++first; } } public: ptr_multiset_adapter( const key_compare& comp = key_compare(), const allocator_type& a = allocator_type() ) : base_type( comp, a ) { } template< class InputIterator > ptr_multiset_adapter( InputIterator first, InputIterator last, const key_compare& comp = key_compare(), const allocator_type& a = allocator_type() ) : base_type( comp, a ) { set_basic_clone_and_insert( first, last ); } template< class U, class Set > explicit ptr_multiset_adapter( const ptr_multiset_adapter
& r ) : base_type( r ) { } template< class PtrContainer > explicit ptr_multiset_adapter( std::auto_ptr
clone ) : base_type( clone ) { } template< class U, class Set > ptr_multiset_adapter& operator=( const ptr_multiset_adapter
& r ) { base_type::operator=( r ); return *this; } template< class T > void operator=( std::auto_ptr
r ) { base_type::operator=( r ); } iterator insert( iterator before, key_type* x ) // strong { return base_type::insert( before, x ); } template< class U > iterator insert( iterator before, std::auto_ptr
x ) { return insert( before, x.release() ); } iterator insert( key_type* x ) // strong { this->enforce_null_policy( x, "Null pointer in 'ptr_multiset::insert()'" ); auto_type ptr( x ); BOOST_DEDUCED_TYPENAME base_type::ptr_iterator res = this->base().insert( x ); ptr.release(); return iterator( res ); } template< class U > iterator insert( std::auto_ptr
x ) { return insert( x.release() ); } template< typename InputIterator > void insert( InputIterator first, InputIterator last ) // basic { set_basic_clone_and_insert( first, last ); } #if defined(BOOST_NO_SFINAE) || defined(BOOST_NO_FUNCTION_TEMPLATE_ORDERING) #else template< class Range > BOOST_DEDUCED_TYPENAME boost::disable_if< ptr_container_detail::is_pointer_or_integral
>::type insert( const Range& r ) { insert( boost::begin(r), boost::end(r) ); } #endif template< class PtrSetAdapter > void transfer( BOOST_DEDUCED_TYPENAME PtrSetAdapter::iterator object, PtrSetAdapter& from ) // strong { this->multi_transfer( object, from ); } template< class PtrSetAdapter > size_type transfer( BOOST_DEDUCED_TYPENAME PtrSetAdapter::iterator first, BOOST_DEDUCED_TYPENAME PtrSetAdapter::iterator last, PtrSetAdapter& from ) // basic { return this->multi_transfer( first, last, from ); } #if defined(BOOST_NO_SFINAE) || defined(BOOST_NO_FUNCTION_TEMPLATE_ORDERING) #else template< class PtrSetAdapter, class Range > BOOST_DEDUCED_TYPENAME boost::disable_if< boost::is_same< Range, BOOST_DEDUCED_TYPENAME PtrSetAdapter::iterator >, size_type >::type transfer( const Range& r, PtrSetAdapter& from ) // basic { return transfer( boost::begin(r), boost::end(r), from ); } #endif template< class PtrSetAdapter > void transfer( PtrSetAdapter& from ) // basic { transfer( from.begin(), from.end(), from ); BOOST_ASSERT( from.empty() ); } }; } // namespace 'boost' #endif
ptr_set_adapter.hpp
Page URL
File URL
Prev
13/21
Next
Download
( 22 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.