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
// Copyright David Abrahams 2002. // Distributed under 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) #ifndef TYPE_ID_DWA2002517_HPP # define TYPE_ID_DWA2002517_HPP # include
# include
# include
# include
# include
# include
# include
# include
# include
# ifndef BOOST_PYTHON_HAVE_GCC_CP_DEMANGLE # if defined(__GNUC__) \ && ((__GNUC__ > 3) || ((__GNUC__ == 3) && (__GNUC_MINOR__ >= 1))) \ && !defined(__EDG_VERSION__) # define BOOST_PYTHON_HAVE_GCC_CP_DEMANGLE # endif # endif namespace boost { namespace python { // for this compiler at least, cross-shared-library type_info // comparisons don't work, so use typeid(x).name() instead. It's not // yet clear what the best default strategy is. # if (defined(__GNUC__) && __GNUC__ >= 3) \ || defined(_AIX) \ || ( defined(__sgi) && defined(__host_mips)) \ || (defined(__hpux) && defined(__HP_aCC)) \ || (defined(linux) && defined(__INTEL_COMPILER) && defined(__ICC)) # define BOOST_PYTHON_TYPE_ID_NAME # endif #ifdef BOOST_PYTHON_HAVE_GCC_CP_DEMANGLE // Runtime detection of broken cxxabi::__cxa_demangle versions, // to avoid #ifdef clutter. bool cxxabi_cxa_demangle_is_broken(); #define BOOST_PYTHON_HAVE_CXXABI_CXA_DEMANGLE_IS_BROKEN #endif // type ids which represent the same information as std::type_info // (i.e. the top-level reference and cv-qualifiers are stripped), but // which works across shared libraries. struct type_info : private totally_ordered
{ inline type_info(std::type_info const& = typeid(void)); inline bool operator<(type_info const& rhs) const; inline bool operator==(type_info const& rhs) const; char const* name() const; friend BOOST_PYTHON_DECL std::ostream& operator<<( std::ostream&, type_info const&); private: // data members # ifdef BOOST_PYTHON_TYPE_ID_NAME typedef char const* base_id_t; # else typedef std::type_info const* base_id_t; # endif base_id_t m_base_type; }; # ifdef BOOST_NO_EXPLICIT_FUNCTION_TEMPLATE_ARGUMENTS # define BOOST_PYTHON_EXPLICIT_TT_DEF(T) ::boost::type
* # else # define BOOST_PYTHON_EXPLICIT_TT_DEF(T) # endif template
inline type_info type_id(BOOST_EXPLICIT_TEMPLATE_TYPE(T)) { return type_info( # if !defined(_MSC_VER) \ || (!BOOST_WORKAROUND(BOOST_MSVC, <= 1300) \ && !BOOST_WORKAROUND(BOOST_INTEL_CXX_VERSION, <= 700)) typeid(T) # else // strip the decoration which msvc and Intel mistakenly leave in python::detail::msvc_typeid((boost::type
*)0) # endif ); } # if (defined(__EDG_VERSION__) && __EDG_VERSION__ < 245) \ || (defined(__sgi) && defined(_COMPILER_VERSION) && _COMPILER_VERSION <= 744) // Older EDG-based compilers seems to mistakenly distinguish "int" from // "signed int", etc., but only in typeid() expressions. However // though int == signed int, the "signed" decoration is propagated // down into template instantiations. Explicit specialization stops // that from taking hold. # define BOOST_PYTHON_SIGNED_INTEGRAL_TYPE_ID(T) \ template <> \ inline type_info type_id
(BOOST_PYTHON_EXPLICIT_TT_DEF(T)) \ { \ return type_info(typeid(T)); \ } BOOST_PYTHON_SIGNED_INTEGRAL_TYPE_ID(short) BOOST_PYTHON_SIGNED_INTEGRAL_TYPE_ID(int) BOOST_PYTHON_SIGNED_INTEGRAL_TYPE_ID(long) // using Python's macro instead of Boost's - we don't seem to get the // config right all the time. # ifdef HAVE_LONG_LONG BOOST_PYTHON_SIGNED_INTEGRAL_TYPE_ID(long long) # endif # undef BOOST_PYTHON_SIGNED_INTEGRAL_TYPE_ID # endif // inline type_info::type_info(std::type_info const& id) : m_base_type( # ifdef BOOST_PYTHON_TYPE_ID_NAME id.name() # else &id # endif ) { } inline bool type_info::operator<(type_info const& rhs) const { # ifdef BOOST_PYTHON_TYPE_ID_NAME return std::strcmp(m_base_type, rhs.m_base_type) < 0; # else return m_base_type->before(*rhs.m_base_type); # endif } inline bool type_info::operator==(type_info const& rhs) const { # ifdef BOOST_PYTHON_TYPE_ID_NAME return !std::strcmp(m_base_type, rhs.m_base_type); # else return *m_base_type == *rhs.m_base_type; # endif } # ifdef BOOST_PYTHON_HAVE_GCC_CP_DEMANGLE namespace detail { BOOST_PYTHON_DECL char const* gcc_demangle(char const*); } # endif inline char const* type_info::name() const { char const* raw_name = m_base_type # ifndef BOOST_PYTHON_TYPE_ID_NAME ->name() # endif ; # ifdef BOOST_PYTHON_HAVE_GCC_CP_DEMANGLE return detail::gcc_demangle(raw_name); # else return raw_name; # endif } BOOST_PYTHON_DECL std::ostream& operator<<(std::ostream&, type_info const&); # if !BOOST_WORKAROUND(BOOST_MSVC, == 1200) template<> inline type_info type_id
(BOOST_PYTHON_EXPLICIT_TT_DEF(void)) { return type_info (typeid (void *)); } # ifndef BOOST_NO_CV_VOID_SPECIALIZATIONS template<> inline type_info type_id
(BOOST_PYTHON_EXPLICIT_TT_DEF(const volatile void)) { return type_info (typeid (void *)); } # endif # endif }} // namespace boost::python #endif // TYPE_ID_DWA2002517_HPP
type_id.hpp
Page URL
File URL
Prev
83/85
Next
Download
( 5 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.